/* =================================================================
   Fly.cool Dashboard — Pink & Black Edition
   -----------------------------------------------------------------
   Aesthetic: Deep black backdrop + electric pink accents +
              clean modern type + refined data cards
   ================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&family=Instrument+Serif:ital@0;1&display=swap');

:root {
    /* ---- brand palette (fly.cool pink & black) ---- */
    --fly-pink:        #FF0080;   /* electric primary pink */
    --fly-pink-soft:   #FF4DA6;
    --fly-pink-deep:   #CC0066;
    --fly-pink-glow:   rgba(255, 0, 128, 0.4);
    --fly-magenta:     #FF006B;
    --fly-purple:      #8B5CF6;
    --fly-accent:      #00E5FF;   /* secondary cyan accent */

    /* ---- surfaces (black theme) ---- */
    --ink:             #000000;   /* pure black background */
    --ink-2:           #0A0A0A;
    --pane:            #111111;   /* card surface */
    --pane-2:          #1A1A1A;   /* raised */
    --pane-line:       rgba(255,255,255,0.08);
    --pane-line-2:     rgba(255,255,255,0.04);
    --glass-tint:      rgba(255,0,128,0.03);

    /* ---- text ---- */
    --text-1:          #FFFFFF;
    --text-2:          #B8B8B8;
    --text-3:          #6E6E6E;
    --text-dim:        #4A4A4A;

    /* ---- semantic ---- */
    --ok:              #00FF94;
    --warn:            #FFB800;
    --bad:             #FF4B6E;

    /* ---- spacing scale ---- */
    --gap-xs:  4px;
    --gap-sm:  8px;
    --gap-md:  16px;
    --gap-lg:  24px;
    --gap-xl:  40px;

    /* ---- radii / elevation ---- */
    --r-sm:  6px;
    --r-md:  12px;
    --r-lg:  18px;
    --shadow-glow: 0 0 0 1px rgba(255,0,128,0.18), 0 8px 30px rgba(255,0,128,0.10);
    --sidebar-width: 284px;
    --topbar-height: 72px;
}

/* =================================================================
   Reset & base
   ================================================================= */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
    font-family: 'Space Grotesk', -apple-system, sans-serif;
    background: var(--ink);
    color: var(--text-1);
    font-size: 14px;
    line-height: 1.5;
    min-height: 100vh;
    overflow-x: hidden;
    background-image:
        radial-gradient(circle at 20% -10%, rgba(255,0,128,0.15), transparent 40%),
        radial-gradient(circle at 90% 10%,  rgba(139,92,246,0.10), transparent 40%),
        radial-gradient(circle at 50% 100%, rgba(255,0,128,0.08), transparent 50%);
    background-attachment: fixed;
}

/* the signature subtle grid */
body::before {
    content: "";
    position: fixed; inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(to right, rgba(255,255,255,0.02) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,0.02) 1px, transparent 1px);
    background-size: 56px 56px;
    z-index: 0;
}

a { color: var(--fly-pink); text-decoration: none; transition: color 0.15s ease; }
a:hover { color: var(--fly-pink-soft); }

::selection { background: var(--fly-pink); color: var(--ink); }

/* =================================================================
   Typography
   ================================================================= */
h1, h2, h3, h4 {
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--text-1);
    margin: 0;
}
h1 { font-size: 28px; letter-spacing: -0.03em; }
h2 { font-size: 20px; }
h3 { font-size: 16px; }

.display {
    font-family: 'Instrument Serif', serif;
    font-style: italic;
    font-weight: 400;
    letter-spacing: -0.01em;
}
.mono { font-family: 'JetBrains Mono', monospace; }

.eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 11px;
    font-weight: 500;
    color: var(--text-3);
}

/* =================================================================
   App shell — sidebar + topbar + main
   ================================================================= */
.app {
    position: relative;
    z-index: 1;
    display: block;
    min-height: 100vh;
}

/* ---------- sidebar ---------- */
.sidebar {
    width: var(--sidebar-width);
    background:
        radial-gradient(circle at 40% 0%, rgba(255,0,128,0.16), transparent 28%),
        linear-gradient(180deg, rgba(18,18,18,0.96) 0%, rgba(0,0,0,0.98) 100%);
    border-right: 1px solid var(--pane-line);
    padding: var(--gap-lg) var(--gap-md);
    overflow-y: auto;
    position: fixed;
    inset: 0 auto 0 0;
    height: 100dvh;
    z-index: 80;
    transform: translateX(0);
    transition: transform 0.24s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.24s ease;
    will-change: transform;
}

body.sidebar-collapsed .sidebar { transform: translateX(calc(-1 * var(--sidebar-width))); }

.sidebar-backdrop {
    position: fixed;
    inset: 0;
    z-index: 70;
    border: 0;
    padding: 0;
    background: rgba(0,0,0,0.58);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.brand {
    display: flex; align-items: center; justify-content: center;
    padding: 0 0 var(--gap-lg);
    margin-bottom: var(--gap-md);
    border-bottom: 1px solid var(--pane-line-2);
}
.brand-mark {
    width: 164px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
.brand-mark img {
    display: block;
    width: 164px;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 0 12px var(--fly-pink-glow));
}
.brand-text { display: flex; flex-direction: column; line-height: 1; }
.brand-name { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; color: var(--fly-pink); }
.brand-tag  { font-size: 10px; color: var(--text-3); letter-spacing: 0.2em; text-transform: uppercase; margin-top: 4px; }

.nav-group { margin-top: var(--gap-md); }
.nav-group-label {
    text-transform: uppercase; letter-spacing: 0.18em;
    font-size: 10px; color: var(--text-dim);
    padding: 0 var(--gap-sm) var(--gap-sm);
}
.nav-item {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 12px;
    border-radius: 12px;
    color: var(--text-2);
    font-size: 13.5px;
    font-weight: 500;
    transition: all 0.15s ease;
    margin-bottom: 1px;
    position: relative;
}
.nav-item:hover {
    background: rgba(255,255,255,0.04);
    color: var(--text-1);
    transform: translateX(2px);
}
.nav-item.active {
    background: linear-gradient(90deg, rgba(255,0,128,0.20), rgba(255,255,255,0.03));
    color: var(--fly-pink);
    box-shadow: inset 0 0 0 1px rgba(255,0,128,0.16), 0 12px 28px rgba(255,0,128,0.08);
}
.nav-item.active::before {
    content: "";
    position: absolute; left: -16px; top: 8px; bottom: 8px;
    width: 3px; border-radius: 0 3px 3px 0;
    background: var(--fly-pink);
    box-shadow: 0 0 12px var(--fly-pink);
}
.nav-item .ico { width: 16px; height: 16px; opacity: 0.8; flex-shrink: 0; }

/* ---------- topbar ---------- */
.topbar {
    display: flex; align-items: center; justify-content: space-between; gap: var(--gap-md);
    min-height: var(--topbar-height);
    margin-left: var(--sidebar-width);
    padding: 0 var(--gap-xl);
    border-bottom: 1px solid var(--pane-line);
    background: rgba(5,5,5,0.78);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    position: sticky; top: 0; z-index: 50;
    transition: margin-left 0.24s cubic-bezier(0.2, 0.8, 0.2, 1);
}
body.sidebar-collapsed .topbar { margin-left: 0; }

.sidebar-toggle {
    width: 42px;
    height: 42px;
    display: inline-flex;
    flex: 0 0 42px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 14px;
    background: rgba(255,255,255,0.035);
    color: var(--text-1);
    cursor: pointer;
    transition: border-color 0.15s ease, background 0.15s ease, transform 0.15s ease;
}
.sidebar-toggle:hover {
    border-color: rgba(255,0,128,0.38);
    background: rgba(255,0,128,0.10);
    transform: translateY(-1px);
}
.sidebar-toggle span {
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transition: transform 0.2s ease, opacity 0.2s ease;
}
@media (min-width: 901px) {
    body:not(.sidebar-collapsed) .sidebar-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    body:not(.sidebar-collapsed) .sidebar-toggle span:nth-child(2) { opacity: 0; }
    body:not(.sidebar-collapsed) .sidebar-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}

@media (max-width: 900px) {
    body.sidebar-open .sidebar-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    body.sidebar-open .sidebar-toggle span:nth-child(2) { opacity: 0; }
    body.sidebar-open .sidebar-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}
.topbar-search {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px;
    background: rgba(255,255,255,0.035);
    border: 1px solid var(--pane-line);
    border-radius: 999px;
    width: min(440px, 42vw);
    transition: all 0.2s ease;
}
.topbar-search .ico {
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    color: var(--fly-pink);
    opacity: 0.9;
}
.topbar-search:focus-within {
    border-color: var(--fly-pink);
    box-shadow: 0 0 0 3px rgba(255,0,128,0.10);
}
.topbar-search input {
    background: transparent; border: 0; outline: 0;
    color: var(--text-1); flex: 1;
    min-width: 0;
    font-size: 13px; font-family: inherit;
}
.topbar-search input::placeholder { color: var(--text-dim); }
.topbar-search kbd {
    font-family: 'JetBrains Mono', monospace; font-size: 10px;
    padding: 2px 6px; border-radius: 3px;
    background: var(--pane-2); color: var(--text-3);
    border: 1px solid var(--pane-line);
    white-space: nowrap;
}
.topbar-actions { display: flex; align-items: center; gap: var(--gap-md); }
.user-chip {
    display: flex; align-items: center; gap: 10px;
    padding: 4px 4px 4px 12px;
    border: 1px solid var(--pane-line);
    border-radius: 999px;
    background: rgba(255,255,255,0.03);
    cursor: pointer;
    transition: border-color 0.15s ease;
}
.user-chip:hover { border-color: var(--fly-pink); }
.user-chip .avatar {
    width: 28px; height: 28px; border-radius: 50%;
    background: linear-gradient(135deg, var(--fly-pink), var(--fly-purple));
    color: var(--ink); font-weight: 700; font-size: 12px;
    display: grid; place-items: center;
}
.user-chip .role { font-size: 11px; color: var(--text-3); margin-top: 2px; }

/* ---------- main ---------- */
.main {
    margin-left: var(--sidebar-width);
    padding: clamp(16px, 3vw, var(--gap-xl));
    overflow-y: auto;
    min-width: 0;
    transition: margin-left 0.24s cubic-bezier(0.2, 0.8, 0.2, 1);
}
body.sidebar-collapsed .main { margin-left: 0; }

.dashboard-hero {
    position: relative;
    display: block;
    gap: var(--gap-lg);
    align-items: stretch;
    margin-bottom: var(--gap-lg);
    padding: clamp(22px, 3vw, 34px);
    border: 1px solid rgba(255,0,128,0.18);
    border-radius: 28px;
    background:
        radial-gradient(circle at 18% 10%, rgba(255,0,128,0.28), transparent 32%),
        linear-gradient(135deg, rgba(255,0,128,0.10), rgba(255,255,255,0.025) 42%, rgba(139,92,246,0.10));
    box-shadow: 0 24px 70px rgba(0,0,0,0.32), 0 0 70px rgba(255,0,128,0.08);
    overflow: hidden;
}
.dashboard-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: linear-gradient(115deg, transparent 0 44%, rgba(255,255,255,0.05) 45%, transparent 46% 100%);
    pointer-events: none;
}
.hero-copy { position: relative; z-index: 1; max-width: none; }
.hero-copy h1 {
    font-size: clamp(32px, 4vw, 58px);
    line-height: 0.98;
    margin: 8px 0 12px;
    white-space: nowrap;
    max-width: calc(100% - 210px);
    overflow-wrap: normal;
}
.hero-copy p { color: var(--text-2); font-size: 16px; max-width: min(720px, calc(100% - 210px)); margin: 0; }
.hero-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: var(--gap-md);
}
.btn-disabled,
.btn-disabled:hover {
    cursor: not-allowed;
    opacity: 0.55;
    color: var(--text-2);
    border-color: var(--pane-line);
    transform: none;
    box-shadow: none;
}
.export-note {
    color: var(--text-3);
    font-size: 12px;
}
.hero-panel {
    position: absolute;
    right: clamp(18px, 3vw, 30px);
    bottom: clamp(18px, 3vw, 30px);
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 8px;
    min-height: 112px;
    width: 170px;
    padding: var(--gap-md);
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 22px;
    background: rgba(0,0,0,0.34);
    overflow: hidden;
}
.hero-panel strong { font-family: 'JetBrains Mono', monospace; font-size: 28px; line-height: 1; }
.hero-orbit {
    position: absolute;
    width: 92px; height: 92px;
    top: -34px; right: -28px;
    border: 1px solid rgba(255,0,128,0.35);
    border-radius: 999px;
    box-shadow: inset 0 0 34px rgba(255,0,128,0.14), 0 0 34px rgba(255,0,128,0.12);
}

.page-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    margin-bottom: var(--gap-lg);
    gap: var(--gap-md);
    flex-wrap: wrap;
}
.page-title { display: flex; flex-direction: column; gap: 4px; }
.page-title h1 { font-size: 32px; }
.page-title .display-accent {
    display: inline; color: var(--fly-pink);
}
.page-title p { color: var(--text-3); margin: 0; max-width: 520px; }

/* =================================================================
   Cards & glass surfaces
   ================================================================= */
.card {
    background: linear-gradient(180deg, rgba(26,26,26,0.92), rgba(12,12,12,0.94));
    border: 1px solid var(--pane-line);
    border-radius: 20px;
    padding: var(--gap-lg);
    position: relative;
    overflow: hidden;
}
.card-glow::after {
    content: "";
    position: absolute; inset: 0;
    background: radial-gradient(circle at top right, rgba(255,0,128,0.08), transparent 50%);
    pointer-events: none;
}
.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--gap-md); }
.card-head h3 { font-size: 14px; color: var(--text-2); font-weight: 500; }

/* =================================================================
   KPI tiles — the dashboard hero row
   ================================================================= */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
    gap: var(--gap-md);
    margin-bottom: var(--gap-lg);
}
.kpi-grid-premium { grid-template-columns: repeat(4, minmax(180px, 1fr)); }
.kpi {
    position: relative;
    background: linear-gradient(180deg, var(--pane-2) 0%, var(--pane) 100%);
    border: 1px solid var(--pane-line);
    border-radius: 20px;
    padding: var(--gap-lg);
    overflow: hidden;
    transition: transform 0.25s cubic-bezier(0.2, 0.8, 0.2, 1), border-color 0.25s ease;
}
.kpi:hover { transform: translateY(-2px); border-color: rgba(255,0,128,0.25); }
.kpi::before {
    content: ""; position: absolute; inset: 0 0 auto 0; height: 2px;
    background: linear-gradient(90deg, transparent, var(--fly-pink), transparent);
    opacity: 0.6;
}
.kpi .kpi-label {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.15em;
    color: var(--text-3); font-weight: 500;
}
.kpi-icon {
    width: 38px; height: 38px;
    display: grid; place-items: center;
    margin-bottom: 18px;
    color: var(--fly-pink);
    border-radius: 14px;
    background: rgba(255,0,128,0.10);
    box-shadow: inset 0 0 0 1px rgba(255,0,128,0.16);
}
.kpi-icon svg { width: 18px; height: 18px; }
.kpi .kpi-value {
    font-size: clamp(28px, 3vw, 36px); font-weight: 600; letter-spacing: -0.03em;
    margin: 8px 0 4px; line-height: 1;
    color: var(--text-1); font-family: 'JetBrains Mono', monospace;
}
.kpi .kpi-delta {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 12px; font-weight: 500;
}
.kpi .kpi-delta svg { width: 13px; height: 13px; }
.kpi-delta.up   { color: var(--ok);  }
.kpi-delta.ok   { color: var(--ok);  }
.kpi-delta.down { color: var(--bad); }
.kpi-delta.flat { color: var(--text-3); }
.kpi-delta.warn { color: var(--warn); }
.kpi-spark {
    position: absolute; right: 16px; bottom: 16px;
    width: 80px; height: 28px; opacity: 0.6;
}

/* =================================================================
   Dashboard charts grid
   ================================================================= */
.chart-grid {
    display: grid; gap: var(--gap-md);
    grid-template-columns: 2fr 1fr;
}
@media (max-width: 1100px) { .chart-grid { grid-template-columns: 1fr; } }

.chart-row {
    display: grid; gap: var(--gap-md);
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
}
.chart-card { min-height: 320px; }
.chart-card-xl { min-height: 360px; }
.chart-canvas-wrap { position: relative; height: 260px; }

.provider-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--gap-md);
}
.provider-card {
    display: flex;
    flex-direction: column;
    gap: var(--gap-lg);
    min-height: 240px;
    padding: var(--gap-lg);
    color: var(--text-1);
    border: 1px solid rgba(255,0,128,0.14);
    border-radius: 22px;
    background: radial-gradient(circle at top right, rgba(255,0,128,0.16), transparent 44%), linear-gradient(180deg, rgba(26,26,26,0.92), rgba(10,10,10,0.96));
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.provider-card:hover {
    color: var(--text-1);
    transform: translateY(-4px);
    border-color: rgba(255,0,128,0.36);
    box-shadow: 0 24px 60px rgba(255,0,128,0.12);
}
.provider-card h3 { font-size: 26px; margin-top: 6px; }
.provider-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    color: var(--text-3);
}
.provider-metrics span {
    display: flex;
    min-height: 86px;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    padding: 14px;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 16px;
    background: rgba(0,0,0,0.24);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}
.provider-metrics strong {
    display: block;
    color: var(--text-1);
    font-family: 'JetBrains Mono', monospace;
    font-size: clamp(22px, 2.2vw, 34px);
    line-height: 1;
    letter-spacing: -0.06em;
}
.provider-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; }
.provider-footer svg { width: 18px; height: 18px; color: var(--fly-pink); }

.dashboard-lower {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: var(--gap-md);
}
.activity-card { align-self: start; }
.activity-list { display: grid; gap: 12px; }
.activity-item {
    display: grid;
    grid-template-columns: 10px minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid var(--pane-line-2);
    border-radius: 14px;
    background: rgba(255,255,255,0.025);
}
.activity-dot { width: 8px; height: 8px; border-radius: 999px; background: var(--fly-pink); box-shadow: 0 0 12px var(--fly-pink); }
.activity-item strong { display: block; font-size: 13px; }
.activity-item span { color: var(--text-3); font-size: 12px; }
.activity-status { color: var(--text-2) !important; text-align: right; }

/* =================================================================
   Tables (data-dense, with sticky header)
   ================================================================= */
.table-wrap {
    background: var(--pane);
    border: 1px solid var(--pane-line);
    border-radius: var(--r-md);
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
}
table.data {
    width: 100%; min-width: 760px; border-collapse: collapse;
    font-size: 13px;
}
table.data thead {
    background: var(--pane-2);
}
table.data th {
    text-align: left;
    padding: 12px 16px;
    font-weight: 500;
    font-size: 11px;
    color: var(--text-3);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border-bottom: 1px solid var(--pane-line);
    position: sticky; top: 0; z-index: 1;
    background: var(--pane-2);
}
table.data td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--pane-line-2);
    color: var(--text-2);
    vertical-align: middle;
}
table.data tbody tr { transition: background-color 0.1s ease; }
table.data tbody tr:hover { background: rgba(255,255,255,0.02); }
table.data td.num { font-family: 'JetBrains Mono', monospace; text-align: right; color: var(--text-1); }
table.data tr.is-highlight { background: rgba(255,0,128,0.04); }

/* =================================================================
   Buttons
   ================================================================= */
.btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 9px 16px;
    border: 1px solid var(--pane-line);
    background: var(--pane);
    color: var(--text-1);
    font-family: inherit; font-size: 13px; font-weight: 500;
    border-radius: var(--r-sm);
    cursor: pointer;
    transition: all 0.15s ease;
}
.btn:hover { border-color: var(--fly-pink); color: var(--fly-pink); }
.btn-primary {
    background: linear-gradient(135deg, var(--fly-pink) 0%, var(--fly-purple) 100%);
    color: white; border: 0;
    font-weight: 600;
    box-shadow: 0 4px 14px rgba(255,0,128,0.30);
}
.btn-primary:hover {
    color: white;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(255,0,128,0.50);
}
.btn-ghost { background: transparent; }
.btn-danger { border-color: rgba(255,75,110,0.3); color: var(--bad); }
.btn-danger:hover { background: rgba(255,75,110,0.08); border-color: var(--bad); }
.btn-sm { padding: 6px 12px; font-size: 12px; }
.btn-icon { padding: 8px; }

/* =================================================================
   Form fields
   ================================================================= */
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--gap-md); }
.field label {
    font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--text-3); font-weight: 500;
}
.field input, .field select, .field textarea {
    background: var(--pane);
    border: 1px solid var(--pane-line);
    border-radius: var(--r-sm);
    color: var(--text-1);
    padding: 10px 14px;
    font-family: inherit; font-size: 13.5px;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.field input:focus, .field select:focus, .field textarea:focus {
    border-color: var(--fly-pink);
    box-shadow: 0 0 0 3px rgba(255,0,128,0.12);
}
.field-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--gap-md); }

/* =================================================================
   Pills, badges, status
   ================================================================= */
.pill {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 500;
    border: 1px solid var(--pane-line);
    background: var(--pane);
    color: var(--text-2);
}
.pill::before {
    content: ""; width: 6px; height: 6px; border-radius: 50%;
    background: var(--text-3);
}
.pill.ok::before    { background: var(--ok);   box-shadow: 0 0 8px var(--ok); }
.pill.warn::before  { background: var(--warn); box-shadow: 0 0 8px var(--warn); }
.pill.bad::before   { background: var(--bad);  box-shadow: 0 0 8px var(--bad); }
.pill.fly::before   { background: var(--fly-pink); box-shadow: 0 0 8px var(--fly-pink); }

.pill.ok    { color: var(--ok);   border-color: rgba(0,255,148,0.25); }
.pill.warn  { color: var(--warn); border-color: rgba(255,180,0,0.25); }
.pill.bad   { color: var(--bad);  border-color: rgba(255,75,110,0.25); }
.pill.fly   { color: var(--fly-pink); border-color: rgba(255,0,128,0.25); }

/* =================================================================
   Filter / segmented control
   ================================================================= */
.segmented {
    display: inline-flex; padding: 3px;
    background: var(--pane); border: 1px solid var(--pane-line);
    border-radius: var(--r-sm);
}
.segmented button {
    background: transparent; border: 0;
    color: var(--text-3);
    padding: 6px 14px;
    font-family: inherit; font-size: 12px; font-weight: 500;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.15s ease;
}
.segmented button:hover { color: var(--text-1); }
.segmented button.active {
    background: var(--pane-2);
    color: var(--fly-pink);
    box-shadow: 0 0 0 1px rgba(255,0,128,0.18);
}

/* =================================================================
   Alerts
   ================================================================= */
.alert {
    padding: 12px 16px;
    border-radius: var(--r-sm);
    border-left: 3px solid var(--fly-pink);
    background: rgba(255,0,128,0.06);
    color: var(--text-1);
    font-size: 13px;
    margin-bottom: var(--gap-md);
}
.alert.error { border-color: var(--bad); background: rgba(255,75,110,0.08); }
.alert.warn  { border-color: var(--warn); background: rgba(255,180,0,0.08); }
.alert.ok    { border-color: var(--ok); background: rgba(0,255,148,0.08); }

/* =================================================================
   Login page (anonymous, full-screen)
   ================================================================= */
.auth-page {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr 1fr;
    overflow: hidden;
}
@media (max-width: 900px) { .auth-page { grid-template-columns: 1fr; } .auth-page .auth-art { display: none; } }

.auth-art {
    position: relative;
    background: linear-gradient(135deg, #FF0080 0%, #8B5CF6 60%, #FF4DA6 100%);
    overflow: hidden;
    display: grid; place-items: center;
    color: white;
}
.auth-art::before {
    content: "";
    position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 20% 80%, rgba(139,92,246,0.5), transparent 50%),
        radial-gradient(circle at 80% 20%, rgba(255,255,255,0.15), transparent 50%);
}
/* the animated fibre-line motif: streaks of light */
.auth-art::after {
    content: "";
    position: absolute; inset: 0;
    background-image:
        repeating-linear-gradient(115deg,
            transparent 0,
            transparent 38px,
            rgba(255,255,255,0.10) 38px,
            rgba(255,255,255,0.10) 39px);
    animation: drift 24s linear infinite;
}
@keyframes drift {
    from { transform: translateX(-40px); }
    to   { transform: translateX(40px); }
}
.auth-art-content {
    position: relative; z-index: 2;
    text-align: left;
    max-width: 420px;
    padding: 0 var(--gap-xl);
}
.auth-art-content .display {
    font-size: 64px; line-height: 1; color: white; margin-bottom: 24px;
}
.auth-art-content p {
    font-size: 16px; line-height: 1.5; color: rgba(255,255,255,0.9); margin: 0;
}
.auth-art-bug {
    position: absolute; bottom: var(--gap-xl); left: var(--gap-xl);
    font-family: 'JetBrains Mono', monospace; font-size: 11px;
    color: rgba(255,255,255,0.7);
    letter-spacing: 0.2em; text-transform: uppercase;
}

.auth-form-wrap {
    background: var(--ink);
    display: grid; place-items: center;
    padding: var(--gap-xl);
    position: relative;
}
.auth-form {
    width: 100%; max-width: 380px;
}
.auth-form h1 {
    font-size: 32px; margin-bottom: 8px;
}
.auth-form p.lead {
    color: var(--text-3); margin: 0 0 var(--gap-lg);
}
.auth-form .btn-primary { width: 100%; justify-content: center; padding: 12px; }

/* Logo on login form */
.auth-logo {
    display: flex;
    justify-content: center;
    margin-bottom: var(--gap-lg);
    animation: logoReveal 0.6s cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

.auth-logo img {
    width: 200px;
    height: auto;
    border-radius: var(--r-md);
    box-shadow: 
        0 8px 32px rgba(255,0,128,0.25),
        0 0 0 1px rgba(255,255,255,0.05);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.auth-logo img:hover {
    transform: translateY(-2px);
    box-shadow: 
        0 12px 40px rgba(255,0,128,0.35),
        0 0 0 1px rgba(255,255,255,0.08);
}

@keyframes logoReveal {
    from { 
        opacity: 0; 
        transform: translateY(-12px) scale(0.95); 
    }
    to { 
        opacity: 1; 
        transform: none; 
    }
}

/* =================================================================
   Subtle reveal animations on page load
   ================================================================= */
.reveal { animation: reveal 0.5s cubic-bezier(0.2, 0.8, 0.2, 1) both; }
.reveal-delayed { animation: reveal 0.5s cubic-bezier(0.2, 0.8, 0.2, 1) 0.05s both; }
.reveal-delayed-2 { animation: reveal 0.5s cubic-bezier(0.2, 0.8, 0.2, 1) 0.10s both; }
.reveal-delayed-3 { animation: reveal 0.5s cubic-bezier(0.2, 0.8, 0.2, 1) 0.15s both; }
@keyframes reveal {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: none; }
}

/* =================================================================
   Utilities
   ================================================================= */
.flex { display: flex; }
.flex-between { display: flex; justify-content: space-between; align-items: center; }
.gap-sm { gap: var(--gap-sm); }
.gap-md { gap: var(--gap-md); }
.gap-lg { gap: var(--gap-lg); }
.text-dim { color: var(--text-3); }
.text-fly { color: var(--fly-pink); }
.mb-sm { margin-bottom: var(--gap-sm); }
.mb-md { margin-bottom: var(--gap-md); }
.mb-lg { margin-bottom: var(--gap-lg); }
.mt-md { margin-top: var(--gap-md); }
.mt-lg { margin-top: var(--gap-lg); }
.hidden { display: none !important; }

@media (max-width: 1200px) {
    .kpi-grid-premium { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .provider-grid { grid-template-columns: 1fr; }
    .dashboard-lower { grid-template-columns: 1fr; }
    .provider-metrics strong { font-size: 30px; }
}

@media (max-width: 1050px) and (min-width: 901px) {
    :root { --sidebar-width: 252px; }
    .sidebar { padding-inline: 12px; }
    .brand-mark, .brand-mark img { width: 148px; }
    .topbar { padding-inline: var(--gap-lg); }
    .topbar-search { width: min(360px, 40vw); }
    .hero-copy h1 { font-size: clamp(30px, 3.4vw, 44px); }
}

@media (max-width: 900px) {
    .sidebar {
        width: min(86vw, 320px);
        transform: translateX(-100%);
        padding: var(--gap-md);
        border-right: 1px solid var(--pane-line);
        border-bottom: 0;
        box-shadow: 24px 0 70px rgba(0,0,0,0.48);
    }
    body.sidebar-open { overflow: hidden; }
    body.sidebar-open .sidebar { transform: translateX(0); }
    body.sidebar-open .sidebar-backdrop { opacity: 1; pointer-events: auto; }
    body.sidebar-collapsed .sidebar { transform: translateX(-100%); }
    .brand { margin-bottom: var(--gap-md); }
    .nav-item.active::before { left: -12px; }
    .topbar {
        position: relative;
        gap: var(--gap-md);
        padding: var(--gap-md);
        flex-wrap: wrap;
        margin-left: 0;
    }
    .topbar-search { width: 100%; order: 2; }
    .topbar-actions { width: 100%; justify-content: space-between; flex-wrap: wrap; }
    .user-chip { max-width: 100%; }
    .main { margin-left: 0; padding: var(--gap-md); }
    .hero-copy h1 { max-width: 100%; white-space: normal; }
    .hero-copy p { max-width: 100%; }
    .hero-panel {
        position: relative;
        right: auto;
        bottom: auto;
        width: 100%;
        min-height: 96px;
        margin-top: var(--gap-md);
    }
}

@media (max-width: 760px) {
    .nav-group { margin-top: 0; }
    .nav-group-label { padding-top: var(--gap-sm); }
    .kpi-grid-premium { grid-template-columns: 1fr; }
    .provider-metrics { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .provider-metrics strong { font-size: clamp(22px, 6vw, 30px); }
    .chart-card, .chart-card-xl { min-height: 280px; }
    .chart-canvas-wrap { height: 220px; }
}

@media (max-width: 620px) {
    .kpi-grid-premium { grid-template-columns: 1fr; }
    .chart-grid { grid-template-columns: 1fr; }
    .hero-copy h1 { font-size: 34px; white-space: normal; }
    .provider-metrics { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .topbar-actions { gap: var(--gap-sm); }
    .topbar-actions .pill.ok { order: 3; width: 100%; justify-content: center; }
    .topbar-actions form { margin-left: auto !important; }
    .topbar-search { padding: 9px 12px; }
    .topbar-search kbd { display: none; }
    .brand-mark, .brand-mark img { width: 150px; }
    .dashboard-hero { padding: 20px; border-radius: 22px; }
    .hero-copy h1 { font-size: clamp(30px, 11vw, 42px); }
    .hero-copy p { font-size: 14px; }
    .hero-panel { min-height: 86px; padding: 14px; border-radius: 18px; }
    .hero-panel strong { font-size: 24px; }
    .kpi, .card, .provider-card { padding: 18px; }
    .provider-card { min-height: auto; }
    .provider-metrics span { min-height: 78px; }
    table.data { min-width: 680px; font-size: 12px; }
    table.data th, table.data td { padding: 10px 12px; }
}

@media (max-width: 360px) {
    .main, .sidebar, .topbar { padding-inline: 12px; }
    .brand-mark, .brand-mark img { width: 138px; }
    .nav-item { padding: 9px 10px; font-size: 13px; }
    .dashboard-hero { padding: 16px; }
    .hero-copy h1 { font-size: 30px; }
    .kpi .kpi-value { font-size: 26px; }
    .provider-metrics strong { font-size: 24px; }
}

/* scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--ink); }
::-webkit-scrollbar-thumb { background: var(--pane-2); border-radius: 999px; border: 2px solid var(--ink); }
::-webkit-scrollbar-thumb:hover { background: var(--text-dim); }
