:root{
  --bg: #f4f8ff;
  --bg-grad: radial-gradient(ellipse 120% 80% at 50% -30%, #dceaff 0%, #f4f8ff 45%, #fafcff 100%);
  --surface: #ffffff;
  --ink: #0a1f44;
  --muted: #64748b;
  --brand: #2563eb;
  --brand-2: #1d4ed8;
  --brand-3: #93c5fd;
  --chip: #eff6ff;
  --border: #e2eaf5;
  --border-soft: #eef3fa;
  --accent: #f8fbff;
  --panel: #f9fbff;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);
  --shadow-1: 0 8px 30px rgba(15, 23, 42, .06);
  --shadow-2: 0 16px 48px rgba(15, 23, 42, .08);
  --radius-sm: 12px;
  --radius-md: 18px;
  --radius-lg: 24px;
  --grad-btn: linear-gradient(135deg, var(--brand), var(--brand-2));
  --grad-head: rgba(255, 255, 255, .82);
  --grad-chip: linear-gradient(180deg, #fff, #f3f8ff);
}
[data-theme="dark"]{
  --bg: #0b1220;
  --bg-grad: radial-gradient(ellipse 120% 80% at 50% -30%, #0f2344 0%, #0b1220 50%, #0a1018 100%);
  --surface: #111c31;
  --ink: #eaf1ff;
  --muted: #94a3b8;
  --brand: #60a5fa;
  --brand-2: #3b82f6;
  --brand-3: #1e3a5f;
  --chip: #152238;
  --border: #24324a;
  --border-soft: #1a2740;
  --accent: #0f1a2e;
  --panel: #121f35;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);
  --shadow-1: 0 8px 30px rgba(0, 0, 0, .28);
  --shadow-2: 0 16px 48px rgba(0, 0, 0, .35);
  --grad-btn: linear-gradient(135deg, var(--brand), var(--brand-2));
  --grad-head: rgba(11, 18, 32, .92);
  --grad-chip: linear-gradient(180deg, #152238, #101a2c);
}
*{box-sizing:border-box}
html{overflow-x:hidden;-webkit-text-size-adjust:100%}
html,body{min-height:100%;max-width:100%}
body{
  margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);background:var(--bg);background-image:var(--bg-grad);
  line-height:1.65;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:var(--brand);text-decoration:none;transition:color .18s ease,opacity .18s ease}
a:hover{color:var(--brand-2);text-decoration:none}
main,header,footer,.container,.card{max-width:100%}
.container{max-width:920px;margin:0 auto;padding:24px 20px}
header{
  position:relative;z-index:10;background:var(--grad-head);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border-soft);
}
header .container.nav{padding-top:16px;padding-bottom:8px}
header .container.header-extra{padding-top:0;padding-bottom:6px}
header .container.search-wrap{padding-top:8px;padding-bottom:18px}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;min-width:0}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0;min-width:0;text-decoration:none}
.brand:hover{text-decoration:none}
.brand img{width:100px;max-width:100%;height:auto;object-fit:contain;flex-shrink:0}
.brand-subtext{
  font-size:14px;font-weight:400;font-style:italic;line-height:1.2;letter-spacing:.01em;color:var(--muted);
  white-space:nowrap
}
.theme-btn{
  appearance:none;border:1px solid var(--border);background:var(--surface);color:var(--ink);
  padding:9px 14px;border-radius:999px;cursor:pointer;font-weight:600;font-size:13px;
  flex-shrink:0;white-space:nowrap;box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease
}
.theme-btn:hover{box-shadow:var(--shadow-1)}
.search-wrap{margin:0 auto;display:flex;align-items:center;justify-content:center;width:100%;min-width:0}
.search{
  display:flex;gap:10px;width:min(720px,100%);max-width:100%;min-width:0;
  background:var(--surface);border:1px solid var(--border);border-radius:999px;
  padding:8px 8px 8px 18px;box-shadow:var(--shadow-1)
}
.search input{flex:1;min-width:0;border:none;outline:none;font-size:17px;background:transparent;color:var(--ink)}
.search input::placeholder{color:var(--muted);opacity:.85}
.search button{
  appearance:none;border:none;background:var(--grad-btn);color:#fff;padding:12px 22px;
  border-radius:999px;cursor:pointer;font-weight:700;font-size:15px;flex-shrink:0;white-space:nowrap
}
.card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:28px;box-shadow:var(--shadow-1);overflow-wrap:break-word
}
.title,.level-title{margin:0;font-size:clamp(1.6rem,4vw,2rem);font-weight:800;line-height:1.2;letter-spacing:-.02em;overflow-wrap:break-word;word-break:break-word}
.title-sm{font-size:clamp(1.25rem,2.5vw,1.5rem)}
.subtitle{margin:10px 0 0;color:var(--muted);font-size:16px;line-height:1.55}
.result-head{margin-bottom:4px}
.chip{
  display:inline-flex;align-items:center;gap:6px;background:var(--grad-chip);
  padding:7px 12px;border-radius:999px;margin:0 8px 8px 0;font-size:13px;font-weight:600;
  border:1px solid var(--border);color:var(--ink)
}
.nav-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:20px 0 0}
.nav-row a,.nav-pill{
  display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;
  font-weight:700;font-size:14px;background:var(--surface);border:1px solid var(--border);
  box-shadow:var(--shadow-sm);text-decoration:none;color:var(--ink);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease
}
.nav-row a:hover,.nav-pill:hover{transform:translateY(-1px);box-shadow:var(--shadow-1);border-color:#c7d7ef;color:var(--brand)}
.nav-pill.is-disabled,.nav-row span.nav-pill.is-disabled{
  opacity:.45;cursor:not-allowed;pointer-events:none;color:var(--muted);box-shadow:none
}
.nav-pill.is-disabled:hover{transform:none;box-shadow:none;border-color:var(--border);color:var(--muted)}
.section-title{
  margin:0 0 14px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted)
}
.list{display:flex;flex-wrap:wrap;gap:10px;margin:0}
.list .word{
  padding:10px 16px;border-radius:999px;border:1px solid var(--border);
  background:var(--surface);font-weight:700;font-size:15px;letter-spacing:.02em;
  overflow-wrap:anywhere;word-break:break-word;max-width:100%;box-shadow:var(--shadow-sm)
}
.list .word-bonus{background:var(--chip);border-color:#dbeafe;color:var(--brand-2)}
.level-shell .word-columns{
  display:flex;flex-direction:row;align-items:flex-start;width:100%;gap:20px
}
.level-shell .word-columns > .word-list{
  flex:1 1 0;min-width:0;width:50%;list-style:none;margin:0;padding:0
}
.level-shell .word-columns > .word-list li{
  position:relative;padding-left:16px;font-size:16px;line-height:1.55;font-weight:600;color:var(--ink);
  margin:0 0 8px
}
.level-shell .word-columns > .word-list li::before{
  content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;border-radius:50%;
  background:var(--brand)
}
.level-shell .word-columns > .word-list-bonus li::before{background:var(--brand-3)}
.split{height:1px;background:var(--border-soft);margin:28px 0;border:none}
.def-item{margin-bottom:12px;font-size:15px;line-height:1.55}
.def-word{font-weight:800;color:var(--brand);text-transform:capitalize;margin-right:6px}
.def-loading{color:var(--muted);font-style:italic;font-size:14px}
.breadcrumb{margin:0 0 18px;font-size:13px;color:var(--muted);overflow-wrap:anywhere}
.breadcrumb a{color:var(--muted);text-decoration:none}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb span{margin:0 5px;opacity:.55}
.voting-btns{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}
.voting-btns button{
  background:var(--surface);color:var(--ink);border:1px solid var(--border);
  padding:10px 20px;margin:0;border-radius:999px;cursor:pointer;font-weight:600;font-size:14px;
  transition:all .15s ease;box-shadow:var(--shadow-sm)
}
.voting-btns button:hover{border-color:var(--brand-3);color:var(--brand)}
.voting-btns button.voted{background:var(--grad-btn);color:#fff;border-color:transparent;box-shadow:var(--shadow-1)}
.share .btns{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}
.share .btn{
  display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;
  font-weight:700;border:1px solid var(--border);background:var(--surface);color:var(--ink);
  cursor:pointer;font-size:14px;text-decoration:none;box-shadow:var(--shadow-sm);transition:transform .15s ease
}
.share .btn:hover{transform:translateY(-1px)}
.share .btn-fb{background:#1877F2;color:#fff;border-color:#1877F2}
.share .btn-wa{background:#25D366;color:#111;border-color:#25D366}
.share .btn-x{background:#111;color:#fff;border-color:#111}
.comments-block .section-title{margin-bottom:12px}
.comments-list{display:flex;flex-direction:column;gap:12px;margin:0 0 20px}
.comment-item{
  padding:16px 18px;border:1px solid #bbf7d0;border-radius:var(--radius-sm);
  background:linear-gradient(180deg,#f0fdf4 0%,#f7fef9 100%);
  box-shadow:var(--shadow-sm)
}
[data-theme="dark"] .comment-item{
  border-color:#166534;background:linear-gradient(180deg,#14532d 0%,#12261a 100%)
}
.comment-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;font-size:14px}
.comment-meta time{color:var(--muted);font-size:13px}
.comment-body{margin:0;line-height:1.6;white-space:pre-wrap}
.comments-empty{margin:0 0 18px}
.comment-form{display:flex;flex-direction:column;gap:12px;margin-bottom:0}
.comment-form .form-row{display:flex;flex-direction:column;gap:6px}
.comment-form label{font-weight:600;font-size:14px;color:var(--ink)}
.comment-form input,.comment-form textarea{
  width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--surface);color:var(--ink);font:inherit;font-size:15px;transition:border-color .15s ease,box-shadow .15s ease
}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--brand-3);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.comment-form textarea{resize:vertical;min-height:110px}
.comment-note{margin:0;font-size:13px;color:var(--muted)}
.comment-form-actions{margin-top:6px}
.comment-submit{
  display:inline-flex;align-items:center;justify-content:center;appearance:none;border:none;
  background:var(--grad-btn);color:#fff;padding:12px 22px;border-radius:999px;
  cursor:pointer;font-weight:700;font-size:15px
}
.comment-notice{padding:14px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:14px;border:1px solid var(--border)}
.comment-notice strong{display:block;margin-bottom:4px}
.comment-notice p{margin:0;color:var(--muted);line-height:1.5}
.comment-notice-success{background:#f0fdf4;border-color:#bbf7d0}
.comment-notice-error{background:#fef2f2;border-color:#fecaca}
.flash-card-success{border-color:#86efac}
.flash-card-error{border-color:#fca5a5}
.level-image{display:flex;flex-direction:column;align-items:center;margin:28px 0 0;text-align:center}
.level-image img{
  max-width:min(380px,100%);width:100%;height:auto;border-radius:var(--radius-md);
  border:1px solid var(--border);box-shadow:var(--shadow-1)
}
.level-image figcaption,.level-image .img-caption{margin-top:10px;color:var(--muted);font-size:13px}

/* Puzzle board */
.board-wrapper{
  display:flex;flex-direction:column;align-items:center;gap:18px;
  margin:28px 0 0;padding:24px 20px;border:1px solid var(--border);
  border-radius:var(--radius-md);background:var(--panel);box-shadow:var(--shadow-sm)
}
.puzzle-board{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.puzzle-board-table{
  margin:0 auto;border-collapse:separate;border-spacing:3px;
  table-layout:fixed
}
.puzzle-cell{
  width:34px;height:34px;padding:0;text-align:center;vertical-align:middle;
  border-radius:6px;border:1px solid transparent
}
.puzzle-cell.is-empty{background:var(--surface);border-color:var(--border-soft)}
.puzzle-cell.is-letter{
  background:linear-gradient(145deg,var(--brand),var(--brand-2));
  border-color:rgba(29,78,216,.35);box-shadow:0 2px 6px rgba(37,99,235,.18)
}
.puzzle-letter{
  display:flex;align-items:center;justify-content:center;
  width:100%;height:100%;font-size:17px;font-weight:800;color:#fff;line-height:1
}
.puzzle-wheel{
  display:flex;flex-direction:column;align-items:center;gap:10px;width:100%
}
.puzzle-wheel-label{
  font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)
}
.puzzle-wheel-letters{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}
.puzzle-wheel-letter{
  display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:50%;
  background:var(--surface);border:2px solid var(--brand-3);
  font-size:18px;font-weight:800;color:var(--brand);
  box-shadow:var(--shadow-sm)
}

.levels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:10px}
.levels-grid a,.popular-grid a{
  display:block;text-align:center;padding:12px 10px;border:1px solid var(--border);
  background:var(--surface);border-radius:var(--radius-sm);font-weight:700;font-size:14px;
  box-shadow:var(--shadow-sm);text-decoration:none;color:var(--ink);transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease
}
.levels-grid a:hover,.popular-grid a:hover{transform:translateY(-1px);border-color:#c7d7ef;box-shadow:var(--shadow-1);color:var(--brand)}
.popular-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}
.seo{color:var(--ink);font-size:16px;line-height:1.7}
.seo p:first-child{margin-top:0}
.seo p:last-child{margin-bottom:0}

/* Level page */
main.level-page{padding-bottom:32px}
.level-shell{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-2);overflow:hidden
}
.level-hero{padding:24px 32px 24px;border-bottom:1px solid var(--border-soft)}
.level-subtitle{margin:8px 0 0;font-size:16px;color:var(--muted);font-weight:500}
.level-answers{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;
  border-bottom:1px solid var(--border-soft)
}
.level-block{padding:28px 32px}
.level-block + .level-block{border-left:1px solid var(--border-soft)}
.level-panel{padding:28px 32px;border-top:1px solid var(--border-soft)}
.level-panel:first-of-type{border-top:none}
.level-panel-vote{text-align:center;background:linear-gradient(180deg,var(--panel),var(--surface))}
.level-panel-vote .voting-btns{justify-content:center}
.level-panel-share{background:var(--panel)}
.level-panel-about .meta-line{margin-bottom:16px}
.level-shell .comments-block{
  margin:0;padding:28px 32px;border:none;border-radius:0;border-top:1px solid var(--border-soft);
  background:var(--surface)
}
.ws-page-card .comments-block{
  margin:28px 0 0;padding:28px 0 0;border-top:1px solid var(--border-soft);background:transparent
}
.level-page .comments-block{
  margin:0;padding:28px 32px;border:none;border-radius:0;border-top:1px solid var(--border-soft);
  background:var(--surface)
}
footer.site-footer{margin:32px 0 40px;color:var(--muted);width:100%}
footer.site-footer .container{padding-top:0;padding-bottom:0;display:flex;flex-direction:column;align-items:center;gap:20px}
footer.site-footer .popular{margin:0;width:100%;align-self:stretch;padding:28px}
footer.site-footer .popular .section-title{margin-top:0}
footer.site-footer .footer-copy{width:100%;text-align:center;font-size:14px;line-height:1.6}
footer.site-footer .footer-copy div{text-align:center}

/* Footer legal & legal pages */
.footer-legal{padding:24px 28px}
.footer-disclaimer-short{margin:0 0 14px;font-size:14px;line-height:1.65;color:var(--ink)}
.footer-legal-details{margin:0 0 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--panel);overflow:hidden}
.footer-legal-details summary{
  cursor:pointer;padding:12px 14px;font-weight:700;font-size:14px;color:var(--brand);
  list-style:none;display:flex;align-items:center;justify-content:space-between
}
.footer-legal-details summary::-webkit-details-marker{display:none}
.footer-legal-details summary::after{content:"+";font-size:18px;font-weight:400;color:var(--muted);line-height:1}
.footer-legal-details[open] summary::after{content:"−"}
.footer-legal-details[open] summary{border-bottom:1px solid var(--border-soft)}
.footer-legal-body{padding:12px 14px 14px;font-size:13px;line-height:1.65;color:var(--muted)}
.footer-legal-body p{margin:0 0 10px}
.footer-legal-body p:last-child{margin-bottom:0}
.footer-legal-nav{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:0 0 12px;font-size:14px;font-weight:700}
.footer-legal-nav span{color:var(--muted);font-weight:400}
.footer-legal-note{margin:0;font-size:13px;line-height:1.6;color:var(--muted)}
.legal-page{padding-top:8px;padding-bottom:32px}
.legal-card{padding:28px 32px}
.legal-header{margin-bottom:20px}
.legal-updated{margin:8px 0 0;font-size:14px;color:var(--muted)}
.legal-sections{display:flex;flex-direction:column;gap:10px}
.legal-details{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--panel);overflow:hidden}
.legal-details summary{
  cursor:pointer;padding:14px 16px;font-weight:700;font-size:15px;color:var(--ink);
  list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px
}
.legal-details summary::-webkit-details-marker{display:none}
.legal-details summary::after{content:"+";font-size:18px;font-weight:400;color:var(--muted);flex-shrink:0}
.legal-details[open] summary{color:var(--brand);border-bottom:1px solid var(--border-soft)}
.legal-details[open] summary::after{content:"−"}
.legal-body{padding:14px 16px 16px;font-size:15px;line-height:1.7;color:var(--ink)}
.legal-body p:first-child{margin-top:0}
.legal-body p:last-child{margin-bottom:0}
.legal-body ul{margin:8px 0 12px;padding-left:1.25rem}
.legal-body li{margin-bottom:6px}
.legal-footer-note{margin:20px 0 0;font-size:14px;color:var(--muted)}
.header-extra{margin:0;font-size:14px;color:var(--muted);text-align:center;overflow-wrap:anywhere;word-break:break-word;line-height:1.5}
.header-extra img,.home-seo img,.seo img,.page-content img{max-width:100%;height:auto;border-radius:var(--radius-sm)}
.home-seo,.seo,.page-content{overflow-wrap:break-word;word-break:break-word}
.page-content h1{margin-top:0}
.muted{color:var(--muted)}
.hidden{display:none}

/* Wordscapes group index — boxed grid layout */
.ws-index-card{padding:28px 32px 32px}
.ws-index-header{margin:0 0 24px;text-align:center}
.ws-index-title{
  margin:0;font-size:clamp(1.5rem,3.5vw,2rem);font-weight:800;line-height:1.25;
  letter-spacing:-.02em;text-transform:uppercase
}
.ws-index-subtitle{margin:8px 0 0;font-size:16px;color:var(--muted);font-weight:400;text-transform:none}

/* 4 category boxes per row within default container width */
.ws-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;
  margin:0;padding:0
}
.ws-box{
  display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);
  border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease
}
.ws-box:hover{border-color:#c7d7ef;box-shadow:var(--shadow-1);transform:translateY(-1px)}
.ws-box.is-active{border-color:var(--brand-3);box-shadow:0 0 0 1px var(--brand-3)}
.ws-box-bar{
  height:4px;width:100%;flex-shrink:0;
  background:linear-gradient(90deg,var(--brand),var(--brand-2));
  border-radius:10px 10px 0 0
}
.ws-box-head{
  display:flex;flex-direction:column;gap:2px;padding:10px 12px 8px;
  background:var(--surface);text-decoration:none;color:var(--ink)
}
.ws-box-head:hover{background:var(--chip)}
.ws-box-head:hover .ws-box-title{color:var(--brand)}
.ws-box-title{
  font-weight:800;font-size:16px;line-height:1.25;text-transform:capitalize;color:var(--ink)
}
.ws-box-range{font-size:11px;color:var(--muted);font-weight:500;line-height:1.3}

/* Packs — single vertical column (5 rows) */
.ws-box-packs{
  list-style:none;margin:0;padding:0 0 6px;display:flex;flex-direction:column;flex:1
}
.ws-box-packs-standalone{
  padding:0;gap:0;border:1px solid var(--border);border-radius:10px;overflow:hidden
}
.ws-box-pack{margin:0;min-width:0;border-top:1px solid var(--border-soft)}
.ws-box-pack:first-child{border-top:none}
.ws-box-pack a{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:6px 12px;text-decoration:none;color:var(--ink);
  transition:background .15s ease,color .15s ease
}
.ws-box-pack a:hover{background:var(--chip);color:var(--brand)}
.ws-box-pack.is-active a{background:var(--chip)}
.ws-box-pack.is-active .ws-pack-name{color:var(--brand);font-weight:700}
.ws-pack-name{
  font-weight:500;font-size:15px;line-height:1.25;text-transform:capitalize;
  overflow-wrap:break-word;word-break:break-word;min-width:0
}
.ws-pack-range{font-size:11px;color:var(--muted);line-height:1.2;white-space:nowrap;flex-shrink:0}

/* Level number boxes */
.ws-level-grid{
  list-style:none;margin:0;padding:0;display:grid;
  grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px
}
.ws-level-grid li{margin:0}
.ws-level-grid a{
  display:flex;align-items:center;justify-content:center;min-height:44px;padding:8px 6px;
  border:1px solid var(--border);border-radius:8px;background:var(--surface);
  font-weight:700;font-size:14px;text-decoration:none;color:var(--ink);
  box-shadow:var(--shadow-sm);transition:border-color .15s ease,background .15s ease,color .15s ease,transform .15s ease
}
.ws-level-grid a:hover{border-color:var(--brand-3);background:var(--chip);color:var(--brand);transform:translateY(-1px)}

.ws-page-card{padding:32px 36px}
.ws-page-header{margin:0 0 24px}
.ws-page-title{
  margin:0;font-size:clamp(1.4rem,3vw,1.85rem);font-weight:800;line-height:1.25;
  letter-spacing:-.02em;text-transform:capitalize
}
.ws-page-meta{margin:8px 0 0;font-size:16px;color:var(--muted)}
.ws-page-section{margin-top:28px}
.ws-page-section:first-of-type{margin-top:0}
.ws-section-label{
  margin:0 0 14px;font-size:13px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted)
}
.ws-back-link{margin:28px 0 0;font-size:15px}
.ws-back-link a{text-decoration:none;font-weight:600}
.level-panel-about .meta-line a.chip:hover{border-color:var(--brand-3);color:var(--brand)}
.level-panel-about .meta-line a.chip{text-decoration:none}

/* Daily puzzle */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0
}
.daily-page .daily-toolbar{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;
  margin:20px 0 0
}
.daily-date-form{display:flex;align-items:center;gap:8px}
.daily-date-form input[type=date]{
  padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--surface);color:var(--ink);font:inherit;font-size:15px
}
.daily-note{
  margin:16px 0 0;padding:10px 14px;border-radius:var(--radius-sm);
  background:var(--chip);border:1px solid var(--brand-3);color:var(--ink);font-size:14px
}
.daily-toolbar-archive{margin-bottom:8px}
.daily-archive-list{list-style:none;margin:0;padding:0}
.daily-archive-list li{border-top:1px solid var(--border-soft)}
.daily-archive-list li:first-child{border-top:none}
.daily-archive-list a{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 4px;text-decoration:none;font-weight:600;color:var(--ink)
}
.daily-archive-list a:hover{color:var(--brand)}
.daily-badge{
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--brand);background:var(--chip);padding:4px 8px;border-radius:999px
}
.daily-archive-list li.is-today{
  background:linear-gradient(90deg,var(--chip),transparent);
  border-radius:var(--radius-sm)
}
.daily-archive-list li.is-today > a{color:var(--brand)}
.daily-archive-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 16px
}
.daily-archive-grid li{border-top:1px solid var(--border-soft)}
.daily-archive-grid li:nth-child(-n+2){border-top:none}
.daily-today-marker{font-weight:700;color:var(--brand)}
.daily-page.is-today .level-subtitle{color:var(--brand);font-weight:700}

.daily-promo{
  margin-bottom:20px;padding:24px 28px;
  background:linear-gradient(135deg,var(--chip) 0%,var(--surface) 55%,var(--accent) 100%);
  border:1px solid var(--brand-3)
}
.daily-promo-main{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px
}
.daily-promo-eyebrow{
  margin:0 0 6px;font-size:12px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--brand)
}
.daily-promo-title{
  margin:0;font-size:clamp(1.2rem,2.5vw,1.55rem);font-weight:800;line-height:1.25;
  letter-spacing:-.02em
}
.daily-promo-text{margin:8px 0 0;font-size:15px;color:var(--muted);max-width:52ch}
.daily-promo-actions{display:flex;flex-direction:column;align-items:flex-start;gap:10px;min-width:220px}
.daily-promo-btn{white-space:nowrap}
.daily-promo-today{font-weight:700;text-decoration:none;color:var(--brand)}
.daily-promo-today:hover{text-decoration:underline}

.daily-today-hero{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;
  margin:0 0 24px;padding:22px 24px;border-radius:var(--radius-md);
  background:var(--grad-btn);color:#fff;box-shadow:var(--shadow-1)
}
.daily-today-eyebrow{
  margin:0 0 4px;font-size:12px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;opacity:.88
}
.daily-today-title{margin:0;font-size:clamp(1.25rem,2.8vw,1.65rem);font-weight:800;line-height:1.2}
.daily-today-date{margin:6px 0 0;font-size:17px;font-weight:600;opacity:.95}
.daily-today-btn{
  background:#fff;color:var(--brand-2);border:none;font-weight:800;
  box-shadow:0 4px 14px rgba(15,23,42,.18)
}
.daily-today-btn:hover{transform:translateY(-1px);color:var(--brand-2)}

@media (max-width:768px){
  .container{padding:18px 16px}
  header .container.nav{padding-top:14px}
  header .container.search-wrap{padding-bottom:14px}
  .brand img{width:100px}
  .brand-subtext{font-size:13px}
  .theme-btn{padding:8px 12px;font-size:12px}
  .search{padding:6px 6px 6px 14px;border-radius:20px}
  .search input{font-size:16px}
  .search button{padding:11px 18px;font-size:14px}
  .card{padding:22px 20px}
  .level-hero,.level-block,.level-panel,.level-shell .comments-block,.level-page .comments-block{padding:22px 20px}
  .footer-legal,.legal-card{padding:22px 20px}
  .level-answers{grid-template-columns:1fr}
  .level-block + .level-block{border-left:none;border-top:1px solid var(--border-soft)}
  .puzzle-cell{width:28px;height:28px}
  .puzzle-letter{font-size:14px}
  .puzzle-wheel-letter{width:36px;height:36px;font-size:16px}
  .board-wrapper{padding:18px 14px}
  .daily-toolbar{flex-direction:column;align-items:stretch}
  .daily-toolbar .nav-pill{justify-content:center}
  .daily-promo{padding:20px}
  .daily-promo-actions{width:100%}
  .daily-promo-btn{width:100%;text-align:center}
  .daily-archive-grid{grid-template-columns:1fr}
  .daily-archive-grid li:nth-child(-n+2){border-top:1px solid var(--border-soft)}
  .daily-archive-grid li:first-child{border-top:none}
  .daily-today-btn{width:100%;text-align:center}
  .comment-form-actions .comment-submit{width:100%}
  .ws-index-card,.ws-page-card{padding:22px 20px}
  .ws-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .ws-pack-range{font-size:10px}
  .ws-box-title{font-size:16px}
  .ws-pack-name{font-size:15px}
  .ws-level-grid{grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:6px}
}
@media (max-width:480px){
  .ws-grid{grid-template-columns:1fr}
  .nav-row{flex-direction:column;align-items:stretch}
  .nav-row a,.nav-pill{justify-content:center}
  .search{flex-direction:column;align-items:stretch;border-radius:var(--radius-md);padding:12px}
  .search button{width:100%}
  .share .btns .btn{flex:1 1 calc(50% - 5px);justify-content:center}
}
