/* ---------- TIM Portal — Trading Lab Theme ---------- */
:root{
  --bg-0:        #07090f;        /* deepest */
  --bg-1:        #0c111c;        /* page bg */
  --bg-2:        #121826;        /* card */
  --bg-3:        #1a2233;        /* card-hover / subtle */
  --bg-4:        #232c40;        /* input / divider */
  --line:        #1f2738;
  --line-bright: #2b3650;

  --txt-1:       #f1f5fb;        /* primary */
  --txt-2:       #b8c1d4;        /* secondary */
  --txt-3:       #7c8699;        /* tertiary */
  --txt-4:       #515c73;        /* muted */

  --accent:      #3da9ff;        /* TIM blue */
  --accent-2:    #4cc9ff;
  --accent-soft: rgba(61,169,255,.14);

  --green:       #22d39a;
  --green-soft:  rgba(34,211,154,.14);
  --red:         #ff5566;
  --red-soft:    rgba(255,85,102,.14);
  --amber:       #f5b54a;
  --amber-soft:  rgba(245,181,74,.14);
  --violet:      #9d7bff;
  --violet-soft: rgba(157,123,255,.14);

  --radius-s:    8px;
  --radius:      12px;
  --radius-l:    16px;

  --sidebar-w:       250px;
  --sidebar-w-coll:  68px;
  --topbar-h:        58px;

  --shadow-1:    0 2px 12px rgba(0,0,0,.32);
  --shadow-2:    0 8px 32px rgba(0,0,0,.45);

  --font-sans:   "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-mono:   "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg-1);color:var(--txt-1);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-2)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:14px;color:var(--txt-1);background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius-s);padding:8px 12px;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
::placeholder{color:var(--txt-4)}

/* page background — subtle radial grid feel */
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(61,169,255,.06), transparent 60%),
    radial-gradient(900px 500px at -10% 20%, rgba(157,123,255,.05), transparent 60%),
    var(--bg-1);
  min-height:100vh;
}

/* ---------- Layout ---------- */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;transition:grid-template-columns .2s ease}
.app.collapsed{grid-template-columns:var(--sidebar-w-coll) 1fr}
.app.auth-only{display:block;min-height:100vh}
.app.auth-only .sidebar,.app.auth-only .topbar{display:none}
.app.auth-only #page{min-height:100vh}

/* ---------- Sidebar ---------- */
.sidebar{
  background:linear-gradient(180deg, #0a0f1c 0%, #07090f 100%);
  border-right:1px solid var(--line);
  position:sticky;top:0;height:100vh;overflow-y:auto;
  display:flex;flex-direction:column;
  padding:14px 10px 22px;
  scrollbar-width:thin;scrollbar-color:var(--bg-4) transparent;
}
.sidebar::-webkit-scrollbar{width:6px}
.sidebar::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:6px}

.brand{display:flex;align-items:center;gap:10px;padding:8px 8px 14px;border-bottom:1px solid var(--line);margin-bottom:10px}
.brand-logo-shell{
  display:flex;
  align-items:center;
  min-width:0;
  flex:1;
  height:38px;
  overflow:hidden;
}
.brand-logo{
  display:block;
  width:138px;
  max-width:100%;
  height:auto;
  max-height:38px;
  object-fit:contain;
  filter:drop-shadow(0 0 12px rgba(61,169,255,.28));
}
.brand .name{font-weight:700;letter-spacing:.6px;font-size:15px}
.brand .tag{font-size:10px;color:var(--txt-3);letter-spacing:1.2px;text-transform:uppercase}
.collapsed .brand .name,.collapsed .brand .tag,.collapsed .brand .meta{display:none}
.collapsed .brand{
  flex-direction:column;
  gap:6px;
  padding:8px 4px 46px;
  min-height:92px;
  position:relative;
}
.collapsed .brand-logo-shell{
  flex:0 0 30px;
  width:30px;
}
.collapsed .brand-logo{
  width:104px;
  max-width:none;
  transform:translateX(-2px);
}

.nav-section{margin-top:14px}
.nav-section-title{
  font-size:10px;letter-spacing:1.6px;text-transform:uppercase;color:var(--txt-4);
  padding:6px 12px;margin-bottom:4px;
}
.collapsed .nav-section-title{
  text-align:center;letter-spacing:.5px;font-size:9px;
  color:var(--txt-4);padding:8px 0 4px;
}
.collapsed .nav-section-title span{display:none}
.collapsed .nav-section-title::before{content:"·";color:var(--txt-4)}

.nav-item{
  display:flex;align-items:center;gap:11px;
  padding:8px 12px;margin:1px 4px;border-radius:8px;
  color:var(--txt-2);font-size:13.5px;cursor:pointer;
  transition:background .12s ease,color .12s ease;
  position:relative;white-space:nowrap;
}
.nav-item:hover{background:var(--bg-3);color:var(--txt-1)}
.nav-item.active{
  background:linear-gradient(90deg, rgba(61,169,255,.18), rgba(61,169,255,.04));
  color:var(--txt-1);
  box-shadow:inset 2px 0 0 var(--accent);
}
.nav-item .ic{
  width:18px;height:18px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--txt-3);
}
.nav-item.active .ic, .nav-item:hover .ic{color:var(--accent)}
.nav-item .badge{
  margin-left:auto;font-size:10px;padding:2px 6px;border-radius:6px;
  background:var(--bg-4);color:var(--txt-2);font-weight:600;letter-spacing:.4px;
}
.nav-item .badge.soon{background:var(--violet-soft);color:#bca6ff}
.nav-item .badge.live{background:var(--green-soft);color:var(--green)}
.nav-section.soon-section{
  margin-top:auto;
  padding-top:14px;
  border-top:1px solid var(--line);
}
.nav-item.soon-muted{
  color:var(--txt-4);
  opacity:.82;
}
.nav-item.soon-muted .ic{color:var(--txt-4)}
.nav-item.soon-muted.active{opacity:1}
.collapsed .nav-item{justify-content:center;padding:10px 0;margin:1px 6px}
.collapsed .nav-item .label,.collapsed .nav-item .badge{display:none}
.collapsed .nav-item .ic{width:20px;height:20px}

.sidebar-toggle{
  display:flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:7px;background:var(--bg-3);
  color:var(--txt-3);margin-left:auto;
  border:1px solid var(--line);
  position:relative;
  transition:background .14s ease,border-color .14s ease,color .14s ease,box-shadow .14s ease,transform .14s ease;
}
.sidebar-toggle:hover{color:var(--txt-1);background:var(--bg-4)}
.sidebar-toggle .ic{transition:transform .16s ease}
.app:not(.collapsed) .sidebar-toggle .ic{transform:rotate(180deg)}
.collapsed .sidebar-toggle{
  position:fixed;
  top:18px;
  left:48px;
  z-index:80;
  width:38px;
  height:38px;
  margin-left:0;
  border-radius:12px;
  color:var(--txt-1);
  background:linear-gradient(135deg,rgba(61,169,255,.22),rgba(157,123,255,.16));
  border-color:rgba(61,169,255,.62);
  box-shadow:0 12px 34px rgba(0,0,0,.38),0 0 0 1px rgba(255,255,255,.06),0 0 22px rgba(61,169,255,.2);
}
.collapsed .sidebar-toggle:hover{
  color:#fff;
  border-color:rgba(61,169,255,.9);
  background:linear-gradient(135deg,rgba(61,169,255,.32),rgba(157,123,255,.22));
  transform:translateX(1px);
}
.collapsed .sidebar-toggle::after{
  content:"Expand";
  position:absolute;
  left:46px;
  top:50%;
  transform:translateY(-50%);
  pointer-events:none;
  opacity:0;
  white-space:nowrap;
  border:1px solid var(--line-bright);
  border-radius:8px;
  background:var(--bg-2);
  color:var(--txt-1);
  font-size:11px;
  font-weight:700;
  padding:6px 8px;
  box-shadow:0 12px 30px rgba(0,0,0,.32);
  transition:opacity .14s ease;
}
.collapsed .sidebar-toggle:hover::after{opacity:1}

/* ---------- Top bar ---------- */
.topbar{
  position:sticky;top:0;z-index:30;
  height:var(--topbar-h);
  background:rgba(12,17,28,.85);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:12px;padding:8px 22px;
  flex-wrap:nowrap;
  min-width:0;
}
.topbar.live-context{
  background:linear-gradient(90deg, rgba(49,12,18,.92), rgba(12,17,28,.88) 36%, rgba(12,17,28,.9));
  border-bottom-color:rgba(255,85,102,.28);
}
.topbar.paper-context{
  background:linear-gradient(90deg, rgba(10,31,42,.92), rgba(12,17,28,.88) 36%, rgba(12,17,28,.9));
  border-bottom-color:rgba(61,169,255,.24);
}
.topbar .search{
  flex:0 0 420px;max-width:420px;min-width:260px;display:flex;align-items:center;gap:8px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:9px;
  padding:7px 12px;color:var(--txt-3);margin:0;
}
.topbar .search-submit{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--txt-3);padding:0;cursor:pointer}
.topbar .search-submit:hover{color:var(--accent)}
.topbar .search input{background:transparent;border:none;padding:0;flex:1;min-width:0;color:var(--txt-1)}
.topbar .search input:focus{box-shadow:none}
.topbar .search kbd{font-family:var(--font-mono);font-size:11px;color:var(--txt-3);background:var(--bg-3);border:1px solid var(--line);border-radius:5px;padding:1px 6px}
.topbar .right{
  display:flex;align-items:center;justify-content:flex-end;gap:8px;
  flex:1 1 auto;flex-wrap:nowrap;margin-left:auto;min-width:0;
}
.topbar .right > *{flex:0 0 auto}

.status-pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:5px 11px;border-radius:999px;font-size:12px;
  background:var(--bg-2);border:1px solid var(--line);color:var(--txt-2);
  white-space:nowrap;flex:0 0 auto;
}
button.status-pill{cursor:pointer}
button.status-pill:hover{border-color:var(--line-bright);background:var(--bg-3)}
.status-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--txt-3)}
.status-pill.green .dot{background:var(--green);box-shadow:0 0 0 3px var(--green-soft)}
.status-pill.amber .dot{background:var(--amber);box-shadow:0 0 0 3px var(--amber-soft)}
.status-pill.red   .dot{background:var(--red);  box-shadow:0 0 0 3px var(--red-soft)}
.status-pill.blue  .dot{background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.status-pill.grey  .dot{background:var(--txt-4);box-shadow:0 0 0 3px rgba(126,140,166,.12)}
.status-pill.live .dot,.status-pill.loading .dot{animation:livePulse 1.4s ease-in-out infinite}
.status-pill .v{color:var(--txt-1);font-weight:600}
.status-pill .v.mono{font-family:var(--font-mono)}
.status-pill.live-mode{border-color:rgba(255,85,102,.28);background:rgba(255,85,102,.09)}
.status-pill.paper-mode{border-color:rgba(61,169,255,.28);background:rgba(61,169,255,.09)}
.status-pill.broker-health{min-width:128px;justify-content:center}
.broker-view-switcher{
  min-width:260px;
  padding-right:8px;
}
.broker-view-switcher select{
  max-width:132px;
  padding:0 18px 0 0;
  border:0;
  background:transparent;
  color:var(--txt-1);
  font-weight:700;
  outline:0;
  box-shadow:none;
}
.broker-view-switcher select:focus{box-shadow:none}
.broker-view-name{
  color:var(--txt-3);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.broker-view-health{font-size:11px}

.system-menu{position:relative;flex:0 0 auto}
.system-menu summary{list-style:none;cursor:pointer}
.system-menu summary::-webkit-details-marker{display:none}
.system-menu[open] .topbar-system{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.topbar-system .ic{width:13px;height:13px;color:var(--txt-3)}
.topbar-system .system-word{color:var(--txt-2);font-weight:650}
.topbar-system .system-summary{font-size:12px}
.system-dropdown{
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  width:min(460px, calc(100vw - 32px));
  z-index:72;
  background:rgba(12,17,28,.985);
  border:1px solid var(--line-bright);
  border-radius:14px;
  box-shadow:var(--shadow-2);
  padding:14px;
}
.system-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding-bottom:12px;
  border-bottom:1px solid var(--line);
}
.system-head b{display:block;color:var(--txt-1);font-size:14px}
.system-head span:not(.chip){display:block;color:var(--txt-3);font-size:12px;margin-top:2px}
.system-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:12px;
}
.system-field{
  min-width:0;
  display:grid;
  gap:5px;
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,.025);
  padding:10px;
}
.system-field span{
  color:var(--txt-3);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.09em;
}
.system-field b{
  color:var(--txt-1);
  font-size:12.5px;
  line-height:1.25;
}
.system-field b.green{color:var(--green)}
.system-field b.amber{color:var(--amber)}
.system-field b.red{color:var(--red)}
.system-field b.grey{color:var(--txt-3)}
.system-field select{
  width:100%;
  min-width:0;
  background:var(--bg-3);
  border:1px solid var(--line);
  color:var(--txt-1);
  border-radius:8px;
  padding:7px 9px;
}
.system-explain{
  margin-top:10px;
  display:grid;
  gap:3px;
  color:var(--txt-3);
  font-size:12px;
  line-height:1.45;
}
.system-explain b{color:var(--txt-1);font-size:12.5px}
.system-actions{
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid var(--line);
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

@media (max-width:1500px){
  .topbar-stream{padding-inline:10px}
}
@media (max-width:1400px){
  .topbar .search{flex-basis:360px;max-width:360px}
}
@media (max-width:1320px){
  .topbar-equity{display:none}
}
@media (max-width:1220px){
  .topbar{gap:8px;padding-left:14px;padding-right:14px}
  .status-pill{padding:5px 9px}
  .topbar .search{flex-basis:300px;max-width:300px}
}
@media (max-width:1080px){
  .topbar .search{flex-basis:220px;max-width:220px;min-width:180px}
  .topbar .search kbd{display:none}
  .status-pill.broker-health{min-width:112px}
  .topbar-stream{display:none}
}
@media (max-width:920px){
  .topbar-today{display:none}
  .topbar .search{flex-basis:180px;max-width:180px}
  .topbar-system .system-summary{display:none}
}
@media (max-width:680px){
  .system-grid{grid-template-columns:1fr}
}

.avatar{
  width:34px;height:34px;border-radius:50%;background:var(--bg-3);
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;color:var(--txt-1);
  border:1px solid var(--line-bright);overflow:hidden;
}
.profile-menu{position:relative;flex:0 0 auto}
.profile-menu summary{list-style:none;cursor:pointer}
.profile-menu summary::-webkit-details-marker{display:none}
.profile-menu[open] .avatar{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.profile-dropdown{
  position:absolute;right:0;top:calc(100% + 10px);min-width:230px;z-index:60;
  background:rgba(12,17,28,.98);border:1px solid var(--line-bright);border-radius:12px;
  box-shadow:var(--shadow-2);padding:10px;
}
.profile-name{font-weight:700;color:var(--txt-1);font-size:13px;padding:4px 6px 0}
.profile-email{font-family:var(--font-mono);font-size:11px;color:var(--txt-3);padding:2px 6px 10px;border-bottom:1px solid var(--line);margin-bottom:6px;word-break:break-all}
.profile-menu-item{
  display:flex;align-items:center;width:100%;padding:8px 7px;border-radius:8px;
  color:var(--txt-2);font-size:13px;text-align:left;background:transparent;
}
.profile-menu-item:hover{background:var(--bg-3);color:var(--txt-1)}
.profile-menu-item.signout{color:#ffadb6}
.profile-menu-item.signout:hover{background:var(--red-soft);color:#ffd8dc}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar.sm{width:26px;height:26px;font-size:11px}
.avatar.lg{width:54px;height:54px;font-size:18px}
.avatar.xl{width:88px;height:88px;font-size:24px}

/* ---------- Main / Page ---------- */
.main{display:flex;flex-direction:column;min-width:0}
.page{padding:22px 28px 60px;max-width:1480px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.page-title{font-size:30px;font-weight:800;letter-spacing:0;margin:0;color:var(--txt-1)}
.page-sub{color:var(--txt-3);font-size:13px;margin-top:4px}
.page-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:9px;font-size:13px;font-weight:600;
  background:var(--bg-3);color:var(--txt-1);border:1px solid var(--line);
  transition:background .12s,border-color .12s,transform .1s;
}
.btn:hover{background:var(--bg-4);border-color:var(--line-bright)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:linear-gradient(180deg,#3da9ff,#1f7ed1);border-color:#3da9ff;color:#fff;box-shadow:0 8px 22px -10px rgba(61,169,255,.7)}
.btn.primary:hover{filter:brightness(1.08)}
.btn.success{background:linear-gradient(180deg,#22d39a,#13a576);border-color:#22d39a;color:#03110b}
.btn.danger{background:linear-gradient(180deg,#ff5566,#cb2c3c);border-color:#ff5566;color:#fff}
.btn.danger-outline{background:transparent;border-color:rgba(255,85,102,.45);color:#ffadb6}
.btn.danger-outline:hover{background:var(--red-soft);border-color:rgba(255,85,102,.65);color:#ffd8dc}
.btn.ghost{background:transparent}
.btn.sm{padding:5px 10px;font-size:12px;border-radius:7px}
.btn.lg{padding:10px 18px;font-size:14px}
.btn .ic{width:14px;height:14px}
.btn.icon{padding:7px 9px}
.btn.loading .ic{animation:liveSpin 1.2s linear infinite}
.topbar-notifications{position:relative;flex:0 0 auto}
.notification-menu{position:relative;flex:0 0 auto}
.notification-menu summary{list-style:none;cursor:pointer}
.notification-menu summary::-webkit-details-marker{display:none}
.topbar-notifications.is-muted{opacity:.48}
.topbar-notifications.has-alerts{opacity:1;border-color:rgba(245,181,74,.34);color:var(--amber)}
.notification-dot{
  position:absolute;right:2px;top:2px;min-width:14px;height:14px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--amber);color:#080a10;font-size:9px;font-weight:800;line-height:1;
  box-shadow:0 0 0 2px var(--bg-1);
}
.btn.control-btn.pause{
  background:transparent;
  border-color:var(--line-bright);
  color:var(--txt-2);
}
.btn.control-btn.pause:hover{background:var(--bg-3);color:var(--txt-1)}
.btn.control-btn.resume{
  background:transparent;
  border-color:rgba(39,222,148,.36);
  color:#9dffd7;
}
.btn.control-btn.resume:hover{background:var(--green-soft);border-color:rgba(39,222,148,.55)}
.btn.control-btn.halted{
  background:linear-gradient(180deg,rgba(255,85,102,.22),rgba(255,85,102,.10));
  border-color:rgba(255,85,102,.42);
  color:#ffd2d7;
}
.notification-dropdown{
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  width:min(420px, calc(100vw - 32px));
  z-index:70;
  background:rgba(12,17,28,.98);
  border:1px solid var(--line-bright);
  border-radius:14px;
  box-shadow:var(--shadow-2);
  padding:12px;
}
.notification-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:2px 2px 10px;
  border-bottom:1px solid var(--line);
}
.notification-head b{display:block;color:var(--txt-1);font-size:13px}
.notification-head span{display:block;color:var(--txt-3);font-size:12px;margin-top:2px}
.notification-list{display:grid;gap:8px;margin-top:10px}
.notification-play{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,.025);
  padding:10px;
}
.notification-play b{display:block;font-family:var(--font-mono);font-size:13px;color:var(--txt-1)}
.notification-play span{display:block;color:var(--txt-3);font-size:12px;margin-top:2px}
.notification-play-side{display:flex;align-items:center;gap:8px;flex-shrink:0}
.notification-play-side .chip{
  display:inline-flex;
  margin-top:0;
}
.notification-foot{
  display:block;
  margin-top:10px;
  padding:9px 10px;
  border-radius:9px;
  color:var(--accent);
  text-align:center;
  background:var(--accent-soft);
}
.notification-empty{padding:16px 6px 4px;color:var(--txt-3);font-size:13px}
.link-btn{
  background:transparent;
  border:none;
  color:var(--accent);
  padding:0;
  font:inherit;
  cursor:pointer;
}
.link-btn:hover{color:var(--txt-1)}

.control-modal-backdrop{
  position:fixed;
  inset:0;
  z-index:80;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(4,7,12,.64);
  backdrop-filter:blur(8px);
}
.control-modal{
  width:min(440px,100%);
  border:1px solid var(--line-bright);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(18,24,38,.98),rgba(9,13,22,.98));
  box-shadow:var(--shadow-2);
  padding:20px;
}
.control-modal-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:12px;
}
.control-modal h2{margin:0 0 8px;font-size:22px;letter-spacing:0;color:var(--txt-1)}
.control-modal p{margin:0;color:var(--txt-2);line-height:1.6}
.control-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}
.setup-approval-modal{width:min(720px,100%)}
.setup-approval-title{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
}
.setup-approval-title p{margin-top:8px}
.setup-approval-score{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:6px;
  flex-shrink:0;
}
.approval-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:18px 0;
}
.approval-grid div{
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,.025);
  padding:10px;
}
.approval-grid span,.approval-broker-row label>span{
  display:block;
  color:var(--txt-4);
  font-size:10px;
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-bottom:5px;
}
.approval-grid b{
  display:block;
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-variant-numeric:tabular-nums;
  overflow:hidden;
  text-overflow:ellipsis;
}
.approval-section{
  border-top:1px solid var(--line);
  padding-top:12px;
  margin-top:12px;
}
.approval-section h3{margin:0 0 8px;font-size:13px;color:var(--txt-1)}
.approval-section ul{margin:0;padding-left:18px;color:var(--txt-2);line-height:1.55}
.approval-section.warning{color:var(--amber)}
.approval-broker-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  margin-top:16px;
}
.approval-broker-row label{display:grid;gap:6px;flex:1}
.approval-broker-row select{
  width:100%;
  background:var(--bg-3);
  border:1px solid var(--line);
  color:var(--txt-1);
  border-radius:9px;
  padding:9px 10px;
}
.approval-mode{
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.approval-mode.live{color:#ffadb6;border-color:rgba(255,85,102,.38);background:var(--red-soft)}
.approval-mode.paper{color:var(--accent);border-color:rgba(61,169,255,.38);background:var(--accent-soft)}
.approval-risk-line{
  margin-top:12px;
  color:var(--txt-3);
  font-size:12px;
  line-height:1.45;
}
.toast-stack{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:90;
  display:grid;
  gap:10px;
  width:min(360px, calc(100vw - 32px));
}
.toast{
  text-align:left;
  border:1px solid rgba(61,169,255,.32);
  border-radius:12px;
  background:linear-gradient(180deg,rgba(18,24,38,.98),rgba(10,15,25,.98));
  box-shadow:var(--shadow-2);
  padding:12px 14px;
  color:var(--txt-1);
}
.toast b{display:block;font-size:13px;margin-bottom:3px}
.toast span{display:block;color:var(--txt-3);font-size:12px;line-height:1.45}

@keyframes livePulse{
  0%,100%{transform:scale(1);opacity:.75}
  50%{transform:scale(1.35);opacity:1}
}

@keyframes liveSpin{
  to{transform:rotate(360deg)}
}

/* ---------- Cards ---------- */
.card{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;position:relative;min-width:0;overflow-x:auto;
}
.card.tight{padding:14px}
.card.dark{background:var(--bg-1)}
.card.glow{
  background:
    radial-gradient(800px 200px at 0% 0%, rgba(61,169,255,.08), transparent 60%),
    var(--bg-2);
  border:1px solid rgba(61,169,255,.22);
}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.card-title{font-size:14px;font-weight:750;color:var(--txt-1);margin:0;letter-spacing:0;display:flex;align-items:center;gap:8px}
.card-title .ic{width:14px;height:14px;color:var(--accent)}
.card-foot{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px}

.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}
.span-3{grid-column:span 3}
.span-4{grid-column:span 4}
.span-5{grid-column:span 5}
.span-6{grid-column:span 6}
.span-7{grid-column:span 7}
.span-8{grid-column:span 8}
.span-9{grid-column:span 9}
.span-12{grid-column:span 12}

@media (max-width:1280px){
  .cols-3,.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .span-3,.span-4{grid-column:span 6}
  .span-5,.span-7{grid-column:span 6}
  .span-8,.span-9{grid-column:span 12}
}
@media (max-width:880px){
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  .span-3,.span-4,.span-5,.span-6,.span-7,.span-8,.span-9{grid-column:span 12}
  .page{padding:16px}
}

/* ---------- Stats ---------- */
.kpi{display:flex;flex-direction:column;gap:4px}
.kpi .label{color:var(--txt-3);font-size:10.5px;text-transform:uppercase;letter-spacing:1px;font-weight:700}
.kpi .value{font-family:var(--font-mono);font-size:24px;font-weight:750;color:var(--txt-1);letter-spacing:0}
.kpi .value.small{font-size:18px;font-family:var(--font-sans)}
.kpi .delta{font-size:12px;color:var(--txt-3);font-family:var(--font-mono)}
.kpi .delta.up{color:var(--green)}
.kpi .delta.dn{color:var(--red)}
.mono,.tbl .num,.kpi .value,.kpi .delta,.setup-grid b,.dashboard-status-strip b{
  font-variant-numeric:tabular-nums;
}

.strategy-toolbar{
  justify-content:flex-end;
  gap:8px;
}
.strategy-table th:first-child,
.strategy-table td:first-child{
  width:54px;
  text-align:center;
}
.strategy-check{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:10px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  cursor:pointer;
  transition:background .16s ease,border-color .16s ease,box-shadow .16s ease;
}
.strategy-check input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.strategy-check span{
  width:16px;
  height:16px;
  border-radius:5px;
  border:1px solid var(--line-bright);
  background:rgba(4,9,18,.65);
  position:relative;
}
.strategy-check span::after{
  content:"";
  position:absolute;
  left:4px;
  top:1px;
  width:5px;
  height:9px;
  border-right:2px solid var(--bg-0);
  border-bottom:2px solid var(--bg-0);
  transform:rotate(45deg) scale(.8);
  opacity:0;
}
.strategy-check:has(input:checked){
  border-color:rgba(112,240,218,.54);
  background:rgba(112,240,218,.08);
  box-shadow:0 0 0 3px rgba(112,240,218,.05);
}
.strategy-check input:checked + span{
  border-color:var(--accent);
  background:var(--accent);
}
.strategy-check input:checked + span::after{
  opacity:1;
}
.strategy-check:hover{
  border-color:var(--line-bright);
  background:rgba(255,255,255,.05);
}

.dashboard-focus{
  display:grid;
  gap:26px;
}
.dashboard-alert-strip{
  display:grid;
  gap:10px;
}
.dashboard-alert{
  display:flex;
  align-items:center;
  gap:12px;
  border:1px solid var(--line);
  border-left:4px solid var(--amber);
  border-radius:12px;
  padding:12px 14px;
  background:rgba(250,204,21,.06);
  color:var(--txt-2);
}
.dashboard-alert.red{
  border-left-color:var(--red);
  background:rgba(255,95,109,.07);
}
.dashboard-alert b{
  color:var(--txt-1);
  font-size:13px;
  white-space:nowrap;
}
.dashboard-alert span{
  font-size:13px;
}
.dashboard-status-strip{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:18px 32px;
  padding:2px 0;
  color:var(--txt-2);
  font-size:14px;
}
.dashboard-status-strip span{
  display:inline-flex;
  align-items:baseline;
  gap:7px;
}
.dashboard-status-strip b{
  font-family:var(--font-mono);
  color:var(--txt-1);
  font-weight:700;
  letter-spacing:0;
}
.dashboard-briefing{
  background:
    radial-gradient(700px 240px at 0% 0%, rgba(61,169,255,.20), transparent 68%),
    linear-gradient(135deg,var(--accent-soft),var(--bg-2) 58%,var(--bg-2));
  border-left:4px solid var(--accent);
  padding:32px;
  box-shadow:0 22px 70px -54px rgba(61,169,255,.72);
}
.dashboard-briefing .photo{
  width:96px;
  height:96px;
}
.dashboard-briefing-copy{
  flex:1;
  min-width:0;
}
.dashboard-briefing h3{
  display:flex;
  align-items:baseline;
  gap:10px;
}
.dashboard-briefing p{
  font-size:16px;
  line-height:1.68;
  max-width:1180px;
}
.briefing-factors{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:20px;
}
.briefing-factors div{
  min-width:0;
  border:1px solid rgba(255,255,255,.07);
  border-radius:12px;
  background:rgba(4,9,18,.28);
  padding:12px;
}
.briefing-factors span{
  display:block;
  color:var(--txt-4);
  font-size:10px;
  font-weight:750;
  letter-spacing:1.1px;
  text-transform:uppercase;
  margin-bottom:6px;
}
.briefing-factors b{
  display:block;
  color:var(--txt-1);
  font-size:13px;
  line-height:1.45;
  white-space:normal;
}
.dashboard-briefing .ts{
  margin-top:18px;
  color:var(--txt-4);
}
.dashboard-panel{
  padding:20px;
}
.dashboard-below-fold{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:18px;
}
.mover-list{
  display:grid;
  gap:8px;
}
.mover-row{
  width:100%;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  align-items:center;
  gap:12px;
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px 12px;
  background:rgba(255,255,255,.018);
  color:var(--txt-1);
  text-align:left;
  cursor:pointer;
}
.mover-row:hover{
  background:rgba(61,169,255,.06);
  border-color:rgba(61,169,255,.28);
}
.mover-row span:first-child{
  min-width:0;
}
.mover-row b{
  display:block;
  font-family:var(--font-mono);
  font-size:14px;
}
.mover-row small{
  display:block;
  color:var(--txt-4);
  margin-top:2px;
}

/* ---------- Markets ---------- */
.markets-page{
  display:grid;
  gap:20px;
}
.markets-hero{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr);
  gap:20px;
  align-items:stretch;
  background:
    radial-gradient(720px 220px at 0% 0%, rgba(61,169,255,.11), transparent 65%),
    linear-gradient(135deg,var(--bg-2),var(--bg-1));
}
.markets-search-panel{
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-width:0;
}
.markets-search-panel h2{
  margin:5px 0 14px;
  color:var(--txt-1);
  font-size:24px;
  line-height:1.15;
  letter-spacing:0;
}
.market-search-form{
  display:flex;
  gap:10px;
  align-items:center;
  max-width:680px;
}
.market-search-form input{
  flex:1;
  min-width:0;
  height:42px;
  font-family:var(--font-mono);
  font-size:14px;
}
.market-search-hints{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.market-search-hints a{
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  color:var(--txt-2);
  text-decoration:none;
  font-family:var(--font-mono);
  font-size:12px;
}
.market-search-hints a:hover{
  border-color:var(--line-bright);
  color:var(--accent);
}
.market-summary-strip{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.market-summary-strip div{
  border:1px solid rgba(255,255,255,.07);
  border-radius:10px;
  background:rgba(255,255,255,.025);
  padding:12px;
}
.market-summary-strip span{
  display:block;
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.85px;
}
.market-summary-strip b{
  display:block;
  margin-top:5px;
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-size:20px;
  font-variant-numeric:tabular-nums;
}
.market-focus-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:10px;
}
.market-focus-tile{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-width:0;
  border:1px solid var(--line);
  border-radius:12px;
  background:rgba(255,255,255,.022);
  padding:12px;
  color:var(--txt-1);
  text-decoration:none;
}
.market-focus-tile:hover,
.market-mini-row:hover{
  border-color:rgba(61,169,255,.32);
  background:rgba(61,169,255,.055);
}
.market-focus-tile b{
  display:block;
  font-family:var(--font-mono);
  font-size:15px;
}
.market-focus-tile span{
  display:block;
  margin-top:3px;
  color:var(--txt-4);
  font-size:11px;
  line-height:1.35;
}
.market-focus-price{
  display:grid;
  justify-items:end;
  gap:4px;
  flex:0 0 auto;
}
.market-focus-price strong{
  color:var(--txt-1);
  font-size:13px;
}
.market-focus-price em{
  font-style:normal;
  font-family:var(--font-mono);
  font-size:12px;
}
.market-mover-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.market-mover-card{
  display:grid;
  align-content:start;
  gap:8px;
}
.market-mini-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  align-items:center;
  gap:10px;
  border:1px solid var(--line);
  border-radius:10px;
  padding:9px 10px;
  color:var(--txt-1);
  text-decoration:none;
}
.market-mini-row b{
  display:block;
  font-family:var(--font-mono);
  font-size:13px;
}
.market-mini-row small{
  display:block;
  color:var(--txt-4);
  margin-top:2px;
  text-transform:capitalize;
}
.market-section-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.market-symbol-link{
  display:inline-grid;
  gap:2px;
  color:var(--txt-1);
  text-decoration:none;
}
.market-symbol-link b{
  font-family:var(--font-mono);
  font-size:13px;
}
.market-symbol-link span{
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.65px;
}
.market-symbol-link:hover b{
  color:var(--accent);
}
.table-scroll{
  overflow-x:auto;
}
.market-table{
  min-width:760px;
}
.market-table-card{
  overflow-x:hidden;
}
.dashboard-performance-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.mini-chart-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:var(--txt-3);
  font-size:12px;
  margin-bottom:12px;
}
.mini-chart-head b{
  font-family:var(--font-mono);
}
.mini-pnl-chart{
  display:flex;
  align-items:end;
  gap:8px;
  height:92px;
  padding:10px 8px 0;
  border:1px solid var(--line);
  border-radius:12px;
  background:rgba(255,255,255,.018);
}
.mini-pnl-bar-col{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
}
.mini-pnl-bar{
  width:100%;
  max-width:22px;
  border-radius:999px 999px 0 0;
  background:var(--green);
  box-shadow:0 0 16px rgba(39,222,148,.18);
}
.mini-pnl-bar.down{
  background:var(--red);
  box-shadow:0 0 16px rgba(255,95,109,.16);
}
.mini-pnl-bar-col span{
  color:var(--txt-4);
  font-size:10px;
}
.mini-chart-empty{
  min-height:92px;
  display:grid;
  place-items:center;
  border:1px solid var(--line);
  border-radius:12px;
  color:var(--txt-4);
  font-size:12px;
  text-align:center;
  padding:12px;
}
.dashboard-position-table td,
.dashboard-position-table th{
  white-space:nowrap;
}

.hero-metrics{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.hero-kpi{
  min-height:126px;
  display:flex;
  align-items:center;
  background:
    radial-gradient(360px 140px at 0% 0%, rgba(61,169,255,.12), transparent 68%),
    linear-gradient(180deg,rgba(20,27,44,.98),rgba(12,17,28,.98));
  border-color:rgba(61,169,255,.20);
}
.hero-kpi .kpi .value{font-size:36px}
.kpi-more{
  margin-top:12px;
}
.kpi-more summary{
  cursor:pointer;
  color:var(--txt-3);
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  margin-bottom:12px;
}
.kpi-more[open] summary{color:var(--accent)}

@media (max-width:980px){
  .hero-metrics{grid-template-columns:1fr}
  .dashboard-below-fold,
  .dashboard-performance-grid,
  .briefing-factors{grid-template-columns:1fr}
  .dashboard-briefing{padding:24px}
  .dashboard-alert{align-items:flex-start;flex-direction:column;gap:4px}
}

/* ---------- TIM Operations ---------- */
.operations-page{
  display:grid;
  gap:22px;
}
.operations-hero{
  display:flex;
  justify-content:space-between;
  gap:22px;
  align-items:flex-start;
  overflow:hidden;
  background:
    radial-gradient(760px 260px at 0% 0%, rgba(61,169,255,.16), transparent 68%),
    linear-gradient(135deg,rgba(61,169,255,.08),var(--bg-2) 62%);
}
.operations-hero.green{border-color:rgba(34,211,154,.25)}
.operations-hero.amber{border-color:rgba(250,204,21,.28)}
.operations-hero.red{border-color:rgba(255,85,102,.32)}
.operations-kicker{
  color:var(--txt-4);
  font-size:11px;
  font-weight:800;
  letter-spacing:2px;
}
.operations-hero h1{
  margin:8px 0 8px;
  font-size:34px;
  letter-spacing:0;
}
.operations-hero p{
  margin:0;
  max-width:780px;
  color:var(--txt-2);
  font-size:15px;
  line-height:1.6;
}
.operations-hero-line{
  display:flex;
  flex-wrap:wrap;
  gap:12px 24px;
  margin-top:18px;
  color:var(--txt-3);
}
.operations-hero-line b{
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-variant-numeric:tabular-nums;
  margin-right:5px;
}
.operations-status-stack{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:8px;
  min-width:180px;
}
.operations-cycle{
  color:var(--txt-4);
  font-size:12px;
}
.operations-metrics{
  gap:12px;
}
.operations-metric{
  overflow:hidden;
}
.operations-metric-top{
  display:flex;
  justify-content:space-between;
  gap:10px;
  color:var(--txt-3);
  font-size:10.5px;
  text-transform:uppercase;
  letter-spacing:1px;
  font-weight:800;
}
.operations-metric > b{
  display:block;
  margin-top:10px;
  color:var(--txt-1);
  font-size:28px;
  letter-spacing:0;
  font-variant-numeric:tabular-nums;
}
.operations-metric p{
  margin:4px 0 0;
  color:var(--txt-3);
  font-size:12px;
  line-height:1.45;
}
.operations-panel{
  min-width:0;
}
.operations-reasons{
  display:grid;
  gap:10px;
}
.operations-reason{
  display:grid;
  grid-template-columns:54px 1fr;
  gap:12px;
  padding:13px;
  border:1px solid var(--line);
  border-left:3px solid var(--txt-4);
  border-radius:12px;
  background:rgba(255,255,255,.018);
}
.operations-reason.green{border-left-color:var(--green)}
.operations-reason.blue{border-left-color:var(--accent)}
.operations-reason.amber{border-left-color:var(--amber)}
.operations-reason.red{border-left-color:var(--red)}
.operations-reason.grey{border-left-color:var(--txt-4)}
.operations-reason-count{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:12px;
  background:var(--bg-3);
  color:var(--txt-1);
  font-weight:800;
  font-variant-numeric:tabular-nums;
}
.operations-reason-title{
  display:flex;
  justify-content:space-between;
  gap:10px;
  margin-bottom:5px;
}
.operations-reason-title b{
  color:var(--txt-1);
}
.operations-reason-title span{
  color:var(--txt-4);
  font-family:var(--font-mono);
  font-size:11px;
}
.operations-reason p{
  margin:0;
  color:var(--txt-3);
  font-size:12.5px;
  line-height:1.45;
}
.operations-reason ul{
  margin:8px 0 0;
  padding-left:17px;
  color:var(--txt-2);
  font-size:12px;
  line-height:1.5;
}
.operations-funnel{
  display:grid;
  gap:13px;
}
.operations-funnel-row{
  display:grid;
  grid-template-columns:126px 1fr 52px;
  align-items:center;
  gap:10px;
  color:var(--txt-3);
  font-size:12px;
}
.operations-funnel-row div{
  height:8px;
  border-radius:999px;
  background:var(--bg-3);
  overflow:hidden;
}
.operations-funnel-row i{
  display:block;
  height:100%;
  border-radius:999px;
  background:var(--accent);
}
.operations-funnel-row i.green{background:var(--green)}
.operations-funnel-row i.amber{background:var(--amber)}
.operations-funnel-row i.grey{background:var(--txt-4)}
.operations-funnel-row b{
  color:var(--txt-1);
  text-align:right;
  font-variant-numeric:tabular-nums;
}
.operations-table{
  min-width:0;
}
.operations-budget-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.operations-budget-item{
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px;
  background:rgba(255,255,255,.018);
  min-width:0;
}
.operations-budget-item span{
  display:block;
  color:var(--txt-4);
  font-size:10px;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
}
.operations-budget-item b{
  display:block;
  margin-top:6px;
  color:var(--txt-1);
  font-size:17px;
  font-variant-numeric:tabular-nums;
}
.operations-budget-item b.green{color:var(--green)}
.operations-budget-item b.amber{color:var(--amber)}
.operations-budget-item b.red{color:var(--red)}
.operations-budget-item small{
  display:block;
  margin-top:4px;
  color:var(--txt-3);
  line-height:1.45;
}

@media (max-width:1180px){
  .operations-hero{flex-direction:column}
  .operations-status-stack{align-items:flex-start}
  .operations-budget-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* ---------- Tables ---------- */
.tbl{width:100%;min-width:640px;border-collapse:collapse;font-size:13px}
.tbl.mini{min-width:0}
.dashboard-position-table{min-width:560px}
.tbl thead th{
  text-align:left;font-weight:600;font-size:11px;color:var(--txt-3);
  text-transform:uppercase;letter-spacing:1.1px;
  padding:10px 12px;border-bottom:1px solid var(--line);
}
.tbl tbody td{padding:11px 12px;border-bottom:1px solid var(--line);color:var(--txt-1)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr:hover{background:var(--bg-3)}
.tbl .num{font-family:var(--font-mono);text-align:right}
.tbl .green{color:var(--green)}
.tbl .red{color:var(--red)}
.tbl .muted{color:var(--txt-3)}
.tbl.mini{font-size:11.5px}
.tbl.mini thead th{font-size:9.5px;padding:7px 8px}
.tbl.mini tbody td{padding:7px 8px}
.journal-ledger-card{
  overflow:hidden;
}
.journal-ledger-table{
  min-width:1080px;
}
.journal-ledger-row td{
  vertical-align:middle;
}
.journal-expand-toggle{
  width:30px;
  height:30px;
  display:inline-grid;
  place-items:center;
  border:1px solid rgba(114,138,170,.26);
  border-radius:6px;
  background:rgba(255,255,255,.035);
  color:var(--txt-3);
  transition:transform .16s ease,border-color .16s ease,color .16s ease;
}
.journal-expand-toggle svg{
  width:14px;
  height:14px;
  transform:rotate(90deg);
  transition:transform .16s ease;
}
.journal-expand-toggle.open{
  color:var(--accent);
  border-color:rgba(61,169,255,.5);
}
.journal-expand-toggle.open svg{
  transform:rotate(270deg);
}
.journal-detail-row[hidden]{
  display:none;
}
.journal-detail-row td{
  background:rgba(4,9,18,.45);
  border-top:1px solid rgba(61,169,255,.18);
  padding:16px;
}
.journal-detail-grid{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:12px;
}
.journal-detail-panel{
  grid-column:span 4;
  min-width:0;
}
.journal-detail-panel.span-6{
  grid-column:span 6;
}
.journal-detail-wide{
  grid-column:1/-1;
}
.journal-detail-panel > b{
  display:block;
  margin-bottom:8px;
  color:var(--txt-2);
  font-size:12px;
}
@media (max-width:900px){
  .journal-detail-panel,
  .journal-detail-panel.span-6{
    grid-column:1/-1;
  }
}
.tight-grid{gap:12px}

.position-mode-toggle{
  display:inline-grid;
  grid-template-columns:1fr 1fr;
  gap:4px;
  min-width:176px;
  padding:4px;
  border:1px solid var(--line);
  border-radius:9px;
  background:rgba(7,9,15,.72);
}
.position-mode-btn{
  min-height:28px;
  padding:0 8px;
  border:1px solid transparent;
  border-radius:7px;
  color:var(--txt-3);
  font-size:10px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.position-mode-btn:hover{
  color:var(--txt-1);
  border-color:var(--line-bright);
}
.position-mode-btn.active{
  color:var(--accent);
  border-color:rgba(61,169,255,.38);
  background:var(--accent-soft);
}
.position-mode-btn.long.active{
  color:var(--amber);
  border-color:rgba(245,181,74,.38);
  background:var(--amber-soft);
}
.position-mode-badge{
  min-height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 8px;
  border:1px solid var(--line-bright);
  border-radius:7px;
  color:var(--txt-2);
  font-size:10px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  white-space:nowrap;
}
.position-mode-badge.managed{
  color:var(--green);
  border-color:rgba(34,211,154,.34);
  background:var(--green-soft);
}
.position-mode-note{
  margin:0 0 14px;
  padding:12px 14px;
  border:1px solid rgba(61,169,255,.22);
  border-radius:var(--radius);
  background:rgba(61,169,255,.06);
  color:var(--txt-2);
}
.position-status{
  margin:0 0 14px;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:var(--radius-s);
  color:var(--txt-2);
  background:var(--bg-1);
}
.position-status.ok{
  color:var(--green);
  border-color:rgba(34,211,154,.28);
  background:var(--green-soft);
}
.position-status.error{
  color:var(--red);
  border-color:rgba(255,85,102,.28);
  background:var(--red-soft);
}
.position-handling{
  max-width:320px;
  color:var(--txt-3);
  line-height:1.45;
}

/* ---------- Badges / chips ---------- */
.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;
  background:var(--bg-3);color:var(--txt-2);border:1px solid var(--line);
  letter-spacing:.2px;
}
.chip.green{background:var(--green-soft);color:var(--green);border-color:transparent}
.chip.red{background:var(--red-soft);color:var(--red);border-color:transparent}
.chip.amber{background:var(--amber-soft);color:var(--amber);border-color:transparent}
.chip.blue{background:var(--accent-soft);color:var(--accent);border-color:transparent}
.chip.violet{background:var(--violet-soft);color:#bca6ff;border-color:transparent}
.chip.grey{background:rgba(126,140,166,.12);color:var(--txt-3);border-color:transparent}
.chip.dot::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}

/* ---------- Toggle / switch ---------- */
.switch{
  position:relative;width:38px;height:22px;background:var(--bg-4);
  border-radius:999px;cursor:pointer;transition:background .15s;flex-shrink:0;
  border:1px solid var(--line);
}
.switch::after{
  content:"";position:absolute;top:2px;left:2px;
  width:16px;height:16px;background:#fff;border-radius:50%;
  transition:left .15s, background .15s;
  box-shadow:0 1px 3px rgba(0,0,0,.4);
}
.switch.on{background:linear-gradient(180deg,#3da9ff,#1f7ed1);border-color:#3da9ff}
.switch.on::after{left:18px}
.switch.danger.on{background:linear-gradient(180deg,#ff5566,#cb2c3c);border-color:#ff5566}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.field label{font-size:12px;color:var(--txt-3);font-weight:600;letter-spacing:.2px}
.field-inline{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
.field-inline:last-child{border-bottom:none}
.field-inline .l{display:flex;flex-direction:column;gap:2px}
.field-inline .l b{font-size:13px;color:var(--txt-1);font-weight:600}
.field-inline .l span{font-size:12px;color:var(--txt-3)}

/* ---------- Mode pill / mode picker ---------- */
.mode-picker{display:inline-flex;background:var(--bg-3);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}
.mode-picker .opt{padding:5px 11px;border-radius:7px;font-size:12px;color:var(--txt-3);font-weight:600;cursor:pointer}
.mode-picker .opt.active{background:var(--accent);color:#03111f}
.mode-picker .opt:hover:not(.active){color:var(--txt-1)}

/* ---------- Sparklines / Chart canvas ---------- */
.spark{width:100%;height:38px}
.chart-area{
  width:100%;height:340px;border-radius:var(--radius-s);
  background:
    linear-gradient(180deg,#0e1422 0%,#0a0f1c 100%);
  border:1px solid var(--line);
  position:relative;overflow:hidden;
}
.chart-area .label{
  position:absolute;font-size:11px;font-family:var(--font-mono);
  background:rgba(12,17,28,.8);padding:3px 7px;border-radius:6px;
  border:1px solid var(--line-bright);color:var(--txt-1);
}

/* ---------- Character cards ---------- */
.team-brief{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-bottom:18px;
}
.team-brief>div{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(61,169,255,.08),rgba(18,24,38,.72));
  padding:14px 16px;
}
.team-brief b{display:block;font-size:13px;margin-bottom:4px;color:var(--txt-1)}
.team-brief span{display:block;color:var(--txt-3);font-size:12.5px;line-height:1.6}
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.char-card{
  background:linear-gradient(180deg,#141b2c,#0e1422);
  border:1px solid var(--line);border-radius:var(--radius-l);
  padding:0;overflow:hidden;display:flex;flex-direction:column;
  transition:border-color .15s, transform .15s;
}
.char-card:hover{border-color:var(--line-bright);transform:translateY(-2px)}
.char-card.team-card{border-color:color-mix(in srgb, var(--team-accent, var(--line-bright)) 28%, var(--line))}
.char-card .photo{
  height:220px;
  background-color:var(--bg-3);
  background-position:center top;
  background-size:cover;
  background-repeat:no-repeat;
  position:relative;
}
.char-card .photo.team-photo-mark{background-position:center 18%}
.char-card .photo.team-photo-curry{background-position:center 8%}
.char-card .photo.team-photo-liam{background-position:center 18%}
.char-card .photo.team-photo-ben{background-position:center 18%}
.char-card .photo.team-photo-cleo{background-position:center 16%}
.char-card .photo.tim-photo{
  height:320px;
  background-position:center top;
}
.char-card .photo.no-photo{
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 50% 30%, color-mix(in srgb, var(--team-accent, var(--accent)) 30%, transparent), transparent 60%),
    var(--bg-3);
}
.photo-initial{
  position:relative;z-index:2;
  width:82px;height:82px;border-radius:20px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);
  border:1px solid color-mix(in srgb, var(--team-accent, var(--accent)) 38%, var(--line));
  color:var(--team-accent, var(--accent));
  font-size:34px;font-weight:800;letter-spacing:.08em;
  box-shadow:0 16px 42px rgba(0,0,0,.32);
}
.char-card .photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%, rgba(14,20,34,.95));
}
.char-card .photo .ribbon{
  position:absolute;top:12px;left:12px;z-index:2;
}
.char-card .body{padding:14px 16px 16px}
.char-card .row1{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2px}
.char-card .name{font-size:18px;font-weight:700;letter-spacing:.5px}
.char-card .acronym{
  color:var(--team-accent, var(--accent));
  font-family:var(--font-mono);
  font-size:10.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  line-height:1.45;
  margin-bottom:8px;
}
.char-card .role{color:var(--txt-2);font-size:12px;margin-bottom:8px;font-weight:600}
.char-card .role-detail{color:var(--txt-3);font-size:12.5px;line-height:1.55;min-height:58px}
.char-card .now{font-size:12.5px;color:var(--txt-2);min-height:34px}
.char-card .now b{color:var(--accent)}
.task-panel{
  margin-top:13px;
  padding:12px;
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-s);
  background:rgba(7,9,15,.38);
}
.task-title{
  color:var(--txt-3);
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.task-panel ol{margin:0;padding-left:18px;color:var(--txt-2);font-size:12px;line-height:1.55}
.task-panel li+li{margin-top:6px}
.char-card .stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line);
}
.char-card .stats .s{font-size:11px;color:var(--txt-3);text-transform:uppercase;letter-spacing:.6px}
.char-card .stats .v{font-family:var(--font-mono);font-size:14px;color:var(--txt-1);font-weight:600}
@media (max-width:1180px){
  .team-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .team-grid,.team-brief{grid-template-columns:1fr}
}

/* ---------- Strategy card ---------- */
.strat-card{padding:14px 16px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius)}
.strat-card .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.strat-card .name{font-weight:600;font-size:14px}
.strat-card .meta{font-size:11.5px;color:var(--txt-3);display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 12px}
.strat-card .meta b{color:var(--txt-1);font-weight:600}
.strat-card .perf{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.strat-card .perf .v{font-family:var(--font-mono);font-weight:600;font-size:14px}
.strat-card .perf .l{font-size:10.5px;color:var(--txt-3);text-transform:uppercase;letter-spacing:.6px}
.strat-card .ctrls{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.strat-card .ctrls select{flex:1;min-width:110px}

/* ---------- Coming soon ---------- */
.soon-hero{
  position:relative;border-radius:var(--radius-l);overflow:hidden;
  border:1px solid rgba(157,123,255,.30);
  background:
    radial-gradient(900px 300px at 80% -10%, rgba(157,123,255,.18), transparent 60%),
    radial-gradient(700px 320px at 0% 100%, rgba(61,169,255,.12), transparent 60%),
    linear-gradient(180deg,#141b2c,#0c121f);
  padding:40px 36px;
}
.soon-hero .badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--violet-soft);color:#bca6ff;font-size:11px;font-weight:700;
  padding:5px 10px;border-radius:999px;letter-spacing:1.2px;text-transform:uppercase;
  margin-bottom:14px;
}
.soon-hero h2{font-size:28px;margin:0 0 8px;letter-spacing:-.4px}
.soon-hero p{color:var(--txt-2);max-width:640px;font-size:14.5px;line-height:1.6;margin:0 0 18px}
.soon-hero .features{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;max-width:680px;margin-bottom:22px}
.soon-hero .features div{font-size:13px;color:var(--txt-2);display:flex;gap:8px;align-items:flex-start}
.soon-hero .features div::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);margin-top:7px;flex-shrink:0;box-shadow:0 0 0 3px var(--accent-soft)}
.soon-hero .cta{display:flex;gap:10px;flex-wrap:wrap}

/* ---------- Misc ---------- */
.divider{height:1px;background:var(--line);margin:14px 0}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.row.between{justify-content:space-between}
.muted{color:var(--txt-3)}
.mono{font-family:var(--font-mono)}
.tiny{font-size:11.5px}
.sec-title{font-size:14px;font-weight:700;letter-spacing:.4px;color:var(--txt-1);margin:0 0 12px;display:flex;align-items:center;gap:8px}
.tag-row{display:flex;flex-wrap:wrap;gap:6px}
.list-clean{list-style:none;padding:0;margin:0}
.list-clean li{padding:9px 0;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:10px}
.list-clean li:last-child{border-bottom:none}

.briefing{
  background:
    radial-gradient(800px 280px at 0% 0%, rgba(61,169,255,.18), transparent 64%),
    radial-gradient(560px 220px at 100% 0%, rgba(39,222,148,.08), transparent 62%),
    linear-gradient(180deg,#182238,#0e1422);
  border:1px solid rgba(61,169,255,.28);
  border-radius:var(--radius-l);
  padding:28px;display:flex;gap:22px;align-items:flex-start;
  box-shadow:0 24px 80px -54px rgba(61,169,255,.65);
}
.briefing .photo{
  width:92px;height:92px;border-radius:16px;flex-shrink:0;overflow:hidden;
  border:1px solid rgba(255,255,255,.12);background:var(--bg-3) center/cover;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
}
.briefing h3{margin:0 0 8px;font-size:20px;font-weight:800}
.briefing h3 .name{color:var(--accent);margin-right:6px}
.briefing p{margin:0;color:var(--txt-1);font-size:15.5px;line-height:1.65;max-width:1100px}
.briefing .ts{font-size:11px;color:var(--txt-4);margin-top:8px;letter-spacing:.5px;text-transform:uppercase}

.setup-feed{
  display:grid;
  gap:8px;
}
.setup-card{
  border:1px solid var(--line);
  border-left-width:3px;
  border-radius:10px;
  padding:10px 12px;
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.01));
}
.setup-card.green{border-left-color:var(--green)}
.setup-card.amber{border-left-color:var(--amber)}
.setup-card.red{border-left-color:var(--red)}
.setup-card.blue{border-left-color:var(--accent)}
.setup-card-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
}
.setup-card-main{
  display:grid;
  grid-template-columns:minmax(220px,1fr) minmax(300px,1.35fr) minmax(360px,1.65fr) auto;
  align-items:center;
  gap:14px;
}
.setup-feed-readonly .setup-card-main{
  grid-template-columns:minmax(220px,1fr) minmax(300px,1.35fr) minmax(420px,2fr);
}
.setup-identity{
  min-width:0;
}
.setup-idline{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
}
.setup-symbol{
  font-family:var(--font-mono);
  font-size:18px;
  font-weight:700;
  color:var(--txt-1);
}
.setup-name{
  margin-top:3px;
  color:var(--txt-2);
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.setup-timing{
  margin-top:3px;
  color:var(--txt-4);
  font-family:var(--font-mono);
  font-size:10.5px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.setup-meta{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.confidence-pill{
  padding:3px 8px;
  font-size:11px;
  letter-spacing:.2px;
}
.setup-grade-pill{
  padding:3px 8px;
  font-size:11px;
  letter-spacing:0;
}
.setup-score-panels,
.ticker-thesis-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  min-width:0;
}
.setup-score-panel,
.ticker-thesis-panel{
  border:1px solid var(--line);
  border-radius:8px;
  background:rgba(255,255,255,.022);
  padding:8px 10px;
  min-width:0;
}
.score-panel-title{
  color:var(--txt-4);
  font-size:9.5px;
  text-transform:uppercase;
  letter-spacing:.8px;
  margin-bottom:4px;
}
.score-panel-main{
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-size:12px;
  font-weight:700;
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.score-panel-main span{
  color:var(--txt-3);
  font-weight:600;
}
.setup-levels{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
}
.setup-levels div{
  min-width:0;
  border-left:1px solid var(--line);
  padding-left:10px;
}
.setup-levels span{
  display:block;
  color:var(--txt-4);
  font-size:9.5px;
  text-transform:uppercase;
  letter-spacing:.8px;
  margin-bottom:3px;
}
.setup-levels b{
  display:block;
  color:var(--txt-1);
  font-size:12px;
  font-family:var(--font-mono);
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.setup-action-col{
  display:flex;
  justify-content:flex-end;
  min-width:142px;
}
.setup-execute{
  white-space:nowrap;
}
.setup-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-top:12px;
}
.setup-grid div{
  background:rgba(255,255,255,.025);
  border:1px solid var(--line);
  border-radius:9px;
  padding:9px;
  min-width:0;
}
.setup-grid span{
  display:block;
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.9px;
  margin-bottom:4px;
}
.setup-grid b{
  display:block;
  color:var(--txt-1);
  font-size:12.5px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.setup-commentary{
  margin-top:8px;
  color:var(--txt-2);
  font-size:12.5px;
  line-height:1.45;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.setup-commentary b{color:var(--accent)}
.setup-reasons{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:8px;
}
.setup-reasons span{
  color:var(--txt-3);
  font-size:11.5px;
  line-height:1.35;
  border:1px solid var(--line);
  border-radius:999px;
  padding:4px 8px;
  background:rgba(255,255,255,.018);
}
.setup-feed-foot,.setup-empty-title{
  margin-top:12px;
  color:var(--accent);
  font-family:var(--font-mono);
  font-size:12px;
}
.setup-empty{
  border:1px dashed rgba(61,169,255,.32);
  background:rgba(61,169,255,.055);
  border-radius:12px;
  padding:18px;
}
.setup-empty .muted{margin-top:8px;line-height:1.5}

@media (max-width:1100px){
  .setup-card-main,
  .setup-feed-readonly .setup-card-main{grid-template-columns:1fr}
  .setup-action-col{justify-content:flex-start}
  .setup-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .setup-score-panels{grid-template-columns:1fr}
  .setup-levels{grid-template-columns:repeat(2,minmax(0,1fr))}
}

.ticker-profile{
  display:grid;
  gap:24px;
}
.ticker-profile-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding:4px 0 0;
}
.ticker-title-block{
  display:grid;
  gap:8px;
  min-width:0;
}
.ticker-symbol-line{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
}
.ticker-symbol-line h1{
  margin:0;
  color:var(--txt-1);
  font-size:32px;
  line-height:1;
  font-weight:800;
  letter-spacing:0;
  font-family:var(--font-mono);
}
.ticker-company{
  color:var(--txt-2);
  font-size:16px;
  font-weight:700;
}
.ticker-price-line{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
}
.ticker-last{
  color:var(--txt-1);
  font-size:24px;
  font-weight:750;
}
.ticker-chart-card{
  padding:0;
  overflow:hidden;
}
.tim-chart-frame{
  position:relative;
  width:100%;
  height:min(68vh,720px);
  min-height:520px;
  background:var(--bg-1);
  border:1px solid var(--line);
  border-radius:10px;
  overflow:hidden;
}
.ticker-chart-card .tim-chart-frame{
  border:0;
  border-radius:0;
}
.tim-chart-mount{
  width:100%;
  height:100%;
  min-height:360px;
  background:#05080f;
}
.tim-chart-mount.empty{
  display:grid;
  place-items:center;
}
.tim-chart-empty{
  width:min(440px,calc(100% - 40px));
  display:grid;
  gap:8px;
  justify-items:center;
  text-align:center;
  color:var(--txt-3);
}
.tim-chart-empty b{
  color:var(--txt-1);
  font-size:15px;
}
.tim-chart-empty span{
  font-size:12px;
  line-height:1.45;
}
.chart-workbench{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,360px);
  gap:18px;
  align-items:start;
}
.chart-frame-card{
  overflow:hidden;
}
.chart-card-head{
  align-items:flex-start;
}
.chart-quote-row{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
}
.chart-last{
  color:var(--txt-1);
  font-size:18px;
  font-weight:800;
  font-variant-numeric:tabular-nums;
}
.chart-toolbar{
  display:flex;
  align-items:center;
  gap:10px;
  margin:12px 0 14px;
}
.chart-toolbar input{
  width:220px;
  max-width:100%;
  font-family:var(--font-mono);
  font-variant-numeric:tabular-nums;
}
.chart-layer-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  padding:12px 14px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.025);
}
.ticker-chart-card .chart-layer-bar{
  border-top:0;
}
.chart-layer-context{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}
.chart-layer-context b{
  color:var(--txt-1);
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.chart-layer-context span{
  color:var(--txt-3);
  font-size:12px;
}
.chart-layer-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
}
.chart-layer-presets,
.chart-layer-group{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
}
.chart-layer-group{
  padding-left:8px;
  border-left:1px solid var(--line);
}
.chart-layer-group > span{
  color:var(--txt-4);
  font-size:10px;
  font-weight:850;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.chart-timeframe-actions{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:6px;
}
.chart-layer-toggle,
.chart-timeframe-toggle{
  border:1px solid var(--line);
  background:rgba(255,255,255,.035);
  color:var(--txt-2);
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:750;
  cursor:pointer;
}
.chart-timeframe-toggle{
  min-width:42px;
  padding-inline:9px;
  font-family:var(--font-mono);
  font-size:11px;
}
.chart-layer-toggle:hover,
.chart-timeframe-toggle:hover{
  border-color:var(--line-bright);
  color:var(--txt-1);
}
.chart-layer-toggle.active,
.chart-timeframe-toggle.active{
  border-color:rgba(61,169,255,.58);
  background:var(--accent-soft);
  color:var(--accent);
}
.chart-layer-toggle.utility{
  color:var(--txt-3);
  border-style:dashed;
  background:rgba(255,255,255,.018);
}
.chart-timeframe-toggle.muted:not(.active){
  color:var(--txt-4);
  border-style:dashed;
}
.chart-level-strip{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  padding:10px 14px;
  border-bottom:1px solid var(--line);
  background:rgba(4,8,14,.42);
}
.chart-level-label{
  color:var(--txt-3);
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-right:2px;
}
.chart-level-pill{
  display:inline-flex;
  align-items:center;
  gap:7px;
  border:1px solid var(--line);
  border-radius:999px;
  padding:5px 8px;
  background:rgba(255,255,255,.025);
  font-size:11px;
}
.chart-level-pill b{
  color:var(--txt-2);
  font-weight:800;
}
.chart-level-pill em{
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-style:normal;
  font-weight:800;
}
.chart-level-pill.support{border-color:rgba(126,231,135,.34)}
.chart-level-pill.resistance{border-color:rgba(255,209,102,.35)}
.chart-level-pill.trend-support{border-color:rgba(111,210,255,.34)}
.chart-level-pill.trend-resistance{border-color:rgba(255,177,97,.38)}
.chart-level-pill.trigger{border-color:rgba(61,169,255,.42)}
.chart-level-pill.invalidation{border-color:rgba(255,90,113,.42)}
.chart-level-pill.target{border-color:rgba(120,231,213,.36)}
.chart-tim-explanation{
  display:grid;
  gap:12px;
  padding:14px;
  border-top:1px solid var(--line);
  background:linear-gradient(135deg,rgba(61,169,255,.08),rgba(4,8,14,.72));
}
.chart-tim-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.chart-tim-head b{
  display:block;
  margin-top:2px;
  color:var(--txt-1);
  font-size:15px;
}
.chart-tim-explanation p{
  max-width:1120px;
  margin:0;
  color:var(--txt-2);
  font-size:14px;
  line-height:1.62;
}
.chart-tim-facts{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
}
.chart-tim-facts span{
  min-width:0;
  border:1px solid var(--line);
  border-radius:9px;
  padding:9px 10px;
  background:rgba(255,255,255,.025);
}
.chart-tim-facts b{
  display:block;
  margin-bottom:5px;
  color:var(--txt-4);
  font-size:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.chart-tim-facts em{
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-size:12px;
  font-style:normal;
  font-variant-numeric:tabular-nums;
}
.chart-symbol-panel{
  overflow:hidden;
}
.chart-symbol-list{
  display:grid;
  gap:8px;
  max-height:650px;
  overflow:auto;
  padding-right:4px;
}
.chart-symbol-row{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  text-align:left;
  border:1px solid var(--line);
  border-radius:10px;
  background:rgba(255,255,255,.02);
  padding:10px 11px;
}
.chart-symbol-row:hover,
.chart-symbol-row.active{
  border-color:rgba(61,169,255,.45);
  background:var(--accent-soft);
}
.chart-symbol-row b{
  display:block;
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-variant-numeric:tabular-nums;
}
.chart-symbol-row small{
  display:block;
  margin-top:2px;
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.chart-symbol-metrics{
  display:grid;
  justify-items:end;
  gap:2px;
  white-space:nowrap;
}
.chart-symbol-metrics em{
  font-style:normal;
  font-family:var(--font-mono);
  font-size:11px;
  font-variant-numeric:tabular-nums;
}
.ticker-layout{
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(300px,1fr);
  gap:24px;
  align-items:start;
}
.ticker-main,.ticker-rail{
  display:grid;
  gap:18px;
  min-width:0;
}
.ticker-read-card{
  border-left:4px solid var(--accent);
  background:linear-gradient(135deg,var(--accent-soft),var(--bg-2) 62%);
}
.ticker-read-summary{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-bottom:16px;
}
.ticker-read-summary > div{
  background:rgba(255,255,255,.025);
  border:1px solid var(--line);
  border-radius:9px;
  padding:10px;
  min-width:0;
}
.ticker-read-summary b{
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-size:13px;
  font-variant-numeric:tabular-nums;
}
.dashboard-performance-terminal{
  display:grid;
  gap:10px;
}
.dashboard-performance-tape,
.dashboard-performance-read{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  color:var(--txt-3);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.55px;
}
.dashboard-performance-tape b{
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-size:13px;
  letter-spacing:0;
}
.dashboard-performance-read{
  color:var(--txt-4);
  text-transform:none;
  letter-spacing:0;
}
.performance-page{
  display:grid;
  gap:14px;
}
.performance-metric-grid{
  display:grid;
  grid-template-columns:repeat(10,minmax(96px,1fr));
  gap:8px;
}
.performance-metric{
  min-width:0;
  border:1px solid rgba(114,138,170,.22);
  background:linear-gradient(180deg,rgba(17,27,42,.88),rgba(9,15,25,.88));
  border-radius:8px;
  padding:10px 11px;
}
.performance-metric span,
.regime-grid span{
  display:block;
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.7px;
  margin-bottom:5px;
}
.performance-metric b{
  display:block;
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-size:15px;
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
.performance-metric.green b{color:var(--green)}
.performance-metric.red b{color:var(--red)}
.performance-panel{
  border-radius:8px;
  padding:16px;
}
.performance-equity-panel{
  min-height:340px;
}
.performance-equity-curve{
  position:relative;
  min-height:318px;
  display:grid;
  grid-template-rows:auto 1fr auto;
  gap:10px;
  border:1px solid rgba(114,138,170,.18);
  border-radius:8px;
  background:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
    radial-gradient(circle at 18% 0%, rgba(61,169,255,.10), transparent 34%),
    rgba(4,8,15,.46);
  background-size:100% 52px,72px 100%,100% 100%,100% 100%;
  padding:12px;
}
.performance-equity-curve.compact{
  min-height:172px;
  padding:8px;
}
.performance-equity-curve svg{
  width:100%;
  height:100%;
  min-height:230px;
  overflow:visible;
}
.performance-equity-curve.compact svg{
  min-height:132px;
}
.performance-chart-toolbar,
.performance-chart-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:var(--txt-3);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.7px;
}
.performance-chart-toolbar div{
  display:flex;
  align-items:center;
  gap:5px;
  flex-wrap:wrap;
}
.perf-range{
  border:1px solid rgba(114,138,170,.28);
  background:rgba(255,255,255,.035);
  color:var(--txt-3);
  border-radius:6px;
  padding:5px 8px;
  font-family:var(--font-mono);
  font-size:10px;
}
.perf-range.active{
  border-color:rgba(61,169,255,.58);
  color:var(--accent);
  background:rgba(61,169,255,.10);
}
.equity-live-line{
  stroke:var(--green);
  stroke-width:3;
  vector-effect:non-scaling-stroke;
  filter:drop-shadow(0 0 7px rgba(62,224,162,.18));
}
.equity-live-line.red{
  stroke:var(--red);
  filter:drop-shadow(0 0 7px rgba(255,95,109,.14));
}
.equity-realized-line{
  stroke:rgba(111,210,255,.76);
  stroke-width:1.5;
  stroke-dasharray:6 6;
  vector-effect:non-scaling-stroke;
}
.drawdown-marker{
  fill:var(--amber);
  stroke:rgba(5,8,14,.9);
  stroke-width:1.5;
}
.performance-chart-empty{
  min-height:210px;
  display:grid;
  place-items:center;
  border:1px dashed rgba(114,138,170,.26);
  border-radius:8px;
  color:var(--txt-4);
  font-family:var(--font-mono);
  font-size:12px;
  text-align:center;
  padding:20px;
}
.performance-main-grid{
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  gap:14px;
}
.performance-strategy-panel,
.performance-distributions,
.performance-main-grid > .performance-panel:nth-child(3),
.performance-main-grid > .performance-panel:nth-child(4){
  grid-column:span 12;
}
.performance-regime-panel{
  grid-column:span 12;
}
.performance-table{
  min-width:980px;
}
.distribution-grid{
  display:grid;
  grid-template-columns:180px repeat(4,minmax(0,1fr));
  gap:14px;
  align-items:stretch;
}
.distribution-block{
  min-width:0;
  border:1px solid rgba(114,138,170,.18);
  border-radius:8px;
  background:rgba(255,255,255,.02);
  padding:12px;
}
.distribution-block > b{
  display:block;
  margin-bottom:10px;
  color:var(--txt-2);
  font-size:12px;
}
.distribution-row{
  display:grid;
  grid-template-columns:minmax(74px,1fr) minmax(60px,1.4fr) 28px;
  align-items:center;
  gap:8px;
  min-height:24px;
  color:var(--txt-3);
  font-size:11px;
}
.distribution-row i{
  height:6px;
  border-radius:999px;
  background:rgba(255,255,255,.055);
  overflow:hidden;
}
.distribution-row em{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,rgba(61,169,255,.68),rgba(120,231,213,.78));
}
.distribution-row strong{
  color:var(--txt-2);
  font-family:var(--font-mono);
  text-align:right;
}
.outcome-donut{
  --win:0;
  display:grid;
  place-items:center;
  min-height:168px;
  border:1px solid rgba(114,138,170,.18);
  border-radius:8px;
  background:conic-gradient(var(--green) calc(var(--win) * 1%), rgba(255,95,109,.72) 0);
  position:relative;
}
.outcome-donut:before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:50%;
  background:#07101b;
  border:1px solid rgba(114,138,170,.20);
}
.outcome-donut div{
  position:relative;
  z-index:1;
  text-align:center;
}
.outcome-donut b{
  display:block;
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-size:22px;
}
.outcome-donut span{
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.75px;
}
.regime-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:10px;
}
.regime-grid div{
  border:1px solid rgba(114,138,170,.18);
  border-radius:8px;
  background:rgba(255,255,255,.02);
  padding:12px;
}
.regime-grid b{
  color:var(--txt-1);
  font-size:14px;
  line-height:1.35;
}
@media (max-width:1100px){
  .performance-metric-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
  .distribution-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .regime-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .performance-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .distribution-grid,.regime-grid{grid-template-columns:1fr}
  .performance-chart-toolbar{align-items:flex-start;flex-direction:column}
  .performance-equity-panel{min-height:auto}
}
.ticker-thesis-grid{
  margin:0 0 16px;
}
.ticker-thesis-panel ul{
  margin:8px 0 0;
  padding-left:18px;
  color:var(--txt-2);
  line-height:1.45;
  font-size:13px;
}
.ticker-read-legacy{
  margin-top:0;
}
.ticker-outlook{
  color:var(--txt-1);
  font-size:15px;
  line-height:1.65;
  margin:0 0 14px;
}
.ticker-execution-note{
  display:flex;
  align-items:flex-start;
  gap:10px;
  border:1px solid rgba(245,181,74,.26);
  border-radius:10px;
  background:rgba(245,181,74,.055);
  padding:10px 12px;
  margin:0 0 14px;
}
.ticker-execution-note b{
  flex:0 0 auto;
  color:var(--amber);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.85px;
}
.ticker-execution-note span{
  min-width:0;
  color:var(--txt-2);
  font-size:13px;
  line-height:1.45;
}
.setup-execution-note{
  display:flex;
  gap:8px;
  align-items:flex-start;
  border:1px solid rgba(245,181,74,.22);
  border-radius:9px;
  background:rgba(245,181,74,.045);
  padding:8px 10px;
  margin-top:10px;
}
.setup-execution-note b{
  flex:0 0 auto;
  color:var(--amber);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.75px;
}
.setup-execution-note span{
  color:var(--txt-3);
  font-size:12px;
  line-height:1.4;
}
.ticker-action-plan{
  display:grid;
  gap:12px;
}
.ticker-trigger-block{
  min-width:0;
  border:1px solid rgba(61,169,255,.22);
  border-radius:12px;
  background:rgba(4,9,18,.30);
  padding:14px;
}
.ticker-trigger-block span,
.ticker-level-pill span{
  display:block;
  margin-bottom:5px;
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.9px;
}
.ticker-trigger-block b{
  display:block;
  color:var(--txt-1);
  font-size:16px;
  font-weight:800;
  line-height:1.35;
  margin-bottom:8px;
}
.ticker-trigger-block p{
  margin:0;
  color:var(--txt-2);
  font-size:14px;
  line-height:1.55;
}
.ticker-trigger-block ul{
  display:grid;
  gap:6px;
  margin:10px 0 0;
  padding-left:18px;
  color:var(--txt-3);
  line-height:1.45;
}
.ticker-level-strip{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.ticker-level-pill{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-width:0;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.025);
  padding:9px 12px;
}
.ticker-level-pill span{
  margin:0;
  white-space:nowrap;
}
.ticker-level-pill b{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-size:13px;
  font-variant-numeric:tabular-nums;
}
.ticker-level-pill.red{border-color:rgba(255,91,111,.28);background:rgba(255,91,111,.055)}
.ticker-level-pill.green{border-color:rgba(62,224,162,.26);background:rgba(62,224,162,.05)}
.ticker-level-pill.blue{border-color:rgba(61,169,255,.24);background:rgba(61,169,255,.05)}
.ticker-evidence-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin-top:16px;
}
.ticker-evidence-grid ul{
  margin:8px 0 0;
  padding-left:18px;
  color:var(--txt-2);
  line-height:1.5;
}
.ticker-flow-list,.ticker-news-list{
  display:grid;
  gap:10px;
}
.ticker-flow-item,
.ticker-news-item{
  display:block;
  border:1px solid var(--line);
  border-radius:10px;
  padding:12px;
  background:rgba(255,255,255,.02);
  color:var(--txt-1);
  text-decoration:none;
}
.ticker-flow-item p,
.ticker-news-item p{
  margin:6px 0 0;
  color:var(--txt-3);
  font-size:12.5px;
  line-height:1.45;
}
.ticker-news-item span{
  display:block;
  margin-top:8px;
  color:var(--txt-4);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.6px;
}
.ticker-news-item:hover{
  border-color:var(--line-bright);
  background:var(--bg-3);
}
.ticker-stat-list{
  display:grid;
  gap:0;
  margin:0;
}
.ticker-stat-list div{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:10px 0;
  border-bottom:1px solid var(--line);
}
.ticker-stat-list div:last-child{border-bottom:0}
.ticker-stat-list dt{
  color:var(--txt-3);
  font-size:12px;
}
.ticker-stat-list dd{
  margin:0;
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-weight:700;
  text-align:right;
  font-variant-numeric:tabular-nums;
}

@media (max-width:1280px){
  .ticker-layout,
  .chart-workbench{grid-template-columns:1fr}
  .ticker-read-summary,.ticker-thesis-grid,.ticker-level-strip,.chart-tim-facts{grid-template-columns:repeat(2,minmax(0,1fr))}
  .markets-hero,
  .market-section-grid{grid-template-columns:1fr}
  .market-mover-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .market-focus-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .tim-chart-frame{height:440px;min-height:440px}
}

.section-h2{
  margin:8px 0 6px;
  font-size:22px;
  letter-spacing:0;
}
.progress-bar{
  height:8px;
  background:var(--bg-3);
  border-radius:999px;
  overflow:hidden;
  margin-top:16px;
}
.progress-bar span{
  display:block;
  height:100%;
  background:linear-gradient(90deg,var(--accent),var(--green));
}
.lesson-progress-ring{
  width:78px;
  height:78px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:radial-gradient(circle at center,var(--bg-2) 56%,transparent 57%), conic-gradient(var(--accent),var(--green));
  border:1px solid var(--line-bright);
  font-family:var(--font-mono);
  font-weight:800;
}
.lesson-list{display:grid;gap:12px}
.lesson-card{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:16px;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.lesson-card.complete{border-color:rgba(39,222,148,.28);background:rgba(39,222,148,.045)}
.lesson-check{
  width:28px;
  height:28px;
  border-radius:50%;
  border:1px solid var(--line-bright);
  background:var(--bg-3);
  color:var(--green);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.lesson-check.complete{background:var(--green-soft);border-color:rgba(39,222,148,.35)}
.lesson-text{margin-top:8px;line-height:1.55}

.referral-box{
  display:flex;
  gap:8px;
  align-items:center;
}
.referral-box input{
  flex:1;
  min-width:0;
  font-family:var(--font-mono);
}

.research-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.research-card{
  border:1px solid var(--line);
  border-radius:12px;
  padding:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.008));
}
.theme-score{
  margin:12px 0 8px;
  font-family:var(--font-mono);
  font-size:30px;
  font-weight:800;
  color:var(--accent);
}

.ai-infra-board{
  margin-top:18px;
  overflow:hidden;
}
.ai-infra-head{
  align-items:flex-start;
  gap:16px;
}
.ai-infra-summary{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
  min-width:280px;
}
.ai-sector-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-top:16px;
}
.ai-sector-card{
  position:relative;
  border:1px solid var(--line);
  border-top:3px solid var(--sector-color);
  border-radius:12px;
  padding:14px;
  background:
    linear-gradient(180deg,color-mix(in srgb, var(--sector-color) 12%, transparent),transparent 42%),
    linear-gradient(180deg,rgba(255,255,255,.026),rgba(255,255,255,.008));
  min-width:0;
}
.ai-sector-title{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:12px;
}
.ai-sector-title b{
  color:var(--txt-1);
  font-size:15px;
  letter-spacing:.1px;
}
.sector-dot{
  display:inline-block;
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--sector-color);
  box-shadow:0 0 14px color-mix(in srgb, var(--sector-color) 65%, transparent);
  margin-right:8px;
}
.ai-sector-perf{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin-bottom:12px;
}
.ai-sector-perf div{
  border:1px solid var(--line);
  border-radius:9px;
  padding:8px;
  background:rgba(7,9,15,.34);
}
.ai-sector-perf span{
  display:block;
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.8px;
  margin-bottom:4px;
}
.ai-stock-table{
  display:grid;
  gap:2px;
}
.ai-stock-row{
  display:grid;
  grid-template-columns:minmax(68px,.7fr) minmax(0,1.2fr) repeat(3,minmax(54px,.52fr));
  align-items:center;
  gap:8px;
  min-width:0;
  padding:7px 0;
  border-top:1px solid rgba(255,255,255,.055);
}
.ai-stock-head{
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.8px;
  padding-top:2px;
}
.ai-stock-symbol{
  display:flex;
  align-items:center;
  gap:6px;
  min-width:0;
  color:var(--txt-1);
  font-family:var(--font-mono);
  font-weight:750;
  font-size:13px;
}
.ai-stock-symbol:hover{color:var(--accent-2)}
.ai-stock-name{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:var(--txt-2);
  font-size:12px;
}
.ai-data-dot{
  width:7px;
  height:7px;
  border-radius:999px;
  background:var(--txt-4);
  flex:0 0 auto;
}
.ai-data-dot.synced{background:var(--green);box-shadow:0 0 12px var(--green-soft)}
.ai-data-dot.delayed{background:var(--amber);box-shadow:0 0 12px var(--amber-soft)}
.ai-data-dot.unavailable{background:var(--txt-4)}
.ai-perf-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:5px;
  min-width:54px;
  border-radius:999px;
  padding:3px 7px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.026);
  color:var(--txt-2);
  font-size:11px;
  font-weight:700;
}
.ai-perf-chip em{
  font-style:normal;
  color:var(--txt-4);
  font-family:var(--font-sans);
  font-size:10px;
  font-weight:800;
  letter-spacing:.6px;
}
.ai-perf-chip.positive{color:var(--green);border-color:rgba(34,211,154,.25);background:var(--green-soft)}
.ai-perf-chip.negative{color:var(--red);border-color:rgba(255,85,102,.24);background:var(--red-soft)}
.ai-perf-chip.flat{color:var(--txt-2)}
.ai-perf-chip.unavailable{color:var(--txt-4)}

.oliver-filter-drawer{
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px;
  align-self:start;
}
.oliver-filter-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:12px;
}
.oliver-filter-head h2{font-size:18px;margin:2px 0 0}
.eyebrow{
  margin:0;
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:1.4px;
  font-weight:800;
}
.oliver-filter-drawer section{
  padding:12px 0;
  border-top:1px solid var(--line);
}
.oliver-filter-drawer h3{
  margin:0 0 8px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--txt-2);
}
.whale-signal-card{
  background:var(--bg-2);
  border:1px solid rgba(61,169,255,.20);
  border-radius:var(--radius);
  padding:16px;
}
.signal-topline{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
}
.signal-topline h3{margin:2px 0 0;font-size:18px}
.signal-topline strong{
  font-family:var(--font-mono);
  font-size:26px;
  color:var(--accent);
}
.whale-signal-card p{color:var(--txt-2);line-height:1.45;font-size:13px}
.whale-signal-card dl{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.whale-signal-card dt{color:var(--txt-4);font-size:10px;text-transform:uppercase;letter-spacing:.8px}
.whale-signal-card dd{margin:2px 0 0;color:var(--txt-1);font-size:12px;font-weight:700}
.risk-flags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.risk-flags span{font-size:10.5px;color:var(--amber);background:var(--amber-soft);border-radius:999px;padding:3px 8px}
.oliver-flow-table-wrap{overflow:auto}
.oliver-flow-table{width:100%;border-collapse:collapse;font-size:12.5px}
.oliver-flow-table th{
  text-align:left;
  font-size:10px;
  color:var(--txt-3);
  text-transform:uppercase;
  letter-spacing:1px;
  padding:10px;
  border-bottom:1px solid var(--line);
}
.oliver-flow-table td{padding:10px;border-bottom:1px solid var(--line);font-family:var(--font-mono)}

.replay-stack{display:grid;gap:14px}
.trade-timeline{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.trade-timeline div{
  border:1px solid var(--line);
  border-radius:12px;
  padding:14px;
  background:rgba(255,255,255,.02);
}
.trade-timeline span{
  display:block;
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:1.1px;
  font-weight:800;
}
.trade-timeline b{display:block;margin-top:6px;color:var(--txt-1)}
.trade-timeline em{display:block;margin-top:4px;color:var(--txt-3);font-size:11.5px;font-style:normal}
.trade-timeline p{margin:10px 0 0;color:var(--txt-2);font-size:12.5px;line-height:1.45}

.trade-desk-hero{
  display:grid;
  grid-template-columns:minmax(0,.82fr) minmax(420px,1.18fr);
  gap:18px;
  align-items:stretch;
  min-height:260px;
  margin-bottom:18px;
  border:1px solid var(--line);
  border-radius:var(--radius-l);
  overflow:hidden;
  background:
    linear-gradient(135deg,rgba(61,169,255,.13),rgba(7,9,15,.72) 42%),
    var(--bg-2);
  box-shadow:var(--shadow-1);
}
.trade-desk-hero-copy{
  padding:26px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:14px;
}
.trade-desk-hero-copy h2{
  margin:0;
  font-size:30px;
  line-height:1.08;
  letter-spacing:-.2px;
}
.trade-desk-hero-copy p{
  margin:0;
  color:var(--txt-2);
  font-size:14.5px;
  line-height:1.65;
  max-width:560px;
}
.trade-desk-hero-stats{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:4px;
}
.trade-desk-hero-stats div{
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px;
  background:rgba(7,9,15,.38);
}
.trade-desk-hero-stats span{
  display:block;
  color:var(--txt-4);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:1px;
  margin-bottom:4px;
}
.trade-desk-hero-stats b{
  color:var(--txt-1);
  font-size:15px;
}
.trade-desk-photo{
  min-height:260px;
  background:
    linear-gradient(90deg,rgba(7,9,15,.12),rgba(7,9,15,0) 28%),
    url(/app-assets/assets/ai-trading-desk.png) center center / cover no-repeat;
  border-left:1px solid var(--line);
}

@media (max-width:1180px){
  .research-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .ai-sector-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .trade-desk-hero{grid-template-columns:1fr}
  .trade-desk-photo{border-left:0;border-top:1px solid var(--line)}
  .trade-timeline{grid-template-columns:1fr}
}
@media (max-width:820px){
  .research-grid{grid-template-columns:1fr}
  .ai-sector-grid{grid-template-columns:1fr}
  .ai-infra-head{flex-direction:column}
  .ai-infra-summary{justify-content:flex-start;min-width:0}
  .referral-box{flex-direction:column;align-items:stretch}
}

/* ---------- Broker card ---------- */
.broker-card{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;display:flex;flex-direction:column;gap:14px;
}
.broker-card .head{display:flex;align-items:center;gap:14px}
.broker-card .logo{
  width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:17px;letter-spacing:.5px;color:#fff;
  background:var(--bg-3);border:1px solid var(--line);
}
.broker-card .logo.kraken{background:linear-gradient(135deg,#5740ad,#8068d6)}
.broker-card .logo.alpaca{background:linear-gradient(135deg,#ffd230,#f5a623);color:#1a1a1a}
.broker-card .logo.coinbase{background:linear-gradient(135deg,#0052ff,#3a78ff)}
.broker-card .logo.tasty{background:linear-gradient(135deg,#1ec977,#0fa15a)}
.broker-card .meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;font-size:12px}
.broker-card .meta .l{color:var(--txt-3);text-transform:uppercase;letter-spacing:.8px;font-size:10.5px}
.broker-card .meta .v{font-family:var(--font-mono);color:var(--txt-1);font-weight:600;margin-top:2px}
.broker-card-actions{
  display:flex;
  justify-content:flex-end;
}
.broker-view-context{
  margin:0 0 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.01));
  color:var(--txt-2);
}
.broker-view-context > div{
  display:flex;
  align-items:center;
  gap:9px;
  min-width:0;
}
.broker-view-context b{color:var(--txt-1)}
.broker-view-context span:last-child{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.broker-view-context .dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--txt-4);
  flex:0 0 auto;
}
.broker-view-context .dot.green{background:var(--green);box-shadow:0 0 0 3px var(--green-soft)}
.broker-view-context .dot.amber{background:var(--amber);box-shadow:0 0 0 3px var(--amber-soft)}
.broker-view-context .dot.red{background:var(--red);box-shadow:0 0 0 3px var(--red-soft)}
.broker-view-context .dot.grey{background:var(--txt-4);box-shadow:0 0 0 3px rgba(126,140,166,.12)}

/* ---------- Drawer / modal hint ---------- */
.banner{
  background:linear-gradient(90deg, rgba(61,169,255,.12), rgba(157,123,255,.06));
  border:1px solid rgba(61,169,255,.25);
  border-radius:var(--radius);padding:12px 16px;
  display:flex;align-items:center;gap:14px;
}
.banner .ic{color:var(--accent);width:18px;height:18px;flex-shrink:0}
.banner b{color:var(--txt-1)}
.banner .actions{margin-left:auto;display:flex;gap:8px}

/* ---------- Risk profile picker ---------- */
.risk-card{
  border:1px solid var(--line);border-radius:var(--radius);padding:16px;
  background:var(--bg-2);cursor:pointer;transition:border-color .12s,background .12s;
  display:flex;flex-direction:column;gap:8px;
}
.risk-card:hover{border-color:var(--line-bright)}
.risk-card.selected{border-color:var(--accent);background:linear-gradient(180deg,rgba(61,169,255,.08),var(--bg-2))}
.risk-card.pending{border-color:rgba(255,209,102,.75);background:linear-gradient(180deg,rgba(255,209,102,.08),var(--bg-2))}
.risk-card.manual{background:linear-gradient(180deg,rgba(128,104,214,.07),var(--bg-2))}
.risk-card .nm{display:flex;align-items:center;justify-content:space-between}
.risk-card .nm b{font-size:14px}
.risk-card .desc{color:var(--txt-3);font-size:12.5px}
.risk-card .vals{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;font-size:11.5px;color:var(--txt-2);margin-top:6px}
.risk-card .vals span{display:flex;justify-content:space-between;border-bottom:1px dashed var(--line);padding-bottom:3px}
.risk-card .vals span b{color:var(--txt-1);font-family:var(--font-mono)}
.manual-risk-fields{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:9px;
  margin-top:4px;
  cursor:default;
}
.manual-risk-fields label{
  display:flex;
  flex-direction:column;
  gap:5px;
  color:var(--txt-3);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.75px;
}
.manual-risk-fields input[type="number"]{
  width:100%;
  min-width:0;
  font-family:var(--font-mono);
  font-size:12.5px;
}
.manual-risk-fields .manual-risk-check{
  flex-direction:row;
  align-items:center;
  text-transform:none;
  letter-spacing:0;
  color:var(--txt-2);
}
.manual-risk-fields .manual-risk-check input{
  width:auto;
}

/* ---------- Functional portal controls ---------- */
.watchlist-add-form{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.watchlist-add-form input{
  min-width:230px;
}
.symbol-chip-grid{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.broker-settings-list{
  display:grid;
  gap:10px;
}
.broker-settings-row{
  display:grid;
  grid-template-columns:minmax(220px,1.25fr) minmax(220px,1fr) auto;
  gap:12px;
  align-items:center;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(255,255,255,.028),rgba(255,255,255,.012));
  padding:12px;
}
.broker-main{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.broker-main .logo{
  width:38px;
  height:38px;
  border-radius:9px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  color:#fff;
  background:var(--bg-3);
  border:1px solid var(--line);
}
.broker-main .logo.kraken{background:linear-gradient(135deg,#5740ad,#8068d6)}
.broker-main .logo.clawstreet{background:linear-gradient(135deg,#1e9b8a,#28d2b4)}
.broker-main .logo.tastytrade{background:linear-gradient(135deg,#5b6cff,#9e7bff)}
.broker-main .logo.alpaca{background:linear-gradient(135deg,#1f7a4a,#59d68c)}
.broker-main .logo.paper{background:linear-gradient(135deg,#3da9ff,#22d39a)}
.broker-main .logo.alpaca{background:linear-gradient(135deg,#ffd230,#f5a623);color:#1a1a1a}
.broker-state-pills,.broker-actions{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.broker-actions{
  justify-content:flex-end;
}
.broker-signup-panel{
  grid-column:1 / -1;
  display:flex;
  align-items:center;
  gap:14px;
  border:1px solid rgba(128,104,214,.32);
  border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(128,104,214,.14),rgba(34,211,154,.05));
  padding:12px;
}
.broker-signup-button{
  flex:0 0 150px;
  width:150px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(128,104,214,.42);
  border-radius:12px;
  background:#fff;
  padding:7px 10px;
  box-shadow:0 12px 34px rgba(0,0,0,.22);
  transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease;
}
.broker-signup-button:hover{
  transform:translateY(-1px);
  border-color:rgba(128,104,214,.72);
  box-shadow:0 16px 42px rgba(0,0,0,.3);
}
.broker-signup-button img{
  display:block;
  width:100%;
  height:auto;
  max-height:72px;
  object-fit:contain;
}
.kraken-signup-button{
  border-color:rgba(128,104,214,.42);
}
.tastytrade-signup-button{
  border-color:rgba(91,108,255,.4);
  flex-basis:220px;
  width:220px;
  min-height:74px;
  padding:8px 12px;
}
.tastytrade-signup-button img{
  max-height:58px;
}
.broker-signup-copy{
  min-width:0;
  color:var(--txt-2);
  font-size:12.5px;
  line-height:1.45;
}
.broker-signup-copy b{
  display:block;
  color:var(--txt-1);
  margin-bottom:3px;
}
.broker-signup-copy .advisory{
  display:block;
  color:var(--txt-3);
  font-size:11.5px;
  margin-top:4px;
}
.journal-note-box{
  margin-top:14px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:rgba(255,255,255,.025);
  padding:12px;
}
.journal-note-box label{
  display:block;
  color:var(--txt-3);
  text-transform:uppercase;
  letter-spacing:.9px;
  font-size:10.5px;
  margin-bottom:8px;
}
.journal-note-box textarea{
  width:100%;
  min-height:92px;
  resize:vertical;
  margin-bottom:10px;
}
button[disabled]{
  opacity:.65;
  cursor:default;
}
select.loading,
button.loading,
form.loading{
  opacity:.7;
  pointer-events:none;
}

@media (max-width:1100px){
  .broker-settings-row{
    grid-template-columns:1fr;
  }
  .broker-actions{
    justify-content:flex-start;
  }
}

@media (max-width:760px){
  .broker-signup-panel{
    align-items:flex-start;
    flex-direction:column;
  }
  .broker-signup-button{
    width:170px;
    flex-basis:auto;
  }
}

/* ---------- Mini icon set (inline SVG sized) ---------- */
.ic{display:inline-block;vertical-align:middle}
svg.ic{stroke-width:2;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* helpers */
.flex{display:flex}.between{justify-content:space-between}.center{align-items:center}
.gap-8{gap:8px}.gap-12{gap:12px}.mb-0{margin-bottom:0}.mb-8{margin-bottom:8px}.mt-12{margin-top:12px}
.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}
.bg-grid{
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:32px 32px;
}

/* ---------- Product access gate ---------- */
.gate-wrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:34px;
  background:
    radial-gradient(900px 460px at 50% 0%, rgba(61,169,255,.12), transparent 60%),
    radial-gradient(680px 360px at 15% 90%, rgba(157,123,255,.08), transparent 55%),
    var(--bg-1);
}
.gate-card{
  width:min(960px,100%);
  display:grid;
  grid-template-columns:minmax(0,1fr) 390px;
  gap:18px;
  align-items:stretch;
}
.gate-hero,.gate-panel{
  border:1px solid var(--line);
  border-radius:var(--radius-l);
  background:linear-gradient(180deg,#141b2c,#0e1422);
  box-shadow:var(--shadow-2);
}
.gate-hero{padding:28px;overflow:hidden;position:relative}
.gate-hero::after{
  content:"";
  position:absolute;
  inset:auto -20% -35% 20%;
  height:220px;
  background:radial-gradient(circle,rgba(61,169,255,.14),transparent 62%);
  pointer-events:none;
}
.gate-logo{height:74px;width:auto;margin-bottom:26px;filter:drop-shadow(0 0 18px rgba(61,169,255,.22))}
.gate-hero h1{font-size:34px;line-height:1.05;margin:0 0 10px;letter-spacing:-.5px}
.gate-hero p{color:var(--txt-2);max-width:520px;margin:0 0 22px;font-size:14.5px;line-height:1.7}
.gate-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:20px}
.gate-grid div{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:var(--radius-s);padding:11px}
.gate-grid b{display:block;font-size:12px;margin-bottom:3px}
.gate-grid span{display:block;color:var(--txt-3);font-size:11.5px}
.gate-panel{padding:22px}
.gate-panel h2{font-size:18px;margin:0 0 4px}
.gate-panel .sub{color:var(--txt-3);font-size:12.5px;margin-bottom:16px}
.gate-message{
  border:1px solid var(--line);
  border-radius:var(--radius-s);
  padding:10px 12px;
  margin-bottom:14px;
  color:var(--txt-2);
  background:var(--bg-3);
  font-size:12.5px;
}
.gate-message.error{background:var(--red-soft);border-color:rgba(255,85,102,.28);color:#ffc2c9}
.gate-message.ok{background:var(--green-soft);border-color:rgba(34,211,154,.28);color:#a5f5dc}
.gate-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.gate-actions .btn{flex:1;justify-content:center}
.auth-switch{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:16px}
.auth-switch .btn{justify-content:center}
.field input{width:100%}
.gate-link{font-size:12px;color:var(--accent);cursor:pointer}
.gate-footer{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);color:var(--txt-4);font-size:11.5px}
@media (max-width:900px){
  .gate-card{grid-template-columns:1fr}
  .gate-logo{height:58px}
  .gate-hero h1{font-size:28px}
}
