/*
Theme Name: Dhulobali
Theme URI: https://example.com/dhulobali
Author: Built for you
Description: ধুলোবালি — a premium Bengali digital literary magazine theme. Clean, Google-inspired editorial design for stories, poetry, rhymes, novels, comics, puzzles and quizzes. Every homepage section is editable and can be toggled on/off from the Customizer.
Version: 1.2.1
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dhulobali
Tags: blog, news, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, threaded-comments, translation-ready
*/

:root{
  --paper:#FCFBF8;
  --surface:#FFFFFF;
  --wash:#F4F0E8;
  --ink:#1A1815;
  --ink-2:#4A453E;
  --ink-3:#8A8378;
  --line:#E8E2D6;
  --line-soft:#F0EBE0;
  --alta:#C73E2E;
  --alta-deep:#A22D20;
  --alta-tint:#FBEDEA;
  /* muted category hues — used only on cover art + tags */
  --c-golpo:#2F5D62;
  --c-kobita:#5B4470;
  --c-chhora:#A8761F;
  --c-sahitya:#34466E;
  --c-uponnash:#3B5B43;
  --c-comics:#B23A2A;
  --c-dhadha:#445660;
  --c-quiz:#9E4E2A;

  --shadow-sm:0 1px 2px rgba(26,24,21,.04), 0 1px 3px rgba(26,24,21,.06);
  --shadow-md:0 4px 14px rgba(26,24,21,.06), 0 2px 6px rgba(26,24,21,.05);
  --shadow-lg:0 18px 50px rgba(26,24,21,.10), 0 6px 18px rgba(26,24,21,.06);

  --serif:"Noto Serif Bengali", Georgia, serif;
  --sans:"Hind Siliguri", system-ui, -apple-system, sans-serif;

  --wrap:1180px;
  --r:18px;
  --r-lg:26px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{max-width:100%;display:block}
::selection{background:var(--alta);color:#fff}
:focus-visible{outline:2.5px solid var(--alta);outline-offset:3px;border-radius:4px}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.bn-num{font-feature-settings:"locl"}

/* ---------- Reading progress ---------- */
#progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--alta);z-index:120;transition:width .1s linear;display:none}

/* ---------- Header ---------- */
.header{
  position:sticky;top:0;z-index:90;
  background:rgba(252,251,248,.82);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s;
}
.header.scrolled{border-bottom-color:var(--line);box-shadow:0 1px 0 rgba(26,24,21,.02)}
.header-inner{display:flex;align-items:center;gap:18px;height:68px}

.logo{display:flex;align-items:baseline;gap:2px;font-family:var(--serif);font-weight:800;font-size:1.7rem;letter-spacing:-.01em;color:var(--ink);position:relative;line-height:1}
.logo .mote{width:8px;height:8px;border-radius:50%;background:var(--alta);display:inline-block;margin-left:3px;transform:translateY(-2px);box-shadow:0 0 0 3px var(--alta-tint)}
.logo small{font-family:var(--sans);font-weight:600;font-size:.6rem;letter-spacing:.22em;color:var(--ink-3);text-transform:uppercase;margin-left:8px;align-self:flex-end;transform:translateY(-3px)}

.nav{display:flex;align-items:center;gap:2px;margin-left:14px;flex:1;overflow:visible}
.nav a{
  font-size:.92rem;font-weight:500;color:var(--ink-2);padding:8px 11px;border-radius:9px;
  transition:background .18s,color .18s;white-space:nowrap;position:relative;
}
.nav a:hover{background:var(--wash);color:var(--ink)}
.nav a.active{color:var(--alta)}
.nav a.active::after{content:"";position:absolute;left:11px;right:11px;bottom:2px;height:2px;background:var(--alta);border-radius:2px}

.header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.icon-btn{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:var(--ink-2);transition:background .18s}
.icon-btn:hover{background:var(--wash);color:var(--ink)}
.btn{
  font-weight:600;font-size:.9rem;padding:9px 18px;border-radius:999px;transition:.2s;white-space:nowrap;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--alta);transform:translateY(-1px)}
.btn-ghost{border:1.5px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--surface)}

.menu-toggle{display:none}

/* ---------- Views ---------- */
.view{display:none;animation:fade .5s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- Hero / Magazine cover ---------- */
.hero{position:relative;padding:14px 0 8px;overflow:hidden}
#dust{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}
.masthead{display:flex;align-items:center;justify-content:center;gap:18px;padding:26px 0 30px;position:relative;z-index:1}
.masthead .rule{height:1px;background:var(--line);flex:1;max-width:200px}
.masthead .issue{font-family:var(--sans);font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3);font-weight:600;text-align:center}
.masthead .issue b{color:var(--alta);font-weight:700}

.cover{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.05fr .95fr;gap:0;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);overflow:hidden;
}
.cover-art{
  position:relative;min-height:480px;
  background:
    radial-gradient(circle at 22% 26%, rgba(255,255,255,.12), transparent 42%),
    linear-gradient(150deg, #3a6469, #2f5d62 48%, #244a4e);
  overflow:hidden;
}
.cover-art .glyph{position:absolute;font-family:var(--serif);font-weight:800;color:rgba(255,255,255,.07);font-size:24rem;line-height:.8;right:-3rem;bottom:-4rem;user-select:none}
.cover-art .dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.13) 1px, transparent 1px);background-size:22px 22px;opacity:.5}
.cover-art .tag{position:absolute;top:26px;left:28px;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);color:#fff;font-size:.78rem;font-weight:600;padding:6px 14px;border-radius:999px;letter-spacing:.04em}
.cover-art .quote{position:absolute;bottom:30px;left:28px;right:28px;color:rgba(255,255,255,.9);font-family:var(--serif);font-size:1.15rem;line-height:1.7;font-style:italic;font-weight:500}

.cover-body{padding:48px 46px;display:flex;flex-direction:column;justify-content:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--alta);margin-bottom:18px}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--alta)}
.cover-body h1{font-family:var(--serif);font-weight:800;font-size:2.9rem;line-height:1.22;letter-spacing:-.01em;margin-bottom:18px;color:var(--ink)}
.cover-body p{font-size:1.08rem;color:var(--ink-2);line-height:1.85;margin-bottom:26px;max-width:46ch}
.byline{display:flex;align-items:center;gap:13px;margin-bottom:28px}
.avatar{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-weight:700;color:#fff;font-size:1.05rem;flex-shrink:0;font-family:var(--serif)}
.byline .meta{font-size:.9rem}
.byline .meta b{display:block;font-weight:600;color:var(--ink);font-size:.96rem}
.byline .meta span{color:var(--ink-3)}
.cover-cta{display:flex;gap:12px;align-items:center}

/* ---------- Section scaffolding ---------- */
.section{padding:62px 0}
.section.wash{background:var(--wash);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:34px;gap:20px}
.section-head h2{font-family:var(--serif);font-weight:700;font-size:1.95rem;letter-spacing:-.01em;display:flex;align-items:center;gap:12px}
.section-head h2 .kicker{width:6px;height:6px;border-radius:50%;background:var(--alta)}
.section-head .sub{font-size:.95rem;color:var(--ink-3);margin-top:4px}
.see-all{font-size:.9rem;font-weight:600;color:var(--alta);display:inline-flex;align-items:center;gap:5px;transition:gap .2s}
.see-all:hover{gap:9px}

/* ---------- Cards ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}

.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;cursor:pointer;transition:transform .26s cubic-bezier(.2,.7,.3,1), box-shadow .26s, border-color .26s;
  display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.card-art{position:relative;aspect-ratio:16/10;overflow:hidden}
.card-art .dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.16) 1px, transparent 1px);background-size:18px 18px;opacity:.45}
.card-art .ag{position:absolute;font-family:var(--serif);font-weight:800;color:rgba(255,255,255,.1);font-size:7rem;right:-1rem;bottom:-2rem;line-height:.8}
.card-art .ctag{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);color:var(--ink);font-size:.72rem;font-weight:700;padding:4px 11px;border-radius:999px;letter-spacing:.02em}
.card-body{padding:20px 21px 22px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-family:var(--serif);font-weight:700;font-size:1.22rem;line-height:1.4;margin-bottom:9px;transition:color .2s}
.card:hover .card-body h3{color:var(--alta)}
.card-body p{font-size:.92rem;color:var(--ink-2);line-height:1.7;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-meta{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--ink-3);margin-top:auto}
.card-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-3)}
.card-meta .mini-av{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:.72rem;font-family:var(--serif)}

/* featured large cards */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.feat{display:grid;grid-template-columns:1fr;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:transform .26s, box-shadow .26s,border-color .26s}
.feat:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.feat-art{position:relative;aspect-ratio:2/1;overflow:hidden}
.feat-art .dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.15) 1px,transparent 1px);background-size:20px 20px;opacity:.45}
.feat-art .ag{position:absolute;font-family:var(--serif);font-weight:800;color:rgba(255,255,255,.1);font-size:9rem;right:-1rem;bottom:-2.5rem;line-height:.8}
.feat-art .ctag{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.92);color:var(--ink);font-size:.74rem;font-weight:700;padding:5px 12px;border-radius:999px}
.feat-body{padding:24px 26px 26px}
.feat-body h3{font-family:var(--serif);font-weight:800;font-size:1.55rem;line-height:1.34;margin-bottom:11px;transition:color .2s}
.feat:hover .feat-body h3{color:var(--alta)}
.feat-body p{color:var(--ink-2);font-size:.98rem;line-height:1.75;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ---------- Category strip ---------- */
.cat-row{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none}
.cat-row::-webkit-scrollbar{display:none}
.cat-chip{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:10px;width:96px;cursor:pointer}
.cat-chip .ring{width:72px;height:72px;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-weight:700;color:#fff;font-size:1.5rem;box-shadow:var(--shadow-sm);transition:transform .22s}
.cat-chip:hover .ring{transform:translateY(-4px) scale(1.05)}
.cat-chip span{font-size:.88rem;font-weight:600;color:var(--ink-2)}

/* ---------- Special sections ---------- */
.special-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.special{position:relative;border-radius:var(--r);padding:30px 28px 26px;color:#fff;overflow:hidden;cursor:pointer;min-height:210px;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .26s,box-shadow .26s}
.special:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.special .dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.16) 1px,transparent 1px);background-size:18px 18px;opacity:.4}
.special .bigicon{position:absolute;top:18px;right:20px;font-size:2.6rem;opacity:.9}
.special h3{font-family:var(--serif);font-weight:800;font-size:1.5rem;margin-bottom:7px;position:relative}
.special p{font-size:.92rem;opacity:.92;position:relative;line-height:1.6}
.special .go{margin-top:14px;font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:6px;position:relative}

/* ---------- Guest CTA band ---------- */
.guest-band{background:var(--ink);color:var(--paper);border-radius:var(--r-lg);padding:54px 50px;position:relative;overflow:hidden;display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center}
.guest-band .dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:24px 24px}
.guest-band h2{font-family:var(--serif);font-weight:800;font-size:2.2rem;margin-bottom:14px;line-height:1.3;position:relative}
.guest-band p{opacity:.78;font-size:1.02rem;line-height:1.8;position:relative;max-width:46ch}
.guest-band .bandcta{position:relative;display:flex;justify-content:flex-end}
.btn-paper{background:var(--paper);color:var(--ink);font-weight:600;font-size:1rem;padding:14px 30px;border-radius:999px;transition:.2s}
.btn-paper:hover{background:var(--alta);color:#fff;transform:translateY(-2px)}

/* ---------- Article reading page ---------- */
.reader{max-width:720px;margin:0 auto;padding:48px 0 30px}
.back-link{display:inline-flex;align-items:center;gap:7px;font-size:.9rem;font-weight:600;color:var(--ink-3);margin-bottom:30px;transition:color .2s,gap .2s}
.back-link:hover{color:var(--alta);gap:11px}
.reader .a-eyebrow{font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--alta);margin-bottom:16px;display:block}
.reader h1{font-family:var(--serif);font-weight:800;font-size:2.7rem;line-height:1.25;letter-spacing:-.01em;margin-bottom:20px}
.reader .lede{font-family:var(--serif);font-size:1.25rem;color:var(--ink-2);line-height:1.7;margin-bottom:30px;font-style:italic}
.a-meta{display:flex;align-items:center;gap:14px;padding-bottom:28px;border-bottom:1px solid var(--line);margin-bottom:0}
.a-meta .meta-txt b{display:block;font-weight:600;font-size:.98rem}
.a-meta .meta-txt span{font-size:.86rem;color:var(--ink-3)}
.a-hero-art{height:340px;border-radius:var(--r);margin:34px 0;position:relative;overflow:hidden}
.a-hero-art .dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.14) 1px,transparent 1px);background-size:22px 22px;opacity:.45}
.a-hero-art .ag{position:absolute;font-family:var(--serif);font-weight:800;color:rgba(255,255,255,.1);font-size:14rem;right:-2rem;bottom:-4rem;line-height:.8}
.article-body{font-family:var(--serif);font-size:1.21rem;line-height:2.05;color:#26231f}
.article-body p{margin-bottom:26px}
.article-body p:first-letter{}
.article-body .firstp:first-letter{font-size:3.6rem;font-weight:700;float:left;line-height:.82;padding:8px 12px 0 0;color:var(--alta)}
.article-body h3{font-family:var(--serif);font-weight:700;font-size:1.5rem;margin:36px 0 16px}
.article-body blockquote{border-left:3px solid var(--alta);padding:6px 0 6px 24px;margin:30px 0;font-style:italic;color:var(--ink-2);font-size:1.3rem;line-height:1.7}

.share-bar{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:26px 0;margin-top:18px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.share-bar .lbl{font-family:var(--sans);font-size:.88rem;font-weight:600;color:var(--ink-3);margin-right:4px;flex-shrink:0}
.share-bar a{display:inline-flex;flex-shrink:0}
.share-bar button:not(.react-btn){width:42px;height:42px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;color:var(--ink-2);transition:.2s;font-family:var(--sans);background:var(--surface);cursor:pointer;flex-shrink:0;padding:0}
.share-bar button:not(.react-btn):hover{border-color:var(--alta);color:var(--alta);transform:translateY(-2px)}
.share-bar .react{margin-left:auto;display:flex;gap:10px;flex-shrink:0}
.react-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:auto;height:auto;font-family:var(--sans);font-size:.9rem;font-weight:600;padding:9px 16px;border-radius:999px;border:1.5px solid var(--line);color:var(--ink-2);background:var(--surface);cursor:pointer;white-space:nowrap;transition:.2s}
.react-btn:hover{border-color:var(--alta);color:var(--alta)}
.react-btn.on{background:var(--alta-tint);border-color:var(--alta);color:var(--alta)}
@media(max-width:600px){
.share-bar{gap:8px}
.share-bar .react{margin-left:0;width:100%;justify-content:space-between;margin-top:6px}
.react-btn{flex:1}
}

/* ---------- Comments ---------- */
.comments{max-width:720px;margin:0 auto;padding:10px 0 40px;font-family:var(--sans)}
.comments h3{font-family:var(--serif);font-weight:700;font-size:1.5rem;margin:36px 0 22px;display:flex;align-items:center;gap:10px}
.comments h3 .count{font-family:var(--sans);font-size:.95rem;font-weight:600;color:#fff;background:var(--alta);padding:2px 11px;border-radius:999px}
.comment-box{display:flex;gap:13px;margin-bottom:30px}
.comment-box textarea{flex:1;border:1.5px solid var(--line);border-radius:14px;padding:13px 16px;font-family:var(--sans);font-size:.96rem;resize:vertical;min-height:54px;background:var(--surface);transition:border-color .2s}
.comment-box textarea:focus{outline:none;border-color:var(--alta)}
.comment{display:flex;gap:13px;margin-bottom:24px}
.comment .body{flex:1}
.comment .top{display:flex;align-items:center;gap:9px;margin-bottom:5px}
.comment .top b{font-size:.94rem;font-weight:600}
.comment .top time{font-size:.8rem;color:var(--ink-3)}
.comment .txt{font-size:.96rem;color:var(--ink-2);line-height:1.7}
.comment .acts{display:flex;gap:18px;margin-top:8px;font-size:.84rem;font-weight:600;color:var(--ink-3)}
.comment .acts button{transition:color .2s;display:inline-flex;align-items:center;gap:5px}
.comment .acts button:hover{color:var(--alta)}
.comment .acts button.liked{color:var(--alta)}
.comment .reply{margin-left:53px}

/* ---------- Related ---------- */
.related{max-width:1000px;margin:0 auto;padding:20px 0 10px}

/* ---------- Quiz ---------- */
.subpage{padding:50px 0 70px}
.subpage-head{text-align:center;max-width:640px;margin:0 auto 44px}
.subpage-head .a-eyebrow{display:block;font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--alta);margin-bottom:14px}
.subpage-head h1{font-family:var(--serif);font-weight:800;font-size:2.6rem;line-height:1.2;margin-bottom:14px}
.subpage-head p{color:var(--ink-2);font-size:1.05rem;line-height:1.7}

.quiz-card{max-width:640px;margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:40px 40px 34px}
.quiz-progress{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;font-size:.86rem;color:var(--ink-3);font-weight:600}
.quiz-bar{height:6px;background:var(--line-soft);border-radius:999px;overflow:hidden;margin-bottom:30px}
.quiz-bar i{display:block;height:100%;background:var(--alta);border-radius:999px;transition:width .4s ease;width:0}
.quiz-q{font-family:var(--serif);font-weight:700;font-size:1.55rem;line-height:1.45;margin-bottom:26px}
.quiz-opts{display:flex;flex-direction:column;gap:12px}
.quiz-opt{text-align:left;border:1.5px solid var(--line);border-radius:14px;padding:16px 18px;font-size:1.02rem;font-weight:500;color:var(--ink);transition:.18s;display:flex;align-items:center;gap:13px}
.quiz-opt .key{width:30px;height:30px;border-radius:8px;background:var(--wash);display:grid;place-items:center;font-weight:700;font-size:.92rem;color:var(--ink-2);flex-shrink:0;transition:.18s}
.quiz-opt:hover{border-color:var(--alta);background:var(--alta-tint)}
.quiz-opt:hover .key{background:var(--alta);color:#fff}
.quiz-opt.correct{border-color:#2e7d51;background:#eaf6ef;color:#1b5e3a}
.quiz-opt.correct .key{background:#2e7d51;color:#fff}
.quiz-opt.wrong{border-color:var(--alta-deep);background:var(--alta-tint);color:var(--alta-deep)}
.quiz-opt.wrong .key{background:var(--alta-deep);color:#fff}
.quiz-opt:disabled{cursor:default}
.quiz-result{text-align:center;padding:14px 0}
.quiz-result .score{font-family:var(--serif);font-weight:800;font-size:4rem;color:var(--alta);line-height:1}
.quiz-result .score small{font-size:1.6rem;color:var(--ink-3)}
.quiz-result h2{font-family:var(--serif);font-size:1.7rem;margin:10px 0 8px}
.quiz-result p{color:var(--ink-2);margin-bottom:24px}

/* ---------- Puzzle ---------- */
.puzzle-list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.puzzle{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;transition:box-shadow .2s}
.puzzle:hover{box-shadow:var(--shadow-md)}
.puzzle .q{font-family:var(--serif);font-size:1.25rem;font-weight:600;line-height:1.6;display:flex;gap:13px}
.puzzle .num{color:var(--alta);font-weight:800}
.puzzle .reveal{margin-top:14px;font-weight:600;font-size:.9rem;color:var(--alta)}
.puzzle .ans{margin-top:14px;padding:14px 18px;background:var(--wash);border-radius:12px;font-size:1rem;color:var(--ink-2);display:none}
.puzzle .ans b{color:var(--ink)}
.puzzle.open .ans{display:block;animation:fade .3s}

/* ---------- Comics reader ---------- */
.comic-reader{max-width:600px;margin:0 auto}
.comic-panel{aspect-ratio:3/4;border-radius:var(--r);position:relative;overflow:hidden;box-shadow:var(--shadow-md);display:grid;place-items:center;text-align:center;color:#fff;padding:40px}
.comic-panel .dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.12) 1px,transparent 1px);background-size:20px 20px;opacity:.4}
.comic-panel .pn{position:absolute;top:16px;left:18px;font-size:.8rem;font-weight:700;letter-spacing:.1em;opacity:.7}
.comic-panel .cap{position:relative;font-family:var(--serif);font-size:1.6rem;font-weight:700;line-height:1.5;text-shadow:0 1px 14px rgba(0,0,0,.25)}
.comic-panel .speech{position:relative;background:#fff;color:var(--ink);font-family:var(--serif);font-size:1.15rem;font-weight:600;padding:18px 24px;border-radius:18px;max-width:80%;box-shadow:var(--shadow-md);line-height:1.6}
.comic-nav{display:flex;align-items:center;justify-content:space-between;margin-top:24px}
.comic-nav button{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.95rem;padding:11px 22px;border-radius:999px;border:1.5px solid var(--line);transition:.2s}
.comic-nav button:hover:not(:disabled){border-color:var(--alta);color:var(--alta)}
.comic-nav button:disabled{opacity:.35;cursor:default}
.comic-dots{display:flex;gap:8px}
.comic-dots i{width:9px;height:9px;border-radius:50%;background:var(--line);transition:.2s;cursor:pointer}
.comic-dots i.on{background:var(--alta);transform:scale(1.25)}

/* ---------- Guest form ---------- */
.guest-form{max-width:640px;margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:40px 40px 36px}
.note{background:var(--alta-tint);border-radius:12px;padding:13px 18px;font-size:.9rem;color:var(--alta-deep);margin-bottom:28px;line-height:1.6;display:flex;gap:10px;align-items:flex-start}
.field{margin-bottom:20px}
.field label{display:block;font-size:.9rem;font-weight:600;margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font-family:var(--sans);font-size:.98rem;background:var(--paper);transition:border-color .2s;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--alta);background:var(--surface)}
.field textarea{resize:vertical;min-height:140px;font-family:var(--serif);font-size:1.08rem;line-height:1.8}
.upload{border:2px dashed var(--line);border-radius:14px;padding:26px;text-align:center;color:var(--ink-3);font-size:.92rem;cursor:pointer;transition:.2s}
.upload:hover{border-color:var(--alta);color:var(--alta);background:var(--alta-tint)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#cfc9bd;padding:64px 0 30px;margin-top:20px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .logo{color:#fff;margin-bottom:16px}
.footer .logo small{color:rgba(255,255,255,.5)}
.footer .about{font-size:.95rem;line-height:1.8;opacity:.7;max-width:34ch}
.footer h4{color:#fff;font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px;opacity:.6}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer ul a{font-size:.95rem;opacity:.78;transition:.2s}
.footer ul a:hover{opacity:1;color:var(--alta)}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;transition:.2s;font-size:.95rem}
.socials a:hover{background:var(--alta);border-color:var(--alta);color:#fff;transform:translateY(-2px)}
.footer-bottom{padding-top:26px;display:flex;justify-content:space-between;font-size:.85rem;opacity:.55;flex-wrap:wrap;gap:10px}

/* ---------- Modal / overlay ---------- */
.overlay{position:fixed;inset:0;background:rgba(26,24,21,.42);backdrop-filter:blur(4px);z-index:200;display:none;align-items:flex-start;justify-content:center;padding:80px 20px;overflow-y:auto}
.overlay.open{display:flex;animation:fade .25s}
.modal{background:var(--surface);border-radius:var(--r-lg);width:100%;max-width:440px;padding:38px 38px 34px;box-shadow:var(--shadow-lg);position:relative;animation:pop .3s cubic-bezier(.2,.8,.3,1)}
@keyframes pop{from{transform:translateY(18px) scale(.97);opacity:0}to{transform:none;opacity:1}}
.modal .close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:var(--ink-3);transition:.2s}
.modal .close:hover{background:var(--wash);color:var(--ink)}
.modal .m-logo{font-family:var(--serif);font-weight:800;font-size:1.6rem;text-align:center;margin-bottom:6px}
.modal .m-sub{text-align:center;color:var(--ink-3);font-size:.92rem;margin-bottom:26px}
.tabs{display:flex;background:var(--wash);border-radius:12px;padding:4px;margin-bottom:24px}
.tabs button{flex:1;padding:9px;border-radius:9px;font-weight:600;font-size:.92rem;color:var(--ink-3);transition:.2s}
.tabs button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}
.modal .btn-primary{width:100%;padding:13px;border-radius:12px;font-size:1rem;margin-top:6px}
.modal .alt{text-align:center;font-size:.88rem;color:var(--ink-3);margin-top:18px}

/* search overlay */
.search-overlay{position:fixed;inset:0;background:rgba(252,251,248,.96);backdrop-filter:blur(8px);z-index:210;display:none;flex-direction:column;align-items:center;padding:14vh 20px 20px}
.search-overlay.open{display:flex;animation:fade .25s}
.search-box{width:100%;max-width:620px}
.search-box .si{display:flex;align-items:center;gap:14px;border-bottom:2px solid var(--ink);padding-bottom:16px}
.search-box input{flex:1;border:none;background:none;font-family:var(--serif);font-size:1.8rem;color:var(--ink);outline:none}
.search-box input::placeholder{color:var(--ink-3)}
.search-close{position:absolute;top:24px;right:28px;font-size:.9rem;font-weight:600;color:var(--ink-3);display:flex;align-items:center;gap:7px}
.search-close:hover{color:var(--alta)}
.search-results{width:100%;max-width:620px;margin-top:24px;max-height:50vh;overflow-y:auto}
.search-results .sr{display:flex;align-items:center;gap:15px;padding:14px 8px;border-radius:12px;cursor:pointer;transition:background .15s}
.search-results .sr:hover{background:var(--wash)}
.search-results .sr .sa{width:46px;height:46px;border-radius:10px;flex-shrink:0}
.search-results .sr b{font-family:var(--serif);font-weight:600;font-size:1.05rem;display:block}
.search-results .sr span{font-size:.84rem;color:var(--ink-3)}
.search-hint{color:var(--ink-3);font-size:.92rem;margin-top:20px}

/* toast */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--ink);color:var(--paper);padding:13px 24px;border-radius:999px;font-size:.92rem;font-weight:500;z-index:300;box-shadow:var(--shadow-lg);transition:transform .35s cubic-bezier(.2,.8,.3,1);display:flex;align-items:center;gap:10px}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast .tm{width:7px;height:7px;border-radius:50%;background:var(--alta)}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;background:var(--paper);z-index:200;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:16px 24px 28px;overflow-y:auto}
.mobile-menu.open{transform:none}
.mobile-menu a{font-family:var(--serif);font-size:1.5rem;font-weight:600;padding:14px 0;border-bottom:1px solid var(--line-soft);color:var(--ink)}
.mobile-menu a:active{color:var(--alta)}

/* ---------- Responsive ---------- */
@media(max-width:1000px){
  .cover{grid-template-columns:1fr}
  .cover-art{min-height:300px;aspect-ratio:16/9}
  .cover-body{padding:36px 32px}
  .cover-body h1{font-size:2.3rem}
  .grid-3,.special-grid{grid-template-columns:repeat(2,1fr)}
  .guest-band{grid-template-columns:1fr;padding:40px 34px}
  .guest-band .bandcta{justify-content:flex-start}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:760px){
  .nav,.header-actions .desktop-only{display:none}
  .menu-toggle{display:grid}
  .feat-grid,.grid-2{grid-template-columns:1fr}
  .section{padding:46px 0}
  .reader h1{font-size:2rem}
  .article-body{font-size:1.12rem;line-height:1.95}
  .cover-body h1{font-size:1.9rem}
  .subpage-head h1{font-size:1.9rem}
  .quiz-card,.guest-form{padding:28px 24px}
  .field-row{grid-template-columns:1fr}
  .reader h1{font-size:1.85rem}
}
@media(max-width:520px){
  .grid-3,.special-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .wrap{padding:0 18px}
  .masthead .rule{max-width:50px}
  .search-box input{font-size:1.3rem}
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important;scroll-behavior:auto}
}
/* ============================================================
   WordPress-specific styles (menus, comments, alignments)
   ============================================================ */
.nav .menu{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
.nav .menu li{position:relative}
.nav .menu li a{font-size:.92rem;font-weight:500;color:var(--ink-2);padding:8px 11px;border-radius:9px;transition:background .18s,color .18s;white-space:nowrap;display:block}
.nav .menu li a:hover{background:var(--wash);color:var(--ink)}
.nav .menu .current-menu-item>a,.nav .menu .current_page_item>a{color:var(--alta)}
.nav .menu .sub-menu{position:absolute;top:100%;left:0;background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;min-width:190px;display:none;flex-direction:column;z-index:50}
.nav .menu li:hover>.sub-menu{display:flex}
.nav .menu .sub-menu a{font-size:.9rem;border-radius:9px}
body.admin-bar .header{top:32px}
@media(max-width:782px){body.admin-bar .header{top:46px}}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 18px;border-radius:0 0 10px 0;z-index:400}
.skip-link:focus{left:0}
.card-art .sticky-badge,.feat-art .sticky-badge{position:absolute;top:14px;right:14px;background:var(--alta);color:#fff;font-size:.66rem;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.04em}
.card-art img,.feat-art img,.a-hero-art img,.cover-art img,.comic-panel>img,.search-results .sa img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.article-body img{border-radius:12px;margin:24px auto;height:auto}
.article-body figure{margin:26px 0}
.article-body figcaption{font-family:var(--sans);font-size:.85rem;color:var(--ink-3);text-align:center;margin-top:8px}
.article-body ul,.article-body ol{margin:0 0 26px 1.4em}
.article-body li{margin-bottom:10px}
.article-body a{color:var(--alta);text-decoration:underline;text-underline-offset:3px}
.alignwide{margin-left:-80px;margin-right:-80px}
.alignfull{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);max-width:100vw;width:100vw}
.aligncenter{margin-left:auto;margin-right:auto;display:block;text-align:center}
@media(max-width:900px){.alignwide{margin-left:0;margin-right:0}}
.comments .comment-list{list-style:none;margin:0;padding:0}
.comments .comment-body{display:flex;gap:13px;margin-bottom:24px}
.comments .comment-author{display:flex;align-items:center;gap:9px;margin-bottom:4px}
.comments .comment-author .avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0}
.comments .comment-author .fn{font-size:.94rem;font-weight:600;font-style:normal}
.comments .comment-meta{font-size:.8rem;color:var(--ink-3);margin-bottom:6px}
.comments .comment-meta a{color:var(--ink-3)}
.comments .comment-content{font-size:.96rem;color:var(--ink-2);line-height:1.7}
.comments .comment-content p{margin-bottom:10px}
.comments .reply{margin-top:8px}
.comments .comment-reply-link{font-size:.84rem;font-weight:600;color:var(--ink-3)}
.comments .comment-reply-link:hover{color:var(--alta)}
.comments .children{list-style:none;margin:0 0 0 53px;padding:0}
.comment-respond{margin-top:14px}
.comment-respond .comment-reply-title{font-family:var(--serif);font-weight:700;font-size:1.35rem;margin-bottom:16px}
.comment-form{display:flex;flex-direction:column;gap:14px}
.comment-form p{margin:0}
.comment-form label{font-size:.88rem;font-weight:600}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font-family:var(--sans);font-size:.96rem;background:var(--surface);margin-top:6px}
.comment-form textarea{font-family:var(--serif);font-size:1.05rem;line-height:1.7;min-height:120px;resize:vertical}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--alta)}
.comment-form-author,.comment-form-email,.comment-form-url{display:inline-block;width:32%;margin-right:1%}
@media(max-width:600px){.comment-form-author,.comment-form-email,.comment-form-url{width:100%;margin-right:0}}
.form-submit input[type=submit]{font-weight:600;font-size:.95rem;padding:12px 26px;border-radius:999px;background:var(--ink);color:var(--paper);cursor:pointer;transition:.2s;border:none}
.form-submit input[type=submit]:hover{background:var(--alta)}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:46px;flex-wrap:wrap}
.pagination .page-numbers{display:grid;place-items:center;min-width:42px;height:42px;padding:0 12px;border:1.5px solid var(--line);border-radius:12px;font-weight:600;color:var(--ink-2);transition:.2s}
.pagination .page-numbers:hover,.pagination .page-numbers.current{border-color:var(--alta);color:var(--alta);background:var(--alta-tint)}
.archive-hero{padding:56px 0 8px}
.archive-hero .a-eyebrow{font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--alta)}
.archive-hero h1{font-family:var(--serif);font-weight:800;font-size:2.6rem;margin:14px 0 8px}
.archive-hero p{color:var(--ink-2)}
.empty-state{text-align:center;padding:60px 20px;color:var(--ink-3)}
.empty-state .big{font-family:var(--serif);font-size:1.6rem;color:var(--ink-2);margin-bottom:8px}
.mobile-menu ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.mobile-menu ul a{display:block}
.mobile-menu-top{display:flex;align-items:center;justify-content:space-between;padding:6px 0 14px;margin-bottom:8px;border-bottom:1px solid var(--line)}
.mm-brand{font-family:var(--serif);font-weight:800;font-size:1.5rem;color:var(--ink);display:inline-flex;align-items:center}
.mm-brand .mote{width:9px;height:9px;border-radius:50%;background:var(--alta);margin-left:7px;display:inline-block}
.mobile-close{width:46px;height:46px;display:grid;place-items:center;border:1.5px solid var(--line);border-radius:50%;background:var(--surface);color:var(--ink);cursor:pointer;transition:.2s;flex-shrink:0}
.mobile-close:hover,.mobile-close:active{background:var(--alta);border-color:var(--alta);color:#fff}
