/* ── RESET & VARS ─────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f0ede8;
  --card:#fff;
  --text:#1c1c1c;
  --sub:#6b6b6b;
  --muted:#a0a0a0;
  --acc:#4a7c59;
  --acc-light:rgba(74,124,89,0.08);
  --acc-mid:rgba(74,124,89,0.2);
  --bd:rgba(0,0,0,0.08);
  --bd2:rgba(0,0,0,0.05);
  --radius:20px;
  --radius-sm:12px;
  --shadow:0 16px 48px rgba(0,0,0,0.08);
  --trans:.2s ease;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ── WRAP ─────────────────────────────────────────────── */
.wrap{max-width:1120px;margin:0 auto;padding:0 32px}

/* ── NAV ──────────────────────────────────────────────── */
.nav{position:sticky;top:0;z-index:100;background:rgba(240,237,232,0.93);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--bd)}
.nav-inner{max-width:1120px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:60px}
.nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0}

/* Logo */
.logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-icon{width:34px;height:34px;flex-shrink:0}
.logo-text{font-family:'Playfair Display',serif;font-size:17px;font-weight:600;color:var(--text);letter-spacing:0.1px}
.logo-text span{color:var(--acc);font-style:italic}

/* Polylang language switcher */
.nav-langs{display:flex;align-items:center;gap:2px;padding:3px;background:var(--bg);border:1px solid var(--bd);border-radius:22px}
.nav-langs ul{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
.nav-langs ul li{list-style:none;margin:0;padding:0}
.nav-langs ul li a,
.nav-langs a{font-size:11px;font-weight:600;color:var(--muted);text-decoration:none;text-transform:uppercase;letter-spacing:0.5px;padding:6px 11px;border-radius:18px;transition:all var(--trans);display:block;line-height:1}
.nav-langs ul li.current-lang a,
.nav-langs a[aria-current="true"]{color:#fff;background:var(--acc)}
.nav-langs a:hover:not([aria-current="true"]){color:var(--acc);background:var(--acc-light)}

/* Burger
   -webkit-appearance/appearance reset is required here: <button> keeps
   native OS chrome (own box model, own vertical centering) in Safari
   and older Chromium unless appearance is explicitly cleared, even
   with border/background already removed by the global "button" rule
   above. Without it the icon can render a few pixels off-center on
   desktop while looking fine on mobile Chrome, which is exactly the
   "crooked on PC" symptom. flex-shrink:0 + box-sizing keep it from
   being squeezed by the language switcher next to it. */
.burger{
  -webkit-appearance:none;appearance:none;box-sizing:border-box;
  width:40px;height:40px;flex-shrink:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  border-radius:10px;transition:background var(--trans);margin-left:6px;padding:0;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation;
  line-height:0;font-size:0;vertical-align:middle;
}
@media(hover:hover){.burger:hover{background:var(--acc-light)}}
.burger:active{background:var(--acc-light)}
.burger span{display:block;flex-shrink:0;width:20px;height:1.5px;background:var(--text);border-radius:2px;transition:transform .28s ease,opacity .2s ease}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── DRAWER ────────────────────────────────────────────── */
.drawer-overlay{position:fixed;inset:0;top:60px;background:rgba(0,0,0,0.22);z-index:98;opacity:0;pointer-events:none;transition:opacity .28s ease}
.drawer-overlay.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:60px;right:0;bottom:0;width:280px;background:var(--card);border-left:1px solid var(--bd);z-index:99;transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);overflow-y:auto;overscroll-behavior:contain}
.drawer.open{transform:translateX(0)}

.drawer-search{padding:18px 20px 10px}
.search-box{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--bd);border-radius:var(--radius-sm);padding:10px 13px;transition:border-color var(--trans)}
.search-box:focus-within{border-color:var(--acc)}
.search-box svg{width:16px;height:16px;stroke:var(--muted);flex-shrink:0}
.search-box input{border:none;background:none;font-family:'Inter',sans-serif;font-size:13px;color:var(--text);width:100%;outline:none}
.search-box input::placeholder{color:var(--muted)}

.drawer-nav{padding:4px 0 24px}
.drawer-cat{padding:0 20px}
.drawer-cat-title{font-size:9px;font-weight:600;letter-spacing:1.8px;color:var(--muted);text-transform:uppercase;padding:14px 0 6px}
.drawer-link{display:block;font-size:13px;color:var(--sub);padding:7px 0;border-bottom:1px solid var(--bd2);transition:color var(--trans)}
.drawer-link:last-child{border-bottom:none}
.drawer-link:hover{color:var(--acc)}

/* ── HERO ──────────────────────────────────────────────── */
.hero{padding:60px 0 52px;border-bottom:1px solid var(--bd)}
.hero-kicker{font-size:11px;font-weight:500;color:var(--muted);letter-spacing:1.8px;text-transform:uppercase;margin-bottom:18px}
.hero h1{font-family:'Playfair Display',serif;font-size:52px;font-weight:400;line-height:1.08;letter-spacing:-1px;color:var(--text);margin-bottom:18px;max-width:600px}
.hero h1 em{font-style:italic;color:var(--acc)}
.hero-sub{font-size:15px;color:var(--sub);line-height:1.8;max-width:560px;padding-left:16px;border-left:2px solid var(--acc-mid)}

/* ── TOOLS SECTION ─────────────────────────────────────── */
.tools{padding:44px 0 0}
.sec-label{font-size:10px;font-weight:600;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:22px}
.tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

.tool-card{background:var(--acc-light);border-radius:var(--radius);overflow:hidden;border:1px solid var(--bd);transition:transform var(--trans),box-shadow var(--trans);display:block}
.tool-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tool-card-img{width:100%;height:220px;object-fit:cover;display:block}
/* min-height so layout stable before img loads */
.tool-card-img-placeholder{width:100%;height:220px;background:var(--bg);min-height:220px}
.tool-card-body{padding:16px 18px 18px}
.tool-card-title{font-family:'Playfair Display',serif;font-size:16px;font-weight:400;color:var(--text);margin-bottom:5px}
.tool-card-sub{font-size:12px;color:var(--muted);line-height:1.5}
.tool-card-cta{display:inline-flex;align-items:center;gap:4px;margin-top:10px;font-size:12px;font-weight:500;color:var(--acc)}
.cta-arr{transition:transform var(--trans)}
.tool-card:hover .cta-arr{transform:translateX(3px)}

/* ── PROMPTS GALLERY ───────────────────────────────────── */
.prompts{padding:44px 0 56px}
.prompts-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:22px}
.prompts-header h2{font-family:'Playfair Display',serif;font-size:28px;font-weight:400;color:var(--text)}
.prompts-see{font-size:12px;color:var(--acc);font-weight:500}
.prompts-see:hover{text-decoration:underline}
.prompts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

.prompt-card{background:var(--acc-light);border-radius:16px;overflow:hidden;border:1px solid var(--bd);transition:transform var(--trans),box-shadow var(--trans);display:block}
.prompt-card:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(0,0,0,0.07)}
.prompt-card-img{width:100%;height:160px;object-fit:cover;display:block}
.prompt-card-bar{height:5px;min-height:5px}
.b1{background:linear-gradient(90deg,#a3c4a8,#4a7c59)}
.b2{background:linear-gradient(90deg,#c4a3b8,#7c4a6b)}
.b3{background:linear-gradient(90deg,#a3b8c4,#4a6b7c)}
.b4{background:linear-gradient(90deg,#c4bca3,#7c714a)}
.b5{background:linear-gradient(90deg,#c4a3a3,#7c4a4a)}
.b6{background:linear-gradient(90deg,#b8c4a3,#6b7c4a)}
.prompt-card-body{padding:14px 16px 16px}
.prompt-card-tag{font-size:9px;font-weight:600;letter-spacing:1px;color:var(--muted);text-transform:uppercase;margin-bottom:6px}
.prompt-card-title{font-size:13px;font-weight:500;color:var(--text);line-height:1.4;margin-bottom:4px}
.prompt-card-count{font-size:11px;color:var(--muted)}

/* ── TOOL PAGE ─────────────────────────────────────────── */
.tool-page{padding:36px 0 56px}
.tool-page-layout{display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start}
.tool-page-main{min-width:0}
.tool-page-header{margin-bottom:32px;max-width:680px}
.tool-breadcrumb{font-size:12px;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:6px}
.tool-breadcrumb a{color:var(--muted);transition:color var(--trans)}
.tool-breadcrumb a:hover{color:var(--acc)}
.tool-page-header h1{font-family:'Playfair Display',serif;font-size:38px;font-weight:400;line-height:1.15;letter-spacing:-0.5px;margin-bottom:12px}
.tool-page-intro{font-size:15px;color:var(--sub);line-height:1.75;padding-left:14px;border-left:2px solid var(--acc-mid)}

/* Tool widget */
.tool-widget{background:var(--acc-light);border:1px solid var(--bd);border-radius:var(--radius);padding:28px;margin-bottom:40px;max-width:680px}

.tool-upload-zone{border:2px dashed var(--bd);border-radius:var(--radius-sm);min-height:200px;cursor:pointer;transition:border-color var(--trans),background var(--trans);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.tool-upload-zone:hover,.tool-upload-zone.drag-over{border-color:var(--acc);background:var(--acc-light)}
.tool-upload-zone.has-file{border-style:solid;border-color:var(--acc-mid)}
.tool-upload-zone.loading{pointer-events:none;opacity:.7}

.tool-upload-content{text-align:center;padding:32px 20px;display:flex;flex-direction:column;align-items:center;gap:10px}
.tool-upload-icon{width:48px;height:48px;flex-shrink:0}
.tool-upload-icon svg{width:48px;height:48px}
.tool-upload-text{font-size:14px;color:var(--sub);font-weight:500}
.tool-upload-hint{font-size:12px;color:var(--muted)}

/* Preview image — server renders hidden, JS reveals.
   Fixed height + object-fit:cover, not object-fit:contain: with
   "contain" a portrait photo gets letterboxed (scaled down to fit
   inside the box, leaving empty space left/right) instead of filling
   the upload zone — that's the "picture doesn't line up" bug. A
   fixed height with "cover" always fills the full width of the zone
   for every photo the user uploads, cropping overflow instead of
   padding it, with no JS measuring/aspect-ratio math needed.
*/
.tool-preview{width:100%;height:280px;object-fit:cover;object-position:center;display:block;border-radius:8px}
.tool-preview[hidden]{display:none}

.tool-text-input{margin-top:16px}
.tool-text-input label{display:block;font-size:12px;font-weight:500;color:var(--sub);margin-bottom:6px}
.tool-text-input textarea{width:100%;min-height:72px;border:1px solid var(--bd);border-radius:var(--radius-sm);padding:10px 13px;font-family:'Inter',sans-serif;font-size:13px;color:var(--text);resize:vertical;transition:border-color var(--trans);background:var(--bg)}
.tool-text-input textarea:focus{outline:none;border-color:var(--acc)}

.tool-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:16px;padding:14px 20px;background:var(--acc);color:#fff;font-size:14px;font-weight:500;font-family:'Inter',sans-serif;border-radius:var(--radius-sm);transition:background var(--trans),opacity var(--trans);min-height:50px}
.tool-btn:hover:not(:disabled){background:#3d6b4a}
.tool-btn:disabled{opacity:.5;cursor:not-allowed}

/* Spinner — pure CSS, no JS DOM building */
.tool-btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,0.35);border-top-color:#fff;border-radius:50%;animation:msn-spin .7s linear infinite;flex-shrink:0}
.tool-btn-spinner[hidden]{display:none}
.tool-btn-text[hidden]{display:none}
@keyframes msn-spin{to{transform:rotate(360deg)}}

/* Result */
.tool-result{margin-top:20px;border:1px solid var(--bd);border-radius:var(--radius-sm);overflow:hidden;min-height:60px}
.tool-result[hidden]{display:none}
.tool-result-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--bd);background:var(--bg)}
.tool-result-title{font-size:11px;font-weight:600;letter-spacing:1px;color:var(--muted);text-transform:uppercase}
.tool-copy-btn{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;color:var(--acc);padding:5px 10px;border-radius:8px;transition:background var(--trans)}
.tool-copy-btn:hover{background:var(--acc-light)}
.tool-copy-btn.copied{color:#059669}
.tool-copy-btn svg{width:14px;height:14px;stroke:currentColor;flex-shrink:0}
.msn-copy-label{pointer-events:none}
.tool-result-text{padding:18px 20px;font-size:14px;line-height:1.8;color:var(--text);white-space:pre-wrap;word-break:break-word;min-height:60px}

/* Error */
.tool-error{margin-top:12px;padding:12px 16px;background:#fff8f8;border:1px solid #fecaca;border-radius:var(--radius-sm);font-size:13px;color:#dc2626;min-height:44px}
.tool-error[hidden]{display:none}

/* ── SIDEBAR (recent blog cards) ──────────────────────────── */
.tool-sidebar{position:sticky;top:84px}
.sidebar-card-group{background:var(--acc-light);border:1px solid var(--bd);border-radius:var(--radius);padding:20px}
.sidebar-title{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.sidebar-post-card{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--bd)}
.sidebar-post-card:last-of-type{border-bottom:none}
.sidebar-post-img{width:64px;height:48px;border-radius:8px;object-fit:cover;flex-shrink:0;background:var(--bg)}
.sidebar-post-img-placeholder{background:linear-gradient(135deg,var(--acc-light),var(--bg))}
.sidebar-post-body{min-width:0}
.sidebar-post-title{font-size:13px;font-weight:500;color:var(--text);line-height:1.4;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sidebar-post-date{font-size:11px;color:var(--muted)}
.sidebar-see-all{display:block;margin-top:14px;font-size:13px;font-weight:500;color:var(--acc);text-align:center}
.sidebar-see-all:hover{text-decoration:underline}

@media (max-width:900px){
  .tool-page-layout{grid-template-columns:1fr}
  .tool-sidebar{position:static}
}

/* Tool page content */
.tool-page-content{max-width:720px;font-size:15px;color:var(--sub);line-height:1.8}
.tool-page-content h2{font-family:'Playfair Display',serif;font-size:24px;font-weight:400;color:var(--text);margin:32px 0 12px}
.tool-page-content h3{font-size:16px;font-weight:500;color:var(--text);margin:24px 0 8px}
.tool-page-content p{margin-bottom:14px}
.tool-page-content ul,.tool-page-content ol{padding-left:20px;margin-bottom:14px}
.tool-page-content li{margin-bottom:6px}

/* FAQ */
.tool-faq{max-width:720px;margin-top:40px;border-top:1px solid var(--bd);padding-top:32px}
.tool-faq h2{font-family:'Playfair Display',serif;font-size:24px;font-weight:400;color:var(--text);margin-bottom:20px}
.faq-item{border-bottom:1px solid var(--bd);padding:18px 0}
.faq-item:last-child{border-bottom:none}
.faq-q{font-size:15px;font-weight:500;color:var(--text);margin-bottom:8px;line-height:1.4}
.faq-a{font-size:14px;color:var(--sub);line-height:1.75}

/* ── RELATED TOOLS (on tool pages) ───────────────────────── */
.related-tools{max-width:720px;margin-top:40px;border-top:1px solid var(--bd);padding-top:32px}
.related-tools .sec-label{margin-bottom:16px}
.related-tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tool-card-sm .tool-card-img,
.tool-card-sm .tool-card-img-placeholder{height:120px}
.tool-card-sm .tool-card-body{padding:14px}
.tool-card-sm .tool-card-title{font-size:14px}
@media(max-width:640px){
  .related-tools-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:400px){
  .related-tools-grid{grid-template-columns:1fr}
}

/* ── RELATED POSTS (after the author box, on single posts) ── */
.related-posts{max-width:720px;margin-top:32px;border-top:1px solid var(--bd);padding-top:32px}
.related-posts .sec-label{margin-bottom:16px}
.related-posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:640px){
  .related-posts-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:400px){
  .related-posts-grid{grid-template-columns:1fr}
}

/* ── SINGLE POST (prompt articles) ────────────────────── */
.post-header{padding:44px 0 32px;border-bottom:1px solid var(--bd);max-width:760px}
.post-breadcrumb{font-size:12px;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:6px}
.post-breadcrumb a{color:var(--muted);transition:color var(--trans)}
.post-breadcrumb a:hover{color:var(--acc)}
.post-header h1{font-family:'Playfair Display',serif;font-size:36px;font-weight:400;line-height:1.15;letter-spacing:-0.3px;margin-bottom:12px}
.post-meta{font-size:12px;color:var(--muted);display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.post-author{display:inline-flex;align-items:center;gap:6px}
.post-author a{color:var(--sub);font-weight:500;transition:color var(--trans)}
.post-author a:hover{color:var(--acc)}
.post-author-avatar{border-radius:50%;display:block}

/* Featured image on single posts */
.post-featured-image{max-width:760px;margin:28px auto 0}
.post-featured-image img{width:100%;height:auto;border-radius:var(--radius-sm);display:block}

/* Table of contents */
.post-toc{max-width:720px;background:var(--acc-light);border:1px solid var(--acc-mid);border-radius:var(--radius-sm);padding:22px 24px;margin-bottom:28px}
.post-toc-title{font-size:11px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.post-toc-list{list-style:none;padding:0;margin:0;counter-reset:msn-toc}
.post-toc-list li{counter-increment:msn-toc;padding:5px 0}
.post-toc-list li::before{content:counter(msn-toc) ".";color:var(--acc);font-weight:600;margin-right:8px}
.post-toc-list a{font-size:14px;color:var(--text);transition:color var(--trans)}
.post-toc-list a:hover{color:var(--acc);text-decoration:underline}

/* Author bio box, end of article */
.post-author-box{max-width:720px;display:flex;gap:16px;align-items:center;margin-top:32px;padding:22px 24px;background:var(--acc-light);border:1px solid var(--acc-mid);border-radius:var(--radius-sm)}
.post-author-box-avatar{border-radius:50%;flex-shrink:0;display:block;box-shadow:0 0 0 3px var(--card)}
.post-author-box-eyebrow{font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--acc);margin-bottom:4px}
.post-author-box-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}
.post-author-box-bio{font-size:13px;color:var(--sub);line-height:1.6}

/* ── HTML SITEMAP PAGE ─────────────────────────────────── */
.sitemap{padding:36px 0 56px;display:grid;grid-template-columns:repeat(3,1fr);gap:32px 24px}
.sitemap-section-wide{grid-column:1/-1}
.sitemap-section h2{font-family:'Playfair Display',serif;font-size:17px;font-weight:500;color:var(--text);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--bd)}
.sitemap-list{list-style:none;padding:0;margin:0}
.sitemap-list li{padding:5px 0}
.sitemap-list a{font-size:13px;color:var(--sub);transition:color var(--trans)}
.sitemap-list a:hover{color:var(--acc);text-decoration:underline}
.sitemap-list-cols{column-count:3;column-gap:24px}
.sitemap-list-cols li{break-inside:avoid}
@media(max-width:900px){
  .sitemap{grid-template-columns:repeat(2,1fr)}
  .sitemap-list-cols{column-count:2}
}
@media(max-width:640px){
  .sitemap{grid-template-columns:1fr}
  .sitemap-list-cols{column-count:1}
}

.post-content{max-width:720px;padding:36px 0 0;font-size:15px;color:var(--sub);line-height:1.8}
.post-content h2{font-family:'Playfair Display',serif;font-size:24px;font-weight:400;color:var(--text);margin:36px 0 14px}
.post-content h3{font-size:17px;font-weight:500;color:var(--text);margin:28px 0 10px}
.post-content p{margin-bottom:16px}
.post-content ul,.post-content ol{padding-left:22px;margin-bottom:16px}
.post-content li{margin-bottom:8px}
.post-content img{border-radius:var(--radius-sm);margin:24px 0;width:100%;height:auto}
.post-content blockquote{border-left:3px solid var(--acc);padding:12px 20px;margin:24px 0;color:var(--sub);font-style:italic}

/* Lightbox for gallery images */
.msn-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:24px 0}
.msn-gallery-item{border-radius:var(--radius-sm);overflow:hidden;cursor:zoom-in;aspect-ratio:4/3}
.msn-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--trans)}
.msn-gallery-item:hover img{transform:scale(1.03)}

/* Lightbox overlay — server-rendered hidden, JS toggles class */
.msn-lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.88);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease}
.msn-lightbox.open{opacity:1;pointer-events:auto}
.msn-lightbox-img{max-width:92vw;max-height:88vh;aspect-ratio:auto;border-radius:var(--radius-sm);object-fit:contain;width:auto;height:auto}
.msn-lightbox-close{position:absolute;top:20px;right:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.1);border-radius:50%;color:#fff;font-size:20px;cursor:pointer;transition:background var(--trans);border:none}
.msn-lightbox-close:hover{background:rgba(255,255,255,0.2)}

/* Archive / category page */
.archive-header{padding:40px 0 28px;border-bottom:1px solid var(--bd)}
.archive-header h1{font-family:'Playfair Display',serif;font-size:36px;font-weight:400}
.cat-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.cat-pill{font-size:12px;font-weight:500;color:var(--sub);background:var(--acc-light);border:1px solid var(--bd);padding:7px 16px;border-radius:20px;transition:all var(--trans)}
.cat-pill:hover{color:var(--acc);border-color:var(--acc-mid);background:var(--acc-light)}
.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:36px 0 56px}

/* Search results */
.search-header{padding:36px 0 24px;border-bottom:1px solid var(--bd)}
.search-header h1{font-family:'Playfair Display',serif;font-size:28px;font-weight:400}
.search-results{padding:28px 0 56px;display:flex;flex-direction:column;gap:20px;max-width:720px}
.search-item{border-bottom:1px solid var(--bd);padding-bottom:20px}
.search-item:last-child{border-bottom:none}
.search-item-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:400;color:var(--acc);margin-bottom:6px}
.search-item-title:hover{text-decoration:underline}
.search-item-excerpt{font-size:13px;color:var(--sub);line-height:1.6}

/* 404 */
.not-found{padding:64px 0 40px;text-align:center}
.not-found-code{font-family:'Playfair Display',serif;font-size:80px;font-weight:400;color:var(--acc);line-height:1;margin-bottom:8px}
.not-found h1{font-size:20px;font-weight:500;color:var(--text);margin-bottom:24px}
.btn-home{display:inline-flex;padding:12px 24px;background:var(--acc);color:#fff;border-radius:var(--radius-sm);font-size:14px;font-weight:500;transition:background var(--trans)}
.btn-home:hover{background:#3d6b4a}
.not-found-search{max-width:420px;margin:0 auto 56px}
.not-found-tools{padding-bottom:56px}

/* Single-post page: same bottom breathing room every other page
   template gets (.tool-page, .archive-grid, .prompts, .sitemap all
   end in 56px) — single.php was missing it entirely because its wrap
   never carried that page-level padding, only .post-content's own
   (misplaced) bottom padding did. */
.post-page{padding-bottom:56px}

/* ── FOOTER ────────────────────────────────────────────── */
.footer{border-top:1px solid var(--bd)}
.footer-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px 24px;padding:22px 0}
.footer-logo{font-family:'Playfair Display',serif;font-size:13px;font-style:italic;color:var(--muted)}
.footer-legal{display:flex;flex-wrap:wrap;align-items:center;gap:4px 18px}
.footer-link{font-size:11px;color:var(--muted);transition:color var(--trans)}
.footer-link:hover{color:var(--acc)}
.footer-credit{margin-left:auto}

/* ── ANIMATIONS (respect prefers-reduced-motion) ────────── */
@media(prefers-reduced-motion:no-preference){
  .fi{opacity:0;transform:translateY(12px);animation:msn-fi .4s ease forwards}
  @keyframes msn-fi{to{opacity:1;transform:none}}
  .fi1{animation-delay:.05s}.fi2{animation-delay:.1s}
  .fi3{animation-delay:.15s}.fi4{animation-delay:.2s}
}

/* ── RESPONSIVE ────────────────────────────────────────── */
@media(max-width:900px){
  .tools-grid{grid-template-columns:repeat(2,1fr)}
  .prompts-grid{grid-template-columns:repeat(2,1fr)}
  .msn-gallery{grid-template-columns:repeat(2,1fr)}
  .archive-grid{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:42px}
}
@media(max-width:640px){
  .wrap{padding:0 20px}
  .nav-inner{padding:0 20px}
  .hero{padding:40px 0 36px}
  .hero h1{font-size:32px;letter-spacing:-0.5px}
  .hero-sub{font-size:14px}
  .tools-grid{grid-template-columns:1fr 1fr}
  .prompts-grid{grid-template-columns:1fr 1fr}
  .tool-card-img,.tool-card-img-placeholder{height:160px}
  .tool-preview{height:220px}
  .drawer{width:100%;border-left:none}
  .prompts-header h2{font-size:22px}
  .tool-page-header h1{font-size:28px}
  .post-header h1{font-size:26px}
  .footer-inner{flex-direction:column;gap:10px;text-align:center}
  .footer-credit{margin-left:0}
  .footer-legal{justify-content:center}
  .msn-gallery{grid-template-columns:1fr 1fr}
  .archive-grid{grid-template-columns:1fr}
}
@media(max-width:400px){
  .tools-grid{grid-template-columns:1fr}
  .prompts-grid{grid-template-columns:1fr}
  .logo-text{font-size:14px}
  .logo-icon{width:28px;height:28px}
  .nav-langs ul li a,
  .nav-langs a{padding:6px 8px;font-size:10px}
  .nav-right{gap:6px}
  .burger{width:34px;height:34px;margin-left:0}
}

/* ── UTILITY CLASSES (replacing inline styles) ────────── */
.pagination-wrap{padding-bottom:40px}
.page-content-wrap{padding-top:40px;padding-bottom:40px}
.page-default-title{font-family:'Playfair Display',serif;font-size:36px;font-weight:400;margin-bottom:24px}
.prompts-empty{grid-column:1/-1;color:var(--muted);font-size:13px}
.archive-desc{font-size:14px;color:var(--sub);margin-top:10px;line-height:1.7}
.no-results{padding:40px 0;color:var(--muted);font-size:14px}
