/* Customer dashboard — shared shell + components (light + dark via CSS vars).
   Used by index.html (Overview) and the inner screens (tags-keywords.html, …). */
:root{
  --brand:#6d4aff;            /* client's brand accent (themeable per tenant) */
  --ink:#1f2430; --muted:#5b6472; --line:#e6e8ee; --bg:#f5f6fa; --card:#fff; --surface:#fff; --hover:#f3f1ff; --track:#eee; --navtext:#3b4252;
  --ok:#1d7a46; --okbg:#e7f6ee; --warn:#9a6a00; --warnbg:#fdf3da; --gate:#8a5cff; --gatebg:#efeaff;
  --ok-text:#147a3e; --gate-text:#6a3fd0; --link:#5b3fd6;  /* accent TEXT — readable on tinted bgs in both modes */
  --badbg:#fdecea; --bad-text:#a3261b; --warn-text:#8a5e00;
  --radius:14px; --font:'Segoe UI',system-ui,-apple-system,sans-serif;
}
body.dark{
  --ink:#e8eaf0; --muted:#9aa0ad; --line:#2a2f3a; --bg:#0f1116; --card:#1b1e26;
  --surface:#1b1e26; --hover:#272233; --track:#2a2f3a; --okbg:#13351f; --gatebg:#241b3d; --navtext:#c6ccd8;
  --ok-text:#5fd38a; --gate-text:#b39bff; --link:#b3a4ff;
  --badbg:#3a1715; --bad-text:#ff8a7a; --warnbg:#3a2f12; --warn-text:#f0c674;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);color:var(--ink);background:var(--bg);display:flex;min-height:100vh}

/* ---- sidebar ---- */
.side{width:236px;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;flex-shrink:0}
.brand{padding:18px 18px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:11px}
.brand .logo{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.brand .logo img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.brand .logo .lg-dark{display:none}                 /* light mode (default): show black horse */
body.dark .brand .logo .lg-light{display:none}      /* dark mode: hide black */
body.dark .brand .logo .lg-dark{display:block}      /* dark mode: show brown horse */
.brand .who{line-height:1.25}
.brand .who b{font-size:0.9375rem} .brand .who span{font-size:0.75rem;color:var(--muted)}
nav{padding:10px 10px;flex:1;overflow:auto}
nav .grp{font-size:0.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:12px 10px 6px;font-weight:700}
nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:9px;text-decoration:none;color:var(--navtext);font-size:0.9375rem;font-weight:500;position:relative}
nav a:hover{background:var(--hover)}
nav a.active{background:var(--brand);color:#fff}
nav a svg{width:18px;height:18px;flex-shrink:0;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
nav a .dot{margin-left:auto;width:7px;height:7px;border-radius:50%}
.dot.go{background:#28c76f}                /* configured/active */
.dot.set{background:#d0c4ff}              /* available, needs setup */
/* SMS is HARD-LOCKED (admin, unfinished) — show a lock instead of a status dot, + hover tooltip */
.dot.gate{width:13px;height:13px;border-radius:0;color:var(--muted);background:currentColor;cursor:not-allowed;position:relative;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 1a5 5 0 0 0-5 5v3H6a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-9a2 2 0 0 0-2-2h-1V6a5 5 0 0 0-5-5zm3 8H9V6a3 3 0 0 1 6 0v3z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 1a5 5 0 0 0-5 5v3H6a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-9a2 2 0 0 0-2-2h-1V6a5 5 0 0 0-5-5zm3 8H9V6a3 3 0 0 1 6 0v3z'/%3E%3C/svg%3E") center/contain no-repeat;}
.dot.gate::after{content:"Admin Locked: Unfinished";position:absolute;right:0;top:calc(100% + 7px);background:#1c2430;color:#fff;font-size:0.75rem;font-weight:500;letter-spacing:.01em;padding:5px 8px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s;z-index:60;box-shadow:0 6px 18px rgba(0,0,0,.28)}
nav a:hover .dot.gate::after{opacity:1}
.side-foot{padding:12px 16px;border-top:1px solid var(--line);font-size:0.75rem;color:var(--muted)}
/* Theme toggles — A (top-bar icon swap) + D (sidebar segmented) */
.tg-iconswap{position:relative;width:40px;height:40px;border-radius:10px;border:1px solid var(--line);background:var(--hover);color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.tg-iconswap svg{position:absolute;width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:opacity .35s ease,transform .45s ease}
body:not(.dark) .tg-iconswap .i-moon{opacity:0;transform:rotate(-70deg) scale(.4)}
body.dark .tg-iconswap .i-sun{opacity:0;transform:rotate(70deg) scale(.4)}
body.dark .tg-iconswap{color:#ffd36b}
.nav-theme{padding:10px 10px 2px}
.tg-seg{display:flex;background:var(--hover);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px}
.tg-seg button{flex:1;border:0;background:none;cursor:pointer;font-size:0.75rem;font-weight:600;color:var(--muted);padding:6px 8px;border-radius:7px;display:flex;align-items:center;justify-content:center;gap:6px;line-height:1}
.tg-seg button svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tg-seg button:hover{color:var(--ink)}
.tg-seg button.on{background:var(--brand);color:#fff}

/* ---- main ---- */
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.top{display:flex;align-items:center;gap:16px;padding:16px 26px;background:var(--surface);border-bottom:1px solid var(--line)}
.top h1{font-size:1.1875rem;font-weight:600}
.top .dom{font-size:0.75rem;color:var(--muted);background:var(--hover);border:1px solid var(--line);padding:3px 9px;border-radius:20px}
.top .spacer{flex:1}
.btn{background:var(--brand);color:#fff;border:0;border-radius:9px;padding:9px 15px;font-size:0.9375rem;font-weight:600;cursor:pointer}
.ghost{background:var(--hover);color:var(--ink);border:1px solid var(--line);border-radius:9px;width:38px;height:36px;font-size:1rem;cursor:pointer;line-height:1}
.content{padding:24px 26px;overflow:auto}

.legend{display:flex;gap:18px;font-size:0.75rem;color:var(--muted);margin-bottom:16px;flex-wrap:wrap}
.legend span{display:flex;align-items:center;gap:6px}
.legend i{width:8px;height:8px;border-radius:50%}

/* module summary cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:0 1px 3px rgba(0,0,0,.04);display:flex;flex-direction:column;gap:6px;min-height:128px}
.card .h{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.card .h svg{width:16px;height:16px;fill:none;stroke:var(--brand);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.card .big{font-size:1.875rem;font-weight:700;line-height:1.1}
.card .sub{font-size:0.75rem;color:var(--muted)}
.card .trend{font-size:0.75rem;font-weight:600;color:var(--ok-text)}
.card .open{margin-top:auto;font-size:0.75rem;font-weight:600;color:var(--link);text-decoration:none}
.pill{align-self:flex-start;font-size:0.75rem;font-weight:700;padding:2px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}
.pill.set{background:var(--gatebg);color:var(--gate-text)}
.pill.gate{background:var(--gatebg);color:var(--gate-text)}
.pill.ok{background:var(--okbg);color:var(--ok-text)}

h2.sec{font-size:0.9375rem;margin:26px 0 12px;font-weight:700}
.two{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}

/* ---- mobile nav (hamburger + off-canvas drawer) ---- */
/* Hamburger lives in the .top bar; hidden on desktop, shown ≤860px. dashboard.js injects it + the scrim. */
.navtoggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;margin-right:8px;
  border:1px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink);cursor:pointer;flex-shrink:0;padding:0}
.navtoggle svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none}
.navtoggle-float{position:fixed;top:10px;left:10px;z-index:61}        /* fallback when a page has no .top bar */
.navclose{display:none;position:absolute;top:10px;right:10px;z-index:2;width:40px;height:40px;align-items:center;
  justify-content:center;border:1px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink);cursor:pointer;padding:0}
.navclose svg{width:20px;height:20px;stroke:currentColor;stroke-width:2;fill:none}
.nav-scrim{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:55;opacity:0;visibility:hidden;transition:opacity .25s ease}
.nav-scrim.show{opacity:1;visibility:visible}

@media(max-width:860px){
  .two{grid-template-columns:1fr}
  .navtoggle{display:inline-flex}                                     /* reveal the hamburger */
  .side{position:fixed;top:0;left:0;bottom:0;z-index:60;width:236px;max-width:82vw;overflow-y:auto;
    transform:translateX(-100%);transition:transform .25s ease;box-shadow:0 0 30px rgba(0,0,0,.28)}
  .side.open{transform:translateX(0)}
  .navclose{display:inline-flex}                                      /* reveal the in-drawer X */
  .side .brand{padding-right:52px}                                    /* reserve room so the X never overlaps the brand */
}
@media(min-width:861px){ .nav-scrim{display:none} }                   /* never intercept clicks on desktop */

/* campaign progress */
.camp{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.camp .ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.camp .ch b{font-size:0.9375rem} .camp .ch span{font-size:0.75rem;color:var(--muted)}
.bar{height:9px;background:var(--track);border-radius:6px;overflow:hidden;margin:10px 0 6px}
.bar i{display:block;height:100%;background:var(--brand);border-radius:6px}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.chip{font-size:0.75rem;background:var(--hover);color:var(--link);border:1px solid var(--line);border-radius:7px;padding:4px 9px;display:flex;align-items:center;gap:5px}

/* activity feed */
.feed{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:8px 4px}
.feed .it{display:flex;gap:11px;padding:11px 14px;border-bottom:1px solid var(--line);font-size:0.9375rem}
.feed .it:last-child{border-bottom:0}
.feed .it .ic{width:28px;height:28px;border-radius:8px;background:var(--hover);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--brand);font-size:0.9375rem}
.feed .it .t{color:var(--muted);font-size:0.75rem;margin-top:2px}

/* ===== Tags & Keywords screen ===== */
.tk-intro{font-size:0.9375rem;color:var(--muted);margin:0 0 18px;max-width:720px;line-height:1.55}
.tk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.tk-plat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;display:flex;flex-direction:column}
.tk-phead{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}
.tk-phead b{font-size:0.9375rem}
.tk-cap{font-size:0.75rem;color:var(--muted);margin-bottom:6px}
.tk-tier{font-size:0.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700;margin:12px 0 6px}
.tags{display:flex;flex-wrap:wrap;gap:6px}
.tag{font-size:0.75rem;background:var(--hover);color:var(--link);border:1px solid var(--line);border-radius:7px;padding:3px 9px;font-weight:600}
.tk-rec{margin-top:14px;padding-top:12px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px}
/* inside the flex-column platform cards, pin the "Copy set" row to the BOTTOM so it lines up across
   cards of unequal height (shorter TikTok/Facebook cards floated it mid-card — other-claude QA). */
.tk-plat .tk-rec{margin-top:auto}
.tk-rec .lbl{font-size:0.75rem;color:var(--muted)}
.copybtn{background:var(--brand);color:#fff;border:0;border-radius:8px;padding:7px 13px;font-size:0.75rem;font-weight:600;cursor:pointer;white-space:nowrap}
.copybtn.copied{background:var(--ok-text)}
/* keyword table */
.kw{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;font-size:0.9375rem}
.kw th{text-align:left;background:var(--hover);color:var(--muted);font-size:0.75rem;text-transform:uppercase;letter-spacing:.06em;padding:9px 12px;font-weight:700}
.kw td{padding:9px 12px;border-top:1px solid var(--line)}
.kw td.r{text-align:right}
.intent{font-size:0.75rem;font-weight:700;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;background:var(--hover);color:var(--link)}
.intent.txn{background:var(--okbg);color:var(--ok-text)}      /* transactional — highest intent */
.intent.comm{background:var(--gatebg);color:var(--gate-text)} /* commercial */
.note{font-size:0.75rem;color:var(--muted);margin-top:12px;line-height:1.5}

/* ===== QR Codes screen ===== */
.qr-wrap{display:grid;grid-template-columns:340px 1fr;gap:16px;align-items:start}
@media(max-width:820px){.qr-wrap{grid-template-columns:1fr}}
.qr-controls{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}
.qr-controls .group{margin-bottom:16px}
.qr-controls .group h3{font-size:0.9375rem;color:var(--ink);margin:0 0 10px;font-weight:700;padding-bottom:7px;border-bottom:1px solid var(--line)}
.qr-controls label{display:block;font-size:0.75rem;font-weight:600;margin:8px 0 4px}
.qr-controls input[type=text],.qr-controls input[type=url],.qr-controls select{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:7px;font-size:0.9375rem;background:var(--surface);color:var(--ink)}
.qr-controls input[type=color]{width:46px;height:32px;border:1px solid var(--line);border-radius:6px;padding:0;background:var(--surface);vertical-align:middle;cursor:pointer}
.qr-controls input[type=file]{font-size:0.75rem;color:var(--muted);max-width:100%}
.qr-controls code{background:var(--hover);padding:1px 5px;border-radius:4px;font-size:0.75rem}
.qr-row{display:flex;align-items:center;gap:10px}.qr-row .col{flex:1}
.qr-chk{display:flex;align-items:center;gap:8px;font-size:0.75rem;font-weight:600;margin:8px 0}.qr-chk input{width:auto;margin:0}
.btn.ghost{background:var(--surface);color:var(--brand);border:1px solid var(--brand);width:auto;height:auto;line-height:1.2;white-space:nowrap}
/* ^ width/height:auto resets the .ghost icon-button sizing (38x36) that was clipping
   text buttons like "SVG (print)". Plain .ghost (the theme toggle) keeps the square size. */
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn.full{width:100%}
.qr-stage{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;align-items:center;gap:16px;position:sticky;top:16px}
#preview{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:0 4px 18px rgba(0,0,0,.06)}
.checker{background-image:linear-gradient(45deg,#eee 25%,transparent 25%),linear-gradient(-45deg,#eee 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#eee 75%),linear-gradient(-45deg,transparent 75%,#eee 75%);background-size:18px 18px;background-position:0 0,0 9px,9px -9px,-9px 0}
.sizes{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.qr-hint{font-size:0.75rem;color:var(--muted);line-height:1.45;margin-top:6px}
.reg{font-size:0.75rem;color:var(--muted);margin-top:6px}.reg code{background:var(--hover);padding:1px 5px;border-radius:4px}
.verify{font-size:0.9375rem;font-weight:700;border-radius:9px;padding:9px 13px;text-align:center;width:100%;max-width:380px}
.verify.ok{background:var(--okbg);color:var(--ok-text);border:1px solid var(--ok-text)}
.verify.bad{background:var(--badbg);color:var(--bad-text);border:1px solid var(--bad-text)}
.verify.warn{background:var(--warnbg);color:var(--warn-text);border:1px solid var(--warn-text)}
.verify.checking{background:var(--hover);color:var(--muted);border:1px solid var(--line)}

/* ===== QR wizard ===== */
.wiz{max-width:640px}   /* left-aligned column; nav sits under the card */
.wiz.w-wide{max-width:880px}       /* design step needs room for controls + preview */
.wiz.w-dl{max-width:860px}         /* download step: stage + summary side by side */
/* progress dots */
.wiz-prog{display:flex;align-items:center;gap:0;margin-bottom:8px;flex-wrap:wrap}
.wiz-prog .st{display:flex;align-items:center;gap:0}
.wiz-prog .n{width:26px;height:26px;border-radius:50%;background:var(--hover);border:1.5px solid var(--line);color:var(--muted);
  display:flex;align-items:center;justify-content:center;font-size:0.75rem;font-weight:700;cursor:default;flex-shrink:0;transition:.15s}
.wiz-prog .st.done .n{background:var(--okbg);border-color:var(--ok-text);color:var(--ok-text);cursor:pointer}
.wiz-prog .st.active .n{background:var(--brand);border-color:var(--brand);color:#fff}
.wiz-prog .ln{width:30px;height:2px;background:var(--line);flex-shrink:0}
.wiz-prog .st.done + .ln{background:var(--ok-text)}
@media(max-width:760px){.wiz-prog .ln{width:14px}}
.wiz-stepname{font-size:0.75rem;color:var(--muted);font-weight:600;margin-bottom:18px}
.wiz-stepname b{color:var(--brand)}

/* step cards */
.wiz-step{display:none}
.wiz-step.show{display:block;animation:wizin .22s ease}
@keyframes wizin{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.wiz-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px 28px;max-width:none}
.wiz-card.wide{max-width:none}
.wiz h2.q{font-size:1.3125rem;font-weight:700;margin-bottom:7px;letter-spacing:-.01em}
.wiz p.lead{font-size:0.9375rem;color:var(--muted);line-height:1.6;margin-bottom:6px;max-width:620px}
.wiz label.fld{display:block;font-size:0.75rem;font-weight:700;margin:18px 0 6px}
.wiz input[type=text],.wiz input[type=url],.wiz select{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font-size:0.9375rem;background:var(--surface);color:var(--ink)}
.wiz select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:38px}
.wiz input:focus,.wiz select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--gatebg)}
.wiz .hint{font-size:0.75rem;color:var(--muted);line-height:1.5;margin-top:7px}
.wiz .err{font-size:0.75rem;color:var(--bad-text);font-weight:600;margin-top:7px;min-height:0}
.linklike{background:none;border:0;color:var(--link);font-family:var(--font);font-size:0.9375rem;font-weight:600;cursor:pointer;padding:16px 0 0;display:inline-block}
.linklike:hover{text-decoration:underline}

/* nav buttons */
.wiz-nav{display:flex;justify-content:space-between;margin-top:22px;gap:12px}
.wiz-nav .btn.back{background:var(--hover);color:var(--ink);border:1px solid var(--line)}

/* toggle switch */
.switch{position:relative;display:inline-block;width:48px;height:27px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0}
.switch .sl{position:absolute;inset:0;background:var(--track);border-radius:27px;transition:.2s;cursor:pointer}
.switch .sl:before{content:"";position:absolute;height:21px;width:21px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.switch input:checked + .sl{background:var(--brand)}
.switch input:checked + .sl:before{transform:translateX(21px)}
.toggle-row{display:flex;align-items:center;gap:14px;background:var(--hover);border:1px solid var(--line);border-radius:11px;padding:15px 17px;margin:18px 0 4px}
.toggle-row .lab b{font-size:0.9375rem;display:block}
.toggle-row .lab span{font-size:0.8125rem;color:var(--muted)}
.toggle-row .grow{flex:1}

/* numbered "how it works" explainer */
.explain{margin:14px 0 4px;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.explain .row{display:grid;grid-template-columns:30px 1fr;gap:13px;padding:13px 16px;align-items:center}
.explain .row + .row{border-top:1px solid var(--line)}
.explain .num{width:28px;height:28px;border-radius:50%;background:var(--gatebg);color:var(--gate-text);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.9375rem}
.explain .tx{font-size:0.9375rem;line-height:1.5}
.explain .tx b{color:var(--ink)}

/* live URL preview + locked field */
.urlprev{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:0.9375rem;background:var(--hover);border:1px dashed var(--line);border-radius:10px;padding:14px 16px;word-break:break-all;line-height:1.5}
.urlprev .lit{color:var(--muted)} .urlprev .var{color:var(--brand);font-weight:700}
.lockfield{display:flex;align-items:center;gap:11px;background:var(--hover);border:1px solid var(--line);border-radius:10px;padding:12px 15px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:0.9375rem;word-break:break-all}
.lockfield svg{width:16px;height:16px;stroke:var(--muted);fill:none;stroke-width:2;flex-shrink:0}
.lockfield .lk{margin-left:auto;font-family:var(--font);font-size:0.75rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.disabledbox{opacity:.5;pointer-events:none}

.camptag{display:inline-flex;align-items:center;gap:6px;font-size:0.75rem;font-weight:700;background:var(--gatebg);color:var(--gate-text);border-radius:7px;padding:4px 10px}
.camptag.evt{background:var(--okbg);color:var(--ok-text)}

/* design step: controls + sticky stage */
.wiz-design{display:grid;grid-template-columns:340px 1fr;gap:16px;align-items:start}
@media(max-width:820px){.wiz-design{grid-template-columns:1fr}}

/* download/summary step */
.sum{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;max-width:520px}
.sumrow{display:flex;justify-content:space-between;gap:18px;padding:11px 0;border-bottom:1px solid var(--line);font-size:0.9375rem}
.sumrow:last-child{border:0}
.sumrow .k{color:var(--muted);flex-shrink:0}
.sumrow .v{font-weight:600;text-align:right;word-break:break-all}
.dl-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;max-width:none}

/* ===== QR hub ===== */
.qr-hub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(264px,1fr));gap:16px}
.qr-newcard{background:var(--card);border:2px dashed var(--line);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;min-height:210px;gap:5px;transition:.15s}
.qr-newcard:hover{border-color:var(--brand);background:var(--hover)}
.qr-newcard .plus{font-size:2.25rem;font-weight:300;line-height:1;color:var(--brand)}
.qr-newcard .nl{font-weight:700;font-size:0.9375rem;color:var(--ink)}
.qr-newcard .ns{font-size:0.75rem;color:var(--muted)}
.qrcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;display:flex;flex-direction:column;gap:6px;min-height:210px}
.qrcard-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2px}
.qr-thumb{width:52px;height:52px;border-radius:11px;background:var(--hover);display:flex;align-items:center;justify-content:center;color:var(--brand)}
.qr-thumb svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.qrname{font-size:0.9375rem}
.qrmeta{font-size:0.75rem;color:var(--muted);line-height:1.4}
.qrscans{font-size:0.75rem;color:var(--ok-text);font-weight:600}
.qractions{margin-top:auto;display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--line)}
.qractions a,.qractions button{font-size:0.75rem;font-weight:600;border-radius:7px;padding:6px 10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);cursor:pointer;text-decoration:none;line-height:1.2}
.qractions a:hover,.qractions button:hover{border-color:var(--brand);color:var(--brand)}
.qractions .del{margin-left:auto;border-color:transparent;color:var(--muted);padding:6px 7px}
.qractions .del svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:block}
.qractions .del:hover{color:var(--bad-text);border-color:var(--bad-text)}
.hubmsg{font-size:0.9375rem;color:var(--gate-text);background:var(--gatebg);border:1px solid var(--gate);border-radius:9px;padding:10px 13px;margin-top:16px;display:none}
.hubmsg.show{display:block}
/* summary edit pencil (wizard step 5 → jump back to a step) */
.editstep{background:none;border:0;cursor:pointer;color:var(--muted);padding:0;margin-left:8px;vertical-align:middle;line-height:0}
.editstep svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.editstep:hover{color:var(--brand)}
/* events: date badge + event form textarea */
.ev-date{width:52px;height:52px;border-radius:11px;background:var(--hover);display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;flex-shrink:0}
.ev-date .m{font-size:0.75rem;font-weight:700;letter-spacing:.08em;color:var(--brand);text-transform:uppercase}
.ev-date .d{font-size:1.25rem;font-weight:700;color:var(--ink);margin-top:3px}
.ev-date.past .m,.ev-date.past .d{color:var(--muted)}
.wiz textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font-size:0.9375rem;background:var(--surface);color:var(--ink);font-family:var(--font);min-height:84px;resize:vertical}
.wiz textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--gatebg)}
/* event-form page address field (locked /events/ prefix + live availability) */
.addr-row{display:flex;align-items:stretch;border:1px solid var(--line);border-radius:9px;overflow:hidden;background:var(--surface)}
.addr-row .pre{display:flex;align-items:center;padding:0 4px 0 13px;color:var(--muted);font-family:ui-monospace,Menlo,Consolas,monospace;font-size:0.9375rem;white-space:nowrap;background:var(--hover);border-right:1px solid var(--line)}
.wiz .addr-row input{border:0;border-radius:0;background:transparent;flex:1;font-family:ui-monospace,Menlo,Consolas,monospace}
.wiz .addr-row input:focus{box-shadow:none}
.addr-status{font-size:0.75rem;font-weight:600;margin-top:6px;min-height:16px}
.addr-status.ok{color:var(--ok-text)} .addr-status.bad{color:var(--bad-text)}

/* ===== public event page (the generated output at /events/<slug>) ===== */
.pubpage{display:block}
.evpreview-bar{background:var(--gatebg);color:var(--gate-text);text-align:center;font-size:0.8125rem;font-weight:600;padding:8px 12px}
.evpage{max-width:680px;margin:0 auto;padding:0 20px 60px}
.evpage-head{display:flex;align-items:center;gap:11px;padding:22px 2px}
.evpage-head .logo{width:40px;height:40px;border-radius:10px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem}
.evpage-head b{font-size:0.9375rem} .evpage-head span{font-size:0.75rem;color:var(--muted)}
.evhero{background:linear-gradient(135deg,var(--brand),#3a1f8f);color:#fff;border-radius:16px;padding:34px 30px}
.evhero h1{font-size:1.875rem;font-weight:700;line-height:1.15;margin-bottom:14px}
.evhero .meta{font-size:0.9375rem;display:flex;flex-direction:column;gap:8px}
.evbody{font-size:0.9375rem;line-height:1.7;color:var(--ink);margin:26px 2px}
.evbody p{margin-bottom:12px}
.evrsvp{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px 26px}
.evrsvp h2{font-size:1.1875rem;margin-bottom:4px}
.evrsvp .cap{font-size:0.9375rem;color:var(--ok-text);font-weight:600;margin-bottom:14px}
.evrsvp label{display:block;font-size:0.75rem;font-weight:700;margin:12px 0 5px}
.evrsvp input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font-size:0.9375rem;background:var(--surface);color:var(--ink)}
.evrsvp input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--gatebg)}
.evrsvp .rbtn{width:100%;margin-top:18px;background:var(--brand);color:#fff;border:0;border-radius:9px;padding:13px;font-size:0.9375rem;font-weight:700;cursor:pointer}
.evrsvp .priv{font-size:0.75rem;color:var(--muted);margin-top:12px;line-height:1.5}
.evthanks{background:var(--okbg);color:var(--ok-text);border-radius:10px;padding:20px;text-align:center;font-weight:600;font-size:0.9375rem}
/* Event page — Eventbrite "Get tickets" widget (link-out; checkout stays on Eventbrite) */
.evtickets{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px 26px}
.evtickets .et-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}
.evtickets .et-head h2{font-size:1.1875rem;margin:0}
.evtickets .et-price{font-size:0.9375rem;font-weight:700;color:var(--ink);white-space:nowrap}
.evtickets .et-sub{font-size:0.9375rem;color:var(--muted);line-height:1.6;margin:10px 0 18px}
.evtickets .et-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:#F05537;color:#fff;border-radius:10px;padding:15px;font-size:1rem;font-weight:700;text-decoration:none}
.evtickets .et-btn:hover{opacity:.93}
.evtickets .et-trust{font-size:0.75rem;color:var(--muted);margin-top:12px;text-align:center}
.evtickets .et-trust b{color:#F05537}
/* Event setup — sign-up method chooser (RSVP vs Eventbrite) */
.signup-modes{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.smode{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);border-radius:11px;padding:14px 16px;cursor:pointer;background:var(--surface)}
.smode input{margin-top:3px;flex-shrink:0}
.smode b{display:block;font-size:0.9375rem;margin-bottom:2px}
.smode span{font-size:0.8125rem;color:var(--muted);line-height:1.5}
.smode:has(input:checked){border-color:var(--brand);box-shadow:0 0 0 3px var(--gatebg)}
/* Event page preview — RSVP/Tickets mode toggle (dev chrome only) */
.evpreview-bar .pvt{margin-left:10px;display:inline-flex;gap:4px;vertical-align:middle}
.evpreview-bar .pvt button{font-size:0.75rem;border:1px solid rgba(127,127,127,.5);background:rgba(127,127,127,.18);color:inherit;border-radius:6px;padding:3px 9px;cursor:pointer;font-weight:700}
.evpreview-bar .pvt button.on{background:#fff;color:#111;border-color:#fff}
/* Links & Tracking — per-link table */
.lt-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius)}
.lt{width:100%;border-collapse:collapse;background:var(--card);font-size:0.9375rem;min-width:0;table-layout:fixed}/* fixed: honor width:100% + wrap within columns so the table never outgrows the scroll-wrap. Column proportions come from each table's <colgroup>. */
.lt th{text-align:left;background:var(--hover);color:var(--muted);font-size:0.75rem;text-transform:uppercase;letter-spacing:.07em;padding:10px 12px;font-weight:700}
.lt td{padding:11px 12px;border-top:1px solid var(--line);vertical-align:middle}
.lt .slug{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:0.8125rem;color:var(--ink);font-weight:600}
.lt .slug .lit{color:var(--muted);font-weight:400}
.lt .dest{font-size:0.75rem;color:var(--muted);margin-top:3px}
.lt .slug,.lt .dest{overflow-wrap:anywhere}   /* long slugs/URLs wrap instead of forcing h-scroll */
.lt .clk{font-weight:700;font-size:0.9375rem}
.lt .when{font-size:0.75rem;color:var(--muted);white-space:nowrap}
.lt .pill{display:inline-block;font-size:0.75rem;border-radius:6px;padding:2px 7px;font-weight:700;white-space:nowrap}
.lt .pill.qr{background:rgba(109,74,255,.14);color:#6d4aff}
.lt .pill.link{background:rgba(27,182,193,.16);color:#1bb6c1}
.lt .pill.social{background:rgba(236,72,153,.14);color:#ec4899}
.lt .pill.email{background:rgba(245,158,11,.16);color:#f59e0b}
.lt .src{font-size:0.75rem;color:var(--muted);margin-top:3px}
.lt .camp{display:inline-block;font-size:0.75rem;background:var(--hover);border:1px solid var(--line);border-radius:6px;padding:2px 8px;color:var(--ink);font-weight:600}
.lt .camp.none{background:none;border:0;color:var(--muted);font-weight:400;padding:2px 0}
.lt .act{display:inline-flex;gap:6px;flex-wrap:wrap}
.lt .act a{font-size:0.75rem;font-weight:600;color:var(--brand);text-decoration:none;white-space:nowrap;align-self:center}
.lt .act a:hover{text-decoration:underline}
.lt .act button{font-size:0.75rem;font-weight:600;border-radius:7px;padding:5px 9px;border:1px solid var(--line);background:var(--surface);color:var(--ink);cursor:pointer;line-height:1.2}
.lt .act button:hover{border-color:var(--brand);color:var(--brand)}
.lt .act .del{border-color:transparent;color:var(--muted);padding:5px 7px}
/* #Keywords — SEO-first reframe */
.sec-tag{font-size:0.75rem;font-weight:700;color:var(--brand);background:var(--hover);border:1px solid var(--line);border-radius:20px;padding:2px 9px;margin-left:8px;vertical-align:middle;text-transform:none;letter-spacing:0}
.sec-tag.muted{color:var(--muted)}
/* one unified panel with hairline dividers (gap shows the --line bg through) — reads as a single
   block belonging to the section, not 4 floating cards. Explicit cols so 4 items always fill evenly. */
.kw-where{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin:0 0 16px;border:1px solid var(--line);border-radius:10px;background:var(--line);overflow:hidden}
@media(max-width:780px){.kw-where{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.kw-where{grid-template-columns:1fr}}
.kw-where-i{background:var(--card);border:none;border-radius:0;padding:11px 14px}
.kw-where-i b{font-size:0.9375rem;display:block}
.kw-where-i span{font-size:0.75rem;color:var(--muted);line-height:1.45;display:block;margin-top:2px}
/* description joined INTO the panel as a full-width header cell (hairline divides it from the cards) */
.kw-where-head{grid-column:1/-1;background:var(--card);padding:13px 14px 12px}
.kw-where-title{font-size:0.9375rem;font-weight:700;margin:0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.kw-where-desc{margin:7px 0 0;font-size:0.8125rem;color:var(--muted);line-height:1.55}
.kw-where-desc b{color:var(--ink)}
.kw-example{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin:18px 0}
.kw-ex-h{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:10px}
.kw-ex-row{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-top:1px solid var(--line)}
.kw-ex-row:first-of-type{border-top:0;padding-top:0}
.kw-ex-lbl{flex-shrink:0;font-size:0.75rem;font-weight:700;border-radius:6px;padding:3px 9px;white-space:nowrap}
.kw-ex-lbl.old{background:var(--hover);color:var(--muted)}
.kw-ex-lbl.new{background:rgba(34,197,94,.16);color:var(--ok-text)}
.kw-ex-txt{font-size:0.9375rem;line-height:1.55;color:var(--ink)}
.kw-ex-tags{color:var(--brand);font-size:0.75rem}
.kw-ex-alt{color:var(--muted);font-size:0.75rem}
.kw .r .copybtn{font-size:0.75rem;padding:4px 9px}
.evpage-foot{text-align:center;font-size:0.75rem;color:var(--muted);margin-top:30px}

/* ===== social hub ===== */
.soc-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:14px;border-bottom:1px solid var(--line)}
.soc-tab{font-size:0.9375rem;font-weight:600;color:var(--muted);background:none;border:0;border-bottom:2px solid transparent;padding:9px 13px;cursor:pointer;margin-bottom:-1px}
.soc-tab:hover{color:var(--ink)}
.soc-tab.active{color:var(--brand);border-bottom-color:var(--brand)}
.soc-subtitle{font-size:0.75rem;color:var(--muted);margin-bottom:14px}
.soc-metrics{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
/* bookings funnel has 5 metrics → 180px min orphaned the 5th on laptop widths (other-claude QA).
   Scoped 150px min lets all 5 sit in one row at common widths; social's row is left untouched. */
#bkMetrics{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.metric{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.metric .mlabel{font-size:0.75rem;color:var(--muted);font-weight:600}
.metric .mval{font-size:1.625rem;font-weight:700;margin-top:4px;line-height:1.1}
.metric .mtrend{font-size:0.75rem;font-weight:600;color:var(--ok-text);margin-top:3px}
.conn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(266px,1fr));gap:14px}
.conncard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:flex-start;gap:13px}
.conncard.off{opacity:.55}
.platlogo{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.platlogo svg{width:24px;height:24px;fill:#fff}
.platlogo.fb{background:#1877F2}
.platlogo.ig{background:linear-gradient(45deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5)}
.platlogo.gg{background:#4285F4}
.platlogo.tt{background:#000;box-shadow:inset 0 0 0 1px rgba(255,255,255,.14)}
.platlogo.yt{background:#FF0000}
.platlogo.pin{background:#BD081C}
.platlogo.x{background:#000;box-shadow:inset 0 0 0 1px rgba(255,255,255,.14)}
/* Email module — provider logo tiles (mc/ml/bv/cc/kit); .lm = lettermark fallback */
.platlogo.mc{background:#FFE01B} .platlogo.mc svg{fill:#000}
.platlogo.ml{background:#09C269}
.platlogo.bv{background:#0B996E}
.platlogo.cc{background:#1851A4}
.platlogo.kit{background:#000;box-shadow:inset 0 0 0 1px rgba(255,255,255,.14)}
.platlogo .lm{color:#fff;font-weight:800;font-size:0.9375rem;letter-spacing:.02em}
/* Bookings + connectors — Google family reuses .gg; others brand-colored (SVG or .lm lettermark) */
.platlogo.calendly{background:#006bff}
.platlogo.square{background:#111;box-shadow:inset 0 0 0 1px rgba(255,255,255,.14)}
.platlogo.acuity{background:#2c5cc5}
.platlogo.ms365{background:#fff;box-shadow:inset 0 0 0 1px var(--line)}
.platlogo.ghl{background:#18816b}
.platlogo.et{background:#0f766e}
.platlogo.ts{background:#c0392b}
.platlogo.sb{background:#2bb3a3}
.platlogo.umami{background:#11a683}
.platlogo.plausible{background:#5850EC}
.platlogo.eventbrite{background:#f05537}
.platlogo.eventzilla{background:#20a39e}
.platlogo.tickettailor{background:#2f3a8f}
.platlogo.luma{background:#e0564b}
.platlogo.ticketsource{background:#1769aa}
.platlogo.zeffy{background:#ff2e7e}
/* bring-your-own-account tie-in tools (client connects their own paid subscription) */
.platlogo.brightlocal{background:#ff5a36}
.platlogo.localfalcon{background:#2b3a55}
.platlogo.gatherup{background:#2f6df6}
.platlogo.whitespark{background:#16a34a}
/* small variant for list rows (settings connectors) */
.platlogo.sm{width:34px;height:34px;border-radius:9px}
.platlogo.sm svg{width:18px;height:18px}
.platlogo.sm .lm{font-size:0.75rem}
.conninfo{flex:1;min-width:0;line-height:1.35}
.conninfo b{font-size:0.9375rem;display:block}
.connstatus{font-size:0.75rem;color:var(--muted)}
.connstatus.ok{color:var(--ok-text);font-weight:600}
/* connection-card feature chips ("what you get") — live (delivered now) vs planned (available) */
.conn-feats{display:flex;flex-wrap:wrap;gap:5px;margin-top:9px}
.conn-feat{font-size:0.75rem;color:var(--ink);background:rgba(109,74,255,.10);border:1px solid transparent;border-radius:999px;padding:2px 9px;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.conn-feat::before{content:"";width:5px;height:5px;border-radius:50%;background:#2f9e6b;flex:0 0 auto}
.conn-feat.soon{background:transparent;border:1px dashed var(--line);color:var(--muted)}
.conn-feat.soon::before{background:var(--muted)}
.conn-legend{font-size:0.75rem;color:var(--muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0 0 14px}
.connbtn{font-size:0.75rem;font-weight:600;border-radius:8px;padding:7px 13px;border:1px solid var(--line);background:var(--surface);color:var(--ink);cursor:pointer;white-space:nowrap}
.connbtn:hover{border-color:var(--brand);color:var(--brand)}
.connbtn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.connbtn.primary:hover{color:#fff;opacity:.92}
/* Social — price decals on connection cards */
.conncard{position:relative;min-height:88px}
/* button sits BOTTOM-right so it clears the absolute price tag (top-right) and never lands on the
   feature-chip text — fixes the conncard overlap (other-claude QA 2026-06). flex-start tops the
   logo+info next to the heading; the button drops to the bottom corner. */
.conncard > .connbtn{align-self:flex-end;margin-left:auto}
.pricetag{position:absolute;top:0;right:0;font-size:0.75rem;font-weight:800;letter-spacing:.02em;padding:3px 9px;border-top-right-radius:var(--radius);border-bottom-left-radius:11px;line-height:1.3}
.pricetag.free{background:#e6f7ec;color:#15803d}
.pricetag.paid{background:#fde7cf;color:#b45309}
body.dark .pricetag.free{background:rgba(34,197,94,.16);color:#4ade80}
body.dark .pricetag.paid{background:rgba(245,158,11,.18);color:#fbbf24}
/* Social — metric trend chart (Tiffany) */
.soc-chart{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px 10px;margin-bottom:16px}
.soc-chart .ch-head{display:flex;align-items:baseline;gap:9px;margin-bottom:6px}
.soc-chart .ch-metric{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.soc-chart .ch-now{font-size:1.375rem;font-weight:800;color:var(--ink);line-height:1}
.soc-chart .ch-delta{font-size:0.75rem;font-weight:700;color:var(--ok-text)}
.soc-chart .ch-cap{margin-left:auto;font-size:0.75rem;color:var(--muted)}
.soc-chart svg{display:block;width:100%;height:auto}
.soc-chart .grid{stroke:var(--line);stroke-width:1}
/* line draws SOLID. The old stroke-dasharray:1/dashoffset:1 "draw" reveal only works if the path
   carries pathLength="1"; these charts are JS-generated without it, so the line rendered as near-
   invisible 1px specks (other-claude QA 2026-06). Solid line = reliably visible in all data states. */
.soc-chart .chline{fill:none;stroke:url(#cstroke);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.soc-chart .charea{opacity:0;animation:chfade .9s ease .2s forwards}
.soc-chart .cdot{fill:var(--card);stroke:#6d4aff;stroke-width:2}
.soc-chart .cdot-end{fill:#6d4aff;stroke:var(--card);stroke-width:3}
.soc-chart .endpulse{fill:#6d4aff;opacity:.16}
.soc-chart .xlab{fill:var(--muted)}
@keyframes chdraw{to{stroke-dashoffset:0}}
@keyframes chfade{to{opacity:1}}
.soc-chart .ch-plot{position:relative}
.soc-chart .ch-legend{position:absolute;top:6px;left:8px;display:flex;flex-direction:column;gap:3px;padding:7px 9px;background:var(--card);border:1px solid var(--line);border-radius:9px;box-shadow:0 2px 8px rgba(0,0,0,.07);z-index:2}
.soc-chart .ch-legend .lg{display:flex;align-items:center;gap:7px;font-size:0.75rem;color:var(--ink);font-weight:600;white-space:nowrap;line-height:1.25}
.soc-chart .ch-legend .sw{width:13px;height:3px;border-radius:2px;flex-shrink:0}
@media(max-width:680px){.dl-grid{grid-template-columns:1fr}}
