/* =============================================
   InstantWordCount.com — main.css
   ============================================= */

/* ── TOKENS ─────────────────────────────────── */
:root {
  --brand:#1a1aff; --brand-d:#1010cc; --brand-mid:#4444ff;
  --brand-soft:#e8e8ff; --brand-xs:#f0f0ff; --brand-glow:rgba(26,26,255,.14);
  --ink:#0b0c15; --ink-2:#2d3044; --ink-3:#5a5f78; --ink-4:#9097b0; --ink-5:#c8cce0;
  --bd:#d6dae8; --bd2:#eceef6;
  --bg:#f3f4fb; --wh:#fff; --s2:#f0f1f8; --s3:#e8eaf4;
  --green:#00b87a; --green-bg:#e3faf1; --green-ink:#065f46;
  --amber:#f59e0b; --amber-bg:#fef3c7; --amber-ink:#92400e;
  --red:#ef4444; --red-bg:#fee2e2; --red-ink:#991b1b;
  --purple:#7c3aed; --purple-bg:#f3effe; --purple-ink:#5b21b6;
  --teal:#06b6d4; --teal-bg:#e0f9ff;
  --fd:"Cabinet Grotesk",system-ui,sans-serif;
  --fb:"Instrument Sans",system-ui,sans-serif;
  --fm:"JetBrains Mono",monospace;
  --ease:cubic-bezier(.22,1,.36,1);
  --r:8px; --r2:14px; --r3:20px; --r4:26px; --pill:999px;
}

/* ── RESET ───────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{color-scheme:light;scroll-behavior:smooth;font-size:16px}
body{font-family:var(--fb);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:var(--bd);border-radius:var(--pill)}
:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:3px}

/* ── LAYOUT ──────────────────────────────────── */
.container{max-width:1300px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0}

/* ── TYPE ────────────────────────────────────── */
.d1{font-family:var(--fd);font-size:clamp(2.4rem,5vw,4.8rem);font-weight:900;line-height:.93;letter-spacing:-.04em}
.d2{font-family:var(--fd);font-size:clamp(1.8rem,3.8vw,3.2rem);font-weight:800;line-height:1.05;letter-spacing:-.03em}
.label{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4)}
.accent{color:var(--brand)}

/* ── BUTTONS ─────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:.52rem 1.2rem;border-radius:var(--r);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:all .15s var(--ease);white-space:nowrap;user-select:none;line-height:1;text-decoration:none}
.btn-p{background:var(--brand);color:#fff}.btn-p:hover{background:var(--brand-d);transform:translateY(-1px);box-shadow:0 8px 22px var(--brand-glow)}
.btn-g{background:transparent;border:1.5px solid var(--bd);color:var(--ink-2)}.btn-g:hover{background:var(--wh);border-color:var(--ink-4)}
.btn-sm{padding:.3rem .72rem;font-size:.76rem}
.btn-full{width:100%;justify-content:center}

/* ── BADGES ──────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:.26rem .72rem;border-radius:var(--pill);font-size:.74rem;font-weight:600;background:var(--wh);border:1px solid var(--bd);color:var(--ink-2)}
.badge.gr{background:var(--green-bg);border-color:transparent;color:var(--green-ink)}
.badge.bl{background:var(--brand-soft);border-color:transparent;color:var(--brand)}
.badge.pu{background:var(--purple-bg);border-color:transparent;color:var(--purple-ink)}

/* ── EYEBROW ─────────────────────────────────── */
.hero-eyebrow{display:inline-flex;align-items:center;gap:7px;background:var(--brand-soft);color:var(--brand);padding:.3rem .9rem;border-radius:var(--pill);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.25rem}
.hero-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand);animation:pulse-dot 2s infinite;flex-shrink:0}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.55)}}

/* ── PANEL ───────────────────────────────────── */
.panel{background:var(--wh);border:1.5px solid var(--bd);border-radius:var(--r3);overflow:hidden}
.ph{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;border-bottom:1px solid var(--bd2);background:var(--s2)}
.pt{font-family:var(--fd);font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);display:flex;align-items:center;gap:6px}
.pt-dot{width:6px;height:6px;border-radius:50%;background:var(--brand);flex-shrink:0}
.pb{padding:1rem}

/* ── NAV ─────────────────────────────────────── */
#nav{position:sticky;top:0;z-index:500;background:rgba(243,244,251,.95);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid rgba(26,26,255,.07);transition:box-shadow .2s}
#nav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.06)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:1rem}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--fd);font-weight:900;font-size:1.05rem;letter-spacing:-.03em;color:var(--ink);flex-shrink:0}
.logo-icon{width:36px;height:36px;border-radius:10px;background:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;overflow:hidden}
.logo-icon::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.28),transparent 55%)}
.logo-icon svg{position:relative;z-index:1}
.logo-word{color:var(--ink)}
.logo-dot{color:var(--brand)}
.nav-links{display:flex;align-items:center;gap:.1rem;flex:1;justify-content:center}
.nav-link{padding:.42rem .9rem;border-radius:var(--r);font-size:.875rem;font-weight:500;color:var(--ink-3);transition:all .15s;text-decoration:none;display:inline-block}
.nav-link:hover{background:var(--s2);color:var(--ink)}
.nav-link.active{background:var(--brand-soft);color:var(--brand);font-weight:600}
.nav-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;border-radius:var(--r)}
.hbg span{width:22px;height:2px;background:var(--ink);border-radius:2px;display:block;transition:all .2s}

/* ── MOBILE NAV ──────────────────────────────── */
.mob-overlay{display:none;position:fixed;inset:0;z-index:800;background:rgba(11,12,21,.55);backdrop-filter:blur(4px)}
.mob-overlay.open{display:block}
.mob-panel{position:absolute;right:0;top:0;bottom:0;width:285px;background:var(--wh);padding:1.5rem;display:flex;flex-direction:column;box-shadow:-16px 0 48px rgba(0,0,0,.12);overflow-y:auto}
.mob-close{width:36px;height:36px;border-radius:var(--r);background:var(--s2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-3);margin-bottom:1.5rem;margin-left:auto}
.mob-link{display:block;padding:.7rem .9rem;border-radius:var(--r);font-size:.92rem;font-weight:600;color:var(--ink-2);text-decoration:none;transition:all .15s;margin-bottom:2px}
.mob-link:hover{background:var(--s2);color:var(--ink)}
.mob-link.active{background:var(--brand-soft);color:var(--brand)}

/* ── COOKIE BANNER ───────────────────────────── */
#cookie-bar{position:fixed;bottom:1.25rem;left:50%;transform:translateX(-50%);width:calc(100% - 2rem);max-width:740px;background:#0b0c15;color:#fff;border-radius:var(--r4);padding:1rem 1.4rem;display:flex;align-items:center;gap:1.25rem;z-index:9000;box-shadow:0 20px 60px rgba(0,0,0,.28);transition:all .4s var(--ease)}
#cookie-bar.gone{opacity:0;pointer-events:none;transform:translateX(-50%) translateY(20px)}
#cookie-bar p{font-size:.82rem;color:rgba(255,255,255,.6);flex:1;line-height:1.5}
#cookie-bar a{color:#fff;text-decoration:underline}
.ck-acts{display:flex;gap:.5rem;flex-shrink:0}
.ck-dec,.ck-acc{border:none;padding:.44rem 1rem;border-radius:var(--r);font-size:.8rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}
.ck-acc{background:var(--brand);color:#fff}.ck-acc:hover{background:var(--brand-d)}
.ck-dec{background:rgba(255,255,255,.08);color:rgba(255,255,255,.6)}

/* ── TOAST ───────────────────────────────────── */
#toast{position:fixed;bottom:5.5rem;right:1.5rem;z-index:9999;background:#0b0c15;color:#fff;padding:.7rem 1.1rem;border-radius:var(--r2);font-size:.83rem;font-weight:500;box-shadow:0 8px 28px rgba(0,0,0,.25);transform:translateY(calc(100% + 2rem));opacity:0;transition:all .3s var(--ease);pointer-events:none;max-width:300px}
#toast.show{transform:translateY(0);opacity:1}
#toast span{display:block}

/* ── BACK TO TOP ─────────────────────────────── */
#back-top{position:fixed;bottom:1.5rem;right:1.5rem;width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px var(--brand-glow);opacity:0;transform:translateY(10px);transition:all .3s var(--ease);pointer-events:none;z-index:900;font-size:1.1rem}
#back-top.show{opacity:1;transform:translateY(0);pointer-events:auto}
#back-top:hover{background:var(--brand-d)}

/* ── ANIMATIONS ──────────────────────────────── */
@keyframes fadeUp{from{transform:translateY(14px);opacity:.01}to{transform:translateY(0);opacity:1}}
.au{animation:fadeUp .5s var(--ease) forwards}
.d1s{animation-delay:.08s}
.d2s{animation-delay:.16s}

/* ── HERO ────────────────────────────────────── */
.hero{padding:4rem 0 2.5rem;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-45%;right:-5%;width:580px;height:580px;background:radial-gradient(circle,var(--brand-soft) 0%,transparent 62%);opacity:.55;pointer-events:none}
.hero-title{margin-bottom:1rem;color:var(--ink)}
.hero-sub{font-size:1.05rem;color:var(--ink-2);max-width:540px;line-height:1.7;margin-bottom:1.5rem}
.hero-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:2.5rem}

/* ── STAT CARDS ──────────────────────────────── */
.stat-row{display:grid;grid-template-columns:repeat(6,1fr);gap:.6rem;margin-bottom:.75rem}
.sc{background:var(--wh);border:1.5px solid var(--bd);border-radius:var(--r2);padding:.85rem .5rem .7rem;text-align:center;position:relative;overflow:hidden;transition:border-color .2s,transform .2s,box-shadow .2s;cursor:default}
.sc::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--brand);transform:scaleX(0);transition:transform .3s var(--ease);transform-origin:left}
.sc:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:0 8px 24px var(--brand-glow)}
.sc:hover::before{transform:scaleX(1)}
.sc.prim{background:var(--brand);border-color:var(--brand)}.sc.prim::before{display:none}
.sc-val{font-family:var(--fd);font-size:1.8rem;font-weight:900;color:var(--ink);line-height:1;margin-bottom:.25rem}
.sc.prim .sc-val{color:#fff}
.sc-lbl{font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4)}
.sc.prim .sc-lbl{color:rgba(255,255,255,.65)}
@keyframes pop{0%{transform:scale(1)}45%{transform:scale(1.14)}100%{transform:scale(1)}}
.popping{animation:pop .24s var(--ease)}

/* ── APP GRID ────────────────────────────────── */
.app-grid{display:grid;grid-template-columns:1fr 305px;gap:1.25rem;align-items:start}

/* ── EDITOR ──────────────────────────────────── */
.ed-shell{background:var(--wh);border:1.5px solid var(--bd);border-radius:var(--r4);overflow:hidden;box-shadow:0 4px 32px rgba(26,26,255,.05)}
.ed-top{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;border-bottom:1px solid var(--bd2);background:var(--s2);gap:.5rem;flex-wrap:wrap}
.tg{display:flex;align-items:center;gap:.2rem;flex-wrap:wrap}
.tb{display:inline-flex;align-items:center;gap:4px;padding:.26rem .56rem;border-radius:var(--r);font-size:.72rem;font-weight:600;cursor:pointer;border:1.5px solid transparent;background:transparent;color:var(--ink-3);transition:all .15s;font-family:inherit}
.tb:hover{background:var(--wh);border-color:var(--bd);color:var(--ink)}
.tb svg{width:12px;height:12px;flex-shrink:0}
.tdiv{width:1px;height:18px;background:var(--bd);margin:0 .1rem;flex-shrink:0}
.toggle-wrap{display:flex;align-items:center;gap:8px;font-size:.72rem;color:var(--ink-3);cursor:pointer;user-select:none}
.switch{position:relative;display:inline-block;width:32px;height:18px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0;position:absolute}
.slider{position:absolute;inset:0;background:var(--bd);border-radius:var(--pill);cursor:pointer;transition:background .2s}
.slider::before{content:"";position:absolute;width:12px;height:12px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}
.switch input:checked+.slider{background:var(--brand)}
.switch input:checked+.slider::before{transform:translateX(14px)}
.ed-area{position:relative}
#editor{width:100%;min-height:300px;max-height:520px;padding:1.5rem;border:none;outline:none;font-family:var(--fb);font-size:1rem;line-height:1.8;color:var(--ink);background:transparent;resize:vertical;position:relative;z-index:1}
#editor::placeholder{color:var(--ink-4)}
#hl-layer{position:absolute;inset:0;padding:1.5rem;font-family:var(--fb);font-size:1rem;line-height:1.8;color:transparent;white-space:pre-wrap;word-wrap:break-word;overflow:hidden;pointer-events:none;z-index:0}
#hl-layer mark.hl-find{background:rgba(245,158,11,.32);border-radius:2px;color:transparent}
#hl-layer mark.hl-long{background:rgba(239,68,68,.14);border-radius:2px;color:transparent}
#hl-layer mark.hl-adverb{background:rgba(124,58,237,.15);border-radius:2px;color:transparent}
.ed-bot{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1rem;border-top:1px solid var(--bd2);background:var(--s2);gap:.75rem;flex-wrap:wrap}
.goal-mini{display:flex;align-items:center;gap:8px;flex:1;min-width:100px}
.mini-track{flex:1;height:5px;background:var(--bd);border-radius:var(--pill);overflow:hidden}
.mini-fill{height:100%;background:var(--brand);border-radius:var(--pill);width:0;transition:width .4s var(--ease)}
.mini-lbl{font-family:var(--fm);font-size:.68rem;color:var(--ink-4);white-space:nowrap}
.ed-acts{display:flex;gap:.4rem}

/* ── TABS ────────────────────────────────────── */
.tabs-shell{background:var(--wh);border:1.5px solid var(--bd);border-radius:var(--r4);overflow:hidden;margin-top:.75rem;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.tabs-nav{display:flex;border-bottom:1px solid var(--bd2);background:var(--s2);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tabs-nav::-webkit-scrollbar{display:none}
.tab-btn{display:block;padding:.68rem 1rem;font-size:.79rem;font-weight:600;color:var(--ink-3);text-decoration:none;white-space:nowrap;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:all .15s}
.tab-btn:hover{color:var(--ink);background:var(--s3)}
.tab-btn.active{color:var(--brand);border-bottom-color:var(--brand);background:var(--wh)}
.tab-pane{display:none;padding:1.25rem}
.tab-pane.active{display:block}

/* ── SENTENCE TAB ────────────────────────────── */
.s-list{display:flex;flex-direction:column;gap:5px;max-height:280px;overflow-y:auto}
.s-row{display:flex;gap:8px;align-items:flex-start;padding:.5rem .65rem;border-radius:var(--r2);border:1px solid var(--bd2);transition:background .15s}
.s-row:hover{background:var(--s2)}
.s-num{font-family:var(--fm);font-size:.62rem;color:var(--ink-4);padding-top:2px;min-width:18px;flex-shrink:0}
.s-text{font-size:.82rem;color:var(--ink-2);line-height:1.5;flex:1}
.s-tag{font-size:.6rem;font-weight:700;padding:.16rem .42rem;border-radius:4px;white-space:nowrap;flex-shrink:0}
.ss{background:var(--green-bg);color:var(--green-ink)}
.sm{background:var(--brand-soft);color:var(--brand)}
.sl{background:var(--amber-bg);color:var(--amber-ink)}
.sv{background:var(--red-bg);color:var(--red-ink)}
.s-legend{display:flex;gap:10px;flex-wrap:wrap;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--bd2)}
.s-leg{display:flex;align-items:center;gap:4px;font-size:.7rem;color:var(--ink-3)}

/* ── N-GRAM TAB ──────────────────────────────── */
.ng-tabs{display:flex;gap:4px;margin-bottom:.85rem}
.ng-tab{padding:.26rem .7rem;font-size:.76rem;font-weight:600;border-radius:var(--r);border:1.5px solid var(--bd);background:var(--s2);color:var(--ink-2);cursor:pointer;font-family:inherit;transition:all .15s}
.ng-tab.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.ng-scroll{max-height:240px;overflow-y:auto}
.ng-table{width:100%;border-collapse:collapse;font-size:.79rem}
.ng-table th{text-align:left;padding:.44rem .55rem;font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);border-bottom:1px solid var(--bd)}
.ng-table td{padding:.4rem .55rem;border-bottom:1px solid var(--bd2)}
.ng-table tr:last-child td{border-bottom:none}
.ng-table tr:hover td{background:var(--s2)}
.ng-phrase{font-family:var(--fm);font-size:.76rem;font-weight:500;color:var(--ink)}
.ng-cnt{font-family:var(--fm);color:var(--ink-3);font-size:.73rem}
.ng-bar-w{width:80px;height:4px;background:var(--s3);border-radius:var(--pill);overflow:hidden}
.ng-bar-f{height:100%;background:var(--purple);border-radius:var(--pill)}

/* ── SEO TAB ─────────────────────────────────── */
.seo-sg{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem;margin-bottom:1rem}
.seo-s{background:var(--s2);border-radius:var(--r2);padding:.78rem}
.lb{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-4);margin-bottom:.22rem}
.vl{font-family:var(--fd);font-size:1.3rem;font-weight:800;color:var(--ink)}
.sb{font-size:.64rem;color:var(--ink-4);margin-top:2px}
.seo-chk{display:flex;flex-direction:column;gap:4px}
.seo-item{display:flex;align-items:flex-start;gap:8px;padding:.4rem .55rem;border-radius:var(--r);font-size:.79rem;color:var(--ink-2)}
.seo-item:hover{background:var(--s2)}
.seo-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}
.dot-p{background:var(--green)}.dot-w{background:var(--amber)}.dot-f{background:var(--red)}

/* ── FIND & REPLACE TAB ──────────────────────── */
.fr-row{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-bottom:.7rem}
.fr-field label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-4);margin-bottom:4px;display:block}
.fr-inp{width:100%;padding:.46rem .7rem;font-size:.84rem;border:1.5px solid var(--bd);border-radius:var(--r);background:var(--s2);color:var(--ink);outline:none;transition:border-color .15s}
.fr-inp:focus{border-color:var(--brand);background:var(--wh)}
.fr-opts{display:flex;gap:1rem;margin-bottom:.7rem;flex-wrap:wrap}
.fr-opt{display:flex;align-items:center;gap:5px;font-size:.79rem;color:var(--ink-2);cursor:pointer;user-select:none}
.fr-result{font-family:var(--fm);font-size:.76rem;color:var(--ink-4);margin:.5rem 0;min-height:18px}
.fr-acts{display:flex;gap:.5rem;flex-wrap:wrap}

/* ── SOCIAL TAB ──────────────────────────────── */
.soc-item{display:flex;align-items:center;gap:8px;padding:.46rem .6rem;border-radius:var(--r);border:1.5px solid var(--bd2);margin-bottom:.38rem;transition:all .15s}
.soc-item.over{border-color:var(--red);background:var(--red-bg)}
.soc-ic{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.58rem;font-weight:900;font-family:var(--fd)}
.soc-name{font-size:.78rem;font-weight:600;color:var(--ink);flex:1}
.soc-info{font-family:var(--fm);font-size:.65rem;color:var(--ink-4)}
.soc-bar-w{width:48px;height:4px;background:var(--s3);border-radius:var(--pill);overflow:hidden}
.soc-bar-f{height:100%;border-radius:var(--pill);transition:width .4s var(--ease),background .3s}
.soc-diff{font-size:.63rem;font-weight:700;width:30px;text-align:right;font-family:var(--fm)}

/* ── HISTORY TAB ─────────────────────────────── */
.h-list{display:flex;flex-direction:column;gap:5px;max-height:280px;overflow-y:auto}
.h-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:.56rem .7rem;border-radius:var(--r2);border:1.5px solid var(--bd2);cursor:pointer;transition:all .15s}
.h-item:hover{background:var(--s2);border-color:var(--brand)}
.h-snip{font-size:.79rem;color:var(--ink-2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.h-meta{font-family:var(--fm);font-size:.68rem;color:var(--ink-4);flex-shrink:0}

/* ── SIDEBAR ─────────────────────────────────── */
.sidebar{display:flex;flex-direction:column;gap:.85rem}

/* Sprint Timer */
.timer-display{font-family:var(--fm);font-size:2.4rem;font-weight:500;color:var(--ink);text-align:center;letter-spacing:.05em;margin-bottom:.75rem}
.timer-acts{display:flex;gap:.5rem;justify-content:center}

/* Readability Ring */
.ring-wrap{text-align:center;padding:.5rem 0 .25rem}
.ring-outer{position:relative;width:112px;height:112px;margin:0 auto .75rem}
.ring-svg{transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:var(--bd);stroke-width:9}
.ring-fill{fill:none;stroke:var(--brand);stroke-width:9;stroke-linecap:round;stroke-dasharray:314;stroke-dashoffset:314;transition:stroke-dashoffset .9s var(--ease),stroke .4s}
.ring-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring-num{font-family:var(--fd);font-size:1.65rem;font-weight:900;line-height:1;color:var(--ink)}
.ring-sub{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4)}
.grade-pill{display:inline-flex;align-items:center;padding:.26rem .75rem;border-radius:var(--pill);font-size:.76rem;font-weight:700;margin-bottom:.4rem}
.gp-easy{background:var(--green-bg);color:var(--green-ink)}
.gp-med{background:var(--amber-bg);color:var(--amber-ink)}
.gp-hard{background:var(--red-bg);color:var(--red-ink)}
.grade-note{font-size:.74rem;color:var(--ink-4);line-height:1.4;max-width:200px;margin:0 auto}
.mr{display:flex;align-items:center;justify-content:space-between;padding:.38rem 0;border-bottom:1px solid var(--bd2);font-size:.79rem}
.mr:last-child{border-bottom:none}
.mr-n{color:var(--ink-2)}.mr-v{font-family:var(--fm);font-size:.72rem;background:var(--s2);padding:.1rem .38rem;border-radius:4px;color:var(--ink)}

/* Keyword */
.kw-search{width:100%;padding:.4rem .7rem;font-size:.8rem;border:1.5px solid var(--bd);border-radius:var(--r);background:var(--s2);outline:none;margin-bottom:.55rem;transition:border-color .15s}
.kw-search:focus{border-color:var(--brand);background:var(--wh)}
.kw-list{display:flex;flex-direction:column;gap:2px;max-height:220px;overflow-y:auto}
.kw-row{display:flex;align-items:center;gap:5px;padding:.36rem .48rem;border-radius:var(--r);transition:background .15s;cursor:default}
.kw-row:hover{background:var(--s2)}
.kw-rank{font-family:var(--fm);font-size:.6rem;color:var(--ink-4);width:14px;text-align:center;flex-shrink:0}
.kw-word{flex:1;font-size:.79rem;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kw-cnt{font-family:var(--fm);font-size:.7rem;color:var(--ink-4);flex-shrink:0}
.kw-bar-w{width:36px;height:4px;background:var(--s3);border-radius:var(--pill);overflow:hidden;flex-shrink:0}
.kw-bar-f{height:100%;background:var(--brand);border-radius:var(--pill)}
.kw-pct{font-family:var(--fm);font-size:.64rem;color:var(--ink-4);width:30px;text-align:right;flex-shrink:0}

/* Goal */
.goal-row{display:flex;align-items:center;gap:8px;margin-bottom:.58rem}
.goal-inp{flex:1;padding:.38rem .62rem;font-size:.82rem;border:1.5px solid var(--bd);border-radius:var(--r);background:var(--s2);color:var(--ink);font-family:var(--fm);outline:none;transition:border-color .15s}
.goal-inp:focus{border-color:var(--brand);background:var(--wh)}
.goal-track{height:8px;background:var(--s3);border-radius:var(--pill);overflow:hidden;margin-bottom:.32rem}
.goal-fill{height:100%;border-radius:var(--pill);background:var(--brand);width:0;transition:width .4s var(--ease),background .3s}
.goal-meta{display:flex;justify-content:space-between;font-family:var(--fm);font-size:.7rem;color:var(--ink-4)}
.pset-grid{display:flex;flex-wrap:wrap;gap:3px;margin-top:.6rem}
.ps-btn{padding:.22rem .5rem;font-size:.68rem;font-weight:600;border-radius:6px;border:1.5px solid var(--bd);background:var(--s2);color:var(--ink-2);cursor:pointer;font-family:inherit;transition:all .15s}
.ps-btn:hover{background:var(--brand-soft);color:var(--brand);border-color:transparent}

/* Export */
.exp-grid{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}
.exp-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:.65rem .4rem;border-radius:var(--r2);border:1.5px solid var(--bd);background:var(--s2);cursor:pointer;transition:all .15s;font-size:.68rem;font-weight:700;color:var(--ink-2);text-align:center;font-family:inherit}
.exp-btn:hover{background:var(--brand-soft);border-color:var(--brand);color:var(--brand);transform:translateY(-1px)}
.exp-btn svg{width:18px;height:18px;stroke-width:1.5}
.exp-btn.full{grid-column:1/-1;flex-direction:row;gap:6px;padding:.5rem .75rem;font-size:.76rem;justify-content:center}

/* Privacy note */
.priv-note{background:var(--green-bg);border:1px solid rgba(0,184,122,.2);border-radius:var(--r2);padding:.85rem .95rem;display:flex;gap:.75rem;align-items:flex-start}
.priv-note svg{flex-shrink:0;margin-top:1px;color:var(--green-ink)}
.priv-note-t{font-size:.72rem;font-weight:700;color:var(--green-ink);margin-bottom:2px}
.priv-note-b{font-size:.7rem;color:var(--green-ink);line-height:1.45}


/* ── HOW IT WORKS ────────────────────────────── */
.how-section{background:var(--wh);border-top:1px solid var(--bd2);border-bottom:1px solid var(--bd2);padding:2.5rem 0}
.how-label{text-align:center;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4);margin-bottom:1.5rem}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.how-card{background:var(--wh);border:1.5px solid var(--bd);border-radius:var(--r3);padding:1.5rem;transition:all .25s var(--ease)}
.how-card:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:0 12px 32px var(--brand-glow)}
.how-num{font-family:var(--fd);font-size:2.8rem;font-weight:900;color:var(--brand);line-height:1;margin-bottom:.6rem;opacity:.18}
.how-card:hover .how-num{opacity:.35}
.how-card h3{font-family:var(--fd);font-size:.95rem;font-weight:800;color:var(--ink);margin-bottom:.35rem}
.how-card p{font-size:.82rem;color:var(--ink-3);line-height:1.55}

/* ── ALL TOOLS PAGE ──────────────────────────── */
.sec-hd{text-align:center;max-width:640px;margin:0 auto 3.5rem}
.sec-hd h1{margin-top:.75rem}
.sec-hd p{font-size:1.05rem;color:var(--ink-3);line-height:1.65;margin-top:.75rem}
.tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}
.tool-card{background:var(--wh);border:1.5px solid var(--bd);border-radius:var(--r3);padding:1.25rem;display:flex;align-items:flex-start;gap:1rem;cursor:pointer;transition:all .25s var(--ease);text-decoration:none}
.tool-card:hover{border-color:var(--brand);box-shadow:0 8px 24px var(--brand-glow);transform:translateY(-2px)}
.tc-icon{width:44px;height:44px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tc-info h3{font-family:var(--fd);font-size:.92rem;font-weight:800;color:var(--ink);margin-bottom:.25rem}
.tc-info p{font-size:.78rem;color:var(--ink-2);line-height:1.4}

/* ── FEATURES PAGE ───────────────────────────── */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.feat-card{background:var(--wh);border:1.5px solid var(--bd);border-radius:var(--r3);padding:1.5rem;transition:all .25s var(--ease)}
.feat-card:hover{border-color:var(--brand);transform:translateY(-4px);box-shadow:0 16px 40px var(--brand-glow)}
.feat-icon{width:44px;height:44px;border-radius:var(--r);background:var(--brand-soft);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.feat-icon svg{width:22px;height:22px;color:var(--brand)}
.feat-card h3{font-family:var(--fd);font-size:1rem;font-weight:800;color:var(--ink);margin-bottom:.5rem}
.feat-card p{font-size:.84rem;color:var(--ink-2);line-height:1.55}
.sec-block{background:var(--ink);border-radius:var(--r4);padding:3.5rem;margin-top:4rem;text-align:center}
.sec-block-inner{max-width:820px;margin:0 auto}
.sec-block h2{color:#fff;margin-bottom:1rem}
.sec-block p{color:rgba(255,255,255,.6);max-width:560px;margin:0 auto 2rem;line-height:1.65;font-size:1rem}
.sec-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:left}
.sec-card{background:rgba(255,255,255,.05);border-radius:var(--r3);padding:1.25rem}
.sec-card-t{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.3);margin-bottom:.5rem}
.sec-card p{font-size:.84rem;color:rgba(255,255,255,.6);line-height:1.5}

/* ── ABOUT PAGE ──────────────────────────────── */
.about-lay{display:grid;grid-template-columns:1fr 400px;gap:4rem;align-items:start}
.about-body h1{margin-bottom:1.5rem}
.about-body>p{font-size:1.05rem;color:var(--ink-2);line-height:1.75;margin-bottom:1.5rem}
.h3{font-family:var(--fd);font-size:1.3rem;font-weight:800;letter-spacing:-.02em}
.val-list{display:flex;flex-direction:column;gap:.75rem}
.val-item{display:flex;gap:1rem;align-items:flex-start}
.val-num{font-family:var(--fd);font-size:1.6rem;font-weight:900;color:var(--brand);line-height:1;flex-shrink:0;width:36px}
.val-text h4{font-family:var(--fd);font-size:.93rem;font-weight:800;color:var(--ink);margin-bottom:.25rem}
.val-text p{font-size:.83rem;color:var(--ink-2);line-height:1.5}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.about-st{background:var(--wh);border:1.5px solid var(--bd);border-radius:var(--r3);padding:1.5rem;text-align:center}
.about-st .big{font-family:var(--fd);font-size:2.5rem;font-weight:900;color:var(--brand);margin-bottom:.25rem}
.about-st .sm{font-size:.8rem;color:var(--ink-2)}
.contact-box{background:var(--brand);border-radius:var(--r3);padding:1.5rem;color:#fff;margin-top:.75rem}
.contact-box .ct{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;opacity:.55;margin-bottom:.5rem}
.contact-box p{font-size:.86rem;opacity:.75;line-height:1.6;margin-bottom:.75rem}
.contact-box a{color:#fff;font-weight:700;font-size:.86rem;text-decoration:underline}

/* ── FAQ PAGE ────────────────────────────────── */
.faq-list{display:flex;flex-direction:column;gap:0;max-width:800px;margin:0 auto}
.faq-item{background:var(--wh);border:1.5px solid var(--bd);border-radius:var(--r2);overflow:hidden;margin-bottom:.5rem;transition:border-color .15s}
.faq-item:hover{border-color:var(--ink-4)}.faq-item.open{border-color:var(--brand)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;cursor:pointer;font-weight:600;font-size:.92rem;color:var(--ink);border:none;background:none;width:100%;text-align:left;gap:1rem;transition:background .15s}
.faq-q:hover{background:var(--s2)}.faq-item.open .faq-q{background:var(--brand-xs);color:var(--brand)}
.faq-arrow{transition:transform .3s var(--ease);flex-shrink:0;color:var(--ink-4)}.faq-item.open .faq-arrow{transform:rotate(180deg);color:var(--brand)}
.faq-a{display:none;padding:0 1.25rem 1rem;font-size:.88rem;color:var(--ink-2);line-height:1.75;border-top:1px solid var(--bd2)}.faq-item.open .faq-a{display:block}

/* ── LEGAL PAGES ─────────────────────────────── */
.legal-lay{display:grid;grid-template-columns:210px 1fr;gap:4rem;align-items:start}
.legal-nav{position:sticky;top:80px}
.legal-nl{display:flex;flex-direction:column;gap:2px}
.legal-ni{padding:.44rem .82rem;border-radius:var(--r);font-size:.8rem;font-weight:500;color:var(--ink-2);cursor:pointer;transition:all .15s}
.legal-ni:hover{background:var(--s2);color:var(--ink)}.legal-ni.on{background:var(--brand-soft);color:var(--brand);font-weight:600}
.legal-content h1{margin-bottom:.5rem}
.legal-meta{font-size:.8rem;color:var(--ink-4);margin-bottom:1.75rem}
.legal-hl{background:var(--brand-soft);border-left:3px solid var(--brand);border-radius:0 var(--r) var(--r) 0;padding:.85rem 1.1rem;margin-bottom:1.75rem;font-size:.88rem;color:var(--ink);line-height:1.6}
.legal-section{margin-bottom:2.5rem}
.legal-section h2{font-family:var(--fd);font-size:1.08rem;font-weight:800;color:var(--ink);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1.5px solid var(--bd2)}
.legal-section p{font-size:.88rem;color:var(--ink-2);line-height:1.8;margin-bottom:.75rem}
.legal-section ul{padding-left:1.3rem;margin-bottom:.75rem;list-style:disc}
.legal-section li{font-size:.88rem;color:var(--ink-2);line-height:1.8;margin-bottom:.3rem}
.legal-section a{color:var(--brand);text-decoration:underline}
.legal-table{width:100%;border-collapse:collapse;font-size:.85rem;margin-bottom:1rem}
.legal-table th{background:var(--s2);padding:.58rem .82rem;text-align:left;font-weight:700;color:var(--ink);border-bottom:2px solid var(--bd);font-size:.78rem}
.legal-table td{padding:.58rem .82rem;border-bottom:1px solid var(--bd2);color:var(--ink-2)}
.legal-table tr:last-child td{border-bottom:none}
.legal-table code{font-family:var(--fm);font-size:.85em;background:var(--s2);padding:.1em .32em;border-radius:3px}

/* ── PAGE SHOW/HIDE ───────────────────────────── */
.page{display:none}.page.active{display:block}.page.active .au{animation-play-state:running}

/* ── FOOTER ──────────────────────────────────── */
footer{background:#0b0c15;color:rgba(255,255,255,.55);padding:4rem 0 0}
.foot-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.foot-brand p{font-size:.82rem;color:rgba(255,255,255,.38);line-height:1.7;max-width:270px;margin:.85rem 0}
.foot-logo{display:flex;align-items:center;gap:10px;font-family:var(--fd);font-weight:900;font-size:1.05rem;color:#fff;letter-spacing:-.03em;text-decoration:none}
.foot-col h4{font-family:var(--fd);font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.24);margin-bottom:.85rem}
.foot-links{display:flex;flex-direction:column;gap:.4rem}
.foot-lk{font-size:.82rem;color:rgba(255,255,255,.48);transition:color .15s;text-decoration:none;display:block}
.foot-lk:hover{color:#fff}
.foot-bot{border-top:1px solid rgba(255,255,255,.06);padding:1.3rem 0;display:flex;align-items:center;justify-content:space-between;font-size:.77rem;color:rgba(255,255,255,.24);flex-wrap:wrap;gap:.75rem}

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:1100px){
  .app-grid{grid-template-columns:1fr}
  .sidebar{display:grid;grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .tools-grid{grid-template-columns:repeat(2,1fr)}
  .about-lay{grid-template-columns:1fr}
  .sec-cards{grid-template-columns:1fr}
  .legal-lay{grid-template-columns:1fr}
  .legal-nav{position:static}
}
@media(max-width:768px){
  .nav-links{display:none}.hbg{display:flex}
  .stat-row{grid-template-columns:repeat(3,1fr)}
  .sidebar{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:1.5rem}
  .foot-bot{flex-direction:column;align-items:center;text-align:center}
  .feat-grid,.tools-grid{grid-template-columns:1fr}
  .fr-row{grid-template-columns:1fr}
  #cookie-bar{flex-direction:column;align-items:flex-start;gap:.75rem}
  .ck-acts{width:100%}.ck-dec,.ck-acc{flex:1;text-align:center}
}
@media(max-width:540px){
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .container{padding:0 1rem}
  .section{padding:3.5rem 0}
}
@media print{
  #nav,#cookie-bar,#toast,#back-top,footer,.tabs-nav,.ed-top,.ed-bot,.sidebar .btn{display:none!important}
  .app-grid,.sidebar{grid-template-columns:1fr!important}
}

/* ── TOOL PAGE HERO ──────────────────────────── */
.tool-hero{padding:3.5rem 0 2.5rem;position:relative;overflow:hidden;border-bottom:1px solid var(--bd2);background:linear-gradient(135deg,var(--wh) 0%,var(--brand-xs) 100%)}
.tool-hero::before{content:"";position:absolute;top:-40%;right:-5%;width:480px;height:480px;background:radial-gradient(circle,var(--brand-soft) 0%,transparent 65%);opacity:.5;pointer-events:none}
.tool-hero-in{position:relative;z-index:1}
.tool-hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--brand);color:#fff;padding:.3rem .9rem;border-radius:var(--pill);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.1rem}
.tool-hero h1{font-family:var(--fd);font-size:clamp(1.8rem,3.5vw,3rem);font-weight:900;line-height:1.05;letter-spacing:-.03em;color:var(--ink);margin-bottom:.85rem}
.tool-hero p{font-size:1rem;color:var(--ink-2);max-width:560px;line-height:1.7;margin-bottom:1.25rem}
.tool-hero-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}
.tool-meta-pill{display:inline-flex;align-items:center;gap:5px;padding:.26rem .7rem;border-radius:var(--pill);font-size:.74rem;font-weight:600;background:var(--wh);border:1px solid var(--bd);color:var(--ink-2)}
/* Tool page focused tab */
.tool-focus-pane{background:var(--wh);border:1.5px solid var(--brand);border-radius:var(--r4);overflow:hidden;margin-bottom:1.25rem;box-shadow:0 4px 32px var(--brand-glow)}
.tool-focus-header{display:flex;align-items:center;gap:10px;padding:.85rem 1.25rem;background:var(--brand);color:#fff}
.tool-focus-title{font-family:var(--fd);font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em}
.tool-focus-body{padding:1.25rem}

/* ══════════════════════════════════════════════
   TIER 1 FEATURES — Dark Mode + New Components
══════════════════════════════════════════════ */

/* ── DARK MODE ───────────────────────────────── */
[data-dark] {
  --brand:#5c5cff; --brand-d:#4444ee; --brand-soft:rgba(92,92,255,.18);
  --brand-xs:rgba(92,92,255,.08); --brand-glow:rgba(92,92,255,.22);
  --ink:#e4e6f3; --ink-2:#b8bcda; --ink-3:#8088a8; --ink-4:#545c7a; --ink-5:#363c54;
  --bd:#2e3450; --bd2:#252b40;
  --bg:#0c0e18; --wh:#141720; --s2:#191d2c; --s3:#1e2335;
  --green:#00d688; --green-bg:rgba(0,214,136,.12); --green-ink:#00d688;
  --amber:#fbbf24; --amber-bg:rgba(251,191,36,.12); --amber-ink:#fbbf24;
  --red:#f87171; --red-bg:rgba(248,113,113,.12); --red-ink:#f87171;
  --purple:#a78bfa; --purple-bg:rgba(167,139,250,.12); --purple-ink:#a78bfa;
  --teal:#22d3ee; --teal-bg:rgba(34,211,238,.12);
}
[data-dark] body { background:var(--bg); color:var(--ink); }
[data-dark] #nav { background:rgba(12,14,24,.95); border-bottom-color:rgba(92,92,255,.12); }
[data-dark] footer { background:#080a12; }
[data-dark] .ed-shell,.tabs-shell,[data-dark] .panel { box-shadow:0 4px 24px rgba(0,0,0,.4); }
[data-dark] #editor { color:var(--ink); }
[data-dark] #cookie-bar { background:#0a0c16; }
[data-dark] .mob-panel { background:var(--wh); }
[data-dark] .sc.prim { background:var(--brand); }
[data-dark] .tool-hero { background:linear-gradient(135deg,var(--wh) 0%,rgba(92,92,255,.06) 100%); }
[data-dark] .feat-card:hover,[data-dark] .how-card:hover,[data-dark] .tool-card:hover { box-shadow:0 12px 36px rgba(0,0,0,.5); }

/* Dark mode transition */
*, *::before, *::after { transition-property:background-color,border-color,color; transition-duration:.2s; }
/* Except animations */
.popping,.au { transition:none !important; }

/* Dark mode toggle button */
.dm-toggle { width:36px; height:36px; border-radius:50%; border:1.5px solid var(--bd); background:var(--s2); cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--ink-3); transition:all .15s; flex-shrink:0; }
.dm-toggle:hover { border-color:var(--brand); color:var(--brand); background:var(--brand-soft); }

/* ── WRITING SPEED TRACKER ───────────────────── */
.speed-stat { display:flex; align-items:center; gap:8px; font-family:var(--fm); }
.speed-val { font-size:1.1rem; font-weight:700; color:var(--brand); font-family:var(--fd); }
.speed-lbl { font-size:.68rem; color:var(--ink-4); text-transform:uppercase; letter-spacing:.08em; }
.speed-dot { width:7px; height:7px; border-radius:50%; background:var(--green); flex-shrink:0; }
.speed-dot.inactive { background:var(--ink-5); }

/* ── WRITING ANALYSIS PANEL ──────────────────── */
.wa-grid { display:grid; grid-template-columns:1fr 1fr; gap:.5rem; margin-bottom:.85rem; }
.wa-stat { background:var(--s2); border-radius:var(--r2); padding:.65rem .75rem; }
.wa-stat-val { font-family:var(--fd); font-size:1.15rem; font-weight:800; color:var(--ink); line-height:1; margin-bottom:.2rem; }
.wa-stat-lbl { font-size:.62rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-4); }
.wa-bar-row { display:flex; align-items:center; gap:8px; margin-bottom:.42rem; }
.wa-bar-label { font-size:.74rem; color:var(--ink-2); width:80px; flex-shrink:0; }
.wa-bar-track { flex:1; height:6px; background:var(--s3); border-radius:var(--pill); overflow:hidden; }
.wa-bar-fill { height:100%; border-radius:var(--pill); transition:width .4s var(--ease); }
.wa-bar-count { font-family:var(--fm); font-size:.7rem; color:var(--ink-4); width:30px; text-align:right; flex-shrink:0; }
.wa-highlight-key { display:flex; flex-wrap:wrap; gap:6px; margin-top:.6rem; padding-top:.6rem; border-top:1px solid var(--bd2); }
.wa-key { display:flex; align-items:center; gap:4px; font-size:.7rem; color:var(--ink-3); }
.wa-key-dot { width:10px; height:10px; border-radius:2px; flex-shrink:0; }
.cliche-count { font-family:var(--fm); font-size:.74rem; color:var(--ink-4); }
.cliche-list { display:flex; flex-direction:column; gap:3px; max-height:130px; overflow-y:auto; margin-top:.45rem; }
.cliche-item { font-size:.76rem; color:var(--red-ink); background:var(--red-bg); padding:.22rem .55rem; border-radius:5px; font-family:var(--fm); }
.transition-list { display:flex; flex-wrap:wrap; gap:4px; max-height:100px; overflow-y:auto; margin-top:.45rem; }
.trans-tag { font-size:.72rem; color:var(--green-ink); background:var(--green-bg); padding:.18rem .48rem; border-radius:5px; font-family:var(--fm); }

/* ── FONT / SPACING CONTROLS ─────────────────── */
.editor-controls { display:flex; align-items:center; gap:1.25rem; padding:.5rem 1rem; border-bottom:1px solid var(--bd2); background:var(--s2); flex-wrap:wrap; }
.ec-group { display:flex; align-items:center; gap:.5rem; }
.ec-label { font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-4); white-space:nowrap; }
.ec-slider { width:70px; height:4px; -webkit-appearance:none; appearance:none; background:var(--bd); border-radius:var(--pill); outline:none; cursor:pointer; }
.ec-slider::-webkit-slider-thumb { -webkit-appearance:none; width:14px; height:14px; border-radius:50%; background:var(--brand); cursor:pointer; border:2px solid var(--wh); box-shadow:0 1px 4px rgba(0,0,0,.2); }
.ec-slider::-moz-range-thumb { width:14px; height:14px; border-radius:50%; background:var(--brand); cursor:pointer; border:2px solid var(--wh); }
.ec-val { font-family:var(--fm); font-size:.72rem; color:var(--ink-3); min-width:24px; }

/* ── DRAG AND DROP ───────────────────────────── */
.drop-overlay { position:absolute; inset:0; background:rgba(26,26,255,.08); border:3px dashed var(--brand); border-radius:var(--r3); display:flex; align-items:center; justify-content:center; z-index:10; opacity:0; pointer-events:none; transition:opacity .2s; }
.drop-overlay.active { opacity:1; pointer-events:auto; }
.drop-msg { text-align:center; }
.drop-msg svg { width:36px; height:36px; color:var(--brand); margin:0 auto .5rem; }
.drop-msg p { font-family:var(--fd); font-size:1.1rem; font-weight:800; color:var(--brand); }
.drop-msg span { font-size:.8rem; color:var(--ink-3); }
.ed-area { position:relative; }

/* ── HIGHLIGHT LAYERS (new) ──────────────────── */
#hl-layer mark.hl-passive { background:rgba(139,92,246,.22); color:transparent; border-radius:2px; }
#hl-layer mark.hl-transition { background:rgba(0,184,122,.18); color:transparent; border-radius:2px; }
#hl-layer mark.hl-cliche { background:rgba(239,68,68,.22); color:transparent; border-radius:2px; border-bottom:2px solid var(--red); }

/* ── SENTENCE VARIETY ────────────────────────── */
.variety-ring { position:relative; width:80px; height:80px; margin:0 auto .5rem; }
.variety-svg { transform:rotate(-90deg); }
.variety-bg { fill:none; stroke:var(--bd); stroke-width:8; }
.variety-fill { fill:none; stroke:var(--brand); stroke-width:8; stroke-linecap:round; stroke-dasharray:220; stroke-dashoffset:220; transition:stroke-dashoffset .8s var(--ease),stroke .4s; }
.variety-val-c { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.variety-num { font-family:var(--fd); font-size:1.1rem; font-weight:900; color:var(--ink); line-height:1; }
.variety-sub { font-size:.52rem; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--ink-4); }

@media(max-width:768px){.wa-grid{grid-template-columns:1fr}.editor-controls{gap:.75rem}}
