/* ══════════════════════════════════════════════════════════════════════
   SMSF Portfolio Tracker — Design System v3
   Theme: Midnight Arctic (dark) / Polar Day (light)
   Fonts: Outfit (display) + DM Mono (numbers) + DM Sans (body fallback)
   Accent: Electric cyan #00d4ff
   ══════════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=DM+Mono:wght@300;400;500&family=DM+Sans:wght@400;500;600;700&display=swap');

/* ── Dark theme (default) — Midnight Arctic ── */
:root,[data-theme="dark"]{
  --font:'Outfit',sans-serif;
  --mono:'DM Mono',monospace;

  /* Backgrounds */
  --bg:#080d17;
  --bg2:#060a12;
  --surface:rgba(255,255,255,0.04);
  --surface2:rgba(255,255,255,0.03);
  --surface3:rgba(255,255,255,0.07);
  --surface4:rgba(255,255,255,0.02);

  /* Borders */
  --border:rgba(148,163,184,0.1);
  --border2:rgba(148,163,184,0.07);
  --border3:rgba(148,163,184,0.05);
  --border4:rgba(148,163,184,0.13);
  --border5:rgba(148,163,184,0.18);

  /* Cyan accent */
  --accent:#00d4ff;
  --accent-hover:#1adcff;
  --accent-light:#38e8ff;
  --accent2:#38e8ff;
  --gold:#00d4ff;
  --gold2:#38e8ff;
  --gold3:#7ef0ff;
  --gold-bg:rgba(0,212,255,0.07);
  --gold-glow:rgba(0,212,255,0.2);

  /* Text */
  --text:#f0f6ff;
  --text2:rgba(240,246,255,0.58);
  --text3:rgba(240,246,255,0.33);
  --text4:rgba(240,246,255,0.17);

  /* Semantic */
  --gain-pos:#10b981;
  --gain-neg:#f43f5e;
  --gl-pos-bg:rgba(16,185,129,0.1);
  --gl-neg-bg:rgba(244,63,94,0.1);
  --gl-pos-c:#10b981;
  --gl-neg-c:#f43f5e;
  --gl-neu-bg:rgba(255,255,255,0.06);
  --gl-neu-c:rgba(240,246,255,0.35);
  --err-bg:rgba(244,63,94,0.12);

  /* Asset badge colours */
  --b-blue-bg:rgba(129,140,248,0.12);  --b-blue-c:#818cf8;
  --b-green-bg:rgba(16,185,129,0.10);  --b-green-c:#10b981;
  --b-amber-bg:rgba(245,158,11,0.12);  --b-amber-c:#f59e0b;
  --b-gray-bg:rgba(148,163,184,0.10);  --b-gray-c:#94a3b8;
  --b-teal-bg:rgba(16,185,129,0.10);   --b-teal-c:#10b981;
  --b-red-bg:rgba(244,63,94,0.12);     --b-red-c:#f43f5e;

  /* UI chrome */
  --topbar-bg:rgba(8,13,23,0.94);
  --topbar-border:rgba(148,163,184,0.08);
  --sidebar-glass:rgba(6,10,18,0.6);
  --card-glass:rgba(255,255,255,0.03);
  --table-head-bg:rgba(0,0,0,0.18);
  --input-bg:rgba(255,255,255,0.06);
  --login-bg:rgba(8,13,23,0.95);
  --card-shadow:0 4px 24px rgba(0,0,0,0.5);
  --alloc-bg:rgba(255,255,255,0.07);
}

/* ── Light theme — Polar Day ── */
[data-theme="light"]{
  --font:'Outfit',sans-serif;
  --mono:'DM Mono',monospace;

  --bg:#f0f5fc;
  --bg2:#e8eef8;
  --surface:rgba(255,255,255,0.7);
  --surface2:rgba(255,255,255,0.5);
  --surface3:rgba(0,100,180,0.06);
  --surface4:rgba(0,100,180,0.03);

  --border:rgba(0,100,180,0.12);
  --border2:rgba(0,100,180,0.08);
  --border3:rgba(0,100,180,0.05);
  --border4:rgba(0,100,180,0.15);
  --border5:rgba(0,100,180,0.22);

  --accent:#0099cc;
  --accent-hover:#0088bb;
  --accent-light:#00b8e0;
  --accent2:#00b8e0;
  --gold:#0099cc;
  --gold2:#00b8e0;
  --gold3:#33c9e8;
  --gold-bg:rgba(0,153,204,0.08);
  --gold-glow:rgba(0,153,204,0.2);

  --text:#0d1b2e;
  --text2:#3a5a7a;
  --text3:#6b8aaa;
  --text4:#99b4cc;

  --gain-pos:#047857;
  --gain-neg:#be123c;
  --gl-pos-bg:rgba(4,120,87,0.09);
  --gl-neg-bg:rgba(190,18,60,0.09);
  --gl-pos-c:#047857;
  --gl-neg-c:#be123c;
  --gl-neu-bg:rgba(0,100,180,0.07);
  --gl-neu-c:#6b8aaa;
  --err-bg:rgba(190,18,60,0.09);

  --b-blue-bg:rgba(99,102,241,0.10); --b-blue-c:#4f46e5;
  --b-green-bg:rgba(4,120,87,0.09);  --b-green-c:#047857;
  --b-amber-bg:rgba(180,83,9,0.09);  --b-amber-c:#b45309;
  --b-gray-bg:rgba(71,85,105,0.09);  --b-gray-c:#475569;
  --b-teal-bg:rgba(4,120,87,0.09);   --b-teal-c:#047857;
  --b-red-bg:rgba(190,18,60,0.09);   --b-red-c:#be123c;

  --topbar-bg:rgba(240,245,252,0.95);
  --topbar-border:rgba(0,100,180,0.1);
  --sidebar-glass:rgba(232,238,248,0.8);
  --card-glass:rgba(255,255,255,0.75);
  --table-head-bg:rgba(255,255,255,0.6);
  --input-bg:rgba(255,255,255,0.85);
  --login-bg:rgba(240,245,252,0.97);
  --card-shadow:0 4px 16px rgba(0,80,160,0.08);
  --alloc-bg:rgba(0,100,180,0.08);
}

/* ══ BASE ══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

body{
  font-family:var(--font);
  font-size:13px;
  color:var(--text);
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 80% 60% at 15% -10%, rgba(0,120,200,0.18) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 88% 108%, rgba(0,80,160,0.12) 0%, transparent 55%);
  background-attachment:fixed;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

[data-theme="light"] body{
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 70% 50% at 10% -5%, rgba(0,153,204,0.1) 0%, transparent 55%),
    radial-gradient(ellipse 45% 35% at 92% 105%, rgba(0,100,180,0.07) 0%, transparent 55%);
}

::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border4);border-radius:99px;}
::-webkit-scrollbar-thumb:hover{background:var(--border5);}

select{color:var(--text);background:var(--input-bg);border-color:var(--border4);font-family:var(--font);}
select option,select optgroup{background:#080d17 !important;color:#f0f6ff !important;}
[data-theme="light"] select option,[data-theme="light"] select optgroup{background:#fff !important;color:#0d1b2e !important;}
[data-theme="light"] select{background:var(--input-bg);color:var(--text);}

.gain-pos{color:var(--gain-pos);}
.gain-neg{color:var(--gain-neg);}
.gain-neu{color:var(--text3);}
.spin{animation:spin 0.9s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.25}}
.mob-hide{display:none;}

/* ══ LOGIN ══ */
#loginScreen{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(0,0,0,0.55);backdrop-filter:blur(20px);}
#loginScreen.hidden{display:none;}
.login-card{width:100%;max-width:400px;background:var(--login-bg);border:1px solid var(--border4);border-radius:20px;padding:40px 36px;backdrop-filter:blur(32px);box-shadow:0 32px 80px rgba(0,0,0,0.45);}
[data-theme="light"] .login-card{background:rgba(255,255,255,0.92);box-shadow:0 24px 64px rgba(0,80,160,0.1);}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px;}
.login-logo-dot{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#0088bb,#00d4ff);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,212,255,0.25);}
[data-theme="light"] .login-logo-dot{background:linear-gradient(135deg,#0077aa,#0099cc);box-shadow:0 4px 16px rgba(0,153,204,0.2);}
.login-logo-text{display:flex;flex-direction:column;gap:1px;}
.login-logo-title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-0.02em;}
.login-logo-sub{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:0.12em;color:var(--text3);}
.login-heading{font-size:22px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-0.03em;}
.login-sub{font-size:13px;color:var(--text3);margin-bottom:28px;}
.login-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.login-label{font-family:var(--mono);font-size:9px;font-weight:400;color:var(--text3);text-transform:uppercase;letter-spacing:0.12em;}
.login-input{padding:11px 16px;font-size:14px;font-family:var(--font);border:1px solid var(--border4);border-radius:10px;background:var(--input-bg);color:var(--text);transition:all 0.15s;width:100%;}
.login-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--gold-bg);}
.login-remember{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2);margin-bottom:20px;cursor:pointer;}
.login-remember input{width:15px;height:15px;accent-color:var(--accent);}
.login-btn{width:100%;padding:12px;font-size:14px;font-weight:600;font-family:var(--font);background:linear-gradient(135deg,#0088bb,#00d4ff);color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all 0.2s;box-shadow:0 4px 16px rgba(0,212,255,0.2);}
[data-theme="light"] .login-btn{background:linear-gradient(135deg,#0077aa,#0099cc);box-shadow:0 4px 16px rgba(0,153,204,0.2);}
.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(0,212,255,0.3);}
.login-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none;}
.login-err{font-size:12px;color:var(--gain-neg);background:var(--err-bg);border-radius:8px;padding:8px 12px;margin-bottom:14px;display:none;}
.login-err.show{display:block;}

/* ══ SYNC TOAST ══ */
#syncToast{position:fixed;bottom:24px;right:24px;z-index:300;display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;background:rgba(8,13,23,0.97);backdrop-filter:blur(16px);border:1px solid var(--border4);font-size:12px;font-weight:500;font-family:var(--mono);color:var(--text2);box-shadow:0 8px 32px rgba(0,0,0,0.4);opacity:0;pointer-events:none;transition:opacity 0.3s;}
#syncToast.show{opacity:1;}
#syncToast .st-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--text4);transition:background 0.3s;}
#syncToast.syncing .st-dot{background:var(--accent);animation:pulse 0.8s infinite;}
#syncToast.synced .st-dot{background:var(--gain-pos);}
#syncToast.err .st-dot{background:var(--gain-neg);}
#syncToast.err{border-color:rgba(244,63,94,0.25);}
[data-theme="light"] #syncToast{background:rgba(255,255,255,0.97);border-color:rgba(0,100,180,0.15);}

/* ══ INACTIVITY WARNING ══ */
#inactivityWarn{display:none;position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:rgba(8,13,23,0.97);backdrop-filter:blur(20px);border:1px solid rgba(0,212,255,0.25);border-radius:10px;padding:12px 20px;font-size:13px;color:var(--text);z-index:500;box-shadow:0 8px 32px rgba(0,0,0,0.4);white-space:nowrap;}
#inactivityWarn.show{display:flex;align-items:center;gap:10px;}
#inactivityCountdown{font-weight:700;color:var(--accent);font-family:var(--mono);}

/* ══ READONLY NOTICE ══ */
.readonly-notice{display:none;position:sticky;top:58px;z-index:35;background:rgba(0,212,255,0.06);border-bottom:1px solid rgba(0,212,255,0.15);padding:8px 32px;font-size:12px;color:var(--accent);text-align:center;}
.readonly-notice.show{display:block;}

/* ══ TOP NAV BAR ══ */
.topbar{
  display:flex;align-items:center;padding:0 24px;height:54px;
  background:var(--topbar-bg);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--topbar-border);
  position:sticky;top:0;z-index:40;gap:0;flex-wrap:nowrap;flex-shrink:0;
  /* Subtle cyan accent line at very top */
}
.topbar::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--accent) 30%,var(--accent2) 60%,transparent 100%);
  opacity:0.35;
}

/* Logo */
.title-block{display:flex;align-items:center;gap:10px;margin-right:28px;flex-shrink:0;}
.title-block h1{font-size:16px;font-weight:700;letter-spacing:-0.3px;color:var(--text);line-height:1;white-space:nowrap;}
.logo-mark{
  width:30px;height:30px;border-radius:8px;
  background:linear-gradient(135deg,#0088bb,#00d4ff);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 0 14px rgba(0,212,255,0.2);
}
[data-theme="light"] .logo-mark{background:linear-gradient(135deg,#0077aa,#0099cc);box-shadow:0 0 10px rgba(0,153,204,0.15);}

/* Nav links */
.nav-links{display:flex;align-items:center;gap:0;flex:1;}
.nav-link{
  padding:0 14px;height:54px;
  display:flex;align-items:center;
  font-size:13px;font-weight:500;color:var(--text3);
  cursor:pointer;transition:color 0.15s;
  white-space:nowrap;border:none;background:none;font-family:var(--font);
  position:relative;
}
.nav-link::after{
  content:'';position:absolute;bottom:0;left:14px;right:14px;
  height:2px;background:var(--accent);border-radius:2px 2px 0 0;
  transform:scaleX(0);transition:transform 0.2s cubic-bezier(0.34,1.56,0.64,1);
}
.nav-link:hover{color:var(--text2);}
.nav-link.active{color:var(--text);font-weight:600;}
.nav-link.active::after{transform:scaleX(1);}

/* Session pills */
.topbar-sessions{display:flex;align-items:center;gap:5px;margin-right:14px;}
.tb-sess{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;font-family:var(--mono);font-size:10px;border:1px solid var(--border);color:var(--text3);white-space:nowrap;letter-spacing:0.03em;}
.tb-sess.live{border-color:rgba(16,185,129,0.28);color:rgba(16,185,129,0.85);}
.tb-sess-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;}

/* Top actions */
.top-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}

.addbtn{
  height:32px;padding:0 16px;border-radius:8px;
  font-size:12px;font-weight:600;font-family:var(--font);
  background:var(--surface3);color:var(--text2);
  border:1px solid var(--border4);cursor:pointer;white-space:nowrap;
  transition:all 0.15s;display:flex;align-items:center;gap:6px;
}
.addbtn:hover{background:var(--surface);color:var(--text);}
.addbtn:disabled{opacity:0.4;cursor:not-allowed;}

/* Primary + Add button gets cyan */
#topbarAddBtn{
  background:var(--accent);color:#fff;border-color:transparent;
  box-shadow:0 0 14px var(--gold-glow);
}
[data-theme="light"] #topbarAddBtn{color:#fff;}
#topbarAddBtn:hover{background:var(--accent-hover);opacity:1;}

.rfbtn{
  height:32px;padding:0 16px;border-radius:8px;
  font-size:12px;font-weight:600;font-family:var(--font);
  background:var(--surface3);color:var(--text2);
  border:1px solid var(--border4);cursor:pointer;white-space:nowrap;
  display:flex;align-items:center;gap:7px;transition:all 0.15s;
}
.rfbtn:hover{border-color:var(--accent);color:var(--accent);}
.rfbtn:disabled{opacity:0.45;cursor:not-allowed;}

/* Portfolio selector */
.portfolio-selector{display:flex;align-items:center;gap:7px;height:32px;padding:0 14px;background:var(--surface3);border:1px solid var(--border4);border-radius:8px;font-size:12px;color:var(--text2);cursor:pointer;transition:background 0.15s;}
.portfolio-selector:hover{background:var(--surface);}
.portfolio-selector select{background:none;border:none;color:var(--text);font-family:var(--font);font-size:12px;font-weight:500;cursor:pointer;outline:none;}

/* User badge */
.user-badge{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#0088bb,#00d4ff);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;flex-shrink:0;border:none;padding:0;box-shadow:0 0 12px rgba(0,212,255,0.18);}
[data-theme="light"] .user-badge{background:linear-gradient(135deg,#0077aa,#0099cc);}
.user-avatar{font-size:12px;font-weight:700;color:#fff;font-family:var(--font);}
.user-name{display:none !important;}
.user-role-badge{display:none !important;}
.sync-bar{display:none !important;}
#lastRefreshedBar{display:none !important;}
#topbar-pnl{display:none !important;}
.aud-pill{display:none !important;}
#hamburgerBtn{display:none !important;}
#mobileSubtitle{display:none;}

/* User dropdown */
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:rgba(8,13,23,0.98);backdrop-filter:blur(24px);border:1px solid var(--border4);border-radius:12px;padding:6px;min-width:200px;z-index:200;box-shadow:0 16px 48px rgba(0,0,0,0.5);display:none;}
.user-dropdown.open{display:block;}
[data-theme="light"] .user-dropdown{background:rgba(250,253,255,0.98);}
.user-dd-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;font-size:13px;color:var(--text2);cursor:pointer;transition:background 0.15s;border:none;background:none;font-family:var(--font);width:100%;text-align:left;}
.user-dd-item:hover{background:var(--surface3);color:var(--text);}
.user-dd-item.danger{color:var(--gain-neg);}
.user-dd-item.danger:hover{background:rgba(244,63,94,0.1);}
.user-dd-divider{height:1px;background:var(--border2);margin:4px 0;}

/* ══ ICON SIDEBAR ══ */
.sidebar{
  width:52px;flex-shrink:0;
  background:var(--sidebar-glass);border-right:1px solid var(--border);
  display:flex;flex-direction:column;align-items:center;
  padding:12px 0;gap:2px;
  height:100%;position:sticky;top:0;overflow:visible;align-self:flex-start;
}
.sb-toggle{display:none !important;}
.sb-logo{display:none !important;}
.sb-section{display:none !important;}
#sb-search{display:none !important;}
.sb-nav{display:flex;flex-direction:column;align-items:center;gap:2px;width:100%;padding:0 7px;flex:1;}
.sb-item{
  width:38px;height:38px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:var(--text4);cursor:pointer;transition:all 0.15s;
  border:none;background:transparent;position:relative;
}
.sb-item:hover{background:var(--surface3);color:var(--text2);}
.sb-item.active{background:var(--gold-bg);color:var(--accent);border:1px solid rgba(0,212,255,0.2);}
[data-theme="light"] .sb-item.active{background:rgba(0,153,204,0.08);border-color:rgba(0,153,204,0.2);}
.sb-item svg{width:17px;height:17px;flex-shrink:0;}
.sb-item::before{display:none !important;}
.sb-label{display:none;}
.sidebar>div:last-child{margin-top:auto !important;padding:12px 7px 0 !important;border-top:1px solid var(--border) !important;width:100%;display:flex;justify-content:center;}
#themeToggleBtn{width:38px !important;height:38px !important;border-radius:8px !important;padding:0 !important;display:flex !important;align-items:center !important;justify-content:center !important;background:var(--surface2) !important;border:1px solid var(--border) !important;color:var(--text3) !important;cursor:pointer !important;}
#themeTogglePill{display:none !important;}
#themeToggleLabel{display:none !important;}
#themeToggleIcon{font-size:15px !important;}

/* ══ LAYOUT ══ */
.wrap{flex:1;padding:24px 28px;min-width:0;overflow-x:hidden;width:100%;}

/* ══ SESSIONS BAR ══ */
.sessions{display:flex;gap:6px;flex-wrap:nowrap;margin-bottom:20px;overflow-x:auto;scrollbar-width:none;padding:0;}
.sessions::-webkit-scrollbar{display:none;}
.session-pill{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;font-weight:400;padding:4px 11px;border-radius:6px;border:1px solid var(--border);color:var(--text3);background:var(--surface);white-space:nowrap;flex-shrink:0;letter-spacing:0.03em;}
.session-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;}
.session-open{border-color:rgba(16,185,129,0.25);color:rgba(16,185,129,0.85);}
.session-open .session-dot{background:#10b981;animation:pulse 2s infinite;}
.session-closed .session-dot{background:var(--text4);}
.session-pre{border-color:rgba(0,212,255,0.22);color:var(--accent);}
.session-pre .session-dot{background:var(--accent);animation:pulse 2s infinite;}

/* ══ HERO — total portfolio value ══ */
/* Replaces the old .scard total value. Full-width, 3-column grid. */
.hero-strip{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:0 28px;
  align-items:center;
  padding:20px 24px;
  margin-bottom:20px;
  background:var(--card-glass);
  border:1px solid var(--border);
  border-radius:16px;
  position:relative;
  overflow:hidden;
}
.hero-strip::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:280px;
  background:radial-gradient(ellipse at 0% 50%,rgba(0,212,255,0.05) 0%,transparent 70%);
  pointer-events:none;
}
[data-theme="light"] .hero-strip::before{
  background:radial-gradient(ellipse at 0% 50%,rgba(0,153,204,0.04) 0%,transparent 70%);
}

.hero-primary{flex-shrink:0;}
.hero-eyebrow{font-family:var(--mono);font-size:9px;color:var(--text4);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:8px;}
.hero-value{
  font-size:38px;font-weight:800;line-height:1;letter-spacing:-0.04em;
  font-variant-numeric:tabular-nums;
  /* Ice-white shimmer */
  background:linear-gradient(135deg,#d8eeff 0%,#f0f8ff 45%,#e0f4ff 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
[data-theme="light"] .hero-value{
  background:linear-gradient(135deg,#0a2a4a 0%,#0d1b2e 50%,#0a2a4a 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-caption{font-size:12px;color:var(--text3);margin-top:6px;display:flex;align-items:center;gap:8px;}
.hero-change-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-family:var(--mono);font-size:11px;}
.hero-pill-pos{background:var(--gl-pos-bg);color:var(--gain-pos);}
.hero-pill-neg{background:var(--gl-neg-bg);color:var(--gain-neg);}

/* Hero metrics card */
.hero-metrics{
  display:flex;gap:0;
  border:1px solid var(--border);border-radius:12px;
  overflow:hidden;background:var(--surface2);
}
.hm{padding:14px 18px;border-right:1px solid var(--border);min-width:110px;}
.hm:last-child{border-right:none;}
.hm-label{font-family:var(--mono);font-size:9px;color:var(--text4);letter-spacing:0.15em;text-transform:uppercase;margin-bottom:6px;}
.hm-value{font-family:var(--mono);font-size:14px;font-weight:500;color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-0.02em;}
.hm-value.pos{color:var(--gain-pos);}
.hm-value.neg{color:var(--gain-neg);}

/* Hero sparkline */
.hero-spark{flex-shrink:0;}
.spark-label{font-family:var(--mono);font-size:9px;color:var(--text4);letter-spacing:0.14em;text-transform:uppercase;margin-bottom:6px;}
/* Sparkline canvas container */
.sparkline{width:100%;height:100%;}
#totalSparkline{height:52px;}

/* ══ SUMMARY CARDS (legacy — kept for compat; hidden in hero layout) ══ */
.summary{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-bottom:22px;}
.scard{background:var(--card-glass);border:1px solid var(--border);border-radius:14px;padding:16px 18px;position:relative;overflow:hidden;transition:border-color 0.2s;}
.scard:hover{border-color:var(--border5);}
.slabel{font-family:var(--mono);font-size:9px;font-weight:400;color:var(--text4);text-transform:uppercase;letter-spacing:0.14em;margin-bottom:7px;}
.sval{font-size:16px;font-weight:700;color:var(--text);line-height:1.2;font-variant-numeric:tabular-nums;letter-spacing:-0.03em;transition:color 0.3s;}
.sval.flash-up{color:var(--gain-pos) !important;}
.sval.flash-down{color:var(--gain-neg) !important;}
.ssub{font-size:11px;margin-top:4px;font-weight:400;color:var(--text3);}
.scard-row2{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;margin-top:12px;padding-top:12px;border-top:1px solid var(--border2);}
.scard-sub-col{display:flex;flex-direction:column;gap:3px;}
.scard-sub-col:not(:last-child){border-right:1px solid var(--border2);padding-right:12px;margin-right:12px;}
.scard-sub-label{font-family:var(--mono);font-size:9px;font-weight:400;color:var(--text4);text-transform:uppercase;letter-spacing:0.1em;}
.scard-sub-val{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--text);font-variant-numeric:tabular-nums;}

/* ══ MID ROW ══ */
.mid-row{display:grid;grid-template-columns:260px 1fr;gap:16px;margin-bottom:16px;}
.pie-dash{padding:16px 16px;}
.dash{background:var(--card-glass);border:1px solid var(--border);border-radius:14px;padding:16px 20px;display:flex;gap:20px;align-items:center;}
.alloc-section{flex:1;min-width:0;}
.alloc-bar{height:6px;background:var(--alloc-bg);border-radius:99px;overflow:hidden;display:flex;gap:2px;margin-bottom:14px;}
.alloc-seg{height:100%;border-radius:99px;transition:width 0.5s;}
.legend{display:flex;flex-direction:column;gap:8px;}
.leg-item{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px;color:var(--text2);}
.leg-left{display:flex;align-items:center;gap:8px;}
.leg-dot{width:3px;height:16px;border-radius:2px;flex-shrink:0;}
.leg-val{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--text);font-variant-numeric:tabular-nums;}
.leg-pct{font-family:var(--mono);font-size:10px;color:var(--text4);min-width:36px;text-align:right;}
.dash-divider{width:1px;background:var(--border);align-self:stretch;flex-shrink:0;}
.pie-section{width:220px;flex-shrink:0;}
.pie-label{font-family:var(--mono);font-size:9px;color:var(--text4);margin-bottom:8px;text-transform:uppercase;letter-spacing:0.12em;}
.pie-legend{display:flex;flex-direction:column;gap:6px;margin-top:10px;}
.pie-leg-row{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text2);}
.pie-leg-left{display:flex;align-items:center;gap:6px;}
.pie-leg-sw{width:3px;height:16px;border-radius:2px;flex-shrink:0;}

/* ══ HISTORY CHART SECTION ══ */
.history-section{background:var(--card-glass);border:1px solid var(--border);border-radius:14px;padding:16px 20px;margin-bottom:16px;}
.history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px;}
.history-title{font-family:var(--mono);font-size:9px;font-weight:400;color:var(--text4);text-transform:uppercase;letter-spacing:0.14em;}
.history-meta{font-family:var(--mono);font-size:10px;color:var(--text4);}

/* ══ SECTIONS ══ */
.section{background:var(--card-glass);border:1px solid var(--border);border-radius:14px;margin-bottom:12px;overflow:hidden;}
.sec-head{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--border2);background:rgba(0,0,0,0.05);}
[data-theme="light"] .sec-head{background:rgba(255,255,255,0.35);}
.sec-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--text);}
.sec-right{display:flex;align-items:center;gap:8px;}
.sec-tot{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--text);}
.tbl-wrap{overflow-x:auto;}

/* ══ TABLES ══ */
table{width:100%;border-collapse:collapse;font-size:13px;}
th{padding:9px 18px;text-align:left;font-family:var(--mono);font-size:9px;font-weight:400;text-transform:uppercase;letter-spacing:0.12em;color:var(--text4);border-bottom:1px solid var(--border2);background:var(--table-head-bg);white-space:nowrap;}
th.r,td.r{text-align:right;}
td{padding:12px 18px;border-bottom:1px solid var(--border3);vertical-align:middle;}
[data-theme="light"] td{border-bottom:1px solid rgba(0,100,180,0.05);}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(0,212,255,0.015);}
[data-theme="light"] tr:hover td{background:rgba(0,153,204,0.03);}

/* Asset type left-border accents */
.tkr-tile{width:34px;height:34px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;font-weight:500;flex-shrink:0;border:1px solid var(--border3);}
.tkr-us{background:rgba(129,140,248,0.1);color:#818cf8;}
.tkr-asx{background:rgba(16,185,129,0.1);color:#10b981;}
.tkr-cry{background:rgba(245,158,11,0.1);color:#f59e0b;}
.tkr-met{background:rgba(148,163,184,0.1);color:#94a3b8;}
.tkr-cell{display:flex;align-items:center;gap:10px;}
.tkr-info{display:flex;flex-direction:column;gap:2px;}
.tkr-sym{font-size:13px;font-weight:600;color:var(--text);}
.tkr-name{font-family:var(--mono);font-size:10px;color:var(--text4);}
tr.hrow-us td:first-child{border-left:2px solid rgba(129,140,248,0.5);}
tr.hrow-asx td:first-child{border-left:2px solid rgba(16,185,129,0.5);}
tr.hrow-cry td:first-child{border-left:2px solid rgba(245,158,11,0.5);}
tr.hrow-met td:first-child{border-left:2px solid rgba(148,163,184,0.4);}

@keyframes rowFlashUp{0%{background:rgba(16,185,129,0.12);}100%{background:transparent;}}
@keyframes rowFlashDown{0%{background:rgba(244,63,94,0.12);}100%{background:transparent;}}
tr.row-up td{animation:rowFlashUp 1.8s ease-out forwards;}
tr.row-down td{animation:rowFlashDown 1.8s ease-out forwards;}
tr.tint-up td{background:transparent;}
tr.tint-down td{background:transparent;}

/* ══ BADGES & CHIPS ══ */
.badge{font-family:var(--mono);font-size:9px;padding:2px 8px;border-radius:4px;font-weight:400;letter-spacing:0.06em;}
.b-blue{background:var(--b-blue-bg);color:var(--b-blue-c);}
.b-green{background:var(--b-green-bg);color:var(--b-green-c);}
.b-amber{background:var(--b-amber-bg);color:var(--b-amber-c);}
.b-gray{background:var(--b-gray-bg);color:var(--b-gray-c);}
.b-teal{background:var(--b-teal-bg);color:var(--b-teal-c);}
.b-red{background:var(--b-red-bg);color:var(--b-red-c);}
.gl-chip{font-family:var(--mono);font-size:10px;font-weight:400;padding:2px 8px;border-radius:4px;}
.gl-pos{background:var(--gl-pos-bg);color:var(--gl-pos-c);}
.gl-neg{background:var(--gl-neg-bg);color:var(--gl-neg-c);}
.gl-neu{background:var(--gl-neu-bg);color:var(--gl-neu-c);}
.dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.dot-live{background:#10b981;animation:pulse 2s infinite;box-shadow:0 0 5px rgba(16,185,129,0.4);}
.dot-stale{background:var(--text4);}
.dot-err{background:var(--gain-neg);}
.dot-loading{background:var(--accent);animation:pulse 0.8s infinite;}

/* ══ BUTTONS ══ */
.csvbtn{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--text2);background:var(--surface);border:1px solid var(--border4);border-radius:8px;padding:5px 14px;cursor:pointer;font-family:var(--font);transition:background 0.15s;}
.csvbtn:hover{background:var(--surface3);color:var(--text);}
.okbtn{padding:8px 20px;border-radius:8px;font-size:13px;font-weight:600;background:var(--accent);color:#fff;border:none;cursor:pointer;font-family:var(--font);transition:opacity 0.15s;}
[data-theme="light"] .okbtn{background:var(--accent);}
.okbtn:hover{opacity:0.88;}
.del{font-size:13px;color:var(--text4);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;font-family:var(--font);transition:color 0.15s;}
.del:hover{color:var(--gain-neg);background:var(--err-bg);}

/* ══ MODALS ══ */
.modal-overlay{display:none;visibility:hidden;position:fixed;inset:0;background:rgba(0,5,20,0.75);z-index:200;align-items:flex-start;justify-content:center;overflow-y:auto;padding:20px 0;}
.modal-overlay.open{display:flex;visibility:visible;backdrop-filter:blur(6px);}
.modal{background:rgba(8,13,23,0.98);backdrop-filter:blur(32px);border:1px solid var(--border4);border-radius:18px;padding:26px;width:480px;max-width:calc(100vw - 32px);position:relative;box-shadow:0 32px 80px rgba(0,0,0,0.5);margin:auto;}
[data-theme="light"] .modal{background:rgba(250,253,255,0.98);}
.modal-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px;letter-spacing:-0.02em;}
.modal-sub{font-family:var(--mono);font-size:11px;color:var(--text3);margin-bottom:18px;}
.modal-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--text3);font-size:18px;cursor:pointer;line-height:1;padding:2px 7px;border-radius:5px;}
.modal-close:hover{color:var(--text);background:var(--surface3);}
.modal-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;}
.modal-label{font-family:var(--mono);font-size:9px;font-weight:400;color:var(--text3);text-transform:uppercase;letter-spacing:0.12em;}
.modal-input{padding:9px 14px;font-size:13px;font-family:var(--font);border:1px solid var(--border4);border-radius:8px;background:var(--surface3);color:var(--text);transition:all 0.15s;width:100%;}
.modal-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--gold-bg);}
.modal-select{padding:8px 12px;font-size:13px;font-family:var(--font);border:1px solid var(--border4);border-radius:8px;background:var(--input-bg);color:var(--text);width:100%;}
.modal-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border2);}
.modal-type-btn{flex:1;padding:6px 4px;font-size:12px;font-weight:500;color:var(--text3);background:transparent;border:1px solid var(--border4);border-radius:8px;cursor:pointer;font-family:var(--font);transition:all 0.15s;text-align:center;}
.modal-type-btn.active{background:var(--gain-pos);color:#fff;border-color:var(--gain-pos);}
.modal-hint{font-size:11px;color:var(--text4);margin-top:-10px;margin-bottom:14px;}

/* ══ TRANSACTIONS / FEES ══ */
.fees-summary{display:flex;align-items:center;gap:20px;padding:10px 18px;background:var(--surface2);border-bottom:1px solid var(--border3);flex-wrap:wrap;}
.fees-fy{font-family:var(--mono);font-size:11px;font-weight:400;color:var(--text3);}
.fees-total{font-family:var(--mono);font-size:14px;font-weight:500;color:var(--gain-neg);}
.tx-row td{padding:0 !important;border-bottom:none !important;background:var(--surface2) !important;}
.tx-drawer{padding:14px 18px 16px;border-top:1px dashed var(--border4);background:var(--surface2);}
.tx-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.tx-title{font-family:var(--mono);font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em;}
.tx-addbtn{font-size:12px;font-weight:500;color:var(--text2);cursor:pointer;border:1px solid var(--border4);background:var(--surface);padding:3px 10px;border-radius:6px;font-family:var(--font);transition:background 0.15s;}
.tx-addbtn:hover{background:var(--surface3);}
.tx-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:8px;}
.tx-table th{padding:5px 10px;font-family:var(--mono);font-size:9px;font-weight:400;color:var(--text4);text-transform:uppercase;letter-spacing:0.1em;border-bottom:1px solid var(--border3);text-align:left;}
.tx-table th.r,.tx-table td.r{text-align:right;}
.tx-table td{padding:8px 10px;border-bottom:1px solid var(--border3);color:var(--text);vertical-align:middle;}
.tx-table tr:last-child td{border-bottom:none;}
.tx-table tr:hover td{background:var(--surface3);}
.tx-buy{color:var(--gain-pos);font-weight:600;}
.tx-sell{color:var(--gain-neg);font-weight:600;}
.tx-add-form{display:none;flex-wrap:wrap;gap:6px;padding:9px 12px;background:var(--surface);border:1px solid var(--border4);border-radius:8px;margin-top:8px;}
.tx-add-form input,.tx-add-form select{padding:5px 8px;font-size:12px;border:1px solid var(--border4);border-radius:6px;background:var(--surface3);color:var(--text);font-family:var(--font);}
.tx-empty{font-family:var(--mono);font-size:11px;color:var(--text4);padding:6px 2px;}
tr.holding-row{cursor:pointer;}
tr.holding-row td:first-child::before{content:'▶';font-size:8px;color:var(--text4);margin-right:8px;display:inline-block;transition:transform 0.15s;}
tr.holding-row.open td:first-child::before{transform:rotate(90deg);color:var(--accent);}

/* ══ MISC ══ */
.footer{font-family:var(--mono);font-size:10px;color:var(--text4);margin-top:1.5rem;line-height:1.8;}
.add-row{padding:10px 18px;background:var(--surface2);display:none;flex-wrap:wrap;gap:8px;align-items:center;border-top:1px solid var(--border3);}
[data-theme="light"] .add-row{background:rgba(255,255,255,0.2);}
.ni{width:70px;font-size:12px;font-family:var(--mono);padding:4px 8px;border:1px solid var(--border4);border-radius:6px;background:var(--surface3);color:var(--text);}
.dim{color:var(--text4);}
.valbold{font-family:var(--mono);font-weight:500;}
.wl-type{font-family:var(--mono);font-size:9px;padding:1px 6px;border-radius:4px;font-weight:400;letter-spacing:0.06em;border:1px solid currentColor;opacity:0.8;}
.wl-above{color:var(--gain-pos);}.wl-below{color:var(--gain-neg);}.wl-near{color:var(--accent);}
.sym{font-size:13px;font-weight:600;color:var(--text);}
.aname{font-family:var(--mono);font-size:10px;color:var(--text4);}
.err-note{font-size:12px;color:var(--gain-neg);padding:8px 14px;background:var(--err-bg);border-radius:7px;margin:8px 14px;}
#importDropZone:hover{border-color:var(--accent);background:var(--gold-bg);}
#importDropZone.drag-over{border-color:var(--accent);background:var(--gold-bg);transform:scale(1.01);}
#portfolioSelectorWrap{display:none;}
#searchCountBadge{font-family:var(--mono);font-size:10px;color:var(--text3);margin-left:6px;}
.access-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border3);}
.access-row:last-child{border-bottom:none;}
.access-user{display:flex;align-items:center;gap:10px;}
.access-avatar{width:30px;height:30px;border-radius:50%;background:var(--surface3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text2);}
.access-name{font-size:13px;font-weight:600;color:var(--text);}
.access-email{font-family:var(--mono);font-size:10px;color:var(--text3);}

/* ══ TAB BAR (mobile) ══ */
.tab-bar{display:none;gap:2px;margin-bottom:1.25rem;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:3px;}
.tab-btn{flex:1;padding:7px 10px;font-size:12px;font-weight:500;color:var(--text3);background:transparent;border:none;border-radius:8px;cursor:pointer;font-family:var(--font);transition:all 0.2s;white-space:nowrap;}
.tab-btn.active{background:var(--accent);color:#fff;font-weight:600;}
.tab-panel{display:none;opacity:0;}
.tab-panel.active{display:block;opacity:1;}

/* ══ CGT ══ */
.cgt-settings-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;background:var(--surface2);border-bottom:1px solid var(--border2);flex-wrap:wrap;}
.cgt-settings-left{display:flex;align-items:center;gap:8px;}
.cgt-settings-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.cgt-rule-label{font-family:var(--mono);font-size:10px;color:var(--text3);letter-spacing:0.06em;}
.cgt-select-label{font-family:var(--mono);font-size:10px;color:var(--text3);white-space:nowrap;}
.cgt-select{font-family:var(--mono);font-size:11px;padding:4px 10px;border:1px solid var(--border4);border-radius:6px;background:var(--surface2);color:var(--text);cursor:pointer;}
.cgt-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-bottom:1px solid var(--border2);}
.cgt-card{padding:16px 18px;border-right:1px solid var(--border2);}
.cgt-card:last-child{border-right:none;}
.cgt-card-hl{background:rgba(244,63,94,0.04);}
.cgt-card-lbl{font-family:var(--mono);font-size:9px;font-weight:400;color:var(--text4);text-transform:uppercase;letter-spacing:0.12em;margin-bottom:7px;}
.cgt-card-val{font-family:var(--mono);font-size:20px;font-weight:500;font-variant-numeric:tabular-nums;line-height:1.2;margin-bottom:4px;letter-spacing:-0.03em;}
.cgt-card-sub{font-family:var(--mono);font-size:10px;color:var(--text4);}
.cgt-section-head{display:flex;align-items:center;justify-content:space-between;padding:14px 2px 8px;flex-wrap:wrap;gap:8px;}
.cgt-section-title{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:0.06em;}
.cgt-sec-head{display:flex;align-items:center;justify-content:space-between;padding:12px 18px 10px;border-bottom:1px solid var(--border3);}
.cgt-sec-title{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--text2);}
.cgt-method-label{font-family:var(--mono);font-size:10px;color:var(--text4);}
.cgt-pos{color:var(--gain-pos);}
.cgt-neg{color:var(--gain-neg);}
tr.cgt-totals td{border-top:2px solid var(--border);background:var(--surface2) !important;font-size:12px;}
.cgt-totals-row td{border-top:1px solid var(--border2);background:rgba(0,0,0,0.05) !important;padding:10px 18px;}
.cgt-disc-badge,.cgt-disc{display:inline-block;font-family:var(--mono);font-size:9px;padding:2px 7px;border-radius:4px;font-weight:400;background:var(--gold-bg);color:var(--accent);white-space:nowrap;}
.cgt-no-badge,.cgt-none{display:inline-block;font-family:var(--mono);font-size:9px;padding:2px 7px;border-radius:4px;font-weight:400;background:var(--surface3);color:var(--text4);white-space:nowrap;}
.cgt-badge{display:inline-block;font-family:var(--mono);font-size:9px;padding:2px 7px;border-radius:4px;font-weight:400;white-space:nowrap;}
.cgt-inline-badge{display:inline-block;margin-left:6px;vertical-align:middle;}
.cgt-pill{display:inline-block;font-family:var(--mono);font-size:9px;padding:2px 7px;border-radius:4px;font-weight:400;white-space:nowrap;}
.cgt-pill.cgt-badge-gain{background:var(--gl-neg-bg);color:var(--gl-neg-c);}
.cgt-pill.cgt-badge-loss{background:var(--gl-pos-bg);color:var(--gl-pos-c);}
.cgt-ledger-pill{display:inline-block;font-family:var(--mono);font-size:9px;padding:2px 7px;border-radius:4px;margin-left:6px;white-space:nowrap;cursor:help;}
.cgt-pill-pos{background:var(--gl-neg-bg);color:var(--gl-neg-c);}
.cgt-pill-neg{background:var(--gl-pos-bg);color:var(--gl-pos-c);}
.cgt-split-amount{display:flex;flex-direction:column;gap:3px;min-width:140px;}
.cgt-split-row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:12px;}
.cgt-split-lbl{font-family:var(--mono);font-size:9px;color:var(--text4);}
.cgt-split-tot{border-top:1px solid var(--border3);margin-top:2px;padding-top:3px;}
.swyftx-split{display:flex;flex-direction:column;min-width:130px;}
.swyftx-row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:12px;}
.swyftx-total{margin-top:4px;padding-top:4px;border-top:1px solid var(--border2);}
.swyftx-lbl{font-family:var(--mono);font-size:9px;color:var(--text4);}

/* ══ BOTTOM NAV (mobile) ══ */
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:rgba(6,10,18,0.98);border-top:1px solid rgba(148,163,184,0.08);padding:7px 0 max(13px,env(safe-area-inset-bottom));flex-direction:row;justify-content:space-around;align-items:center;backdrop-filter:blur(20px);}
[data-theme="light"] .bottom-nav{background:rgba(240,245,252,0.97);border-top-color:rgba(0,100,180,0.1);}
.bn-item{display:flex;flex-direction:column;align-items:center;gap:4px;font-family:var(--mono);font-size:9px;font-weight:400;color:rgba(240,246,255,0.2);cursor:pointer;padding:5px 4px;border:none;background:transparent;font-family:var(--font);transition:color 0.15s;position:relative;}
[data-theme="light"] .bn-item{color:var(--text3);}
.bn-item.active{color:var(--accent);}
.bn-item svg{width:22px;height:22px;stroke:currentColor;}
.bn-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);position:absolute;bottom:1px;opacity:0;transition:opacity 0.15s;}
.bn-item.active .bn-dot{opacity:1;}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:199;}
.sidebar-overlay.visible{display:block;}

/* ══ FAB ══ */
#mobile-fab{position:fixed;bottom:calc(68px + env(safe-area-inset-bottom) + 12px);right:18px;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#0088bb,#00d4ff);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:300;color:#fff;box-shadow:0 6px 24px rgba(0,212,255,0.25),0 2px 8px rgba(0,0,0,0.3);border:none;z-index:50;cursor:pointer;font-family:var(--font);transition:transform 0.15s,box-shadow 0.15s;}
[data-theme="light"] #mobile-fab{background:linear-gradient(135deg,#0077aa,#0099cc);}
#mobile-fab:active{transform:scale(0.92);}

/* ══ ROLE BADGES ══ */
.role-admin{background:rgba(129,140,248,0.12);color:#818cf8;}
.role-readonly{background:var(--surface3);color:var(--text3);}

/* ══ DESKTOP (≥801px) ══ */
@media(min-width:801px){
  body{display:flex;flex-direction:column;min-height:100vh;}
  .topbar{flex-shrink:0;}
  .app-body{display:flex;flex:1;min-height:0;}
  .sidebar{display:flex;}
  #hamburgerBtn{display:none !important;}
  .bottom-nav{display:none !important;}
  .tab-bar{display:none !important;}
  #mobile-fab{display:none !important;}
  .mob-hide{display:block;}
  th.mob-hide,td.mob-hide{display:table-cell;}
  .wrap{padding:22px 28px;}
  .summary{grid-template-columns:repeat(6,minmax(0,1fr));}
}

/* ══ MOBILE (≤800px) ══ */
@media(max-width:800px){
  .sidebar{display:none !important;}
  .sidebar-overlay{display:none !important;}
  .bottom-nav{display:flex;}
  .wrap{margin-left:0;padding:0 0 calc(68px + env(safe-area-inset-bottom));width:100%;}
  .topbar{height:auto;padding:12px 16px 10px;gap:10px;flex-wrap:nowrap;align-items:center;}
  .title-block{flex:1;min-width:0;flex-direction:column;gap:2px;margin-right:0;}
  .title-block h1{font-size:20px;}
  #mobileSubtitle{display:block;font-family:var(--mono);font-size:9px;color:var(--text3);letter-spacing:0.06em;line-height:1;margin-top:2px;}
  .sync-bar{display:none !important;}
  #lastRefreshedBar{display:none !important;}
  #topbar-pnl{display:none !important;}
  #topbarAddBtn{display:none !important;}
  .aud-pill{display:none !important;}
  .nav-links{display:none !important;}
  .topbar-sessions{display:none !important;}
  .rfbtn{width:40px;height:40px;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;min-width:40px;flex-shrink:0;}
  .rfbtn-label{display:none !important;}
  .rfbtn svg,#rfIcon{width:17px;height:17px;}
  .user-badge{border:none;flex-shrink:0;}
  .top-actions{gap:8px;flex-shrink:0;}
  .sessions{padding:8px 16px;margin-bottom:0;gap:5px;overflow-x:auto;flex-wrap:nowrap;}
  .session-pill{font-size:9px;padding:3px 8px;flex-shrink:0;}
  /* Hero strip stacks on mobile */
  .hero-strip{grid-template-columns:1fr;gap:16px;padding:16px;border-radius:0;border-left:none;border-right:none;border-top:none;margin-bottom:0;}
  .hero-metrics{display:grid;grid-template-columns:1fr 1fr;}
  .hero-spark{display:none;}
  .hero-value{font-size:32px;}
  .scard{border-radius:0;border-left:none;border-right:none;border-top:none;padding:16px 16px 14px;}
  .summary{display:block;margin-bottom:0;}
  .summary .scard:not(:first-child){display:none;}
  .slabel{font-size:9px;margin-bottom:4px;}
  .sval{font-size:32px;font-weight:800;letter-spacing:-2px;}
  .scard-row2{grid-template-columns:1fr 1fr 1fr;margin-top:12px;padding-top:12px;}
  .scard-sub-col:last-child{display:block !important;}
  .scard-sub-col:not(:last-child){border-right:1px solid var(--border2);padding-right:10px;margin-right:10px;}
  .scard-sub-val{font-size:12px;}
  .scard-sub-label{font-size:8px;}
  .scard:first-child .sparkline{height:48px !important;margin-top:10px !important;}
  .mid-row{grid-template-columns:1fr;gap:8px;padding:0 12px;margin-bottom:8px;margin-top:8px;}
  .dash{flex-direction:column;align-items:stretch;border-radius:12px;padding:14px;}
  .dash-divider{width:100%;height:1px;}
  .pie-section{width:100%;}
  .section{border-radius:12px;margin:0 10px 8px;}
  .sec-head{padding:10px 14px;}
  .sec-title{font-size:12px;}
  td,th{padding:10px 12px;}
  th{padding:8px 12px;}
  .cgt-cards{grid-template-columns:1fr 1fr;}
  .cgt-card{border-bottom:1px solid var(--border2);}
  .cgt-card:nth-child(odd){border-right:1px solid var(--border2);}
  .cgt-card:nth-child(even){border-right:none;}
  .cgt-settings-bar{flex-direction:column;align-items:flex-start;}
  .modal{width:calc(100vw - 24px);max-width:calc(100vw - 24px);padding:18px;border-radius:16px;}
  .modal-row{grid-template-columns:1fr;gap:10px;}
  .modal-input,.modal-select{font-size:14px;padding:10px 12px;}
  .bottom-nav .bn-item:last-child{display:none !important;}
  .bn-item{font-size:9px;padding:6px 4px;gap:3px;}
  .bn-item svg{width:22px;height:22px;}
  .readonly-notice{padding:6px 14px;top:64px;font-size:11px;}
  #syncToast{bottom:calc(80px + env(safe-area-inset-bottom));right:16px;}
}

/* ══ NARROW — Z Fold 6 (≤420px) ══ */
@media(max-width:420px){
  .topbar{padding:10px 14px 8px;gap:8px;}
  .title-block h1{font-size:18px;}
  .rfbtn{width:38px;height:38px;}
  td,th{padding:9px 8px;}
  .tkr-tile{width:28px;height:28px;font-size:9px;border-radius:6px;}
  .tkr-sym{font-size:12px;}
  .tkr-name{font-size:9px;}
  .gl-chip{font-size:9px;padding:2px 6px;}
  .section{border-radius:10px;margin:0 8px 8px;}
  .mid-row{padding:0 8px;}
  .session-pill{font-size:9px;padding:3px 7px;}
  .scard-sub-val{font-size:11px;}
  .scard-sub-label{font-size:8px;}
  .cgt-cards{grid-template-columns:1fr;}
  .cgt-card{border-right:none;}
  #mobile-fab{width:50px;height:50px;font-size:22px;}
  .bn-item{font-size:9px;padding:5px 2px;}
  .bn-item svg{width:20px;height:20px;}
  .wrap{padding-bottom:calc(64px + env(safe-area-inset-bottom));}
  .hero-value{font-size:28px;}
  .hm{padding:10px 12px;}
  .hm-value{font-size:12px;}
}

/* ══ PERFORMANCE CHART TABS ══ */
.perf-tab{
  padding:5px 13px;border-radius:6px;font-size:12px;font-weight:500;
  color:var(--text3);background:transparent;border:none;
  cursor:pointer;font-family:var(--font);transition:all 0.15s;white-space:nowrap;
}
.perf-tab:hover{color:var(--text2);background:var(--surface3);}
.perf-tab.active{background:var(--accent);color:#fff;font-weight:600;}
[data-theme="light"] .perf-tab.active{color:#fff;}

.perf-gran{
  padding:4px 11px;border-radius:6px;font-family:var(--mono);font-size:10px;font-weight:400;
  color:var(--text3);background:transparent;border:none;
  cursor:pointer;transition:all 0.15s;
}
.perf-gran:hover{color:var(--text2);}
.perf-gran.active{background:var(--gold-bg);color:var(--accent);border:1px solid rgba(0,212,255,0.2);}
[data-theme="light"] .perf-gran.active{background:rgba(0,153,204,0.08);color:var(--accent);border-color:rgba(0,153,204,0.2);}

@media(max-width:800px){
  .perf-tab{font-size:11px;padding:4px 10px;}
  .perf-gran{font-size:9px;padding:3px 8px;}
}


/* ── Round 2: teammate-review fixes (scoped — v2) ─────────── */

/* [1] Holdings table only — fixed column widths + nowrap */
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table {
  table-layout: fixed;
  width: 100%;
}
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th,
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-left: 8px;
  padding-right: 8px;
}
/* Holdings columns: Asset | Type | Qty | Price | Value | 24h | P&L | Trend | × */
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th:nth-child(1),
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td:nth-child(1) { width: auto; min-width: 180px; }
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th:nth-child(2),
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td:nth-child(2) { width: 64px; text-align: center; }
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th:nth-child(3),
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td:nth-child(3) { width: 82px; }
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th:nth-child(4),
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td:nth-child(4) { width: 110px; }
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th:nth-child(5),
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td:nth-child(5) { width: 120px; }
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th:nth-child(6),
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td:nth-child(6) { width: 82px; }
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th:nth-child(7),
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td:nth-child(7) { width: 130px; }
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th:nth-child(8),
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td:nth-child(8) { width: 64px; }
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table th:nth-child(9),
#tab-portfolio .section:has(#allHoldingsB) .tbl-wrap > table td:nth-child(9) { width: 36px; }

/* Badges + chips inline */
#allHoldingsB td .badge,
#allHoldingsB td .gl-chip { display: inline-block; vertical-align: middle; }
#allHoldingsB td { vertical-align: middle; }

/* [2] Allocation table only — scoped via :has(#allocTableBody) */
.section:has(#allocTableBody) .tbl-wrap > table { table-layout: auto; width: 100%; }
.section:has(#allocTableBody) .tbl-wrap > table td,
.section:has(#allocTableBody) .tbl-wrap > table th { padding-left: 10px; padding-right: 10px; white-space: nowrap; }
.section:has(#allocTableBody) .tbl-wrap > table th:nth-child(1),
.section:has(#allocTableBody) .tbl-wrap > table td:nth-child(1) { width: auto; }
.section:has(#allocTableBody) .tbl-wrap > table th:nth-child(2),
.section:has(#allocTableBody) .tbl-wrap > table td:nth-child(2) { width: 130px; text-align: right; }
.section:has(#allocTableBody) .tbl-wrap > table th:nth-child(3),
.section:has(#allocTableBody) .tbl-wrap > table td:nth-child(3) { width: 70px; text-align: right; }
.section:has(#allocTableBody) .tbl-wrap > table th:nth-child(4),
.section:has(#allocTableBody) .tbl-wrap > table td:nth-child(4) { width: 140px; text-align: right; }
.section:has(#allocTableBody) .tbl-wrap > table th:nth-child(5),
.section:has(#allocTableBody) .tbl-wrap > table td:nth-child(5) { width: 160px; text-align: right; }

/* [3] Hero AUD/USD tile — keep value proportional */
.hero-metrics .hm { min-width: 0; }
.hero-metrics .hm:nth-child(3) { max-width: 90px; }
.hero-metrics .hm .hm-value { font-variant-numeric: tabular-nums; overflow: hidden; text-overflow: ellipsis; }


/* ── Round 2 mobile overrides — phones < 640px ─────────────── */
@media (max-width: 640px) {
  /* Allocation table: let Value breathe, drop %-only row to narrow */
  .section:has(#allocTableBody) .tbl-wrap > table { table-layout: auto; }
  .section:has(#allocTableBody) .tbl-wrap > table th,
  .section:has(#allocTableBody) .tbl-wrap > table td {
    padding-left: 6px;
    padding-right: 6px;
    white-space: nowrap;
  }
  .section:has(#allocTableBody) .tbl-wrap > table th:nth-child(2),
  .section:has(#allocTableBody) .tbl-wrap > table td:nth-child(2) { width: auto; min-width: 110px; }
  .section:has(#allocTableBody) .tbl-wrap > table th:nth-child(3),
  .section:has(#allocTableBody) .tbl-wrap > table td:nth-child(3) { width: 56px; }

  /* Cash table: stop Balance from being clipped.
     It's a plain .tbl-wrap > table (no id on the body), so target by scope. */
  #tab-portfolio .section:not(:has(#allHoldingsB)):not(:has(#allocTableBody)) .tbl-wrap > table {
    table-layout: auto !important;
    width: 100%;
  }
  #tab-portfolio .section:not(:has(#allHoldingsB)):not(:has(#allocTableBody)) .tbl-wrap > table td,
  #tab-portfolio .section:not(:has(#allHoldingsB)):not(:has(#allocTableBody)) .tbl-wrap > table th {
    overflow: visible !important;
    text-overflow: clip !important;
    white-space: nowrap;
    padding-left: 6px;
    padding-right: 6px;
  }

  /* Hide the inline edit input on narrow screens — tap the row to edit instead.
     This frees room for the Balance value. */
  #cashB td input.ni { display: none; }
  #cashB td .del { margin-left: 4px; }

  /* Shrink hero AUD/USD cap so it doesn't waste room */
  .hero-metrics .hm:nth-child(3) { max-width: none; }
}
