/* ═══════════════════════════════════════════════════════════════════
   REPUTON — design tokens / TERRITORY LEDGER (6 виборів, до коду):
   1) Layout-архетип : bento-плитки всередині sidebar-app shell
   2) Шрифти         : Space Grotesk (заголовки) + Inter (текст)
   3) Логіка кольору : duotone — фіолет #5B3DF5 + бурштин #FFB020
   4) Радіус/щільність: soft/airy (16–20px, багато повітря)
   5) Рух            : fade+підйом на завантаженні (respect reduced-motion)
   6) Підпис-фішка   : KPI-спарклайни + сентимент-донат + AI-composer
   ═══════════════════════════════════════════════════════════════════ */

:root{
  /* duotone core */
  --violet:#5B3DF5;
  --violet-700:#4A2FD6;
  --violet-100:#ECE9FE;
  --violet-50:#F4F2FF;
  --amber:#FFB020;
  --amber-100:#FFF1D6;

  /* canvas + ink (нейтрали тоновані в бік фіолету) */
  --canvas:#F7F7FB;
  --surface:#FFFFFF;
  --ink:#1A1A22;
  --ink-2:#52525F;
  --ink-3:#8B8B98;
  --line:#E7E5F0;
  --line-2:#EFEDF6;

  /* dark sidebar */
  --side:#13131A;
  --side-2:#1E1E28;
  --side-ink:#C7C5D6;
  --side-ink-2:#7A7889;

  /* semantic */
  --pos:#16A34A;  --pos-bg:#E6F6EC;
  --neu:#B7791F;  --neu-bg:#FCF1DC;
  --neg:#DC2626;  --neg-bg:#FCE9E9;
  --star:#FFB020;

  /* sources */
  --c-google:#5B3DF5;
  --c-maps:#7C66F7;
  --c-facebook:#9D8CF9;
  --c-2gis:#C3B8FB;

  /* shape */
  --r-lg:20px; --r-md:16px; --r-sm:12px; --r-xs:9px;
  --pad:clamp(16px,3vw,28px);
  --shadow:0 1px 2px rgba(26,26,34,.04), 0 8px 24px -12px rgba(91,61,245,.18);
  --shadow-lg:0 24px 60px -28px rgba(91,61,245,.40);

  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:'Space Grotesk','Inter',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);background:var(--canvas);color:var(--ink);
  font-size:15px;line-height:1.5;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--display);margin:0;line-height:1.12;letter-spacing:-.01em;font-weight:600}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--violet);outline-offset:2px;border-radius:6px}

/* ── motion ── */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.rise{animation:rise .55s cubic-bezier(.2,.7,.2,1) both}
.d1{animation-delay:.05s}.d2{animation-delay:.11s}.d3{animation-delay:.17s}
.d4{animation-delay:.23s}.d5{animation-delay:.29s}.d6{animation-delay:.35s}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}

/* ════ APP SHELL ════ */
.app{display:flex;min-height:100vh}
.side{
  width:248px;flex:0 0 248px;background:var(--side);color:var(--side-ink);
  display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;
  height:100vh;
}
.side__brand{display:flex;align-items:center;gap:11px;padding:6px 8px 22px;font-family:var(--display);font-weight:700;font-size:19px;color:#fff;letter-spacing:-.02em}
.logo-dot{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--violet),var(--amber));display:grid;place-items:center;flex:0 0 auto;box-shadow:0 6px 16px -6px rgba(91,61,245,.7)}
.logo-dot svg{width:17px;height:17px}
.side__sec{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--side-ink-2);padding:14px 12px 6px;font-weight:600}
.nav-i{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:11px;color:var(--side-ink);font-weight:500;font-size:14.5px;min-height:44px}
.nav-i svg{width:18px;height:18px;flex:0 0 auto;opacity:.85}
.nav-i:hover{background:var(--side-2);color:#fff}
.nav-i.on{background:linear-gradient(120deg,rgba(91,61,245,.30),rgba(91,61,245,.10));color:#fff}
.nav-i.on svg{opacity:1}
.nav-i.dis{opacity:.4;pointer-events:none}
.side__foot{margin-top:auto;padding:14px 12px 4px;font-size:12px;color:var(--side-ink-2);line-height:1.45}
.side__foot a{color:var(--side-ink)}

.main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}
.topbar{
  display:flex;align-items:center;gap:14px;padding:16px var(--pad);
  background:rgba(247,247,251,.85);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;
}
.topbar h1{font-size:clamp(1.05rem,2.4vw,1.4rem)}
.topbar .sub{color:var(--ink-3);font-size:12.5px;margin-top:2px}
.biz-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 12px 6px 6px;font-size:13px;font-weight:600;box-shadow:var(--shadow)}
.biz-chip .av{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--violet-700));color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700;font-family:var(--display)}
.grow{flex:1 1 auto}
.btn-ghost{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:9px 13px;font-size:13.5px;font-weight:600;color:var(--ink);min-height:40px}
.btn-ghost:hover{border-color:var(--violet);color:var(--violet)}
.btn-ghost svg{width:16px;height:16px}

.content{padding:var(--pad);max-width:1180px;width:100%;margin:0 auto}

/* mobile sidebar → topbar pills */
.m-nav{display:none}
@media(max-width:900px){
  .app{flex-direction:column}
  .side{display:none}
  .m-nav{
    display:flex;gap:7px;overflow-x:auto;padding:10px var(--pad);
    background:var(--side);position:sticky;top:0;z-index:40;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .m-nav::-webkit-scrollbar{display:none}
  .m-nav a{flex:0 0 auto;color:var(--side-ink);background:var(--side-2);padding:9px 14px;border-radius:999px;font-size:13.5px;font-weight:600;min-height:40px;display:flex;align-items:center}
  .m-nav a.on{background:linear-gradient(120deg,var(--violet),var(--violet-700));color:#fff}
  .m-nav a.dis{opacity:.4}
  .m-brand{flex:0 0 auto;display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--display);font-weight:700;padding-right:6px}
  .m-brand .logo-dot{width:26px;height:26px}
}

/* ════ BENTO ════ */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:18px;box-shadow:var(--shadow);min-width:0;
}
.card h3{font-size:14px;color:var(--ink-2);font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:4px}
.card .hd{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}
.span3{grid-column:span 3}.span4{grid-column:span 4}.span5{grid-column:span 5}
.span6{grid-column:span 6}.span7{grid-column:span 7}.span8{grid-column:span 8}
.span12{grid-column:span 12}
@media(max-width:1024px){
  .span3{grid-column:span 6}.span4{grid-column:span 6}.span5{grid-column:span 6}
  .span7{grid-column:span 12}.span8{grid-column:span 12}.span6{grid-column:span 12}
}
@media(max-width:560px){
  .bento{gap:13px}
  .span3,.span4,.span5,.span6,.span7,.span8{grid-column:span 12}
}

/* ── KPI ── */
.kpi .top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.kpi .lbl{font-size:12.5px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.kpi .val{font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,3vw,2.05rem);letter-spacing:-.02em;margin-top:6px;display:flex;align-items:baseline;gap:6px}
.kpi .val .unit{font-size:.55em;color:var(--ink-3);font-weight:600}
.kpi .delta{font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:3px;padding:3px 7px;border-radius:999px}
.delta.up{color:var(--pos);background:var(--pos-bg)}
.delta.down{color:var(--neg);background:var(--neg-bg)}
.delta.good{color:var(--pos);background:var(--pos-bg)}
.spark{margin-top:12px;width:100%;height:34px;display:block}
.stars{color:var(--star);letter-spacing:1px;font-size:13px;line-height:1}
.stars .o{color:var(--line)}

/* chips */
.chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px;line-height:1.4}
.chip.pos{color:var(--pos);background:var(--pos-bg)}
.chip.neu{color:var(--neu);background:var(--neu-bg)}
.chip.neg{color:var(--neg);background:var(--neg-bg)}
.chip.src{color:var(--violet);background:var(--violet-100)}
.chip.dot::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor}

/* donut legend */
.legend{display:flex;flex-direction:column;gap:9px;margin-top:4px}
.legend .row{display:flex;align-items:center;gap:9px;font-size:13.5px}
.legend .sw{width:11px;height:11px;border-radius:4px;flex:0 0 auto}
.legend .nm{color:var(--ink-2);font-weight:500}
.legend .pc{margin-left:auto;font-weight:700;font-family:var(--display)}

/* source bars */
.bars{display:flex;flex-direction:column;gap:13px}
.bar-row{display:grid;grid-template-columns:74px 1fr auto;align-items:center;gap:11px;font-size:13px}
.bar-track{height:9px;border-radius:999px;background:var(--line-2);overflow:hidden}
.bar-fill{height:100%;border-radius:999px}
.bar-row .v{font-weight:700;font-family:var(--display);color:var(--ink)}

/* topic cloud */
.topics{display:flex;flex-wrap:wrap;gap:8px}
.topic{font-size:13px;font-weight:600;padding:6px 11px;border-radius:999px;border:1px solid var(--line)}
.topic .n{color:var(--ink-3);font-weight:600;margin-left:4px;font-size:12px}
.topic.pos{background:var(--pos-bg);border-color:transparent;color:var(--pos)}
.topic.neg{background:var(--neg-bg);border-color:transparent;color:var(--neg)}
.topic.neu{background:var(--neu-bg);border-color:transparent;color:var(--neu)}

/* review feed (dashboard) */
.feed{display:flex;flex-direction:column;gap:2px}
.rev{display:flex;gap:13px;padding:15px 4px;border-bottom:1px solid var(--line-2)}
.rev:last-child{border-bottom:0}
.av{width:40px;height:40px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-weight:700;font-family:var(--display);font-size:14px;color:#fff;background:linear-gradient(135deg,var(--violet),var(--violet-700))}
.av.neg{background:linear-gradient(135deg,#E5484D,#B42318)}
.av.neu{background:linear-gradient(135deg,#D9A93A,#B7791F)}
.rev .bd{min-width:0;flex:1}
.rev .meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px}
.rev .who{font-weight:700;color:var(--ink)}
.rev .t{color:var(--ink-3);font-size:12px}
.rev .txt{color:var(--ink-2);font-size:13.5px;margin-top:6px;line-height:1.5}
.ai-prev{margin-top:10px;border:1px dashed var(--violet);background:var(--violet-50);border-radius:var(--r-sm);padding:10px 12px}
.ai-prev .lead{display:flex;align-items:center;gap:7px;font-size:11.5px;font-weight:700;color:var(--violet);text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}
.ai-prev .lead svg{width:14px;height:14px}
.ai-prev p{margin:0;font-size:13.5px;color:var(--ink);line-height:1.5}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;font-weight:600;font-size:14.5px;padding:11px 17px;min-height:44px;border:1px solid transparent;transition:transform .12s ease,box-shadow .2s ease}
.btn svg{width:17px;height:17px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--violet);color:#fff;box-shadow:0 10px 24px -12px rgba(91,61,245,.8)}
.btn-primary:hover{background:var(--violet-700)}
.btn-amber{background:var(--amber);color:#3d2a00}
.btn-amber:hover{filter:brightness(.97)}
.btn-out{background:var(--surface);border-color:var(--line);color:var(--ink)}
.btn-out:hover{border-color:var(--violet);color:var(--violet)}
.btn-soft{background:var(--violet-100);color:var(--violet-700)}
.btn-soft:hover{background:var(--violet-50)}

.note{display:flex;gap:12px;background:var(--violet-50);border:1px solid var(--violet-100);border-radius:var(--r-md);padding:15px 17px;font-size:13.5px;color:var(--ink-2);line-height:1.55}
.note svg{width:20px;height:20px;flex:0 0 auto;color:var(--violet)}
.note b{color:var(--ink)}

/* footer */
.site-foot{padding:20px var(--pad) 30px;color:var(--ink-3);font-size:12.5px;text-align:center}
.site-foot a{color:var(--violet);font-weight:600}
