/* Self-hosted Inter (variable) — no external font request, no render block. */
@font-face{font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;src:url('../fonts/inter-var.woff2') format('woff2')}

/* ==========================================================================
   VGCPayment — "Aurora" console UI
   Two-tone shell: a dark premium navigation rail + a light, airy content area.
   Indigo→violet accent, soft layered shadows, rich KPI cards with sparklines.
   Light is default; dark is a cohesive override of the content area.
   ========================================================================== */

:root {
    /* content surfaces */
    --bg:#f5f7fa; --panel:#ffffff; --panel-2:#f7f9fc; --panel-3:#eef2f7;
    --line:#e3e8ee; --line-strong:#d2d9e2;
    --text:#15181a; --muted:#343b41; --faint:#4b525a;
    /* brand (PayPal) */
    --accent:#0070ba; --accent-hover:#005ea6; --accent-2:#009cde; --accent-weak:#e6f2fb; --on-accent:#fff;
    --navy:#003087; --gold:#ffc439; --on-gold:#001435;
    --ring:rgba(0,112,186,.22);
    /* semantic */
    --success:#067647; --success-bg:#ecfdf3; --success-bd:#abefc6;
    --info:#175cd3;    --info-bg:#eff6ff;    --info-bd:#b2ddff;
    --warn:#b54708;    --warn-bg:#fffaeb;    --warn-bd:#fedf89;
    --danger:#b42318;  --danger-bg:#fef3f2;  --danger-bd:#fecdca;
    --neutral:#475467; --neutral-bg:#f2f4f7; --neutral-bd:#e4e7ec;
    --pos:#067647;
    /* dark nav rail (fixed regardless of content theme) */
    --sb-bg:#001c64; --sb-elev:#0a2876; --sb-text:#eef3fb; --sb-muted:#aab6d8; --sb-faint:#6c7cae; --sb-line:#143079; --sb-hover:#0b2674;
    /* effects */
    --shadow-sm:0 1px 2px rgba(16,24,40,.05);
    --shadow-card:0 1px 2px rgba(16,24,40,.05), 0 1px 3px rgba(16,24,40,.04);
    --shadow-pop:0 16px 40px -16px rgba(16,24,40,.22), 0 4px 12px -6px rgba(16,24,40,.10);
    --shadow:var(--shadow-pop);
    /* type scale */
    --fs-sm:.9375rem; --fs-base:1rem; --fs-md:1.125rem; --fs-lg:1.375rem; --fs-xl:1.75rem; --fs-2xl:2.25rem;
    /* shape & motion */
    --radius:16px; --radius-md:12px; --radius-sm:10px; --radius-xs:8px;
    --sidebar-w:260px;
    --ease:cubic-bezier(.4,0,.2,1);
}
html[data-theme="dark"] {
    --bg:#0a0e18; --panel:#121829; --panel-2:#161d31; --panel-3:#1b2338;
    --line:#222c44; --line-strong:#2c3852;
    --text:#e8eef8; --muted:#9aa7be; --faint:#697590;
    --accent:#4cb3ff; --accent-hover:#7cc8ff; --accent-2:#009cde; --accent-weak:rgba(76,179,255,.14); --on-accent:#001435;
    --navy:#7cc8ff;
    --ring:rgba(76,179,255,.32);
    --success:#34d399; --success-bg:rgba(16,185,129,.13); --success-bd:rgba(52,211,153,.30);
    --info:#60a5fa;    --info-bg:rgba(96,165,250,.13);    --info-bd:rgba(96,165,250,.30);
    --warn:#fbbf24;    --warn-bg:rgba(245,158,11,.14);    --warn-bd:rgba(251,191,36,.30);
    --danger:#f87171;  --danger-bg:rgba(239,68,68,.13);   --danger-bd:rgba(248,113,113,.30);
    --neutral:#cbd5e1; --neutral-bg:rgba(148,163,184,.12);--neutral-bd:rgba(148,163,184,.26);
    --pos:#34d399;
    --shadow-card:0 1px 0 rgba(255,255,255,.02), 0 10px 26px -16px rgba(0,0,0,.6);
    --shadow-pop:0 20px 46px -18px rgba(0,0,0,.72);
}

/* ----- Base ----- */
* { box-sizing:border-box; }
html { font-size:16px; -webkit-text-size-adjust:100%; }
body { margin:0; background:var(--bg); color:var(--text);
    font-family:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
    font-size:var(--fs-base); line-height:1.6; font-weight:500;
    -webkit-font-smoothing:auto; text-rendering:optimizeLegibility;
    transition:background .25s var(--ease),color .25s var(--ease); }
h1{font-size:var(--fs-2xl);font-weight:800;letter-spacing:-.022em;margin:0}
h2{font-size:var(--fs-xl);font-weight:750;letter-spacing:-.018em;margin:0}
h3{font-size:var(--fs-lg);font-weight:700;letter-spacing:-.01em;margin:0}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-hover)}
code{font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:.9em}
[x-cloak]{display:none!important}
::selection{background:var(--accent-weak);color:var(--accent-hover)}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px;border:3px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--faint)}
::-webkit-scrollbar-track{background:transparent}

/* ----- Surfaces ----- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);transition:border-color .2s var(--ease),box-shadow .2s var(--ease),transform .2s var(--ease)}
.card-hover{cursor:pointer}
.card-hover:hover{border-color:var(--line-strong);box-shadow:var(--shadow-pop);transform:translateY(-2px)}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);overflow:hidden}
.panel__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}
.panel__title{font-size:15px;font-weight:700;letter-spacing:-.01em}
.panel__body{padding:20px}

/* ----- Buttons ----- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:999px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid transparent;text-decoration:none;font-family:inherit;line-height:1.2;user-select:none;white-space:nowrap;transition:background .15s var(--ease),border-color .15s var(--ease),color .15s var(--ease),box-shadow .15s var(--ease),transform .06s var(--ease)}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}
.btn-primary{color:var(--on-accent);background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 10px 22px -12px var(--accent)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-ghost{background:var(--panel);border-color:var(--line-strong);color:var(--muted)}
.btn-ghost:hover{color:var(--text);border-color:var(--faint);background:var(--panel-2)}
.btn-danger{background:var(--panel);border-color:var(--danger-bd);color:var(--danger)}
.btn-danger:hover{background:var(--danger-bg)}
.btn-gold{background:var(--gold);color:var(--on-gold);box-shadow:0 8px 18px -10px var(--gold)}
.btn-gold:hover{filter:brightness(.97);color:var(--on-gold)}
.btn-sm{padding:6px 11px;font-size:13px}
.icon-btn{width:36px;height:36px;padding:0;justify-content:center;border-radius:var(--radius-xs)}
.row-actions{display:flex;gap:7px;align-items:center;flex-wrap:wrap}

/* ----- Form controls ----- */
.input{width:100%;background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:14px;outline:none;font-family:inherit;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.input::placeholder{color:var(--faint)}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
select.input{cursor:pointer}
.label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}
.seg{padding:8px 14px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--panel);color:var(--muted);cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:all .15s var(--ease)}
.seg.on{border-color:var(--accent);color:var(--accent);background:var(--accent-weak)}
/* Segmented toggle buttons (Payment action, Status, shield picker) */
.segbar{display:inline-flex;flex-wrap:wrap;gap:8px}
.segbtn{padding:9px 16px;border:1px solid var(--line-strong);border-radius:10px;background:var(--panel);color:var(--muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;text-transform:capitalize;line-height:1.2;transition:background .15s var(--ease),border-color .15s var(--ease),color .15s var(--ease),box-shadow .15s var(--ease),transform .06s var(--ease)}
.segbtn:hover{border-color:var(--faint);color:var(--text);background:var(--panel-2)}
.segbtn:active{transform:translateY(1px)}
.segbtn.is-on{border-color:transparent;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:0 8px 18px -9px var(--accent)}
.segbtn--sm{padding:6px 13px;font-size:12.5px;border-radius:9px}
/* Custom dropdown (prettier than a native <select>; the option list is fully styleable) */
.dd{position:relative;display:inline-block}
.dd__btn{display:inline-flex;align-items:center;gap:9px;padding:9px 13px;border:1px solid var(--line-strong);border-radius:10px;background:var(--panel);color:var(--text);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;line-height:1.2;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.dd__btn:hover{border-color:var(--faint)}
.dd__btn:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
.dd__chev{color:var(--faint);transition:transform .2s var(--ease);flex-shrink:0}
.dd.open .dd__btn{border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
.dd.open .dd__chev{transform:rotate(180deg)}
.dd__menu{position:absolute;top:calc(100% + 7px);left:0;min-width:100%;z-index:70;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-pop);padding:6px;max-height:340px;overflow:auto;animation:vgcDrop .16s var(--ease)}
.dd__menu--right{left:auto;right:0}
.dd__item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:9px 12px;border:0;border-radius:8px;background:transparent;color:var(--text);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .12s var(--ease)}
.dd__item:hover{background:var(--panel-2)}
.dd__item.is-sel{background:var(--accent-weak);color:var(--accent);font-weight:700}
/* segmented tabs */
.tabs{display:inline-flex;gap:4px;background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:4px;max-width:100%;overflow-x:auto}
.tab{padding:8px 16px;border:0;border-radius:9px;background:transparent;color:var(--muted);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;font-family:inherit;transition:background .15s var(--ease),color .15s var(--ease),box-shadow .15s var(--ease)}
.tab:hover{color:var(--text)}
.tab.active{background:var(--panel);color:var(--accent);box-shadow:var(--shadow-sm)}
/* color swatch */
.swatch{width:30px;height:30px;border-radius:50%;border:0;padding:0;cursor:pointer;transition:transform .12s var(--ease)}
.swatch:hover{transform:scale(1.08)}
.swatch.is-sel{outline:2px solid var(--text);outline-offset:2px}
/* toast / flash notification */
.toast{position:fixed;top:80px;right:24px;z-index:200;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-md);padding:13px 18px;color:var(--text);box-shadow:var(--shadow-pop);display:flex;gap:10px;align-items:center;max-width:380px;animation:vgcDrop .25s var(--ease)}
.toast__icon{color:var(--success);display:flex;flex-shrink:0}
.toast--error{border-color:var(--danger)}
.toast--error .toast__icon{color:var(--danger)}
.switch{width:42px;height:24px;border-radius:99px;border:0;cursor:pointer;position:relative;background:var(--line-strong);transition:background .18s var(--ease);flex-shrink:0}
.switch.on{background:var(--accent)}
.switch__dot{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:left .18s var(--ease)}
.switch.on .switch__dot{left:21px}

/* ----- Tables ----- */
table.tbl{width:100%;border-collapse:collapse}
.tbl thead tr{background:var(--panel-2)}
.tbl tbody tr{border-top:1px solid var(--line);transition:background .14s var(--ease)}
.tbl tbody tr:hover{background:var(--panel-2)}
.th{text-align:left;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:12px 16px;white-space:nowrap}
.td{padding:13px 16px;font-size:14px;color:var(--text);vertical-align:middle}
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-wrap .tbl{min-width:620px}
/* table pagination (built by vgcPaginateTable) */
.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 16px;border-top:1px solid var(--line)}
.pager__info{font-size:13px;color:var(--faint);font-variant-numeric:tabular-nums}
.pager__btns{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.pager__gap{color:var(--faint);padding:0 2px}
.page-link[disabled]{opacity:.4;cursor:default;pointer-events:none}

/* ----- Chips / badges ----- */
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:var(--radius-xs);font-size:12px;font-weight:600;text-transform:capitalize;white-space:nowrap;line-height:1.4;border:1px solid var(--chip-bd,var(--neutral-bd));background:var(--chip-bg,var(--neutral-bg));color:var(--chip-fg,var(--neutral))}
button.chip{cursor:pointer;font-family:inherit}
.chip--success{--chip-bg:var(--success-bg);--chip-fg:var(--success);--chip-bd:var(--success-bd)}
.chip--info{--chip-bg:var(--info-bg);--chip-fg:var(--info);--chip-bd:var(--info-bd)}
.chip--warn{--chip-bg:var(--warn-bg);--chip-fg:var(--warn);--chip-bd:var(--warn-bd)}
.chip--danger{--chip-bg:var(--danger-bg);--chip-fg:var(--danger);--chip-bd:var(--danger-bd)}
.chip--neutral{--chip-bg:var(--neutral-bg);--chip-fg:var(--neutral);--chip-bd:var(--neutral-bd)}
.chip--accent{--chip-bg:var(--accent-weak);--chip-fg:var(--accent);--chip-bd:transparent}
.chip--cart{--chip-bg:#fce7f3;--chip-fg:#9d174d;--chip-bd:#fbcfe8}
html[data-theme="dark"] .chip--cart{--chip-bg:rgba(236,72,153,.16);--chip-fg:#f9a8d4;--chip-bd:rgba(236,72,153,.3)}
/* Realtime visitor feed rows */
.feed-row{padding:11px 11px;border-bottom:1px solid var(--line);border-radius:8px}
.feed-row--bot{background:repeating-linear-gradient(135deg,var(--warn-bg),var(--warn-bg) 8px,transparent 8px,transparent 16px)}
.feed-row--cart{background:color-mix(in srgb,#ec4899 9%,var(--panel))}
.pp{display:inline-block;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:700;letter-spacing:.3px;white-space:nowrap;
    background:color-mix(in srgb,var(--pp,#5b50f0) 13%,transparent);color:var(--pp,#5b50f0);border:1px solid color-mix(in srgb,var(--pp,#5b50f0) 26%,transparent)}
.pp.sm{font-size:11px;padding:1px 7px}
html[data-theme="dark"] .pp{background:color-mix(in srgb,var(--pp,#8b80ff) 20%,transparent);color:color-mix(in srgb,var(--pp,#8b80ff) 72%,#fff)}
.pp[data-code="PP01"]{--pp:#6366f1}.pp[data-code="PP02"]{--pp:#0ea5e9}.pp[data-code="PP03"]{--pp:#10b981}
.pp[data-code="PP04"]{--pp:#8b5cf6}.pp[data-code="PP05"]{--pp:#ef4444}.pp[data-code="PP06"]{--pp:#22c55e}
.pp[data-code="PP07"]{--pp:#64748b}.pp[data-code="PP08"]{--pp:#d97706}.pp[data-code="PP09"]{--pp:#14b8a6}
.pp[data-code="PP10"]{--pp:#ec4899}
.amount{font-weight:700;color:var(--text)}
.amount-pos{font-weight:700;color:var(--pos)}
.alert{border-radius:var(--radius-sm);padding:11px 14px;font-size:13.5px;border:1px solid var(--line)}
.alert--error{background:var(--danger-bg);border-color:var(--danger-bd);color:var(--danger)}
.page-link{min-width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);text-decoration:none;font-size:14px;font-weight:600;border:1px solid var(--line);color:var(--muted);background:var(--panel);transition:all .14s var(--ease)}
.page-link:hover{border-color:var(--line-strong);color:var(--text)}
.page-link.active{border-color:var(--accent);color:var(--accent);background:var(--accent-weak)}
.bar{flex:1;min-width:64px;background:var(--line);border-radius:99px;height:7px;overflow:hidden}
.bar > span{display:block;height:100%;border-radius:99px;transition:width .3s var(--ease)}

/* ----- KPI cards ----- */
.grid-kpi{display:grid;grid-template-columns:repeat(auto-fit,minmax(232px,1fr));gap:16px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:18px 20px;display:flex;flex-direction:column;gap:14px;transition:border-color .2s var(--ease),box-shadow .2s var(--ease),transform .2s var(--ease)}
.kpi:hover{border-color:var(--line-strong);box-shadow:var(--shadow-pop);transform:translateY(-2px)}
.kpi__top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.kpi__label{font-size:11.5px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--faint);margin-bottom:9px}
.kpi__value{font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1}
.kpi__icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--c,var(--accent));background:color-mix(in srgb,var(--c,var(--accent)) 14%,transparent);flex-shrink:0}
.kpi__foot{display:flex;align-items:center;gap:12px;height:34px;min-width:0}
.kpi__spark{color:var(--c,var(--accent));flex:1;min-width:0;overflow:hidden}
.kpi__sub{font-size:12px;color:var(--muted);white-space:nowrap;font-weight:500;flex-shrink:0}
.kpi__meter{flex:1;height:8px;border-radius:99px;background:var(--line);overflow:hidden}
.kpi__meter>span{display:block;height:100%;background:linear-gradient(90deg,var(--c,var(--accent)),color-mix(in srgb,var(--c,var(--accent)) 55%,#fff));border-radius:99px}
.spark{display:block;width:100%;height:34px}
/* Reserve chart height so deferred Chart.js draws into a fixed box (no layout shift / CLS). */
.chart-box{position:relative;width:100%;height:200px}
.chart-box canvas{position:absolute;inset:0}
/* Pulsing "online / live" dot */
.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--success);flex-shrink:0;animation:vgcPulse 1.6s infinite}
@keyframes vgcPulse{0%{box-shadow:0 0 0 0 rgba(6,118,71,.5)}70%{box-shadow:0 0 0 7px rgba(6,118,71,0)}100%{box-shadow:0 0 0 0 rgba(6,118,71,0)}}
/* Feed status dots (static): bot / offline. Online uses .live-dot (pulsing). */
.feed-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}
.feed-dot--bot{background:var(--warn)}
.feed-dot--off{background:var(--line-strong)}
.feed-online{display:inline-flex;align-items:center;background:var(--success-bg);color:var(--success);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.04em;padding:1px 7px;border-radius:999px}

/* ----- Navigation rail (dark, two-tone) ----- */
.navlink{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--muted);font-size:14.5px;font-weight:500;transition:background .15s var(--ease),color .15s var(--ease),box-shadow .15s var(--ease)}
.navlink:hover{background:var(--panel-2);color:var(--text)}
.navlink.active{background:var(--accent-weak);color:var(--accent);font-weight:600;box-shadow:inset 3px 0 0 var(--accent)}
.navlink .ico{display:flex;width:20px;justify-content:center}

.theme-toggle,.iconbtn{width:40px;height:40px;border-radius:var(--radius-md);cursor:pointer;background:var(--panel);border:1px solid var(--line);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;position:relative;transition:border-color .15s var(--ease),color .15s,transform .06s}
.theme-toggle:hover,.iconbtn:hover{border-color:var(--line-strong);color:var(--text)}
.theme-toggle:active,.iconbtn:active{transform:translateY(1px)}
.iconbtn__dot{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:2px solid var(--panel)}
.t-sun,.t-moon{display:none}
html[data-theme="dark"] .t-sun{display:block}
html[data-theme="light"] .t-moon{display:block}
.menu{position:absolute;right:0;top:48px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-md);min-width:200px;z-index:50;box-shadow:var(--shadow-pop);overflow:hidden;animation:vgcPop .14s var(--ease)}
.menu button,.menu a{display:flex;align-items:center;gap:9px;width:100%;background:transparent;border:0;padding:10px 14px;color:var(--text);font-size:14px;text-align:left;cursor:pointer;text-decoration:none;font-family:inherit;transition:background .12s var(--ease)}
.menu button:hover,.menu a:hover{background:var(--panel-2)}

/* ----- App shell ----- */
.layout{display:flex;min-height:100vh}
.layout__main{flex:1;display:flex;flex-direction:column;min-width:0}
.content{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:26px 30px;animation:vgcRise .3s var(--ease);overflow-x:clip}
.page-title{font-size:1.6rem;font-weight:750;letter-spacing:-.02em;margin:0 0 18px}

/* PayPal-style top navigation */
.topnav{position:sticky;top:0;z-index:50;background:var(--panel);border-bottom:1px solid var(--line);box-shadow:0 1px 3px rgba(16,24,40,.05)}
.topnav__inner{max-width:1280px;margin:0 auto;min-height:64px;display:flex;align-items:center;gap:10px;padding:0 24px}
.topnav__brand{display:flex;align-items:center;gap:10px;margin-right:12px;flex-shrink:0;text-decoration:none}
.topnav__logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--navy),var(--accent-2));color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 14px -8px var(--accent);flex-shrink:0}
.topnav__word{font-weight:800;font-style:italic;font-size:18px;letter-spacing:-.02em;white-space:nowrap}
.topnav__word .a{color:var(--navy)} .topnav__word .b{color:var(--accent)}
.topnav__menu{display:flex;align-items:center;gap:3px;flex:1;min-width:0;overflow-x:auto}
.topnav__link{padding:8px 14px;border-radius:999px;color:var(--muted);font-weight:600;font-size:14.5px;white-space:nowrap;transition:background .15s var(--ease),color .15s var(--ease)}
.topnav__link:hover{color:var(--text);background:var(--panel-2)}
.topnav__link.active{color:var(--accent);background:var(--accent-weak)}
.topnav__right{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0}
.topnav__drawer{border-top:1px solid var(--line);padding:8px 16px 12px;display:flex;flex-direction:column;gap:2px}
.topnav__drawer .topnav__link{padding:11px 14px}
@media (min-width:861px){ .topnav__drawer{display:none!important} }

/* Bottom navigation (mobile tab bar, PayPal-app style) */
.bottomnav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:45;background:var(--panel);border-top:1px solid var(--line);padding:6px 6px;padding-bottom:max(6px,env(safe-area-inset-bottom));box-shadow:0 -2px 12px rgba(16,24,40,.07)}
.bottomnav__item{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;border-radius:10px;color:var(--faint);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s var(--ease),background .15s var(--ease)}
.bottomnav__item:hover{color:var(--muted)}
.bottomnav__item.active{color:var(--accent)}
.bottomnav__item .ico{display:flex}

.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--panel);color:var(--text);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:60}
.sidebar__brand{display:flex;align-items:center;gap:11px;padding:20px 18px;border-bottom:1px solid var(--line)}
.sidebar__logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--navy),var(--accent-2));color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px -8px var(--accent)}
.sidebar__name{font-weight:800;font-size:18px;letter-spacing:-.02em;font-style:italic}
.sidebar__name .a{color:var(--navy)} .sidebar__name .b{color:var(--accent)}
.brand-logo{height:30px;width:auto;max-width:100%;display:block}
.sidebar__nav{flex:1;padding:10px 12px 16px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.sidebar__group{font-size:10.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--faint);padding:16px 12px 7px}
.sidebar__foot{padding:14px 16px;border-top:1px solid var(--line);display:flex;align-items:center;gap:9px;font-size:12px;color:var(--faint)}
.sidebar__status{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.16);flex-shrink:0}
.scrim{display:none}

.topbar{height:66px;flex-shrink:0;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--panel) 84%,transparent);backdrop-filter:saturate(180%) blur(10px);display:flex;align-items:center;gap:14px;padding:0 26px;position:sticky;top:0;z-index:40}
.topbar__heading{font-size:var(--fs-lg);font-weight:750;letter-spacing:-.014em;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar__search{display:flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius-md);padding:0 12px;height:40px;flex:0 1 320px;min-width:0;color:var(--faint);transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.topbar__search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
.topbar__search input{border:0;background:transparent;outline:none;color:var(--text);font-size:14px;font-family:inherit;width:100%;min-width:0}
.topbar__user{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-md);padding:5px 9px 5px 13px;cursor:pointer;color:var(--text);transition:border-color .15s var(--ease)}
.topbar__user:hover{border-color:var(--line-strong)}
.avatar{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
img.avatar{object-fit:cover;display:block}
.nav-toggle{display:none;width:40px;height:40px;flex-shrink:0;border-radius:var(--radius-sm);background:var(--panel);border:1px solid var(--line);color:var(--text);align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s var(--ease)}
.nav-toggle:hover{border-color:var(--line-strong)}
.topbar__brand{display:none;text-decoration:none}
.topbar__brand img{height:30px;width:30px;border-radius:8px;display:block}
.spacer{flex:1}

/* ----- Utilities ----- */
.stack{display:flex;flex-direction:column;gap:20px}
.page-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.muted{color:var(--muted)} .faint{color:var(--faint)}
.mono{font-family:ui-monospace,'SF Mono',Menlo,monospace}
.grid-main-side{display:grid;grid-template-columns:minmax(0,1fr) 348px;gap:16px}
.grid-main-side>*{min-width:0}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:16px}
.grid-3>*{min-width:0}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}

/* ----- Drawer ----- */
.drawer-overlay{position:fixed;inset:0;z-index:100;display:flex;background:rgba(14,20,38,.5);animation:vgcFade .18s var(--ease)}
.drawer{width:452px;max-width:94vw;margin-left:auto;background:var(--panel);border-left:1px solid var(--line);height:100vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-pop);animation:vgcSlide .26s var(--ease)}
.drawer__head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}

@keyframes vgcFade{from{opacity:0}to{opacity:1}}
@keyframes vgcSlide{from{transform:translateX(30px);opacity:.4}to{transform:translateX(0);opacity:1}}
@keyframes vgcRise{from{transform:translateY(7px)}to{transform:translateY(0)}}
@keyframes vgcDrop{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
@keyframes vgcPop{from{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ----- Responsive ----- */
@media (max-width:1024px){ .grid-main-side{grid-template-columns:1fr} }
@media (max-width:860px){
    .nav-toggle{display:inline-flex}
    .topbar__search{display:none}
    .topnav__menu{display:none}
    .sidebar{position:fixed;left:0;top:0;height:100vh;height:100dvh;transform:translateX(-100%);transition:transform .3s cubic-bezier(.22,.61,.36,1);box-shadow:var(--shadow-pop);will-change:transform}
    .sidebar.is-open{transform:translateX(0)}
    .scrim{display:block;position:fixed;inset:0;background:rgba(14,20,38,.42);z-index:55;opacity:0;pointer-events:none;transition:opacity .28s var(--ease)}
    .scrim.is-open{opacity:1;pointer-events:auto}
    .bottomnav{display:flex}
    .content{padding-bottom:84px}
    .toast{top:76px;left:16px;right:16px;max-width:none}
    .topbar__brand{display:inline-flex;align-items:center;flex-shrink:0}
}
@media (max-width:600px){
    :root{--fs-2xl:1.95rem;--fs-xl:1.55rem;--fs-lg:1.3rem}
    .content{padding:16px 14px 84px}
    .topbar{padding:0 14px;gap:10px}
    .drawer{width:100%;max-width:100%}
    .hide-sm{display:none!important}
    .kpi__sub{display:none}
    /* denser tables + full-width action buttons so they're tappable */
    .th{padding:10px 12px;font-size:11px}
    .td{padding:11px 12px;font-size:13.5px}
    .pager{padding:10px 12px}
    .page-head{margin-bottom:14px}
    .grid-kpi{grid-template-columns:1fr 1fr;gap:12px}
    .kpi{padding:14px 15px}
    .kpi__value{font-size:23px}
    .btn{padding:10px 16px}
    /* forms that lay out inline should stack and go full-width on phones */
    form.card[style*="flex"]{flex-direction:column;align-items:stretch}
}
@media (max-width:380px){
    .grid-kpi{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}

/* ----- Mail ----- */
.mail{display:grid;grid-template-columns:228px 1fr;gap:16px;align-items:start}
.mail-rail{padding:10px}
.mail-folder{display:flex;align-items:center;gap:10px;width:100%;padding:9px 11px;border-radius:var(--radius-sm);color:var(--text);font-size:14px;background:transparent;border:0;cursor:pointer;text-align:left;font-family:inherit;transition:background .12s var(--ease)}
.mail-folder:hover{background:var(--panel-2)}
.mail-folder.active{background:var(--accent-weak);color:var(--accent);font-weight:600}
.mail-folder .ico{display:flex;flex-shrink:0;opacity:.85}
.mail-folder .lbl{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mail-folder .cnt{font-size:12px;font-weight:700;color:var(--accent);min-width:18px;text-align:right}
.mlist{display:flex;flex-direction:column}
.mrow{display:flex;align-items:center;gap:11px;padding:12px 14px;border-top:1px solid var(--line);cursor:pointer;transition:background .12s var(--ease)}
.mrow:first-child{border-top:0}
.mrow:hover{background:var(--panel-2)}
.mrow .mdot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;visibility:hidden}
.mrow.unread .mdot{visibility:visible}
.mrow .mstar{display:flex;color:var(--faint);flex-shrink:0;background:none;border:0;cursor:pointer;padding:0}
.mrow .mstar.on{color:#f5b301}
.mrow .mfrom{width:172px;min-width:96px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mrow .mbody{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mrow .mdate{font-size:12.5px;color:var(--faint);white-space:nowrap;flex-shrink:0}
.mrow.unread .mfrom,.mrow.unread .msubject{font-weight:700}
.mrow .mreplied{display:inline-flex;color:var(--faint);margin-right:5px;vertical-align:-2px}
.mail-frame{width:100%;border:1px solid var(--line);background:#fff;border-radius:8px;min-height:340px}
.mail-empty{padding:48px 24px;text-align:center}
.drawer--wide{width:760px}
@media (max-width:840px){ .mail{grid-template-columns:1fr} .mail-rail{position:static} .mrow .mfrom{width:128px} }
/* Desktop: keep the folder rail fixed and scroll only the message list. position:sticky
   is unreliable here (the .content overflow clip becomes the sticky scroll-container), so
   give the mail area a viewport-height pane with an inner-scrolling list instead. */
@media (min-width:841px){
    .mail{height:calc(100dvh - 200px)}
    .mail-rail{position:static;align-self:start;max-height:100%;overflow-y:auto}
    .mail-main{display:flex;flex-direction:column;min-height:0}
    .mail-main .mlist{flex:1;overflow-y:auto;min-height:0}
}
a.feed-link[href]:hover{text-decoration:underline!important;cursor:pointer}

/* Reports — period-over-period delta chips + shield-health rows */
.delta{display:inline-flex;align-items:center;font-size:12px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}
.delta--up{color:var(--pos)}
.delta--down{color:var(--danger)}
.delta--flat{color:var(--faint)}
.hrow{display:flex;flex-direction:column;gap:6px}
.hrow__top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.hrow__meta{font-size:12px;color:var(--faint);font-variant-numeric:tabular-nums}
.hscore{font-size:12px;font-weight:700;font-variant-numeric:tabular-nums}
.hbar{height:7px;border-radius:99px;background:var(--panel-3);overflow:hidden}
.hbar>span{display:block;height:100%;border-radius:99px}
.report-controls{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.report-controls .input--date{width:auto;min-width:150px}
