/* ─────────────────────────────────────────────
   RACI Generator — Base Foundation
   Shared across every page.  Loaded BEFORE the
   inline <style> so templates can override.
   ───────────────────────────────────────────── */

/* ══════════════════════════════════════════════
   1. DESIGN TOKENS
   ══════════════════════════════════════════════ */
:root {
    /* Glass morphism */
    --glass: rgba(255,255,255,0.05);
    --glass-strong: rgba(255,255,255,0.08);
    --glass-border: rgba(255,255,255,0.10);
    --glass-border-light: rgba(255,255,255,0.15);
    --glass-hover: rgba(255,255,255,0.10);

    /* Brand */
    --accent: #818cf8;
    --accent-bright: #a5b4fc;
    --accent-glow: rgba(129,140,248,0.3);
    --cyan: #22d3ee;
    --cyan-glow: rgba(34,211,238,0.25);

    /* Text */
    --text: #e2e8f0;
    --text-muted: rgba(255,255,255,0.4);
    --text-dim: rgba(255,255,255,0.25);

    /* Backgrounds */
    --bg-from: #0f0b2e;
    --bg-to: #1a103c;
    --bg-mid: #0c1445;

    /* Status / Impact */
    --red: #f87171;    --red-bg: rgba(248,113,113,0.15);    --red-border: rgba(248,113,113,0.3);
    --amber: #fbbf24;  --amber-bg: rgba(251,191,36,0.15);   --amber-border: rgba(251,191,36,0.3);
    --green: #34d399;   --green-bg: rgba(52,211,153,0.15);   --green-border: rgba(52,211,153,0.3);
    --rose: #fb7185;   --rose-bg: rgba(251,113,133,0.15);   --rose-border: rgba(251,113,133,0.3);
    --blue: #60a5fa;   --blue-bg: rgba(96,165,250,0.15);    --blue-border: rgba(96,165,250,0.3);

    /* Motion */
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --speed-fast: 0.15s;
    --speed-normal: 0.25s;
}

/* ══════════════════════════════════════════════
   2. GLOBAL RESET & FOUNDATION
   ══════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: linear-gradient(135deg, var(--bg-from) 0%, var(--bg-to) 50%, var(--bg-mid) 100%);
    color: var(--text);
    min-height: 100vh;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Selection */
::selection {
    background: rgba(129,140,248,0.35);
    color: #fff;
}
::-moz-selection {
    background: rgba(129,140,248,0.35);
    color: #fff;
}

/* Focus ring — visible only on keyboard nav.
   No border-radius here so each element keeps its own corner shape. */
*:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}
*:focus:not(:focus-visible) { outline: none; }

/* ══════════════════════════════════════════════
   3. SCROLLBAR
   ══════════════════════════════════════════════ */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: rgba(129,140,248,0.25);
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover { background: rgba(129,140,248,0.4); }
* { scrollbar-width: thin; scrollbar-color: rgba(129,140,248,0.25) transparent; }

/* ══════════════════════════════════════════════
   4. ANIMATED GRADIENT ORBS
   ══════════════════════════════════════════════ */
body::before, body::after {
    content: '';
    position: fixed;
    border-radius: 50%;
    filter: blur(100px);
    opacity: 0.2;
    pointer-events: none;
    z-index: 0;
    animation: drift 25s var(--ease-out) infinite;
}
body::before {
    width: 600px; height: 600px;
    background: radial-gradient(circle, #6366f1, transparent 70%);
    top: -15%; left: -5%;
}
body::after {
    width: 500px; height: 500px;
    background: radial-gradient(circle, #22d3ee, transparent 70%);
    bottom: -15%; right: -5%;
    animation-delay: -12s;
    animation-direction: reverse;
}
@keyframes drift {
    0%, 100% { transform: translate(0, 0) scale(1); }
    33%  { transform: translate(50px, -40px) scale(1.06); }
    66%  { transform: translate(-30px, 30px) scale(0.94); }
}

/* ══════════════════════════════════════════════
   5. TOOLTIP SYSTEM
   ══════════════════════════════════════════════ */
[data-tip] { position: relative; }
[data-tip]::after {
    content: attr(data-tip);
    position: absolute; bottom: calc(100% + 8px); left: 50%;
    transform: translateX(-50%) scale(0.92); transform-origin: bottom center;
    background: rgba(15,12,40,0.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    color: #e2e8f0; font-size: 11px; font-weight: 500; line-height: 1.4;
    padding: 6px 12px; border-radius: 8px; white-space: nowrap;
    border: 1px solid rgba(255,255,255,0.12);
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
    pointer-events: none; opacity: 0;
    transition: opacity var(--speed-fast), transform var(--speed-fast);
    z-index: 900;
}
[data-tip]:hover::after { opacity: 1; transform: translateX(-50%) scale(1); }
[data-tip]:has([data-tip]:hover)::after { opacity: 0; transform: translateX(-50%) scale(0.92); }
[data-tip].tip-bottom::after { bottom: auto; top: calc(100% + 8px); transform-origin: top center; }
[data-tip].tip-left::after  { left: 0; transform: translateX(0) scale(0.92); }
[data-tip].tip-left:hover::after  { transform: translateX(0) scale(1); }
[data-tip].tip-right::after { left: auto; right: 0; transform: translateX(0) scale(0.92); }
[data-tip].tip-right:hover::after { transform: translateX(0) scale(1); }
@media (max-width: 700px) { [data-tip]::after { display: none; } }

/* ══════════════════════════════════════════════
   6. SHARED HEADER (authenticated pages)
   ══════════════════════════════════════════════ */
.header {
    position: sticky; top: 0; z-index: 50;
    background: rgba(15,11,46,0.88);
    backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
    border-bottom: 1px solid var(--glass-border-light);
    padding: 12px 28px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 16px; flex-wrap: wrap;
}
.header h1 {
    font-size: 18px; font-weight: 700; white-space: nowrap;
    background: linear-gradient(135deg, #c7d2fe 0%, #818cf8 50%, #22d3ee 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.header-right { display: flex; align-items: center; gap: 12px; }

/* Nav links */
.nav-links { display: flex; gap: 6px; }
.nav-link {
    padding: 7px 18px; border-radius: 12px;
    font-size: 13px; font-weight: 500;
    text-decoration: none;
    transition: all var(--speed-normal) var(--ease-out);
    border: 1px solid var(--glass-border);
    color: var(--text-muted); background: var(--glass);
    display: inline-flex; align-items: center; gap: 7px;
}
.nav-link:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-1px); }
.nav-link.active {
    background: linear-gradient(135deg, #6366f1, #818cf8);
    color: #fff; border-color: transparent;
    box-shadow: 0 2px 16px var(--accent-glow);
}
.nav-link svg { width: 14px; height: 14px; }

/* User pill */
.user-pill {
    display: flex; align-items: center; gap: 8px;
    background: var(--glass); border: 1px solid var(--glass-border);
    padding: 4px 14px 4px 4px; border-radius: 24px;
    font-size: 13px; font-weight: 500;
    transition: border-color var(--speed-normal);
}
.user-pill:hover { border-color: var(--glass-border-light); }
.user-pill .avatar {
    width: 28px; height: 28px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-weight: 700; font-size: 12px;
}

/* Logout / Switch User */
.btn-logout {
    background: none; border: 1px solid var(--glass-border);
    color: var(--text-muted); padding: 5px 12px; border-radius: 8px;
    font-size: 12px; cursor: pointer;
    transition: all var(--speed-normal) var(--ease-out);
    text-decoration: none; font-family: inherit;
}
.btn-logout:hover { border-color: var(--accent); color: var(--accent); }

/* Help button */
.btn-help {
    width: 28px; height: 28px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    background: var(--glass); border: 1px solid var(--glass-border);
    color: var(--text-muted); font-size: 12px; font-weight: 700;
    cursor: pointer;
    transition: all var(--speed-normal) var(--ease-out);
    font-family: inherit;
}
.btn-help:hover { border-color: var(--accent); color: var(--accent); }

/* ══════════════════════════════════════════════
   7. SHARED BADGE SYSTEM
   ══════════════════════════════════════════════ */
.badge {
    padding: 4px 12px; border-radius: 20px; font-size: 10px; font-weight: 700;
    display: inline-block; text-align: center; min-width: 60px;
    border: 1px solid transparent; white-space: nowrap;
    letter-spacing: 0.2px;
}
.status-open        { background: var(--red-bg);   color: var(--red);   border-color: var(--red-border); }
.status-in-progress { background: var(--amber-bg); color: var(--amber); border-color: var(--amber-border); }
.status-done        { background: var(--green-bg); color: var(--green); border-color: var(--green-border); }
.status-blocked     { background: var(--rose-bg);  color: var(--rose);  border-color: var(--rose-border); }
.impact-high   { background: var(--red-bg);   color: var(--red);   border-color: var(--red-border); }
.impact-medium { background: var(--amber-bg); color: var(--amber); border-color: var(--amber-border); }
.impact-low    { background: var(--green-bg); color: var(--green); border-color: var(--green-border); }

/* ══════════════════════════════════════════════
   8. SHARED BUTTON PATTERNS
   ══════════════════════════════════════════════ */
.btn-primary-gradient {
    background: linear-gradient(135deg, #6366f1, #818cf8);
    color: #fff; border: none;
    box-shadow: 0 2px 16px var(--accent-glow);
    transition: all var(--speed-normal) var(--ease-out);
    cursor: pointer; font-family: inherit;
}
.btn-primary-gradient:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 28px var(--accent-glow);
}

/* Top bar (pitch, faq, report) */
.top-bar {
    display: flex; justify-content: space-between; align-items: center;
    gap: 12px; flex-wrap: wrap;
}
.btn-back {
    padding: 10px 20px;
    background: var(--glass);
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--glass-border);
    color: var(--text-muted);
    border-radius: 10px;
    text-decoration: none;
    font-size: 13px; font-weight: 500;
    transition: all var(--speed-normal) var(--ease-out);
    display: inline-flex; align-items: center; gap: 6px;
}
.btn-back:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-1px); }
.btn-back svg { width: 14px; height: 14px; }

.btn-cta {
    padding: 12px 28px;
    background: linear-gradient(135deg, #6366f1, #818cf8);
    color: #fff; border: none; border-radius: 12px;
    font-size: 14px; font-weight: 600; cursor: pointer;
    text-decoration: none; display: inline-flex; align-items: center; gap: 8px;
    box-shadow: 0 4px 20px var(--accent-glow);
    transition: all var(--speed-normal) var(--ease-out);
    font-family: inherit;
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
.btn-cta:hover { transform: translateY(-2px); box-shadow: 0 6px 28px var(--accent-glow); }
.btn-cta svg { width: 16px; height: 16px; }

/* ══════════════════════════════════════════════
   9. GLASS CARD UTILITY
   ══════════════════════════════════════════════ */
.glass-card {
    background: var(--glass);
    backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    border: 1px solid var(--glass-border);
    border-radius: 18px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15), 0 0 0 1px rgba(255,255,255,0.03);
    transition: border-color var(--speed-normal), transform var(--speed-normal) var(--ease-out), box-shadow var(--speed-normal);
}
.glass-card:hover {
    border-color: var(--glass-border-light);
    box-shadow: 0 6px 28px rgba(0,0,0,0.2), 0 0 0 1px rgba(255,255,255,0.05);
}

/* ══════════════════════════════════════════════
   10. SHARED GRADIENT TEXT
   ══════════════════════════════════════════════ */
.gradient-text {
    background: linear-gradient(135deg, #c7d2fe 0%, #818cf8 50%, #22d3ee 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ══════════════════════════════════════════════
   11. SHARED RESPONSIVE BREAKPOINTS
   ══════════════════════════════════════════════ */
@media (max-width: 700px) {
    .header { padding: 10px 16px; gap: 10px; }
    .nav-links { gap: 4px; }
    .nav-link { padding: 5px 10px; font-size: 12px; }
    .header-right { gap: 8px; }
    .btn-logout { padding: 4px 10px; font-size: 11px; }
    .top-bar { margin-bottom: 24px; }
    .btn-cta { padding: 10px 20px; font-size: 13px; }
}

/* ══════════════════════════════════════════════
   12. PRINT GLOBAL RESETS
   ══════════════════════════════════════════════ */
@media print {
    body::before, body::after { display: none !important; }
    .header { position: static !important; }
    .theme-toggle { display: none !important; }
}

/* ══════════════════════════════════════════════
   13. REDUCED MOTION
   Honour the user's OS-level "reduce motion" setting
   by disabling the heavy ambient animations and the
   small hover transforms.
   ══════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    body::before, body::after { animation: none !important; }
}
