/* Twister King - static site styles */
:root{
  --bg:#fff8ee;
  --bg-alt:#fff2dd;
  --ink:#2a1a0f;
  --ink-soft:#6b4c38;
  --accent:#ff5a5f;
  --accent-2:#ffb400;
  --accent-3:#4ecdc4;
  --accent-4:#a06cd5;
  --card:#ffffff;
  --border:#efe0c7;
  --shadow:0 4px 0 rgba(42,26,15,.08), 0 2px 14px rgba(42,26,15,.06);
  --shadow-hover:0 6px 0 rgba(42,26,15,.10), 0 8px 22px rgba(42,26,15,.10);
  --radius:14px;
  --radius-lg:22px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Nunito','Segoe UI',system-ui,-apple-system,'Helvetica Neue',Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none;font-weight:700}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}

/* Header */
.site-header{
  background:linear-gradient(135deg,#fff8ee 0%, #ffe5c2 100%);
  border-bottom:3px solid var(--border);
  position:sticky;top:0;z-index:50;
}
.site-header .bar{display:flex;align-items:center;gap:18px;padding:14px 0;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;color:var(--ink);font-size:22px}
.brand img{height:44px;width:auto}
.nav{display:flex;flex-wrap:wrap;gap:4px;margin-left:auto;align-items:center}
.nav a{color:var(--ink);font-weight:700;padding:8px 12px;border-radius:10px;font-size:15px}
.nav a:hover{background:var(--bg-alt);text-decoration:none}
.nav a.cta{background:var(--accent);color:#fff}
.nav a.cta:hover{background:#ff3840}

/* Hero */
.hero{padding:60px 0 40px;text-align:center;position:relative;overflow:hidden}
.hero h1{
  font-size:clamp(34px,5.5vw,58px);
  line-height:1.05;
  margin:0 0 14px;
  font-weight:900;
  letter-spacing:-.02em;
}
.hero h1 .wobble{display:inline-block;color:var(--accent)}
.hero h1 .wobble:nth-child(2){color:var(--accent-2)}
.hero h1 .wobble:nth-child(3){color:var(--accent-3)}
.hero h1 .wobble:nth-child(4){color:var(--accent-4)}
.hero p.lede{font-size:19px;color:var(--ink-soft);max-width:640px;margin:0 auto 28px}

.searchbox{
  max-width:560px;margin:20px auto 0;display:flex;gap:8px;
  background:#fff;border:3px solid var(--ink);border-radius:999px;padding:6px;
  box-shadow:var(--shadow);
}
.searchbox input{
  flex:1;border:0;outline:0;padding:12px 18px;font-size:17px;background:transparent;border-radius:999px;font-family:inherit;color:var(--ink)
}
.searchbox button{
  background:var(--ink);color:#fff;border:0;padding:12px 22px;border-radius:999px;font-weight:900;cursor:pointer;font-family:inherit;font-size:15px
}
.searchbox button:hover{background:var(--accent)}

/* Tiles */
.section{padding:48px 0}
.section h2{font-size:clamp(24px,3.5vw,34px);margin:0 0 18px;font-weight:900}
.section .eyebrow{color:var(--accent);font-weight:900;letter-spacing:.1em;text-transform:uppercase;font-size:13px;margin-bottom:6px}

.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.tile{
  background:var(--card);border:3px solid var(--ink);border-radius:var(--radius);
  padding:18px;box-shadow:var(--shadow);transition:.15s transform,.15s box-shadow;
  display:flex;flex-direction:column;gap:6px;color:var(--ink);
}
.tile:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-hover);text-decoration:none}
.tile .tname{font-weight:900;font-size:18px}
.tile .tdesc{color:var(--ink-soft);font-size:14px}
.tile .tcount{font-size:12px;color:var(--accent);font-weight:900;margin-top:auto}
.tile.c1{background:#fff1e0}
.tile.c2{background:#ffe8f0}
.tile.c3{background:#e5fbf5}
.tile.c4{background:#f0eaff}
.tile.c5{background:#fff8d4}
.tile.c6{background:#e8f4ff}

/* Alphabet grid */
.alphabet{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px}
.letter{
  background:var(--card);border:3px solid var(--ink);border-radius:var(--radius);
  padding:14px 0;text-align:center;font-weight:900;font-size:24px;color:var(--ink);
  box-shadow:var(--shadow);
}
.letter:hover{text-decoration:none;background:var(--accent);color:#fff}
.letter .sub{display:block;font-size:12px;font-weight:700;color:var(--ink-soft);margin-top:2px}
.letter:hover .sub{color:#fff}

/* Cards / twister list */
.card-list{display:grid;grid-template-columns:1fr;gap:14px}
.tw{
  background:var(--card);border:3px solid var(--ink);border-radius:var(--radius);
  padding:18px 20px;box-shadow:var(--shadow);position:relative;
}
.tw .text{font-size:18px;line-height:1.55;font-weight:600;margin:0 0 10px;white-space:pre-wrap}
.tw .meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12px;color:var(--ink-soft)}
.tag{display:inline-block;padding:3px 10px;border-radius:999px;font-weight:900;font-size:11px;background:var(--bg-alt);color:var(--ink);border:1.5px solid var(--border);text-transform:uppercase;letter-spacing:.03em}
.tag.easy{background:#defbe6;border-color:#70d99a;color:#186a36}
.tag.medium{background:#fff5cd;border-color:#f0c76a;color:#7a4b00}
.tag.hard{background:#ffd9db;border-color:#ff8286;color:#8a0e12}
.tag.short{background:#e0f4ff;border-color:#7ac6f4;color:#123b59}
.tag.long{background:#efe0ff;border-color:#b694db;color:#3c1f68}
.tw .actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.btn{
  background:var(--bg-alt);border:2px solid var(--ink);color:var(--ink);
  padding:6px 12px;border-radius:999px;font-weight:800;font-size:13px;cursor:pointer;font-family:inherit;
}
.btn:hover{background:var(--accent);color:#fff;text-decoration:none}
.btn.primary{background:var(--ink);color:#fff}
.btn.primary:hover{background:var(--accent)}

/* Filters */
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:18px}
.filter-group{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.filter-group .label{font-weight:900;font-size:13px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;margin-right:4px}
.chip{
  border:2px solid var(--ink);background:#fff;color:var(--ink);border-radius:999px;
  padding:6px 12px;font-weight:800;font-size:13px;cursor:pointer;font-family:inherit;
}
.chip.active{background:var(--ink);color:#fff}
.chip:hover{background:var(--accent-2)}
.chip.active:hover{background:var(--accent)}

.counter{margin-left:auto;font-weight:800;color:var(--ink-soft);font-size:14px}

/* Tongue twister single page */
.twister-hero{
  background:linear-gradient(135deg,#fff 0%, #ffeec4 100%);
  border:3px solid var(--ink);border-radius:var(--radius-lg);padding:32px;
  box-shadow:var(--shadow);margin:24px 0;
}
.twister-hero .text{font-size:clamp(22px,3vw,30px);line-height:1.45;font-weight:800;margin:0 0 16px;white-space:pre-wrap;font-family:inherit;color:var(--ink)}
h1.text{letter-spacing:-.005em}
.twister-hero .meta{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0 0}
.twister-hero .actions{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;
}
.twister-hero .actions .btn{white-space:nowrap;min-height:42px;padding:10px 16px;font-size:14px}
@media (max-width:620px){
  .twister-hero{padding:22px 18px}
  .twister-hero .actions{gap:8px;margin-top:18px}
  .twister-hero .actions .btn{flex:1 1 auto;min-width:0;font-size:13px;padding:9px 12px}
  .twister-hero .actions .btn.more-letter{flex-basis:100%}
}

/* Content / prose */
.prose{max-width:780px;margin:0 auto}
.prose h1{font-size:clamp(28px,4vw,42px);margin:0 0 14px;font-weight:900}
.prose h2{font-size:clamp(22px,3vw,28px);margin:32px 0 10px;font-weight:900}
.prose h3{font-size:20px;margin:22px 0 8px;font-weight:900}
.prose p{font-size:17px;color:var(--ink);margin:0 0 14px}
.prose ul{margin:0 0 14px 20px}
.prose a{color:var(--accent)}

/* Breadcrumbs */
.crumbs{font-size:13px;color:var(--ink-soft);margin:16px 0 0}
.crumbs a{color:var(--ink-soft);font-weight:700}
.crumbs a:hover{color:var(--accent)}

/* Footer */
.site-footer{
  background:var(--ink);color:#f3e5c9;margin-top:60px;padding:40px 0 24px;
}
.site-footer a{color:var(--accent-2)}
.site-footer .cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px}
.site-footer h4{margin:0 0 10px;font-weight:900;color:#fff;font-size:14px;letter-spacing:.08em;text-transform:uppercase}
.site-footer ul{list-style:none;padding:0;margin:0;font-size:14px}
.site-footer ul li{margin:4px 0}
.site-footer .copy{border-top:1px solid #3a2a1c;margin-top:24px;padding-top:16px;font-size:13px;color:#b89a76;text-align:center}

/* Utilities */
.hidden{display:none!important}
.center{text-align:center}

/* Mobile */
@media (max-width:700px){
  .hero{padding:40px 0 24px}
  .searchbox{flex-direction:row}
  .section{padding:32px 0}
  .brand span{display:none}
}

/* Print-style read-aloud indicator */
.tw.speaking{outline:3px solid var(--accent-2);outline-offset:2px}

/* Pagination for all page is just scroll - uses virtualization via simple JS show/hide */
.load-more{text-align:center;margin:20px 0}

/* Contact form */
.contact-form{display:grid;gap:14px;max-width:560px;margin:20px 0 0}
.contact-form .field{display:flex;flex-direction:column;gap:6px}
.contact-form label{font-weight:800;font-size:14px;color:var(--ink)}
.contact-form input,
.contact-form textarea{
  font-family:inherit;font-size:16px;color:var(--ink);
  border:2px solid var(--ink);border-radius:10px;padding:10px 12px;
  background:#fff;outline:none;box-shadow:var(--shadow);
}
.contact-form input:focus,
.contact-form textarea:focus{border-color:var(--accent)}
.contact-form textarea{resize:vertical;min-height:140px}
.contact-form .hp{position:absolute;left:-9999px;height:0;width:0;overflow:hidden}
.contact-form .cf-turnstile{margin-top:6px}
.form-notice{
  padding:14px 16px;border-radius:12px;margin:16px 0;font-weight:700;
  border:2px solid var(--ink);
}
.form-notice.ok{background:#defbe6;border-color:#70d99a;color:#186a36}
.form-notice.err{background:#ffd9db;border-color:#ff8286;color:#8a0e12}

/* Cookie consent banner - anchored bottom-right on desktop, slide-in on mobile */
.tk-consent{
  position:fixed;
  right:20px;
  bottom:calc(20px + env(safe-area-inset-bottom, 0px));
  z-index:2147483000;
  width:360px;max-width:calc(100vw - 32px);
  background:#1c110a;color:#fff8ee;
  border:2px solid #fff8ee;border-radius:16px;
  box-shadow:0 18px 40px rgba(0,0,0,.45);
  font-family:inherit;
  /* opaque bg, no backdrop blur - readable over anything */
}
.tk-consent-inner{padding:16px 18px;display:flex;flex-direction:column;gap:12px}
.tk-consent-inner p{margin:0;font-size:13.5px;line-height:1.5;color:#fff8ee}
.tk-consent-inner a{color:#ffb400;text-decoration:underline;text-underline-offset:2px}
.tk-consent-actions{display:flex;gap:8px;justify-content:flex-end}
.tk-consent .btn{
  background:transparent;color:#fff8ee;border:2px solid #fff8ee;
  padding:8px 16px;font-size:13px;font-weight:800;border-radius:999px;
  cursor:pointer;font-family:inherit;white-space:nowrap;
}
.tk-consent .btn:hover{background:#fff8ee;color:#1c110a}
.tk-consent .btn.primary{background:#ff5a5f;border-color:#ff5a5f;color:#fff}
.tk-consent .btn.primary:hover{background:#ffb400;border-color:#ffb400;color:#1c110a}

/* Leave space above AdSense anchor ads on mobile (approx 60-100px tall) */
@media (max-width:900px){
  .tk-consent{
    left:12px;right:12px;width:auto;max-width:none;
    bottom:calc(104px + env(safe-area-inset-bottom, 0px));
  }
}
@media (max-width:420px){
  .tk-consent-inner{padding:14px 14px;gap:10px}
  .tk-consent-inner p{fon