/* ============================================================
   GeoAIVO — App / Dashboard styles (app.html)
   Loaded in addition to styles.css
   ============================================================ */

body.app{background:var(--ink);color:var(--txt-light);overflow-x:hidden}
.app-shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* ---------- sidebar ---------- */
.side{background:var(--ink-2);border-right:1px solid var(--line-d);padding:18px 14px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side__brand{display:flex;align-items:center;gap:.55em;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.12rem;color:#fff;padding:6px 8px 18px}
.side__brand span{color:var(--mint-2)}
.side__group{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--txt-dim);padding:14px 12px 6px;opacity:.7}
.side__nav{display:flex;flex-direction:column;gap:3px}
.snav{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;font-size:.92rem;font-weight:500;color:var(--txt-dim);transition:.18s;text-align:left;width:100%}
.snav:hover{background:var(--ink-3);color:#fff}
.snav.active{background:rgba(109,94,252,.16);color:#fff}
.snav.active .snav__i{color:var(--violet-2)}
.snav:focus-visible,.appbar__icon:focus-visible,.brandswitch:focus-visible{outline:2px solid var(--violet-2);outline-offset:2px}
.snav__i{width:18px;text-align:center;font-size:1rem;flex:none}
.snav__badge{margin-left:auto;font-size:.66rem;font-weight:700;background:var(--red);color:#fff;border-radius:99px;padding:.1em .5em}
.side__foot{margin-top:auto;padding:12px}
.side__upsell{background:linear-gradient(140deg,rgba(109,94,252,.2),rgba(34,200,245,.1));border:1px solid var(--line-d);border-radius:14px;padding:14px}
.side__upsell b{color:#fff;font-size:.9rem;font-family:'Space Grotesk',sans-serif}
.side__upsell p{font-size:.78rem;color:var(--txt-dim);margin:.3rem 0 .7rem}

/* ---------- topbar ---------- */
.app-main{display:flex;flex-direction:column;min-width:0}
.appbar{height:62px;border-bottom:1px solid var(--line-d);display:flex;align-items:center;justify-content:space-between;padding:0 26px;position:sticky;top:0;background:rgba(11,12,20,.85);backdrop-filter:blur(12px);z-index:20;gap:16px}
.brandswitch{display:flex;align-items:center;gap:10px;background:var(--ink-3);border:1px solid var(--line-d);border-radius:10px;padding:7px 12px;font-weight:600;font-size:.9rem;color:#fff;cursor:pointer}
.brandswitch .av{width:24px;height:24px;border-radius:6px;background:var(--grad);display:grid;place-items:center;font-size:.7rem;font-weight:800}
.appbar__actions{display:flex;align-items:center;gap:12px}
.appbar__icon{width:38px;height:38px;border-radius:10px;background:var(--ink-3);display:grid;place-items:center;color:var(--txt-dim);transition:.2s}
.appbar__icon:hover{color:#fff;background:var(--ink-4)}
.mobtoggle{display:none}

/* ---------- content ---------- */
.app-body{padding:26px;max-width:1080px;width:100%;margin:0 auto}
.panel{display:none;animation:fade .4s var(--ease)}
.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.phead{margin-bottom:22px}
.phead h1{font-size:1.7rem;color:#fff}
.phead p{color:var(--txt-dim);margin-top:.3rem}

/* ---------- run/empty state ---------- */
.runcard{background:var(--ink-2);border:1px solid var(--line-d);border-radius:var(--radius-lg);padding:38px;text-align:center;max-width:600px;margin:40px auto}
.runcard h2{color:#fff;margin-bottom:.6rem}
.runcard p{color:var(--txt-dim);margin-bottom:1.4rem}
.runform{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.runform input,.runform select{padding:.85em 1em;border-radius:11px;border:1px solid var(--ink-4);background:var(--ink-3);color:#fff;font-size:.98rem}
.runform input{flex:1;min-width:200px}
.runform input:focus,.runform select:focus{outline:none;border-color:var(--violet)}

/* scanning */
.scan{max-width:560px;margin:50px auto;text-align:center}
.scan__ring{width:120px;height:120px;margin:0 auto 22px;border-radius:50%;border:4px solid var(--ink-4);border-top-color:var(--violet);border-right-color:var(--mint);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.scan__log{text-align:left;background:var(--ink-2);border:1px solid var(--line-d);border-radius:14px;padding:16px 18px;font-family:'Space Grotesk',monospace;font-size:.86rem;max-width:440px;margin:0 auto}
.scan__line{display:flex;align-items:center;gap:10px;padding:5px 0;color:var(--txt-dim);opacity:.4;transition:opacity .3s}
.scan__line.on{opacity:1;color:var(--txt-light)}
.scan__line.done .tick{color:var(--mint)}
.scan__line .tick{color:var(--txt-dim);width:16px}

/* ---------- KPI cards ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.kpi{background:var(--ink-2);border:1px solid var(--line-d);border-radius:14px;padding:18px}
.kpi__label{font-size:.78rem;color:var(--txt-dim);display:flex;align-items:center;gap:6px}
.kpi__val{font-family:'Space Grotesk',sans-serif;font-size:1.9rem;color:#fff;margin-top:6px;line-height:1}
.kpi__delta{font-size:.76rem;font-weight:700;margin-top:6px}
.up{color:var(--green)}.down{color:var(--red)}.flat{color:var(--txt-dim)}

/* grid blocks */
.blocks{display:grid;grid-template-columns:1.3fr .7fr;gap:16px}
.block{background:var(--ink-2);border:1px solid var(--line-d);border-radius:16px;padding:22px;margin-bottom:16px}
.block__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:12px}
.block__head h3{color:#fff;font-size:1.08rem}
.block__head .hint{font-size:.78rem;color:var(--txt-dim)}

/* big score ring */
.bigscore{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.bigring{--p:0;width:150px;height:150px;border-radius:50%;flex:none;display:grid;place-items:center;position:relative;
  background:conic-gradient(var(--ring-c,var(--mint)) calc(var(--p)*1%),var(--ink-4) 0)}
.bigring::before{content:"";position:absolute;inset:12px;border-radius:50%;background:var(--ink-2)}
.bigring b{position:relative;font-family:'Space Grotesk',sans-serif;font-size:2.6rem;color:#fff;line-height:1}
.bigring small{position:relative;color:var(--txt-dim);font-size:.72rem}
.scorelegend{flex:1;min-width:200px;display:grid;gap:10px}
.slrow{display:flex;align-items:center;gap:10px;font-size:.86rem}
.slrow .lbl{width:130px;flex:none;color:var(--txt-dim)}
.slrow .track{flex:1;height:8px;background:var(--ink-3);border-radius:99px;overflow:hidden}
.slrow .track i{display:block;height:100%;border-radius:99px;width:0;transition:width 1s var(--ease)}
.slrow .num{width:36px;text-align:right;font-family:'Space Grotesk',sans-serif;color:#fff}

/* SoM bars */
.sombars{display:grid;gap:12px}
.sbar{display:flex;align-items:center;gap:12px}
.sbar__eng{width:120px;flex:none;font-size:.88rem;color:var(--txt-light);display:flex;align-items:center;gap:7px}
.sbar__eng .zh{background:var(--ink-4);border-radius:6px;padding:.1em .45em;font-size:.78rem}
.sbar__track{flex:1;height:22px;background:var(--ink-3);border-radius:8px;overflow:hidden;position:relative}
.sbar__fill{height:100%;border-radius:8px;width:0;transition:width 1.1s var(--ease);background:var(--grad);display:flex;align-items:center;justify-content:flex-end;padding-right:8px}
.sbar__fill span{font-size:.72rem;font-weight:700;color:#fff}
.sbar__na{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:.72rem;color:var(--txt-dim)}

/* competitor table */
.ctbl{width:100%;border-collapse:collapse;font-size:.9rem}
.ctbl th,.ctbl td{padding:12px 10px;text-align:left;border-bottom:1px solid var(--line-d)}
.ctbl th{color:var(--txt-dim);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}
.ctbl td{color:var(--txt-light)}
.ctbl .you{background:rgba(109,94,252,.1)}
.ctbl .you td:first-child{border-left:3px solid var(--violet)}
.ctbl .rank{font-family:'Space Grotesk',sans-serif;color:var(--txt-dim);width:36px}
.ctbl .name{font-weight:600;color:#fff}
.ctbl .tag{font-size:.7rem;font-weight:700;padding:.15em .55em;border-radius:99px;background:rgba(109,94,252,.18);color:var(--violet-2)}
.mini-track{height:7px;background:var(--ink-3);border-radius:99px;overflow:hidden;width:90px;display:inline-block;vertical-align:middle;margin-right:8px}
.mini-track i{display:block;height:100%;background:var(--grad);border-radius:99px;width:0;transition:width 1s var(--ease)}

/* sentiment donut */
.donut{width:150px;height:150px;border-radius:50%;flex:none;position:relative;
  background:conic-gradient(var(--green) 0 var(--pos),var(--txt-dim) var(--pos) var(--neu),var(--red) var(--neu) 100%)}
.donut::before{content:"";position:absolute;inset:26px;border-radius:50%;background:var(--ink-2)}
.donut b{position:absolute;inset:0;display:grid;place-content:center;text-align:center;font-family:'Space Grotesk',sans-serif;color:#fff;font-size:1.3rem;line-height:1.1}
.donut b small{display:block;font-size:.62rem;color:var(--txt-dim)}
.sentlegend{display:grid;gap:10px}
.sentlegend div{display:flex;align-items:center;gap:9px;font-size:.86rem;color:var(--txt-light)}
.dot{width:11px;height:11px;border-radius:3px}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.tags span{font-size:.78rem;padding:.3em .7em;border-radius:99px;background:var(--ink-3);border:1px solid var(--line-d);color:var(--txt-light)}

/* suggestions / roadmap */
.sugg{display:flex;gap:14px;padding:16px;background:var(--ink-3);border-radius:12px;margin-bottom:12px;border:1px solid var(--line-d)}
.sugg__pri{flex:none;width:70px;font-size:.68rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:.35em 0;text-align:center;border-radius:8px;height:fit-content}
.pri-hi{background:rgba(255,77,109,.16);color:var(--red)}
.pri-md{background:rgba(255,176,32,.16);color:var(--amber)}
.pri-lo{background:rgba(34,197,94,.14);color:var(--green)}
.sugg h4{color:#fff;font-size:.98rem;margin-bottom:.2rem}
.sugg p{font-size:.86rem;color:var(--txt-dim)}
.sugg__impact{font-size:.74rem;color:var(--mint-2);margin-top:.4rem;font-weight:600}
.roadmap{display:grid;gap:0}
.rm{display:grid;grid-template-columns:110px 1fr;gap:16px;padding:16px 0;border-bottom:1px solid var(--line-d)}
.rm__q{font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--violet-2)}
.rm h4{color:#fff;font-size:.96rem}
.rm p{font-size:.86rem;color:var(--txt-dim);margin-top:.2rem}

.locked{position:relative}
.locked::after{content:"";position:absolute;inset:0;display:grid;place-items:center;background:rgba(11,12,20,.72);backdrop-filter:blur(3px);border-radius:16px;color:#fff;font-weight:600;font-size:.9rem}

@media (max-width:900px){
  .app-shell{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;z-index:60;width:248px;transform:translateX(-100%);transition:transform .3s var(--ease)}
  .side.open{transform:none}
  .mobtoggle{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--ink-3);color:#fff}
  .kpis{grid-template-columns:1fr 1fr}
  .blocks{grid-template-columns:1fr}
  .rm{grid-template-columns:1fr}
}
@media (max-width:520px){.kpis{grid-template-columns:1fr}}
