/* ════════════════════════════════════════════════════════════════════════════
   PnLStack — Premium Dashboard Design System
   Dark-first fintech aesthetic · full-width dashboard · tabular numerics
   ════════════════════════════════════════════════════════════════════════════ */

:root {
  --brand: #00C875;
  --brand-2: #00E888;
  --brand-soft: rgba(0,200,117,0.14);
  --brand-glow: rgba(0,200,117,0.10);

  --green: #2BD17E;
  --green-soft: rgba(43,209,126,0.13);
  --green-line: rgba(43,209,126,0.30);
  --red: #FF5470;
  --red-soft: rgba(255,84,112,0.13);
  --red-line: rgba(255,84,112,0.30);
  --blue: #4DA6FF;
  --blue-soft: rgba(77,166,255,0.14);
  --amber: #FFB22E;
  --amber-soft: rgba(255,178,46,0.14);

  --font: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: 'JetBrains Mono', 'SF Mono', ui-monospace, Menlo, monospace;

  --sidebar-w: 248px;
  --topbar-h: 64px;
  --maxw: 1320px;
  --r-sm: 9px;
  --r: 13px;
  --r-lg: 18px;
  --r-xl: 24px;
}

[data-theme="dark"] {
  --bg: #0A0C12;
  --bg-grad: radial-gradient(1200px 600px at 75% -10%, rgba(0,200,117,0.06), transparent 60%);
  --surface: #11141E;
  --surface-2: #161A26;
  --surface-3: #1C2130;
  --border: #20263400;
  --border-c: #212635;
  --border-2: #2C3344;
  --text: #EAEDF3;
  --text-2: #98A1B4;
  --text-3: #5B647A;
  --cell-win-bg: rgba(43,209,126,0.10);
  --cell-loss-bg: rgba(255,84,112,0.10);
  --cell-flat-bg: #0E121B;
  --inset-top: inset 0 1px 0 rgba(255,255,255,0.04);
  --shadow: 0 10px 30px rgba(0,0,0,0.45);
  --shadow-sm: 0 4px 16px rgba(0,0,0,0.35);
}

[data-theme="light"] {
  --bg: #F4F6FA;
  --bg-grad: radial-gradient(1200px 600px at 75% -10%, rgba(0,200,117,0.09), transparent 60%);
  --surface: #FFFFFF;
  --surface-2: #F6F8FB;
  --surface-3: #EEF1F6;
  --border-c: #E5E9F0;
  --border-2: #D8DEE8;
  --text: #0E1320;
  --text-2: #5A6478;
  --text-3: #97A1B4;
  --cell-win-bg: rgba(43,209,126,0.13);
  --cell-loss-bg: rgba(255,84,112,0.12);
  --cell-flat-bg: #F0F2F6;
  --inset-top: inset 0 1px 0 rgba(255,255,255,0.6);
  --shadow: 0 12px 32px rgba(20,30,60,0.10);
  --shadow-sm: 0 4px 14px rgba(20,30,60,0.07);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: var(--font);
  background: var(--bg);
  background-image: var(--bg-grad);
  background-attachment: fixed;
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.01em;
}
.hidden { display: none !important; }
input, textarea, select, button { font-family: inherit; }
input:focus, textarea:focus, select:focus { outline: none; }
.mono, .num { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.up { color: var(--green); }
.down { color: var(--red); }

::-webkit-scrollbar { width: 9px; height: 9px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 5px; border: 2px solid transparent; background-clip: content-box; }
::-webkit-scrollbar-thumb:hover { background: var(--text-3); background-clip: content-box; }

/* ════════════════════════════════════════════════════════════════════════════
   AUTH
   ════════════════════════════════════════════════════════════════════════════ */
.auth-overlay { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 24px; overflow: auto; background: var(--bg); background-image: var(--bg-grad); }
.auth-bg-glow { position: absolute; top: -10%; left: 50%; transform: translateX(-50%); width: 720px; height: 520px; border-radius: 50%; background: radial-gradient(circle, var(--brand-glow), transparent 65%); pointer-events: none; filter: blur(8px); }
.auth-card { position: relative; z-index: 1; width: 100%; max-width: 410px; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-xl); padding: 38px 34px; box-shadow: var(--shadow), var(--inset-top); }
.auth-logo { display: flex; align-items: center; gap: 11px; margin-bottom: 30px; }
.auth-logo-text { font-size: 19px; font-weight: 800; letter-spacing: -0.4px; }
.auth-title { font-size: 27px; font-weight: 800; letter-spacing: -1px; margin-bottom: 7px; }
.auth-sub { font-size: 14px; color: var(--text-2); margin-bottom: 26px; line-height: 1.5; }
.auth-error { background: var(--red-soft); border: 1px solid var(--red-line); color: var(--red); font-size: 13px; font-weight: 600; padding: 11px 14px; border-radius: var(--r); margin-bottom: 16px; }
.auth-fields { display: flex; flex-direction: column; gap: 15px; margin-bottom: 22px; }
.auth-label { display: block; font-size: 11px; font-weight: 700; color: var(--text-3); letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 8px; }
.auth-input { width: 100%; background: var(--surface-2); border: 1px solid var(--border-c); border-radius: var(--r); padding: 13px 15px; color: var(--text); font-size: 15px; transition: border-color 0.15s, box-shadow 0.15s; }
.auth-input:focus { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-soft); }
.auth-submit { width: 100%; background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #03200F; border: none; border-radius: var(--r); padding: 14px; font-size: 15px; font-weight: 800; cursor: pointer; transition: transform 0.1s, box-shadow 0.2s; box-shadow: 0 6px 20px rgba(0,200,117,0.35); }
.auth-submit:hover { box-shadow: 0 8px 26px rgba(0,200,117,0.38); }
.auth-submit:active { transform: scale(0.99); }
.auth-submit:disabled { opacity: 0.5; cursor: default; box-shadow: none; }
.auth-switch { text-align: center; margin-top: 20px; font-size: 14px; color: var(--text-2); }
.auth-switch-btn { background: none; border: none; color: var(--brand-2); font-weight: 700; cursor: pointer; font-size: 14px; margin-left: 5px; }
.auth-divider { display: flex; align-items: center; gap: 14px; margin: 24px 0 18px; color: var(--text-3); font-size: 12px; }
.auth-divider::before, .auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--border-c); }
.auth-offline { width: 100%; background: var(--surface-2); color: var(--text); border: 1px solid var(--border-c); border-radius: var(--r); padding: 13px; font-size: 14px; font-weight: 700; cursor: pointer; transition: border-color 0.15s; }
.auth-offline:hover { border-color: var(--border-2); }
.auth-offline-note { text-align: center; font-size: 12px; color: var(--text-3); margin-top: 11px; line-height: 1.5; }

/* logo mark */
.logo-mark { width: 34px; height: 34px; border-radius: 10px; background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #03200F; font-weight: 900; font-size: 19px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 4px 14px rgba(0,200,117,0.40); }

/* ════════════════════════════════════════════════════════════════════════════
   SIDEBAR
   ════════════════════════════════════════════════════════════════════════════ */
.sidebar { position: fixed; top: 0; left: 0; bottom: 0; width: var(--sidebar-w); background: var(--surface); border-right: 1px solid var(--border-c); display: flex; flex-direction: column; padding: 20px 14px; z-index: 50; }
.sidebar-logo { display: flex; align-items: center; gap: 12px; padding: 6px 10px 24px; }
.logo-text { font-size: 19px; font-weight: 800; letter-spacing: -0.4px; }
.sidebar-nav { display: flex; flex-direction: column; gap: 3px; flex: 1; }
.nav-item { display: flex; align-items: center; gap: 13px; padding: 11px 14px; background: none; border: none; border-radius: var(--r); cursor: pointer; color: var(--text-2); font-size: 14.5px; font-weight: 600; text-align: left; width: 100%; transition: background 0.13s, color 0.13s; position: relative; }
.nav-item:hover { background: var(--surface-2); color: var(--text); }
.nav-item.active { background: var(--brand-soft); color: var(--brand-2); }
.nav-item.active::before { content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 3px; height: 18px; background: var(--brand); border-radius: 3px; }
.nav-icon { width: 22px; height: 22px; display: flex; align-items: center; justify-content: center; }
.nav-icon svg { width: 19px; height: 19px; stroke: currentColor; fill: none; stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; }
.sidebar-footer { padding: 13px; margin-top: 8px; border: 1px solid var(--border-c); border-radius: var(--r); background: var(--surface-2); }
.sidebar-account { font-size: 13px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 8px; }
.sidebar-account::before { content: ''; width: 7px; height: 7px; border-radius: 4px; background: var(--text-3); flex-shrink: 0; }
.sidebar.synced .sidebar-account::before { background: var(--green); box-shadow: 0 0 8px var(--green); }
.sidebar-sync { font-size: 11.5px; color: var(--text-3); margin-top: 4px; padding-left: 15px; }

/* ════════════════════════════════════════════════════════════════════════════
   TOPBAR + LAYOUT
   ════════════════════════════════════════════════════════════════════════════ */
.main { margin-left: var(--sidebar-w); min-height: 100vh; }
.topbar { position: sticky; top: 0; z-index: 40; height: var(--topbar-h); display: flex; align-items: center; justify-content: space-between; padding: 0 28px; background: color-mix(in srgb, var(--bg) 82%, transparent); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); border-bottom: 1px solid var(--border-c); }
.topbar-left { display: flex; align-items: center; gap: 14px; min-width: 0; }
.topbar-title { font-size: 18px; font-weight: 800; letter-spacing: -0.5px; }
.topbar-right { display: flex; align-items: center; gap: 10px; }
.acct-chip { display: flex; align-items: center; gap: 9px; padding: 8px 14px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 999px; cursor: pointer; font-size: 13px; font-weight: 700; color: var(--text); transition: border-color 0.15s; }
.acct-chip:hover { border-color: var(--border-2); }
.acct-chip .dot { width: 7px; height: 7px; border-radius: 4px; background: var(--brand); }
.icon-btn { width: 40px; height: 40px; border-radius: 11px; background: var(--surface); border: 1px solid var(--border-c); cursor: pointer; color: var(--text-2); display: flex; align-items: center; justify-content: center; transition: 0.15s; }
.icon-btn:hover { color: var(--text); border-color: var(--border-2); }
.icon-btn svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; }
.icon-btn.active { background: var(--brand-soft); color: var(--brand-2); border-color: transparent; }

.screen { display: none; }
.screen.active { display: block; animation: fade 0.3s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.screen-pad { max-width: var(--maxw); margin: 0 auto; padding: 28px 28px 80px; }
.screen-pad.narrow { max-width: 680px; }
.page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 22px; flex-wrap: wrap; }
.page-title { font-size: 28px; font-weight: 800; letter-spacing: -1px; }
.page-sub { font-size: 13.5px; color: var(--text-2); margin-top: 4px; }
.screen-title { font-size: 28px; font-weight: 800; letter-spacing: -1px; margin-bottom: 22px; }

/* ════════════════════════════════════════════════════════════════════════════
   BUTTONS
   ════════════════════════════════════════════════════════════════════════════ */
.btn-primary, .btn-ghost, .btn-danger { border: none; border-radius: var(--r); cursor: pointer; font-weight: 700; transition: transform 0.1s, box-shadow 0.2s, border-color 0.15s, background 0.15s, color 0.15s; white-space: nowrap; display: inline-flex; align-items: center; gap: 7px; }
.btn-primary { background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #03200F; padding: 11px 18px; font-size: 14px; box-shadow: 0 5px 16px rgba(0,200,117,0.32); }
.btn-primary:hover { box-shadow: 0 7px 22px rgba(0,200,117,0.38); }
.btn-primary:active { transform: scale(0.98); }
.btn-ghost { background: var(--surface); color: var(--text-2); border: 1px solid var(--border-c); padding: 10px 16px; font-size: 13px; }
.btn-ghost:hover { color: var(--text); border-color: var(--border-2); }
.btn-danger { background: var(--red-soft); color: var(--red); border: 1px solid var(--red-line); padding: 10px 16px; font-size: 13px; }
.btn-danger:hover { background: rgba(255,84,112,0.2); }
.btn-danger:disabled, .btn-primary:disabled { opacity: 0.4; cursor: default; box-shadow: none; }
.btn-sm { padding: 9px 14px !important; font-size: 12.5px !important; }

/* ════════════════════════════════════════════════════════════════════════════
   PANELS + CARDS
   ════════════════════════════════════════════════════════════════════════════ */
.panel { background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); box-shadow: var(--shadow-sm), var(--inset-top); overflow: hidden; }
.panel-head { display: flex; align-items: center; justify-content: space-between; padding: 17px 20px; border-bottom: 1px solid var(--border-c); }
.panel-title { font-size: 14px; font-weight: 800; letter-spacing: -0.3px; }
.panel-sub { font-size: 12px; color: var(--text-3); font-weight: 600; }
.panel-body { padding: 20px; }

/* KPI WIDGETS */
.kpi-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; margin-bottom: 22px; }
.kpi { position: relative; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); padding: 16px 17px; box-shadow: var(--shadow-sm), var(--inset-top); overflow: hidden; }
.kpi::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--accent, var(--brand)); opacity: 0.85; }
.kpi.pos { --accent: var(--green); }
.kpi.neg { --accent: var(--red); }
.kpi.neu { --accent: var(--brand); }
.kpi-label { font-size: 10.5px; font-weight: 700; color: var(--text-3); letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 10px; display: flex; align-items: center; gap: 6px; }
.kpi-value { font-family: var(--mono); font-size: 23px; font-weight: 700; letter-spacing: -0.5px; line-height: 1; }
.kpi-foot { font-size: 11.5px; color: var(--text-3); margin-top: 8px; font-weight: 600; }
.kpi-chip { display: inline-block; font-size: 11px; font-weight: 800; padding: 2px 7px; border-radius: 6px; margin-top: 8px; font-family: var(--mono); }
.kpi-chip.pos { background: var(--green-soft); color: var(--green); }
.kpi-chip.neg { background: var(--red-soft); color: var(--red); }

/* ════════════════════════════════════════════════════════════════════════════
   HOME DASHBOARD
   ════════════════════════════════════════════════════════════════════════════ */
.seg { display: inline-flex; background: var(--surface); border: 1px solid var(--border-c); border-radius: 11px; padding: 3px; gap: 2px; }
.seg button, .period-tab { background: none; border: none; cursor: pointer; padding: 7px 15px; font-size: 13px; font-weight: 700; color: var(--text-2); border-radius: 8px; transition: 0.15s; }
.seg button.active, .period-tab.active { background: var(--surface-3); color: var(--text); box-shadow: var(--inset-top); }
.period-tabs { display: inline-flex; background: var(--surface); border: 1px solid var(--border-c); border-radius: 11px; padding: 3px; gap: 2px; }
.period-tab.active::after { display: none; }

.home-nav { display: inline-flex; gap: 6px; margin-left: 8px; }
.nav-arrow { width: 38px; height: 38px; border-radius: 10px; background: var(--surface); border: 1px solid var(--border-c); cursor: pointer; font-size: 18px; color: var(--text-2); display: inline-flex; align-items: center; justify-content: center; transition: 0.15s; }
.nav-arrow:hover { background: var(--surface-3); color: var(--text); }

.home-summary { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.summary-pnl { font-family: var(--mono); font-size: 17px; font-weight: 700; letter-spacing: -0.3px; }
.summary-meta { font-size: 13.5px; color: var(--text-2); font-weight: 600; }

.home-grid { display: grid; grid-template-columns: 1fr 360px; gap: 18px; align-items: start; }
.home-main { display: flex; flex-direction: column; gap: 18px; min-width: 0; }
.home-side { display: flex; flex-direction: column; gap: 18px; }

/* Goal card */
.goal-card { background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); padding: 18px 20px; box-shadow: var(--shadow-sm), var(--inset-top); }
.goal-card-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 13px; }
.goal-card-label { font-size: 11px; font-weight: 700; color: var(--text-2); text-transform: uppercase; letter-spacing: 0.6px; }
.goal-card-pct { font-family: var(--mono); font-size: 14px; font-weight: 800; }
.goal-bar { height: 9px; background: var(--surface-3); border-radius: 5px; overflow: hidden; }
.goal-bar-fill { height: 100%; border-radius: 5px; transition: width 0.5s cubic-bezier(.2,.7,.3,1); }
.goal-card-foot { display: flex; justify-content: space-between; margin-top: 11px; font-size: 12.5px; color: var(--text-3); font-family: var(--mono); }

/* Calendar */
.cal-head { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px 4px; }
.cal-head-title { font-size: 15px; font-weight: 800; }
.calendar-wrap { padding: 14px 18px 20px; }
.cal-weekdays { display: grid; gap: 7px; margin-bottom: 9px; }
.cal-weekday { text-align: center; font-size: 10px; font-weight: 700; color: var(--text-3); letter-spacing: 0.8px; }
.cal-grid { display: grid; gap: 7px; }
.cal-cell { aspect-ratio: 1.05; border-radius: 11px; padding: 9px; cursor: pointer; display: flex; flex-direction: column; justify-content: space-between; position: relative; border: 1px solid var(--border-c); background: var(--cell-flat-bg); transition: transform 0.12s, box-shadow 0.15s, border-color 0.15s; }
.cal-cell:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); border-color: var(--border-2); z-index: 1; }
.cal-cell.empty { cursor: default; background: transparent; border-color: transparent; }
.cal-cell.empty:hover { transform: none; box-shadow: none; }
.cal-cell.win { background: var(--cell-win-bg); border-color: var(--green-line); }
.cal-cell.loss { background: var(--cell-loss-bg); border-color: var(--red-line); }
.cal-cell.today { outline: 2px solid var(--brand); outline-offset: -1px; }
.cal-daynum { font-size: 11px; font-weight: 700; color: var(--text-3); }
.cal-cell.win .cal-daynum, .cal-cell.loss .cal-daynum { color: var(--text-2); }
.cal-pnl { font-family: var(--mono); font-size: 12.5px; font-weight: 700; letter-spacing: -0.3px; }
.cal-pnl.win { color: var(--green); }
.cal-pnl.loss { color: var(--red); }
.cal-pnl.flat { color: var(--text-3); }
.cal-note-dot { width: 6px; height: 6px; border-radius: 3px; background: var(--brand); position: absolute; top: 9px; right: 9px; }

/* Week view */
.week-row { display: grid; grid-auto-flow: column; grid-auto-columns: 1fr; gap: 8px; padding: 16px 18px; }
.week-cell { border-radius: 13px; padding: 14px 8px; cursor: pointer; text-align: center; min-height: 104px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; border: 1px solid var(--border-c); background: var(--cell-flat-bg); transition: transform 0.12s; }
.week-cell:hover { transform: translateY(-2px); }
.week-cell.win { background: var(--cell-win-bg); border-color: var(--green-line); }
.week-cell.loss { background: var(--cell-loss-bg); border-color: var(--red-line); }
.week-cell.today { outline: 2px solid var(--brand); outline-offset: -1px; }
.week-dayname { font-size: 9.5px; color: var(--text-3); font-weight: 700; letter-spacing: 0.4px; }
.week-daynum { font-size: 19px; font-weight: 800; color: var(--text); }
.week-pnl { font-family: var(--mono); font-size: 12px; font-weight: 700; }

/* Year view */
.year-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; padding: 18px; }
.year-cell { border-radius: 14px; padding: 18px 14px; cursor: pointer; text-align: center; min-height: 96px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; border: 1px solid var(--border-c); background: var(--cell-flat-bg); transition: transform 0.12s; }
.year-cell:hover { transform: translateY(-2px); }
.year-cell.win { background: var(--cell-win-bg); border-color: var(--green-line); }
.year-cell.loss { background: var(--cell-loss-bg); border-color: var(--red-line); }
.year-month { font-size: 12px; color: var(--text-2); font-weight: 700; }
.year-pnl { font-family: var(--mono); font-size: 17px; font-weight: 700; letter-spacing: -0.3px; }
.year-meta { font-size: 10.5px; color: var(--text-3); }

/* recent trades side panel */
.mini-trade { display: flex; align-items: center; gap: 11px; padding: 11px 16px; border-bottom: 1px solid var(--border-c); cursor: pointer; transition: background 0.13s; }
.mini-trade:last-child { border-bottom: none; }
.mini-trade:hover { background: var(--surface-2); }
.mini-tk { font-size: 13.5px; font-weight: 800; flex: 1; }
.mini-sub { font-size: 11px; color: var(--text-3); font-weight: 600; }
.mini-pnl { font-family: var(--mono); font-size: 13.5px; font-weight: 700; }
.mini-equity-wrap { padding: 8px 12px 14px; height: 150px; position: relative; }

/* hero / all-time */
.hero-card { padding: 30px; background: linear-gradient(135deg, var(--surface), var(--surface-2)); border: 1px solid var(--border-c); border-radius: var(--r-xl); box-shadow: var(--shadow-sm), var(--inset-top); position: relative; overflow: hidden; }
.hero-card::after { content: ''; position: absolute; top: -40%; right: -10%; width: 380px; height: 380px; border-radius: 50%; background: radial-gradient(circle, var(--brand-glow), transparent 65%); pointer-events: none; }
.hero-label { font-size: 11px; color: var(--text-3); font-weight: 700; letter-spacing: 0.7px; text-transform: uppercase; margin-bottom: 10px; }
.hero-value { font-family: var(--mono); font-size: 44px; font-weight: 700; letter-spacing: -2px; margin-bottom: 8px; }
.hero-meta { font-size: 13.5px; color: var(--text-2); font-weight: 600; }
.stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 18px; }
.stat-card { padding: 18px; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); box-shadow: var(--shadow-sm), var(--inset-top); }
.stat-card-label { font-size: 10.5px; color: var(--text-3); font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 9px; }
.stat-card-value { font-family: var(--mono); font-size: 20px; font-weight: 700; letter-spacing: -0.4px; }
.section-label { font-size: 12px; color: var(--text-3); font-weight: 700; margin: 24px 0 13px; text-transform: uppercase; letter-spacing: 0.6px; }

/* weekend toggle */
.weekend-toggle { display: flex; align-items: center; gap: 12px; padding: 14px 20px 4px; }
.toggle-label { font-size: 13px; color: var(--text-2); font-weight: 600; }
.toggle-switch { width: 44px; height: 26px; border-radius: 13px; background: var(--surface-3); padding: 3px; cursor: pointer; transition: background 0.2s; flex-shrink: 0; }
.toggle-switch.on { background: var(--brand); }
.toggle-knob { width: 20px; height: 20px; border-radius: 10px; background: #fff; transition: transform 0.2s; box-shadow: 0 1px 3px rgba(0,0,0,0.3); }
.toggle-switch.on .toggle-knob { transform: translateX(18px); }

/* FAB (mobile only) */
.fab { display: none; position: fixed; right: 22px; bottom: 22px; width: 58px; height: 58px; border-radius: 29px; background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #03200F; border: none; font-size: 30px; cursor: pointer; box-shadow: 0 10px 28px rgba(0,200,117,0.38); z-index: 30; align-items: center; justify-content: center; }

/* empty hint */
.empty-hint { margin: 50px auto; max-width: 380px; padding: 40px; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-xl); text-align: center; box-shadow: var(--shadow-sm); }
.empty-icon { font-size: 40px; margin-bottom: 14px; }
.empty-title { font-size: 18px; font-weight: 800; margin-bottom: 7px; }
.empty-body { font-size: 14px; color: var(--text-2); line-height: 1.5; }

/* ════════════════════════════════════════════════════════════════════════════
   TRADES
   ════════════════════════════════════════════════════════════════════════════ */
.trades-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.trades-actions, .trades-select-actions { display: flex; gap: 9px; align-items: center; }
.import-btn-label { cursor: pointer; }
.trades-toolbar { display: flex; gap: 12px; align-items: center; margin-bottom: 18px; flex-wrap: wrap; }
.search-wrap { position: relative; flex: 1; min-width: 220px; }
.search-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--text-3); font-size: 15px; }
.search-input { width: 100%; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r); padding: 11px 14px 11px 40px; color: var(--text); font-size: 14px; transition: border-color 0.15s, box-shadow 0.15s; }
.search-input:focus { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-soft); }
.filter-chips { display: flex; gap: 8px; }
.filter-chip { background: var(--surface); border: 1px solid var(--border-c); border-radius: 999px; padding: 8px 16px; font-size: 13px; font-weight: 700; color: var(--text-2); cursor: pointer; transition: 0.15s; }
.filter-chip:hover { border-color: var(--border-2); color: var(--text); }
.filter-chip.active { background: var(--brand-soft); border-color: transparent; color: var(--brand-2); }

/* trades as a table-like list inside a panel */
.trades-panel { background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-sm), var(--inset-top); }
.trade-date-group { }
.trade-date-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 20px; background: var(--surface-2); border-bottom: 1px solid var(--border-c); border-top: 1px solid var(--border-c); }
.trade-date-group:first-child .trade-date-header { border-top: none; }
.trade-date-label { font-size: 12px; font-weight: 700; color: var(--text-2); text-transform: uppercase; letter-spacing: 0.4px; }
.trade-date-total { font-family: var(--mono); font-size: 13px; font-weight: 800; }
.trade-card { padding: 14px 20px; cursor: pointer; display: flex; align-items: center; gap: 14px; transition: background 0.13s; border-bottom: 1px solid var(--border-c); }
.trade-card:last-child { border-bottom: none; }
.trade-card:hover { background: var(--surface-2); }
.trade-card.selected { background: var(--brand-soft); }
.trade-check { width: 22px; height: 22px; border-radius: 7px; border: 1px solid var(--border-2); flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.trade-check.on { background: var(--brand); border-color: var(--brand); color: #fff; font-weight: 900; font-size: 13px; }
.trade-icon { width: 38px; height: 38px; border-radius: 10px; background: var(--surface-3); display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 13px; font-weight: 800; color: var(--text-2); flex-shrink: 0; }
.trade-card-main { flex: 1; min-width: 0; }
.trade-card-top { display: flex; align-items: center; gap: 8px; margin-bottom: 3px; flex-wrap: wrap; }
.trade-ticker { font-size: 14.5px; font-weight: 800; }
.trade-badge { font-size: 9.5px; font-weight: 800; padding: 2px 7px; border-radius: 5px; letter-spacing: 0.3px; }
.trade-badge.call { background: var(--green-soft); color: var(--green); }
.trade-badge.put { background: var(--blue-soft); color: var(--blue); }
.trade-badge.zdte { background: var(--amber-soft); color: var(--amber); }
.trade-badge.open { background: var(--amber-soft); color: var(--amber); }
.trade-badge.neutral { background: var(--surface-3); color: var(--text-2); }
.trade-card-sub { font-size: 12px; color: var(--text-3); font-weight: 600; }
.trade-card-pnl { font-family: var(--mono); font-size: 15px; font-weight: 700; letter-spacing: -0.3px; text-align: right; }

/* ════════════════════════════════════════════════════════════════════════════
   ANALYTICS
   ════════════════════════════════════════════════════════════════════════════ */
.analytics-tabs { display: inline-flex; gap: 2px; margin-bottom: 22px; background: var(--surface); padding: 3px; border-radius: 11px; border: 1px solid var(--border-c); flex-wrap: wrap; }
.analytics-tab { padding: 9px 16px; background: none; border: none; border-radius: 8px; font-size: 13px; font-weight: 700; color: var(--text-2); cursor: pointer; white-space: nowrap; transition: 0.15s; }
.analytics-tab.active { background: var(--surface-3); color: var(--text); box-shadow: var(--inset-top); }
.analytics-stats-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-bottom: 18px; }
.an-stat-card { background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); padding: 18px; box-shadow: var(--shadow-sm), var(--inset-top); }
.an-stat-label { font-size: 10.5px; color: var(--text-3); font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 10px; }
.an-stat-value { font-family: var(--mono); font-size: 21px; font-weight: 700; letter-spacing: -0.5px; }
.an-stat-sub { font-size: 11px; color: var(--text-3); margin-top: 5px; font-weight: 600; }
.chart-card { background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); padding: 20px; margin-bottom: 16px; box-shadow: var(--shadow-sm), var(--inset-top); }
.chart-card-title { font-size: 14px; font-weight: 800; color: var(--text); margin-bottom: 18px; }
.chart-canvas-wrap { position: relative; height: 300px; }
.strat-stat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 16px; }
.strat-stat { background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); padding: 16px; box-shadow: var(--shadow-sm), var(--inset-top); }
.strat-stat-name { font-size: 13.5px; font-weight: 800; margin-bottom: 8px; }
.strat-stat-row { display: flex; justify-content: space-between; font-size: 11.5px; color: var(--text-3); margin-top: 4px; font-weight: 600; }
.strat-stat-row b { color: var(--text); font-weight: 700; font-family: var(--mono); }

/* ════════════════════════════════════════════════════════════════════════════
   JOURNAL
   ════════════════════════════════════════════════════════════════════════════ */
.journal-eyebrow { font-size: 12px; font-weight: 700; color: var(--brand-2); text-transform: uppercase; letter-spacing: 0.6px; margin-bottom: 5px; }
.day-rail { display: flex; gap: 9px; overflow-x: auto; padding-bottom: 12px; margin-bottom: 18px; }
.day-chip { flex-shrink: 0; min-width: 58px; padding: 11px 13px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 14px; text-align: center; cursor: pointer; transition: 0.14s; }
.day-chip:hover { border-color: var(--border-2); }
.day-chip.active { background: var(--brand-soft); border-color: transparent; }
.day-chip.has-data::after { content: ''; display: block; width: 5px; height: 5px; border-radius: 3px; background: var(--brand); margin: 5px auto 0; }
.day-chip-dow { font-size: 10px; color: var(--text-3); font-weight: 700; }
.day-chip-num { font-size: 17px; font-weight: 800; margin-top: 3px; }
.day-chip.active .day-chip-num { color: var(--brand-2); }
.day-stats-card { background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); padding: 18px 22px; margin-bottom: 16px; display: flex; gap: 32px; box-shadow: var(--shadow-sm), var(--inset-top); }
.day-stat-label { font-size: 10.5px; color: var(--text-3); font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 6px; }
.day-stat-value { font-family: var(--mono); font-size: 21px; font-weight: 700; letter-spacing: -0.4px; }
.journal-card { background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); padding: 20px; margin-bottom: 16px; box-shadow: var(--shadow-sm), var(--inset-top); }
.journal-card-title { font-size: 14px; font-weight: 800; color: var(--text); margin-bottom: 18px; }
.mood-slider-row { display: flex; align-items: center; gap: 16px; margin-bottom: 17px; }
.mood-slider-label { width: 86px; font-size: 13px; font-weight: 700; }
.mood-slider { flex: 1; -webkit-appearance: none; appearance: none; height: 6px; border-radius: 3px; background: var(--surface-3); cursor: pointer; }
.mood-slider::-webkit-slider-thumb { -webkit-appearance: none; width: 20px; height: 20px; border-radius: 10px; background: var(--brand); cursor: pointer; box-shadow: 0 2px 8px rgba(0,200,117,0.38); }
.mood-slider::-moz-range-thumb { width: 20px; height: 20px; border: none; border-radius: 10px; background: var(--brand); cursor: pointer; }
.mood-score { width: 28px; text-align: center; font-family: var(--mono); font-size: 16px; font-weight: 800; color: var(--brand-2); }
.mood-score.fomo-score { color: var(--amber); }
.mindset-score-row { display: flex; justify-content: space-between; align-items: center; padding-top: 12px; border-top: 1px solid var(--border-c); margin-top: 6px; }
.mindset-score-label { font-size: 13px; color: var(--text-2); font-weight: 600; }
.mindset-score-value { font-family: var(--mono); font-size: 19px; font-weight: 800; color: var(--brand-2); }
.prompts-row { display: flex; flex-wrap: wrap; gap: 8px; }
.prompt-chip { padding: 9px 15px; background: var(--surface-2); border: 1px solid var(--border-c); border-radius: 999px; font-size: 12.5px; font-weight: 600; color: var(--text-2); cursor: pointer; transition: 0.14s; }
.prompt-chip:hover { border-color: var(--brand); color: var(--brand-2); }
.ai-insight-card { border-color: var(--brand-soft); position: relative; }
.ai-insight-body { font-size: 14px; line-height: 1.75; color: var(--text); margin-bottom: 18px; white-space: pre-line; min-height: 40px; }
.ai-insight-placeholder { color: var(--text-3); font-style: italic; }
.ai-generate-btn { width: 100%; background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #03200F; border: none; border-radius: var(--r); padding: 13px; font-size: 14px; font-weight: 800; cursor: pointer; transition: box-shadow 0.2s; box-shadow: 0 5px 18px rgba(0,200,117,0.35); }
.ai-generate-btn:hover { box-shadow: 0 7px 24px rgba(0,200,117,0.45); }
.ai-generate-btn:disabled { opacity: 0.55; cursor: default; box-shadow: none; }
.save-journal-btn { width: 100%; padding: 14px; font-size: 15px; justify-content: center; }
.journal-actions { margin: 6px 0 28px; }
.timeline-title { font-size: 12px; color: var(--text-3); font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; margin-bottom: 13px; }
.timeline-item { display: flex; align-items: center; gap: 15px; padding: 14px 18px; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r); margin-bottom: 9px; cursor: pointer; transition: border-color 0.15s; box-shadow: var(--shadow-sm); }
.timeline-item:hover { border-color: var(--border-2); }
.timeline-date { font-family: var(--mono); font-size: 13px; font-weight: 700; width: 64px; flex-shrink: 0; }
.timeline-body { flex: 1; min-width: 0; }
.timeline-note { font-size: 12.5px; color: var(--text-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.timeline-meta { font-size: 11px; color: var(--text-3); margin-top: 3px; font-family: var(--mono); }
.timeline-pnl { font-family: var(--mono); font-size: 14px; font-weight: 700; }

/* tag chips (shared) */
.tag-row { display: flex; flex-wrap: wrap; gap: 7px; }
.tag-chip { padding: 8px 15px; background: var(--surface-2); border: 1px solid var(--border-c); border-radius: 999px; font-size: 12px; font-weight: 600; color: var(--text-2); cursor: pointer; transition: 0.13s; }
.tag-chip:hover { border-color: var(--border-2); }
.tag-chip.on { background: var(--brand-soft); border-color: transparent; color: var(--brand-2); }
.tag-chip.on-warn { background: var(--amber-soft); border-color: transparent; color: var(--amber); }
.tag-chip.on-red { background: var(--red-soft); border-color: transparent; color: var(--red); }

/* ════════════════════════════════════════════════════════════════════════════
   LOG TRADE
   ════════════════════════════════════════════════════════════════════════════ */
.log-top-bar { position: sticky; top: 0; z-index: 30; display: flex; align-items: center; justify-content: space-between; padding: 16px 0; margin-bottom: 8px; background: color-mix(in srgb, var(--bg) 85%, transparent); backdrop-filter: blur(12px); }
.close-btn { width: 38px; height: 38px; border-radius: 11px; background: var(--surface); border: 1px solid var(--border-c); cursor: pointer; font-size: 15px; color: var(--text-2); }
.log-top-title { font-size: 17px; font-weight: 800; }
.save-btn { background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: #03200F; border: none; padding: 11px 24px; border-radius: 999px; font-size: 14px; font-weight: 800; cursor: pointer; box-shadow: 0 5px 16px rgba(0,200,117,0.35); }
.save-btn:disabled { opacity: 0.4; cursor: default; box-shadow: none; }
.log-pad { max-width: 640px; margin: 0 auto; }

.mode-toggle { position: relative; display: flex; background: var(--surface); border: 1px solid var(--border-c); border-radius: 14px; padding: 4px; margin-bottom: 20px; }
.mode-slider { position: absolute; top: 4px; bottom: 4px; left: 4px; width: calc(50% - 4px); background: var(--surface-3); border-radius: 10px; transition: transform 0.24s cubic-bezier(.3,.7,.3,1); box-shadow: var(--inset-top); }
.mode-slider.right { transform: translateX(100%); }
.mode-btn { flex: 1; position: relative; z-index: 1; background: none; border: none; cursor: pointer; padding: 11px; font-size: 13.5px; font-weight: 700; color: var(--text-3); }
.mode-btn.active { color: var(--text); }

.date-row { display: flex; align-items: center; gap: 14px; padding: 15px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 14px; cursor: pointer; margin-bottom: 20px; transition: border-color 0.15s; }
.date-row:hover { border-color: var(--border-2); }
.date-row-icon { width: 38px; height: 38px; border-radius: 11px; background: var(--brand-soft); display: flex; align-items: center; justify-content: center; font-size: 17px; }
.date-row-text { flex: 1; }
.date-row-label { font-size: 10px; color: var(--text-3); font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 3px; }
.date-row-value { font-size: 14px; font-weight: 700; }
.date-row-arrow { font-size: 18px; color: var(--text-3); }

.hero-block { padding: 26px 22px; background: var(--green-soft); border: 1px solid var(--green-line); border-radius: var(--r-xl); margin-bottom: 22px; transition: background 0.2s, border-color 0.2s; }
.hero-block.loss { background: var(--red-soft); border-color: var(--red-line); }
.outcome-bar { display: flex; background: var(--surface); border: 1px solid var(--border-c); border-radius: 13px; padding: 4px; margin-bottom: 20px; }
.outcome-pill { flex: 1; padding: 10px; border: none; border-radius: 9px; cursor: pointer; font-size: 12.5px; font-weight: 800; letter-spacing: 0.4px; color: var(--text-3); background: none; transition: 0.15s; }
.outcome-pill.active-win { background: var(--green); color: #04130C; }
.outcome-pill.active-loss { background: var(--red); color: #fff; }
.amount-row { display: flex; align-items: baseline; justify-content: center; }
.amount-prefix { font-family: var(--mono); font-size: 28px; font-weight: 700; color: var(--green); margin-right: 2px; }
.amount-prefix.loss { color: var(--red); }
.amount-input { font-family: var(--mono); font-size: 56px; font-weight: 700; color: var(--green); letter-spacing: -3px; text-align: center; background: none; border: none; width: 260px; max-width: 100%; }
.amount-input.loss { color: var(--red); }
.amount-input::-webkit-outer-spin-button, .amount-input::-webkit-inner-spin-button { -webkit-appearance: none; }
.amount-input { -moz-appearance: textfield; }
.amount-hint { font-size: 12px; color: var(--text-3); font-weight: 600; text-align: center; margin-top: 8px; }
.quick-amount-chips { display: flex; gap: 8px; margin-top: 18px; }
.quick-chip { flex: 1; background: var(--surface); border: 1px solid var(--border-c); border-radius: 11px; padding: 9px; font-family: var(--mono); font-size: 12px; font-weight: 800; color: var(--text-2); cursor: pointer; transition: 0.14s; }
.quick-chip:hover { border-color: var(--border-2); }

.form-section { margin-bottom: 18px; }
.form-label { font-size: 11px; color: var(--text-3); font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 9px; }
.input-modern { width: 100%; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r); padding: 13px 15px; color: var(--text); font-size: 14px; transition: border-color 0.15s, box-shadow 0.15s; }
.input-modern:focus { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-soft); }
select.input-modern { cursor: pointer; }
.notes-input { width: 100%; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r); padding: 14px; color: var(--text); font-size: 14px; min-height: 90px; resize: vertical; font-family: inherit; line-height: 1.6; transition: border-color 0.15s; }
.notes-input:focus { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-soft); }
.notes-counter { font-size: 10px; color: var(--text-3); text-align: right; margin-top: 5px; font-family: var(--mono); }

.ticker-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 11px; }
.ticker-chip { padding: 7px 13px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 8px; font-size: 11px; font-weight: 700; color: var(--text-2); cursor: pointer; font-family: var(--mono); transition: 0.13s; }
.ticker-chip:hover { border-color: var(--border-2); }
.ticker-chip.selected { background: var(--brand-soft); border-color: transparent; color: var(--brand-2); }

.collapsible-section, .adv-section { margin-bottom: 15px; }
.section-toggle { width: 100%; min-height: 58px; padding: 14px 17px; border-radius: 14px; border: 1px solid var(--border-c); background: var(--surface); display: flex; align-items: center; justify-content: space-between; cursor: pointer; transition: border-color 0.15s; }
.section-toggle:hover { border-color: var(--border-2); }
.section-toggle-title { font-size: 13.5px; font-weight: 800; text-align: left; }
.section-toggle-sub { font-size: 11px; color: var(--text-3); font-weight: 600; margin-top: 2px; text-align: left; }
.section-toggle-icon { font-size: 24px; color: var(--text-2); font-weight: 300; }
.section-body { padding-top: 6px; }
.adv-section-title { font-size: 12px; font-weight: 800; margin-bottom: 11px; }
.section-title-row { display: flex; justify-content: space-between; align-items: baseline; }

.type-grid { display: flex; gap: 7px; margin-bottom: 11px; }
.type-btn { flex: 1; padding: 12px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 12px; font-size: 12.5px; font-weight: 700; color: var(--text-2); cursor: pointer; transition: 0.14s; }
.type-btn.active { background: var(--brand-soft); border-color: transparent; color: var(--brand-2); }
.cp-toggle, .premium-toggle { display: flex; gap: 7px; margin-bottom: 9px; }
.cp-btn { flex: 1; padding: 11px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 12px; font-size: 13px; font-weight: 700; color: var(--text-2); cursor: pointer; }
.cp-btn.call-active { background: var(--green-soft); border-color: var(--green-line); color: var(--green); }
.cp-btn.put-active { background: var(--blue-soft); border-color: transparent; color: var(--blue); }
.premium-btn { flex: 1; padding: 10px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 12px; font-size: 12px; font-weight: 700; color: var(--text-2); cursor: pointer; }
.premium-btn.active { background: var(--amber-soft); border-color: transparent; color: var(--amber); }
.dte-row { display: flex; gap: 7px; flex-wrap: wrap; }
.dte-pill { padding: 7px 15px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 999px; font-size: 11px; font-weight: 700; color: var(--text-2); cursor: pointer; }
.dte-pill.active { background: var(--amber-soft); border-color: transparent; color: var(--amber); }
.ls-toggle, .plan-toggle { display: flex; gap: 7px; }
.ls-btn { flex: 1; padding: 11px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 12px; font-size: 12.5px; font-weight: 700; color: var(--text-3); cursor: pointer; }
.ls-btn.active { background: var(--surface-3); color: var(--text); }
.trade-type-row { display: flex; gap: 7px; }
.trade-type-btn { flex: 1; padding: 11px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 12px; font-size: 12.5px; font-weight: 700; color: var(--text-2); cursor: pointer; }
.trade-type-btn.active { background: var(--blue-soft); border-color: transparent; color: var(--blue); }
.plan-btn { flex: 1; padding: 10px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 12px; font-size: 12px; font-weight: 700; color: var(--text-2); cursor: pointer; }
.plan-btn.active { background: var(--green-soft); border-color: var(--green-line); color: var(--green); }

.num-grid { display: flex; flex-wrap: wrap; gap: 9px; }
.num-field { background: var(--surface); border: 1px solid var(--border-c); border-radius: 12px; padding: 12px 14px; flex: 1 1 calc(50% - 9px); min-width: 130px; transition: border-color 0.15s; }
.num-field:focus-within { border-color: var(--brand); }
.num-field-label { font-size: 9px; color: var(--text-3); font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase; margin-bottom: 4px; }
.num-field-input { width: 100%; background: none; border: none; color: var(--text); font-family: var(--mono); font-size: 16px; font-weight: 700; }
.num-field-input::-webkit-outer-spin-button, .num-field-input::-webkit-inner-spin-button { -webkit-appearance: none; }
.qty-presets { display: flex; gap: 7px; margin-top: 11px; }
.qty-preset { padding: 7px 15px; background: var(--surface); border: 1px solid var(--border-c); border-radius: 999px; font-family: var(--mono); font-size: 11px; font-weight: 800; color: var(--text-2); cursor: pointer; }
.qty-preset.active { background: var(--brand-soft); border-color: transparent; color: var(--brand-2); }

.pnl-ticket { padding: 18px; background: var(--surface); border: 1px solid var(--green-line); border-radius: var(--r-lg); margin-bottom: 18px; box-shadow: var(--shadow-sm); }
.pnl-ticket.loss { border-color: var(--red-line); }
.pnl-ticket-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.pnl-ticket-label { font-size: 10px; color: var(--text-3); font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 5px; }
.pnl-ticket-formula { font-size: 11px; color: var(--text-3); font-family: var(--mono); }
.pnl-ticket-value { font-family: var(--mono); font-size: 26px; font-weight: 700; color: var(--green); letter-spacing: -0.8px; }
.pnl-ticket-value.loss { color: var(--red); }
.pnl-breakdown { display: flex; flex-wrap: wrap; gap: 9px; }
.mini-metric { flex: 1 1 30%; min-width: 90px; padding: 11px; border-radius: 11px; background: var(--surface-2); }
.mini-metric-label { font-size: 9px; color: var(--text-3); font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 4px; }
.mini-metric-value { font-family: var(--mono); font-size: 13px; font-weight: 800; }

.exit-leg-row { display: flex; align-items: center; gap: 9px; margin-bottom: 9px; }
.exit-leg-label { width: 56px; font-size: 11px; color: var(--text-3); font-weight: 700; }
.exit-leg-input { flex: 1; background: var(--surface); border: 1px solid var(--border-c); border-radius: 11px; padding: 11px 12px; color: var(--text); font-family: var(--mono); font-size: 14px; font-weight: 700; min-width: 0; }
.exit-leg-input:focus { border-color: var(--brand); }
.remove-leg-btn { width: 36px; height: 36px; border-radius: 11px; background: var(--surface); border: 1px solid var(--border-c); color: var(--text-3); font-size: 20px; cursor: pointer; flex-shrink: 0; }
.add-leg-btn { margin-top: 5px; padding: 9px 16px; background: var(--brand-soft); border: 1px solid transparent; border-radius: 999px; color: var(--brand-2); font-size: 12px; font-weight: 800; cursor: pointer; }
.position-intent { margin: 11px 0; padding: 13px; border-radius: 13px; border: 1px solid var(--border-c); background: var(--surface); }
.position-intent.open { border-color: var(--amber-soft); background: var(--amber-soft); }
.position-intent.closed { border-color: var(--green-line); background: var(--green-soft); }
.position-intent.error { border-color: var(--red-line); background: var(--red-soft); }
.position-intent-label { font-size: 9px; color: var(--text-3); font-weight: 800; letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 3px; }
.position-intent-title { font-size: 14px; font-weight: 900; }
.position-intent-copy { font-size: 11px; color: var(--text-2); font-weight: 600; margin-top: 3px; line-height: 1.5; }
.adv-checkbox-row { display: flex; align-items: center; gap: 13px; margin-top: 13px; padding: 13px; border-radius: 13px; background: var(--surface); border: 1px solid var(--border-c); cursor: pointer; }
.checkbox { width: 22px; height: 22px; border-radius: 7px; border: 1px solid var(--border-2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.checkbox.on { background: var(--brand); border-color: var(--brand); }
.checkbox.on::after { content: '✓'; color: #fff; font-size: 13px; font-weight: 900; }
.adv-checkbox-title { font-size: 12.5px; font-weight: 800; }
.adv-checkbox-sub { font-size: 11px; color: var(--text-3); font-weight: 600; margin-top: 2px; }
.rule-notice { padding: 15px; border-radius: var(--r-lg); background: var(--amber-soft); border: 1px solid var(--amber); margin-bottom: 18px; }
.rule-notice-title { color: var(--amber); font-size: 13px; font-weight: 900; margin-bottom: 5px; }
.rule-notice-text { color: var(--text); font-size: 12px; font-weight: 600; line-height: 1.6; white-space: pre-line; }
.save-intent-copy { text-align: center; font-size: 12px; color: var(--text-2); font-weight: 700; margin: 10px 0; }

/* ════════════════════════════════════════════════════════════════════════════
   SETTINGS
   ════════════════════════════════════════════════════════════════════════════ */
.settings-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; align-items: start; }
.settings-group { margin-bottom: 0; }
.settings-group-label { font-size: 12px; color: var(--text-3); font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; margin-bottom: 12px; }
.settings-card { background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-lg); padding: 20px; box-shadow: var(--shadow-sm), var(--inset-top); }
.settings-divider { height: 1px; background: var(--border-c); margin: 16px 0; }
.settings-inline-btn { width: 100%; background: var(--brand-soft); color: var(--brand-2); border: 1px solid transparent; border-radius: var(--r); padding: 12px; font-size: 13px; font-weight: 800; cursor: pointer; }
.settings-inline-btn.signout { background: var(--red-soft); color: var(--red); }
.settings-toggle-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.settings-toggle-row:last-child { margin-bottom: 0; }
.settings-toggle-label { font-size: 14px; font-weight: 700; }
.settings-toggle-sub { font-size: 12px; color: var(--text-3); margin-top: 3px; }
.account-row { display: flex; align-items: center; justify-content: space-between; }
.account-name { font-size: 15px; font-weight: 800; }
.account-meta { font-size: 12px; color: var(--text-3); margin-top: 3px; font-family: var(--mono); }
.cloud-status-row { display: flex; align-items: center; justify-content: space-between; }
.cloud-status-label { font-size: 14px; font-weight: 800; }
.cloud-status-sub { font-size: 12px; color: var(--text-3); margin-top: 3px; }
.cloud-status-dot { width: 10px; height: 10px; border-radius: 5px; background: var(--text-3); }
.cloud-status-dot.online { background: var(--green); box-shadow: 0 0 8px var(--green); }
.goal-input-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 12px; }
.goal-input-row:last-of-type { margin-bottom: 16px; }
.goal-input-label { font-size: 14px; font-weight: 600; color: var(--text-2); }
.goal-input { width: 150px; background: var(--surface-2); border: 1px solid var(--border-c); border-radius: var(--r-sm); padding: 10px 13px; color: var(--text); font-family: var(--mono); font-size: 14px; font-weight: 700; text-align: right; }
.goal-input:focus { border-color: var(--brand); }
.account-switch-item { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; background: var(--surface-2); border: 1px solid var(--border-c); border-radius: var(--r); margin-bottom: 9px; cursor: pointer; transition: border-color 0.15s; }
.account-switch-item.active { border-color: var(--brand); background: var(--brand-soft); }
.account-switch-item:hover { border-color: var(--border-2); }
.settings-row { width: 100%; display: flex; align-items: center; gap: 14px; padding: 15px 18px; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r); margin-bottom: 9px; cursor: pointer; transition: border-color 0.15s; box-shadow: var(--shadow-sm); }
.settings-row:hover { border-color: var(--border-2); }
.settings-row-icon { font-size: 16px; width: 20px; text-align: center; color: var(--text-2); }
.settings-row-label { flex: 1; text-align: left; font-size: 14px; font-weight: 600; }
.settings-row-arrow { font-size: 18px; color: var(--text-3); }

/* ════════════════════════════════════════════════════════════════════════════
   MODALS
   ════════════════════════════════════════════════════════════════════════════ */
.modal-backdrop { position: fixed; inset: 0; z-index: 200; background: rgba(5,7,12,0.66); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; padding: 20px; animation: fade 0.2s; }
.modal-sheet { width: 100%; max-width: 460px; background: var(--surface); border: 1px solid var(--border-c); border-radius: var(--r-xl); padding-bottom: 22px; max-height: 88vh; overflow-y: auto; box-shadow: var(--shadow); animation: pop 0.25s cubic-bezier(.3,.8,.4,1); }
@keyframes pop { from { transform: scale(0.96) translateY(10px); opacity: 0; } to { transform: scale(1) translateY(0); opacity: 1; } }
.modal-handle { display: none; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 22px 24px 16px; }
.modal-title { font-size: 18px; font-weight: 800; }
.modal-close { width: 32px; height: 32px; border-radius: 10px; background: var(--surface-2); border: 1px solid var(--border-c); color: var(--text-2); cursor: pointer; font-size: 13px; }
.modal-footer { display: flex; gap: 11px; padding: 18px 24px 4px; }
.modal-footer .btn-primary, .modal-footer .btn-ghost, .modal-footer .btn-danger { flex: 1; justify-content: center; }
.modal-section { padding: 0 24px; }
.dp-month-nav { display: flex; align-items: center; justify-content: space-between; padding: 0 24px; margin-bottom: 16px; }
.dp-month-label { font-size: 16px; font-weight: 800; }
.dp-weekdays { display: grid; grid-template-columns: repeat(7, 1fr); padding: 0 24px; margin-bottom: 8px; }
.dp-weekdays span { text-align: center; font-size: 10px; color: var(--text-3); font-weight: 700; }
.dp-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; padding: 0 20px; }
.dp-day { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 14px; font-weight: 600; cursor: pointer; border-radius: 10px; max-width: 42px; margin: 0 auto; width: 100%; transition: 0.1s; }
.dp-day:hover { background: var(--surface-3); }
.dp-day.selected { background: var(--brand); color: #fff; font-weight: 800; }
.dp-day.today { border: 1.5px solid var(--brand); color: var(--brand-2); }
.dp-day.disabled { color: var(--text-3); opacity: 0.4; cursor: default; }
.dp-day.disabled:hover { background: none; }
.dp-day.empty { cursor: default; }
.dp-day.empty:hover { background: none; }
.detail-row { display: flex; justify-content: space-between; padding: 11px 24px; font-size: 14px; }
.detail-row-label { color: var(--text-3); }
.detail-row-value { font-weight: 700; font-family: var(--mono); }
.detail-pnl-hero { text-align: center; padding: 20px 24px; }
.detail-pnl-value { font-family: var(--mono); font-size: 38px; font-weight: 700; letter-spacing: -1px; }
.detail-tags { display: flex; flex-wrap: wrap; gap: 7px; padding: 14px 24px; }

/* toast */
.toast { position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%); background: var(--surface); color: var(--text); border: 1px solid var(--border-2); padding: 13px 22px; border-radius: 999px; font-size: 14px; font-weight: 700; z-index: 500; box-shadow: var(--shadow); animation: toastIn 0.3s ease; }
@keyframes toastIn { from { transform: translate(-50%, 20px); opacity: 0; } to { transform: translate(-50%, 0); opacity: 1; } }

/* mobile header (hidden on desktop) */
.mobile-header { display: none; }

/* ════════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1180px) {
  .kpi-grid { grid-template-columns: repeat(3, 1fr); }
  .home-grid { grid-template-columns: 1fr; }
  .analytics-stats-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 920px) {
  .sidebar { transform: translateX(-100%); transition: transform 0.26s cubic-bezier(.3,.7,.3,1); box-shadow: 0 0 50px rgba(0,0,0,0.5); }
  .sidebar.open { transform: translateX(0); }
  .mobile-header { display: flex; position: fixed; top: 0; left: 0; right: 0; height: 56px; z-index: 60; background: var(--surface); border-bottom: 1px solid var(--border-c); align-items: center; justify-content: space-between; padding: 0 16px; }
  .hamburger { background: none; border: none; cursor: pointer; display: flex; flex-direction: column; gap: 4px; padding: 8px; }
  .hamburger span { width: 20px; height: 2px; background: var(--text); border-radius: 2px; }
  .mobile-logo { display: flex; align-items: center; gap: 9px; }
  .mobile-logo .logo-mark { width: 28px; height: 28px; font-size: 16px; }
  .mobile-logo .logo-text { font-size: 16px; }
  .mobile-privacy-btn { background: none; border: none; font-size: 18px; cursor: pointer; padding: 8px; opacity: 0.7; }
  .main { margin-left: 0; padding-top: 56px; }
  .topbar { display: none; }
  .screen-pad { padding: 20px 16px 90px; }
  .fab { display: flex; }
  .settings-grid { grid-template-columns: 1fr; }
  .sidebar-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 49; }
}
@media (max-width: 580px) {
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .analytics-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .year-grid { grid-template-columns: repeat(3, 1fr); }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .strat-stat-grid { grid-template-columns: 1fr; }
  .hero-value { font-size: 36px; }
  .amount-input { font-size: 46px; width: 190px; }
  .page-title, .screen-title { font-size: 24px; }
  .day-stats-card { gap: 20px; }
}

/* ── DARK MODE TEXT FIXES ── */

select, select option {
  color: var(--text) !important;
  background: var(--surface-2) !important;
}

input[type="number"],
input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
textarea {
  color: var(--text);
  background-color: var(--surface);
}
input::placeholder, textarea::placeholder {
  color: var(--text-3);
  opacity: 1;
}
input:-webkit-autofill,
input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--text) !important;
  -webkit-box-shadow: 0 0 0 1000px var(--surface-2) inset !important;
  caret-color: var(--text);
}

.modal-sheet, .modal-sheet * {
  color: inherit;
}
.dp-day, .dp-weekdays span {
  color: var(--text-2);
}
.dp-day.selected { color: #03200F; }
.dp-day.today { color: var(--brand); }
.dp-day.disabled { color: var(--text-3); }
.dp-day.empty { color: transparent; }

.trade-icon {
  color: var(--text-2) !important;
  background: var(--surface-3) !important;
}

.settings-toggle-label, .settings-toggle-sub,
.goal-input-label, .account-name, .account-meta,
.cloud-status-label, .cloud-status-sub,
.settings-group-label, .panel-title, .panel-sub,
.chart-card-title, .strat-stat-name,
.timeline-date, .timeline-note, .timeline-meta,
.form-label, .adv-section-title, .section-title-row,
.adv-checkbox-title, .adv-checkbox-sub,
.exit-leg-label, .position-intent-title, .position-intent-copy,
.rule-notice-text, .pnl-ticket-formula, .mini-metric-label,
.num-field-label, .amount-hint, .save-intent-copy,
.notes-counter, .ticker-chip, .tag-chip,
.auth-label, .auth-offline-note,
.mode-btn, .ls-btn, .type-btn, .cp-btn, .dte-pill, .trade-type-btn, .plan-btn, .premium-btn,
.cal-daynum, .week-dayname, .year-month,
.kpi-label, .kpi-foot,
.an-stat-label, .an-stat-sub,
.stat-card-label, .hero-label, .hero-meta,
.section-label, .toggle-label, .logo-text,
.acct-chip, .topbar-title, .page-title, .page-sub, .screen-title, .panel-head,
.trade-date-label, .trade-card-sub,
.sidebar-sync, .sidebar-account,
.detail-row-label {
  color: inherit;
}

.detail-row { color: var(--text); }
.detail-row-label { color: var(--text-3) !important; }
.detail-row-value { color: var(--text) !important; }
.modal-title { color: var(--text); }
.modal-close { color: var(--text-2); }
.nav-item { color: var(--text-2); }
.nav-item.active { color: var(--brand); }
.topbar-title { color: var(--text); }
.acct-chip { color: var(--text); }
.log-top-title { color: var(--text); }
.close-btn { color: var(--text-2); background: var(--surface); border: 1px solid var(--border-c); }
.date-row-value { color: var(--text); }
.date-row-label { color: var(--text-3); }
.week-daynum { color: var(--text); }
.mindset-score-label { color: var(--text-2); }
.journal-card-title { color: var(--text); }
.day-stat-label { color: var(--text-3); }
.timeline-title { color: var(--text-3); }
.prompt-chip { color: var(--text-2); }
.section-toggle-title { color: var(--text); }
.section-toggle-sub { color: var(--text-3); }
.section-toggle-icon { color: var(--text-2); }
.dp-month-label { color: var(--text); }
.home-summary { color: var(--text); }
.trade-ticker { color: var(--text); }
.trade-card-pnl { /* handled by .up/.down */ }
.year-pnl { /* handled by .up/.down */ }

/* ── SHARPNESS + POLISH ── */
/* Thinner, crisper card outlines */
.panel, .kpi, .chart-card, .an-stat-card, .stat-card, .journal-card,
.day-stats-card, .goal-card, .timeline-item, .strat-stat,
.settings-card, .trades-panel { border-width: 1px; }

/* Sharper typography weights */
.page-title, .screen-title, .panel-title, .modal-title { letter-spacing: -1.2px; }
.kpi-value { font-size: 22px; font-weight: 700; }
.trade-date-label { font-weight: 800; letter-spacing: 0.6px; }

/* Green brand active indicator instead of purple */
.nav-item.active { color: var(--brand) !important; background: rgba(0,200,117,0.12) !important; }
.nav-item.active::before { background: var(--brand) !important; }
.filter-chip.active { background: rgba(0,200,117,0.13) !important; border-color: rgba(0,200,117,0.35) !important; color: var(--brand) !important; }
.analytics-tab.active { color: var(--text) !important; }
.period-tab.active { color: var(--text) !important; }
.day-chip.active { background: rgba(0,200,117,0.13) !important; border-color: rgba(0,200,117,0.35) !important; }
.day-chip.active .day-chip-num { color: var(--brand) !important; }
.journal-eyebrow { color: var(--brand) !important; }
.settings-inline-btn { background: rgba(0,200,117,0.12) !important; color: var(--brand) !important; border-color: rgba(0,200,117,0.28) !important; }
.settings-inline-btn.signout { background: var(--red-soft) !important; color: var(--red) !important; border-color: var(--red-line) !important; }
.add-leg-btn { background: rgba(0,200,117,0.12) !important; color: var(--brand) !important; }
.outcome-pill.active-win { background: var(--brand) !important; color: #03200F !important; }
.auth-switch-btn { color: var(--brand) !important; }
.mood-score { color: var(--brand) !important; }
.mindset-score-value { color: var(--brand) !important; }
.pnl-ticket { border-color: rgba(0,200,117,0.30) !important; }
.position-intent.closed { border-color: rgba(0,200,117,0.32) !important; background: rgba(0,200,117,0.08) !important; }
.num-field:focus-within { border-color: var(--brand) !important; }
.input-modern:focus, .auth-input:focus, .search-input:focus, .notes-input:focus, .goal-input:focus { border-color: var(--brand) !important; box-shadow: 0 0 0 3px rgba(0,200,117,0.15) !important; }
.acct-chip .dot { background: var(--brand) !important; }
.cloud-status-dot.online { background: var(--brand) !important; box-shadow: 0 0 8px var(--brand) !important; }
.sidebar.synced .sidebar-account::before { background: var(--brand) !important; box-shadow: 0 0 8px var(--brand) !important; }
.checkbox.on { background: var(--brand) !important; border-color: var(--brand) !important; }
.checkbox.on::after { color: #03200F !important; }
.qty-preset.active, .ticker-chip.selected { background: rgba(0,200,117,0.12) !important; border-color: rgba(0,200,117,0.3) !important; color: var(--brand) !important; }
.tag-chip.on { background: rgba(0,200,117,0.12) !important; border-color: rgba(0,200,117,0.3) !important; color: var(--brand) !important; }
.type-btn.active, .plan-btn.active { background: rgba(0,200,117,0.12) !important; border-color: rgba(0,200,117,0.3) !important; color: var(--brand) !important; }
.acct-chip:focus-within, .dte-pill.active { background: rgba(0,200,117,0.12); border-color: rgba(0,200,117,0.3); color: var(--brand); }
.section-toggle:hover { border-color: var(--brand); }
.ai-insight-card { border-color: rgba(0,200,117,0.28) !important; }
.logo-mark { box-shadow: 0 4px 14px rgba(0,200,117,0.45) !important; }
.btn-primary { box-shadow: 0 5px 16px rgba(0,200,117,0.32) !important; }
.btn-primary:hover { box-shadow: 0 7px 22px rgba(0,200,117,0.45) !important; }
.save-btn { box-shadow: 0 5px 16px rgba(0,200,117,0.35) !important; }
.auth-submit { box-shadow: 0 6px 20px rgba(0,200,117,0.38) !important; }
.fab { box-shadow: 0 10px 28px rgba(0,200,117,0.45) !important; }

/* Richer calendar empty cells — show dates even with no trades */
.cal-cell.flat { background: transparent; border-color: var(--border-c); }
.cal-cell.flat .cal-daynum { color: var(--text-3); }
.cal-cell:not(.empty):hover { background: var(--surface-2) !important; }

/* Sharper trade cards */
.trade-card { border-left: 3px solid transparent; }
.trade-card:hover { border-left-color: var(--border-2); }
.trade-card.win-left { border-left-color: var(--green-line); }

/* Tighter home grid spacing */
.home-grid { gap: 16px; }
.kpi-grid { gap: 10px; }
.kpi { padding: 15px 16px; }

/* Make the modal center-pop instead of bottom-sheet on desktop */
@media (min-width: 921px) {
  .modal-backdrop { align-items: center; }
  .modal-sheet { border-radius: var(--r-xl); max-height: 82vh; }
}
