:root, [data-theme="light"] {
  --color-bg: #fbf7fc;
  --color-surface: #ffffff;
  --color-surface-2: #f5edf7;
  --color-surface-offset: #ecdef0;
  --color-divider: #e4d2ea;
  --color-border: #d0b5db;
  --color-text: #1d1222;
  --color-text-muted: #624a6c;
  --color-text-faint: #a38fad;

  --color-accent: #8b3fc5;
  --color-accent-soft: #eedcf4;
  --color-accent-hover: #6e29a7;
  --color-accent-2: #d94480;
  --color-accent-2-soft: #fbd6e2;

  --color-yellow: #d69c00;
  --color-pink: #d94480;
  --color-pink-soft: #fbd6e2;
  --color-teal: #0e9488;

  --grad-hero: linear-gradient(120deg, #8b3fc5 0%, #d94480 100%);
  --grad-accent: linear-gradient(135deg, #8b3fc5, #d94480);
  --grad-purple: linear-gradient(135deg, #8b3fc5, #6e29a7);

  --shadow-sm: 0 1px 2px rgba(40,10,50,.06);
  --shadow-md: 0 8px 24px rgba(40,10,50,.08);
  --shadow-lg: 0 20px 50px rgba(40,10,50,.12);
  --shadow-glow: 0 10px 30px rgba(139,63,197,.18);
  --shadow-glow-purple: 0 10px 30px rgba(139,63,197,.25);

  --radius-sm: 6px; --radius-md: 12px; --radius-lg: 20px; --radius-xl: 28px;
  --transition: 200ms cubic-bezier(.16,1,.3,1);

  --text-xs: clamp(.75rem, .7rem + .25vw, .875rem);
  --text-sm: clamp(.875rem, .8rem + .35vw, 1rem);
  --text-base: clamp(1rem, .95rem + .25vw, 1.0625rem);
  --text-lg: clamp(1.125rem, 1rem + .5vw, 1.375rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --text-2xl: clamp(2.25rem, 1.5rem + 3vw, 3.75rem);

  --space-1: .25rem; --space-2: .5rem; --space-3: .75rem; --space-4: 1rem;
  --space-5: 1.25rem; --space-6: 1.5rem; --space-8: 2rem; --space-10: 2.5rem;
  --space-12: 3rem; --space-16: 4rem; --space-20: 5rem; --space-24: 6rem;

  --font-body: 'Inter', system-ui, -apple-system, sans-serif;
  --font-display: 'Fraunces', Georgia, serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;
}

[data-theme="dark"] {
  --color-bg: #150d19;
  --color-surface: #1c1220;
  --color-surface-2: #221527;
  --color-surface-offset: #2a1b31;
  --color-divider: #33203a;
  --color-border: #422a4b;
  --color-text: #f1e6f3;
  --color-text-muted: #a894ae;
  --color-text-faint: #715a78;
  --color-accent: #c97ee8;
  --color-accent-soft: #3a1d46;
  --color-accent-hover: #e29bfb;
  --color-accent-2: #f276a2;
  --color-accent-2-soft: #3d1f2a;
  --color-pink-soft: #3d1f2a;
  --grad-hero: linear-gradient(120deg, #c97ee8 0%, #f276a2 100%);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.3);
  --shadow-md: 0 8px 24px rgba(0,0,0,.45);
  --shadow-lg: 0 20px 50px rgba(0,0,0,.55);
  --shadow-glow: 0 10px 30px rgba(201,126,232,.15);
  --shadow-glow-purple: 0 10px 30px rgba(201,126,232,.2);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px;-webkit-font-smoothing:antialiased}
body{
  font-family:var(--font-body);font-size:var(--text-base);line-height:1.6;
  color:var(--color-text);background:var(--color-bg);
  min-height:100dvh;position:relative;overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
input,button,textarea,select{font:inherit;color:inherit}
button{cursor:pointer;background:none;border:none}
h1,h2,h3{line-height:1.1;text-wrap:balance}
p{text-wrap:pretty}
a{color:var(--color-accent);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--color-accent-hover)}
:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:var(--radius-sm)}

.container{width:min(100% - 2rem, 980px);margin-inline:auto;position:relative}

.bg-blobs{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(100px);opacity:.55}
[data-theme="dark"] .blob{opacity:.3}
.blob-1{width:520px;height:520px;top:-180px;left:-140px;background:#8b3fc5}
.blob-2{width:460px;height:460px;top:360px;right:-180px;background:#d94480}
.blob-3{width:380px;height:380px;top:1400px;left:30%;background:#b968d8}

.site-header{
  position:sticky;top:0;z-index:20;
  background:color-mix(in oklab,var(--color-bg) 80%,transparent);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--color-divider);
}
.header-inner{display:flex;align-items:center;gap:var(--space-6);padding-block:var(--space-4)}
.brand{display:inline-flex;align-items:center;gap:var(--space-3);font-weight:700;font-size:var(--text-lg);color:var(--color-text);letter-spacing:-.02em}
.brand:hover{color:var(--color-text)}
.brand svg{transition:transform var(--transition)}
.brand:hover svg{transform:rotate(-8deg) scale(1.08)}
.site-header nav{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-left:auto;font-size:var(--text-sm);font-weight:500}
.site-header nav a{color:var(--color-text-muted)}
.site-header nav a:hover{color:var(--color-text)}
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);color:var(--color-text-muted);border:1px solid var(--color-divider)}
.theme-toggle:hover{background:var(--color-surface-offset);color:var(--color-text)}

@media (max-width:720px){.site-header nav{display:none}}

.hero{padding-block:clamp(var(--space-16),10vw,var(--space-24)) var(--space-12)}
.eyebrow{display:inline-block;font-size:var(--text-xs);font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:var(--space-2) var(--space-3);background:var(--color-accent-soft);color:var(--color-accent);border-radius:999px;margin-bottom:var(--space-5)}
.hero h1{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:500;letter-spacing:-.03em;margin-bottom:var(--space-5);max-width:18ch}
.hero h1 em{font-style:italic;font-weight:500;background:var(--grad-hero);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.hero .lede{font-size:var(--text-lg);color:var(--color-text-muted);max-width:58ch;margin-bottom:var(--space-8)}
.hero-chips{display:flex;flex-wrap:wrap;gap:var(--space-3)}
.chip{display:inline-flex;align-items:center;padding:var(--space-3) var(--space-5);border-radius:999px;font-size:var(--text-sm);font-weight:600;background:var(--color-accent-soft);color:var(--color-accent);transition:all var(--transition)}
.chip:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);color:var(--color-accent-hover)}

.ad-slot{margin-block:var(--space-8);min-height:90px}
.ad-placeholder{min-height:90px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-offset);border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-faint);font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase}

.tool{padding-block:var(--space-10)}
.tool-head{margin-bottom:var(--space-6)}
.tool-tag{display:inline-block;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--space-3);color:var(--color-accent)}
.tool-head h2{font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;letter-spacing:-.02em;margin-bottom:var(--space-2)}
.tool-head p{color:var(--color-text-muted);max-width:62ch}

.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-md)}
.card-glow{box-shadow:var(--shadow-md),var(--shadow-glow)}

.field{display:flex;flex-direction:column;gap:var(--space-2)}
.field label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}

input[type="number"],input[type="text"],select,textarea{
  background:var(--color-surface-2);border:1px solid var(--color-border);
  border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);
  font-size:var(--text-base);
  transition:border-color var(--transition),box-shadow var(--transition);
  width:100%;font-family:var(--font-body);
}
textarea{resize:vertical;min-height:120px;line-height:1.6}
input:hover,select:hover,textarea:hover{border-color:var(--color-text-faint)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}

/* ======= Platform picker ======= */
.platform-picker{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-5)}
.platform-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-2);font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted);transition:all var(--transition)}
.platform-btn:hover{color:var(--color-text);border-color:var(--color-accent);transform:translateY(-1px)}
.platform-btn[aria-selected="true"]{background:var(--grad-purple);color:white;border-color:transparent;box-shadow:var(--shadow-glow-purple)}
.platform-btn .dot{width:8px;height:8px;border-radius:50%;background:currentColor}

.platform-meta{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-accent-soft);border-radius:var(--radius-md);margin-bottom:var(--space-4);color:var(--color-text)}
.platform-name{font-weight:700;font-size:var(--text-base);margin-bottom:2px}
.platform-note{font-size:var(--text-xs);color:var(--color-text-muted)}

.limit-ring{position:relative;width:44px;height:44px;flex-shrink:0;color:var(--color-accent)}
.limit-ring svg{transition:color var(--transition)}
.limit-ring.warn{color:var(--color-yellow)}
.limit-ring.over{color:var(--color-pink)}
.ring-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--color-text)}

#wc-text{font-size:var(--text-base)}
#wc-text.over{border-color:var(--color-pink);background:color-mix(in oklab,var(--color-pink-soft) 50%,var(--color-surface-2))}

.counter-bar{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-4);margin-top:var(--space-3);padding:var(--space-3) var(--space-2);border-bottom:1px solid var(--color-divider)}
.counter-main{display:flex;align-items:baseline;gap:var(--space-2);flex-wrap:wrap}
.counter-num{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700;color:var(--color-accent)}
.counter-num.warn{color:var(--color-yellow)}
.counter-num.over{color:var(--color-pink)}
.counter-max{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted)}
.counter-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-left:var(--space-2)}
.counter-warn{font-size:var(--text-xs);font-weight:600;color:var(--color-pink)}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:var(--space-3);margin-top:var(--space-5)}
.stat{padding:var(--space-4) var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-divider);border-radius:var(--radius-md);text-align:center;transition:transform var(--transition),border-color var(--transition)}
.stat:hover{transform:translateY(-2px);border-color:var(--color-accent)}
.stat-num{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700;color:var(--color-accent);margin-bottom:var(--space-1)}
.stat-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}

/* Hashtags */
.hashtags{margin-top:var(--space-6);padding:var(--space-5);background:linear-gradient(135deg,color-mix(in oklab,var(--color-accent-soft) 80%,transparent),color-mix(in oklab,var(--color-accent-2-soft) 80%,transparent));border-radius:var(--radius-lg);border:1px solid var(--color-divider)}
.hashtags-head{margin-bottom:var(--space-3)}
.hashtags-head h3{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;margin-bottom:var(--space-1);color:var(--color-text)}
.hashtags-hint{font-size:var(--text-xs);color:var(--color-text-muted)}
.hashtag-list{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4);min-height:34px}
.hashtag{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:600;color:var(--color-accent);cursor:pointer;transition:all var(--transition)}
.hashtag:hover{background:var(--color-accent);color:white;border-color:var(--color-accent);transform:translateY(-1px)}
.hashtag.copied{background:var(--color-teal);color:white;border-color:var(--color-teal)}
.hashtag-empty{font-size:var(--text-sm);color:var(--color-text-muted);font-style:italic}

/* Buttons */
.btn-primary{padding:var(--space-3) var(--space-5);background:var(--grad-purple);color:white;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;transition:all var(--transition);box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-glow-purple)}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}

.actions{display:flex;gap:var(--space-3);margin-top:var(--space-5);flex-wrap:wrap}
.btn-secondary{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;color:var(--color-text);background:var(--color-surface-2);transition:all var(--transition)}
.btn-secondary:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-soft)}

/* Grid utilities */
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-5)}

/* Result cells */
.result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-3);margin-top:var(--space-5)}
.result-cell{padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);background:var(--color-surface-2);border:1px solid var(--color-divider)}
.result-cell.accent{background:var(--color-accent-soft);border-left:3px solid var(--color-accent);border-color:var(--color-accent-soft)}
.rc-label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:var(--space-2);display:block}
.rc-num{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700;color:var(--color-accent);letter-spacing:-.01em}
.result-cell:not(.accent) .rc-num{color:var(--color-text)}
.rc-sub{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}
.result-meta{margin-top:var(--space-4);font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic}

/* Case converter */
.case-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-5);margin-bottom:var(--space-5)}
.preset-btn{padding:var(--space-2) var(--space-4);border-radius:999px;background:var(--color-surface-2);border:1px solid var(--color-border);font-size:var(--text-xs);font-family:var(--font-mono);font-weight:600;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition)}
.preset-btn:hover{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-soft)}
.case-output-wrap{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4)}
.case-output-wrap textarea{background:var(--color-surface-2);font-family:var(--font-mono);font-size:var(--text-sm)}
.case-output-wrap .btn-secondary{align-self:flex-start}

/* Cleanup checkboxes */
.clean-options{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-block:var(--space-5)}
.clean-options label{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition)}
.clean-options label:hover{color:var(--color-text);border-color:var(--color-accent)}
.clean-options input[type="checkbox"]{width:auto;margin:0;accent-color:var(--color-accent)}

.about{padding-block:var(--space-16)}
.about h2{font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;margin-bottom:var(--space-5);letter-spacing:-.02em}
.about p{max-width:68ch;color:var(--color-text-muted)}

footer{border-top:1px solid var(--color-divider);padding-block:var(--space-8);margin-top:var(--space-16);color:var(--color-text-muted);font-size:var(--text-sm)}
.footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--space-4);align-items:center}
footer nav{display:flex;flex-wrap:wrap;gap:var(--space-4)}
footer a{color:var(--color-text-muted)}
footer a:hover{color:var(--color-accent)}
.quiet-corner{width:100%;text-align:center;padding-top:var(--space-4);border-top:1px solid var(--color-divider);margin-top:var(--space-4);font-size:var(--text-xs);color:var(--color-text-faint);font-style:italic}
.quiet-corner a{color:var(--color-text-muted);text-decoration:underline;text-decoration-color:var(--color-divider);text-underline-offset:3px}
.quiet-corner a:hover{color:var(--color-accent);text-decoration-color:var(--color-accent)}

@media (max-width:720px){.platform-meta{flex-direction:column;align-items:flex-start;text-align:left}.limit-ring{align-self:flex-end}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
