/* ============================================================================
   Aurelous Advisor — "Clean institutional" design system
   Warm-white surfaces · deep emerald accent · precise type · generous whitespace.
   Type: Schibsted Grotesk (display) · Hanken Grotesk (UI/body) · Geist Mono (data)
   ============================================================================ */
:root{
  /* surfaces (warm paper whites) */
  --surface:#FBFAF7; --panel:#FFFFFF; --panel-2:#F4F2EC; --panel-3:#EEEBE1;
  /* ink */
  --ink:#16181D; --ink-2:#575C66; --ink-3:#8C909B;
  /* lines (warm hairlines) */
  --line:#E9E5DA; --line-2:#DCD7CA;
  /* brand emerald */
  --accent:#1F5F4E; --accent-2:#2A7A63; --accent-ink:#143F34;
  --accent-soft:rgba(31,95,78,.07); --accent-line:rgba(31,95,78,.22);
  /* market */
  --up:#1F8A5B; --down:#C0463B; --up-soft:rgba(31,138,91,.12); --down-soft:rgba(192,70,59,.12);
  /* effects */
  --shadow-sm:0 1px 2px rgba(22,24,29,.05);
  --shadow:0 1px 2px rgba(22,24,29,.04), 0 10px 30px -16px rgba(22,24,29,.18);
  --radius:14px; --radius-sm:10px; --radius-xs:8px;
  /* type */
  --display:'Schibsted Grotesk',system-ui,sans-serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'Geist Mono',ui-monospace,'SF Mono',Menlo,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--surface); color:var(--ink);
  font:400 14.5px/1.55 var(--sans);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-2)}
.mono{font-family:var(--mono);font-feature-settings:'tnum' 1,'zero' 1}
.muted{color:var(--ink-2)} .dim{color:var(--ink-3)}
.pos{color:var(--up)} .neg{color:var(--down)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}

/* ---- controls ---- */
.btn{
  background:var(--accent);color:#fff;border:0;border-radius:var(--radius-sm);
  padding:10px 18px;font:600 13.5px/1 var(--sans);letter-spacing:.01em;cursor:pointer;
  transition:background .15s ease, transform .04s ease;
}
.btn:hover{background:var(--accent-2)}
.btn:active{transform:translateY(1px)}
.btn.ghost{background:transparent;border:1px solid var(--line-2);color:var(--ink-2)}
.btn.ghost:hover{background:var(--panel-2);color:var(--ink)}
input,select{
  background:var(--panel);border:1px solid var(--line-2);color:var(--ink);
  border-radius:var(--radius-sm);padding:10px 13px;font:400 14px/1.3 var(--sans);width:100%;
  transition:border-color .15s ease, box-shadow .15s ease;
}
input::placeholder{color:var(--ink-3)}
input:focus,select:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* ---- surfaces ---- */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.sectitle{font:600 10.5px/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}

/* ---- brand lockup ---- */
.brand{display:inline-flex;align-items:center;gap:10px;font:700 17px/1 var(--display);letter-spacing:-.01em;color:var(--ink)}
.brand .mark{
  width:27px;height:27px;border-radius:8px;background:var(--accent);color:#fff;
  display:grid;place-items:center;font:700 15px/1 var(--display);box-shadow:inset 0 0 0 1px rgba(255,255,255,.14);
  flex:0 0 auto;
}
.brand .a{color:var(--ink)} .brand .b{color:var(--ink-3);font-weight:500}

/* ============================================================ login ======== */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login{width:380px;max-width:92vw;padding:38px 34px;text-align:center}
.login .brand{font-size:24px;justify-content:center;margin-bottom:4px}
.login .brand .mark{width:34px;height:34px;border-radius:10px;font-size:19px}
.sub{color:var(--ink-3);font-size:13px;margin:10px 0 28px;letter-spacing:.01em}
.login form{display:flex;flex-direction:column;gap:11px}
.login .btn{width:100%;padding:12px;margin-top:5px}
.err{color:var(--down);font-size:12.5px;min-height:18px;margin-top:4px}
.discl{color:var(--ink-3);font-size:10.5px;line-height:1.6;margin-top:26px;padding-top:20px;border-top:1px solid var(--line)}

/* ============================================================ app shell ==== */
.top{
  display:flex;align-items:center;gap:16px;padding:13px 24px;
  border-bottom:1px solid var(--line);background:rgba(251,250,247,.82);backdrop-filter:blur(10px);
  position:sticky;top:0;z-index:10;
}
.top .who{margin-left:auto;color:var(--ink-2);font-size:13px;display:flex;align-items:center;gap:10px}
.top .who a{color:var(--ink-2)} .top .who a:hover{color:var(--accent)}
.top .who .me{color:var(--ink);font-weight:600}
.sep{color:var(--line-2)}

/* live indicator (calm, not a loud pill) */
.live{display:inline-flex;align-items:center;gap:7px;font:600 10px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.live .dot{width:7px;height:7px;border-radius:50%;background:var(--up);box-shadow:0 0 0 0 rgba(31,138,91,.45);animation:pulse 2.4s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(31,138,91,.4)}70%{box-shadow:0 0 0 6px rgba(31,138,91,0)}100%{box-shadow:0 0 0 0 rgba(31,138,91,0)}}

/* ---- price ticker rail ---- */
.ticker{display:flex;gap:0;overflow-x:auto;border-bottom:1px solid var(--line);background:var(--panel);scrollbar-width:none}
.ticker::-webkit-scrollbar{display:none}
.ticker .pc{display:flex;align-items:baseline;gap:9px;padding:11px 22px;border-right:1px solid var(--line);white-space:nowrap;flex:0 0 auto}
.ticker .pc .k{font:600 10.5px/1 var(--mono);letter-spacing:.08em;color:var(--ink-3)}
.ticker .pc .p{font:500 14px/1 var(--mono);color:var(--ink);font-feature-settings:'tnum' 1}
.ticker .pc .p.up{color:var(--up)} .ticker .pc .p.down{color:var(--down)}
.ticker .empty{padding:11px 22px;color:var(--ink-3);font-size:12.5px}

/* ---- workspace grid ---- */
.grid{display:grid;grid-template-columns:minmax(0,1fr) 384px;gap:18px;padding:18px 24px;max-width:1520px;margin:0 auto}
@media(max-width:1040px){.grid{grid-template-columns:1fr}}
.chart-wrap{height:min(64vh,600px);padding:0;overflow:hidden;position:relative;display:flex;flex-direction:column}
.chart-head{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.tabs{display:flex;gap:5px;flex-wrap:wrap}
.tab{
  background:transparent;border:1px solid var(--line-2);color:var(--ink-2);border-radius:var(--radius-xs);
  padding:6px 11px;font:500 12px/1 var(--mono);letter-spacing:.02em;cursor:pointer;transition:all .13s ease;
}
.tab:hover{background:var(--panel-2);color:var(--ink)}
.tab.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.chartlegend{margin-left:auto;font:600 12px/1 var(--mono);color:var(--ink-2);display:flex;gap:9px;align-items:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:46%}
.chartlegend .muted{color:var(--ink-3)} .chartlegend .lup{color:var(--up)} .chartlegend .ldn{color:var(--down)}
.chartwrap{position:relative;flex:1;min-height:0}
#chart{position:absolute;inset:0}
/* floating chart controls (ported from the live agent) */
.cbtn{
  position:absolute;z-index:6;background:rgba(255,255,255,.86);border:1px solid var(--line-2);color:var(--ink-2);
  border-radius:9px;padding:6px 11px;font:600 11px/1 var(--mono);cursor:pointer;backdrop-filter:blur(7px);
  box-shadow:var(--shadow-sm);transition:background .14s ease,color .14s ease,border-color .14s ease,transform .05s ease;
}
.cbtn:hover{color:#fff;background:var(--accent);border-color:var(--accent)}
.cbtn:active{transform:scale(.96)}
.cbtn-now{bottom:14px;right:74px}
.cbtn-price{top:12px;right:12px}

.side{display:flex;flex-direction:column;gap:18px;min-width:0}

/* ---- setups (analyst's research notes) ---- */
.side .panel{display:flex;flex-direction:column;min-height:0}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:15px 16px 0}
.setups{padding:6px 16px 16px;overflow:auto;max-height:300px}
.setup{position:relative;border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px;margin-top:11px;background:var(--panel)}
.setup::before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:2px;border-radius:2px;background:var(--accent-line)}
.setup .sh{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:7px}
.setup .sym{font:600 14px/1 var(--display);color:var(--ink);letter-spacing:-.01em}
.setup .last{font:500 11.5px/1 var(--mono);color:var(--ink-3)}
.lvl{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 0;font-size:12.5px}
.lvl+.lvl{border-top:1px dashed var(--line)}
.lvl .lab{color:var(--ink-2)} .lvl .val{font:500 12.5px/1 var(--mono);color:var(--ink)}

/* ---- chat (ask the analyst) ---- */
.chat{height:440px}
.chat .panel-head{padding-bottom:12px;border-bottom:1px solid var(--line)}
.thread{flex:1;overflow:auto;display:flex;flex-direction:column;gap:11px;padding:16px}
.cmsg{max-width:86%;padding:10px 13px;border-radius:13px;font-size:13.5px;line-height:1.5;word-wrap:break-word;overflow-wrap:anywhere}
.cme{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.cag{align-self:flex-start;max-width:93%;background:var(--panel-2);color:var(--ink);border:1px solid var(--line);border-bottom-left-radius:4px}
.cw{font:600 9px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;margin-bottom:5px;opacity:.7}
.cme .cw{color:rgba(255,255,255,.85)} .cag .cw{color:var(--accent)}
.cme .mdc{white-space:pre-wrap}
/* rendered-markdown styling for the analyst's replies */
.cag .mdc>*:first-child{margin-top:0}.cag .mdc>*:last-child{margin-bottom:0}
.cag .mdc h1,.cag .mdc h2,.cag .mdc h3,.cag .mdc h4{font-family:var(--display);font-weight:600;line-height:1.3;margin:11px 0 6px}
.cag .mdc h1{font-size:15.5px}.cag .mdc h2{font-size:14.5px}.cag .mdc h3,.cag .mdc h4{font-size:13.5px}
.cag .mdc p{margin:6px 0}
.cag .mdc ul,.cag .mdc ol{margin:6px 0;padding-left:18px}.cag .mdc li{margin:3px 0}
.cag .mdc strong{font-weight:600;color:var(--ink)}
.cag .mdc a{color:var(--accent);text-decoration:underline}
.cag .mdc code{font-family:var(--mono);font-size:12px;background:var(--panel-3);padding:1px 5px;border-radius:5px}
.cag .mdc pre{background:var(--panel-3);padding:9px 11px;border-radius:8px;overflow:auto;margin:7px 0}
.cag .mdc pre code{background:none;padding:0;font-size:11.5px}
.cag .mdc blockquote{margin:7px 0;padding:2px 0 2px 11px;border-left:3px solid var(--accent-line);color:var(--ink-2)}
.cag .mdc hr{border:0;border-top:1px solid var(--line);margin:10px 0}
.cag .mdc table{border-collapse:collapse;margin:8px 0;font-size:12.5px;display:block;overflow-x:auto;max-width:100%}
.cag .mdc th,.cag .mdc td{border:1px solid var(--line-2);padding:5px 8px;text-align:left;white-space:nowrap}
.cag .mdc th{background:var(--panel);font-weight:600}
/* typing / pending indicator */
.cmsg.typing{display:flex;align-items:center;gap:8px}
.cmsg.typing .cw{margin-bottom:0}
.tdots{display:inline-flex;gap:4px}
.tdots i{width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.4;animation:tbounce 1.15s infinite}
.tdots i:nth-child(2){animation-delay:.18s}.tdots i:nth-child(3){animation-delay:.36s}
@keyframes tbounce{0%,65%,100%{opacity:.35;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.tstatus{font-size:12px;color:var(--ink-3)}
.chatbar{display:flex;gap:9px;padding:14px 16px;border-top:1px solid var(--line)}
.empty{color:var(--ink-3);font-size:12.5px;text-align:center;padding:26px 16px;line-height:1.6}

/* ============================================================ admin ======== */
.wrap{max-width:920px;margin:24px auto;padding:0 24px;display:flex;flex-direction:column;gap:18px}
.card{padding:20px 22px}
.card .sectitle{margin-bottom:14px}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:10px 10px}
th{color:var(--ink-3);font:600 10px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--line-2)}
td{border-bottom:1px solid var(--line)}
tbody tr:hover td{background:var(--panel-2)}
tbody tr:last-child td{border-bottom:0}
td b{font-weight:600}
.row{display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.row input,.row select{width:auto;flex:1;min-width:130px}

/* ---- responsive ---- */
@media(max-width:760px){.chartlegend{display:none}}
@media(max-width:560px){
  .top{padding:12px 16px;gap:12px} .grid{padding:14px 16px;gap:14px}
  .ticker .pc{padding:10px 16px} .wrap{padding:0 16px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
