/*
Theme Name: Show Up Online Journal
Theme URI: https://showuponline.co
Author: Show Up Online by Mary Milagros LLC
Author URI: https://showuponline.co
Description: Editorial blog theme for Show Up Online - matches the main site design system with Cormorant + Outfit typography, navy/cream/teal palette, and product card grid layout.
Version: 3.1.3
License: Proprietary
Text Domain: marymilagros
*/

/* ═══════════════════════════════════════
   RESET
   ═══════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
img{max-width:100%;height:auto;display:block}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}

/* ═══════════════════════════════════════
   DESIGN SYSTEM
   ═══════════════════════════════════════ */
:root{
  --bg:#FDFCFB;--bg2:#fff;--bg3:#F6F5F3;--bg4:#EEEDEB;
  --navy:#1f2e42;--navy-d:#0c1420;
  --teal:#3499b1;--teal2:#42b8d4;--ice:#badce5;
  --tx:#1C2024;--tx2:#5A5F65;--tx3:#8A8F95;--tx4:#B5B8BD;
  --ac:#3499b1;--ac-g:rgba(52,153,177,.15);
  --bd:rgba(28,32,36,.07);
  --e:cubic-bezier(.16,1,.3,1);
  --fd:'Cormorant',Georgia,serif;
  --fu:'Outfit',system-ui,sans-serif;
  --px:clamp(20px,4vw,56px);
}

[data-theme="dark"]{
  --bg:#111315;--bg2:#1A1D20;--bg3:#1E2226;--bg4:#262A2E;
  --navy:#0A0B0D;--navy-d:#050608;
  --tx:#F5F5F4;--tx2:#A1A5A9;--tx3:#6B7075;--tx4:#4A4F54;
  --ac:#8FBDD0;--ac-g:rgba(143,189,208,.15);
  --bd:rgba(255,255,255,.08);
}
[data-theme="weird"]{
  --bg:#0D0221;--bg2:#1A0A3E;--bg3:#220E4A;--bg4:#2D1560;
  --navy:#050111;--navy-d:#030010;
  --tx:#F0E6FF;--tx2:#C9B0FF;--tx3:#9B7ADB;--tx4:#6B4FA0;
  --ac:#FF6BCC;--ac-g:rgba(255,107,204,.15);
  --bd:rgba(255,255,255,.12);
}

body{
  background:var(--bg);
  color:var(--tx);
  font-family:var(--fu);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.6;
  transition:background .6s ease,color .6s ease;
}
::selection{background:var(--ac);color:#fff}

/* ═══════════════════════════════════════
   ACCESSIBILITY
   ═══════════════════════════════════════ */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;top:-100px;left:16px;background:var(--ac);color:#fff;padding:12px 24px;font-family:var(--fu);font-size:.75rem;font-weight:600;border-radius:0 0 8px 8px;z-index:100000;transition:top .3s}
.skip-link:focus{top:0}
*:focus-visible{outline:2px solid var(--ac);outline-offset:3px;border-radius:4px}

/* ═══════════════════════════════════════
   GRAIN (subtle texture overlay)
   ═══════════════════════════════════════ */
.grain{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.012}
.grain::before{content:'';position:absolute;inset:-200%;width:400%;height:400%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");animation:gn 8s steps(8) infinite}
@keyframes gn{0%{transform:translate(0)}25%{transform:translate(-5%,-5%)}50%{transform:translate(5%,-3%)}75%{transform:translate(-3%,5%)}100%{transform:translate(0)}}
@media(prefers-reduced-motion:reduce){.grain::before{animation:none}}

/* ═══════════════════════════════════════
   TOP BAR
   ═══════════════════════════════════════ */
.topbar{
  background:var(--navy);
  text-align:center;
  padding:10px 16px;
  font-family:var(--fu);
  font-size:.6rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
  position:relative;
  z-index:201;
}
.topbar a{color:var(--ac);font-weight:500;margin-left:6px;transition:color .3s}
.topbar a:hover{color:var(--ice)}
[data-theme="dark"] .topbar{background:#0A0B0D}
[data-theme="weird"] .topbar{background:#050111}

/* ═══════════════════════════════════════
   MAIN NAV
   ═══════════════════════════════════════ */
.site-nav{
  position:sticky;
  top:0;
  z-index:200;
  padding:18px 0;
  background:rgba(253,252,251,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bd);
  transition:background .6s ease,border-color .6s ease;
}
[data-theme="dark"] .site-nav{background:rgba(17,19,21,.92)}
[data-theme="weird"] .site-nav{background:rgba(13,2,33,.92)}
.nav-in{
  max-width:1400px;
  margin:0 auto;
  padding:0 var(--px);
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.nav-logo{
  font-family:var(--fd);
  font-size:.95rem;
  font-weight:400;
  letter-spacing:.35em;
  text-transform:uppercase;
  color:var(--tx);
  transition:color .3s;
}
.nav-logo:hover{color:var(--ac)}
.nav-r{
  display:flex;
  align-items:center;
  gap:clamp(14px,2.5vw,32px);
}
.nav-a{
  font-family:var(--fu);
  font-size:.65rem;
  font-weight:400;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--tx3);
  transition:color .3s;
}
.nav-a:hover,.nav-a.active{color:var(--tx)}
.nav-cta{
  font-family:var(--fu);
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:11px 24px;
  background:var(--ac);
  color:#fff;
  border-radius:100px;
  box-shadow:0 6px 20px var(--ac-g);
  transition:all .35s var(--e);
}
.nav-cta:hover{background:var(--teal2);transform:translateY(-2px);box-shadow:0 10px 28px var(--ac-g);color:#fff}
.tt{
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  color:var(--tx3);
  transition:color .3s;
}
.tt:hover{color:var(--ac)}
.tt svg{width:16px;height:16px}

/* ═══════════════════════════════════════
   BLOG HERO (index page)
   ═══════════════════════════════════════ */
.blog-hero{
  padding:clamp(80px,12vh,140px) var(--px) clamp(40px,6vh,60px);
  text-align:center;
  max-width:880px;
  margin:0 auto;
}
.blog-hero-tag{
  font-family:var(--fu);
  font-size:.5rem;
  font-weight:600;
  letter-spacing:.4em;
  text-transform:uppercase;
  color:var(--ac);
  margin-bottom:18px;
}
.blog-hero h1{
  font-family:var(--fd);
  font-size:clamp(3rem,7vw,6rem);
  font-weight:300;
  line-height:.92;
  letter-spacing:-.02em;
  margin-bottom:20px;
  color:var(--tx);
}
.blog-hero h1 em{font-style:italic;font-weight:400;color:var(--ac)}
.blog-hero p{
  font-family:var(--fu);
  font-size:.85rem;
  color:var(--tx2);
  font-weight:300;
  max-width:520px;
  margin:0 auto;
  line-height:1.8;
}

/* ═══════════════════════════════════════
   CATEGORY FILTERS
   ═══════════════════════════════════════ */
.blog-filters{
  border-top:1px solid var(--bd);
  border-bottom:1px solid var(--bd);
  padding:20px 0;
  background:var(--bg);
  margin-bottom:clamp(40px,6vh,60px);
}
.blog-filters-in{
  max-width:1400px;
  margin:0 auto;
  padding:0 var(--px);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
}
.cat-pill{
  font-family:var(--fu);
  font-size:.6rem;
  font-weight:500;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:9px 20px;
  border-radius:100px;
  border:1px solid var(--bd);
  color:var(--tx3);
  transition:all .3s var(--e);
}
.cat-pill:hover{border-color:var(--ac);color:var(--ac)}
.cat-pill.current{background:var(--navy);color:#fff;border-color:var(--navy)}
[data-theme="dark"] .cat-pill.current{background:var(--ac);color:var(--navy-d);border-color:var(--ac)}

/* ═══════════════════════════════════════
   BLOG GRID (index / category / search)
   - Matches the .prod-card style from index.html
   ═══════════════════════════════════════ */
.blog-grid{
  max-width:1400px;
  margin:0 auto;
  padding:0 var(--px) clamp(60px,10vh,120px);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,3vw,32px);
}
@media(max-width:960px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.blog-grid{grid-template-columns:1fr}}

.post-card{
  background:var(--bg2);
  border:1px solid var(--bd);
  border-radius:6px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .5s var(--e),box-shadow .5s var(--e);
}
.post-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(28,32,36,.08);
}
[data-theme="dark"] .post-card{background:var(--bg2);border-color:var(--bd)}
[data-theme="weird"] .post-card{background:rgba(26,10,62,.6);border-color:rgba(255,107,204,.15)}
[data-theme="weird"] .post-card:hover{border-color:rgba(255,107,204,.4)}

.post-card-img{
  aspect-ratio:4/3;
  background:var(--bg3);
  overflow:hidden;
  position:relative;
}
.post-card-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s var(--e);
}
.post-card:hover .post-card-img img{transform:scale(1.05)}

.post-card-img-placeholder{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--bg3),var(--bg4));
  font-family:var(--fd);
  font-style:italic;
  font-size:1.3rem;
  color:var(--tx3);
  padding:20px;
  text-align:center;
}

.post-card-body{
  padding:20px 22px 22px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}
.post-card-meta{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--fu);
  font-size:.5rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--tx3);
}
.post-card-cat{
  color:var(--ac);
  font-weight:700;
}
.post-card-sep{color:var(--tx4)}
.post-card-title{
  font-family:var(--fd);
  font-size:1.25rem;
  font-weight:500;
  color:var(--tx);
  line-height:1.25;
  letter-spacing:-.01em;
  margin:2px 0 4px;
}
.post-card-excerpt{
  font-family:var(--fu);
  font-size:.72rem;
  color:var(--tx2);
  font-weight:300;
  line-height:1.6;
  flex:1;
}
.post-card-arrow{
  font-family:var(--fu);
  font-size:.55rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ac);
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:6px;
  transition:gap .3s var(--e);
}
.post-card:hover .post-card-arrow{gap:12px}

/* Featured post (first card on first page) - spans 2 columns at desktop */
.blog-grid.has-featured .post-card:first-child{
  grid-column:span 2;
  grid-row:span 1;
}
.blog-grid.has-featured .post-card:first-child .post-card-img{
  aspect-ratio:16/9;
}
.blog-grid.has-featured .post-card:first-child .post-card-title{
  font-size:1.7rem;
}
@media(max-width:960px){
  .blog-grid.has-featured .post-card:first-child{grid-column:span 2}
}
@media(max-width:640px){
  .blog-grid.has-featured .post-card:first-child{grid-column:span 1}
  .blog-grid.has-featured .post-card:first-child .post-card-title{font-size:1.3rem}
}

/* ═══════════════════════════════════════
   PAGINATION
   ═══════════════════════════════════════ */
.blog-pagination{
  max-width:1400px;
  margin:0 auto clamp(60px,8vh,100px);
  padding:0 var(--px);
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
}
.blog-pagination .page-numbers{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:40px;
  height:40px;
  padding:0 14px;
  font-family:var(--fu);
  font-size:.7rem;
  font-weight:500;
  letter-spacing:.08em;
  color:var(--tx3);
  border:1px solid var(--bd);
  border-radius:100px;
  transition:all .3s var(--e);
}
.blog-pagination .page-numbers:hover{border-color:var(--ac);color:var(--ac)}
.blog-pagination .page-numbers.current{
  background:var(--navy);
  color:#fff;
  border-color:var(--navy);
}
[data-theme="dark"] .blog-pagination .page-numbers.current{background:var(--ac);color:var(--navy-d);border-color:var(--ac)}

/* ═══════════════════════════════════════
   SINGLE POST PAGE - 3-column layout
   ┌─────────────────────────────────────────┐
   │  POST TOP (title + featured image)       │
   ├──────────┬───────────────────┬───────────┤
   │  TOC     │  POST CONTENT     │  SIDEBAR  │
   │  sticky  │  ~720px centered  │  sticky   │
   └──────────┴───────────────────┴───────────┘
   ═══════════════════════════════════════ */

/* Top section - full-width title block above the 3-column layout */
.post-top{
  max-width:880px !important;
  margin:0 auto !important;
  padding:clamp(40px,6vh,80px) var(--px) clamp(24px,3vh,40px);
}
.post-top-in{max-width:720px;margin:0 auto;width:100%}
.post-back{
  display:inline-block;
  font-family:var(--fu);
  font-size:.55rem;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--tx3);
  margin-bottom:clamp(28px,4vh,40px);
  transition:color .3s;
}
.post-back:hover{color:var(--ac)}
.post-tag{
  font-family:var(--fu);
  font-size:.5rem;
  font-weight:700;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ac);
  margin-bottom:14px;
}
.post-title{
  font-family:var(--fd);
  font-size:clamp(2.2rem,4.5vw,3.6rem);
  font-weight:300;
  line-height:1.05;
  letter-spacing:-.015em;
  margin-bottom:20px;
  color:var(--tx);
}
.post-title em{font-style:italic;font-weight:400}
.post-meta{
  font-family:var(--fu);
  font-size:.6rem;
  font-weight:400;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--tx3);
  margin-bottom:clamp(32px,4vh,48px);
  padding-bottom:clamp(24px,3vh,36px);
  border-bottom:1px solid var(--bd);
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.post-meta-author{color:var(--tx2);font-weight:500}
.post-meta-sep{color:var(--tx4)}

/* Featured image */
.post-featured{margin:0}
.post-featured img{
  width:100%;
  height:auto;
  max-height:560px;
  object-fit:cover;
  border-radius:8px;
}

/* 3-column layout - using !important to defeat any plugin/cache override */
.post-layout{
  max-width:1400px !important;
  margin:0 auto !important;
  padding:0 var(--px) clamp(40px,6vh,80px);
  display:grid !important;
  grid-template-columns:220px minmax(0,720px) 280px !important;
  gap:clamp(32px,4vw,56px);
  justify-content:center;
  align-items:start;
  position:relative;
}

/* Center column - post content */
.post{
  min-width:0;
  padding:0;
  max-width:720px;
  width:100%;
}

/* TOC sidebar (left) */
.post-toc{position:relative}
.post-toc-sticky{
  position:sticky;
  top:96px;
  padding-top:8px;
}
.post-toc-toggle{
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:100%;
  padding:0 0 14px;
  font-family:var(--fu);
  font-size:.5rem;
  font-weight:700;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ac);
  cursor:default;
  border-bottom:1px solid var(--bd);
  margin-bottom:14px;
}
.post-toc-chevron{display:none}
.post-toc-list{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.post-toc-list a{
  display:block;
  padding:8px 0 8px 12px;
  border-left:2px solid transparent;
  font-family:var(--fu);
  font-size:.7rem;
  font-weight:400;
  line-height:1.5;
  color:var(--tx3);
  transition:color .3s,border-color .3s;
}
.post-toc-list a:hover{color:var(--tx)}
.post-toc-list a.active{
  color:var(--ac);
  border-left-color:var(--ac);
  font-weight:500;
}

/* Product promo sidebar (right) */
.post-side{position:relative}
.post-side-sticky{
  position:sticky;
  top:96px;
  padding-top:8px;
}

/* Override the bottom promo padding when used in sidebar */
.post-side .post-promo{
  margin:0;
  padding:24px 22px 26px;
}
.post-side .post-promo-title{
  font-size:clamp(1.1rem,1.5vw,1.3rem);
  margin-bottom:10px;
}
.post-side .post-promo-body{
  font-size:.7rem;
  line-height:1.65;
  margin-bottom:14px;
}
.post-side .post-promo-price{
  font-size:1.15rem;
  margin-bottom:12px;
}
.post-side .post-promo-price s{font-size:.75rem}
.post-side .post-promo-cta{
  font-size:.58rem;
  padding:11px 22px;
  width:100%;
  justify-content:center;
}

/* TL;DR box */
.post-tldr{
  background:var(--bg3);
  border-left:3px solid var(--ac);
  padding:clamp(20px,3vh,28px) clamp(20px,3vw,32px);
  margin:0 0 clamp(32px,4vh,44px);
  border-radius:0 6px 6px 0;
}
.post-tldr-label{
  font-family:var(--fu);
  font-size:.5rem;
  font-weight:700;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ac);
  margin-bottom:8px;
}
.post-tldr-body{
  font-family:var(--fu);
  font-size:.8rem;
  font-weight:300;
  color:var(--tx);
  line-height:1.7;
}
.post-tldr-body p{margin-bottom:8px}
.post-tldr-body p:last-child{margin-bottom:0}
.post-tldr-body ul,.post-tldr-body ol{margin-left:18px;margin-bottom:8px}
.post-tldr-body strong{font-weight:500;color:var(--tx)}

/* Post body */
.post-body{font-family:var(--fu)}
.post-body p{
  font-family:var(--fu);
  font-size:.85rem;
  font-weight:300;
  line-height:1.95;
  color:var(--tx2);
  margin-bottom:20px;
}
.post-body h2{
  font-family:var(--fd);
  font-size:clamp(1.4rem,2.4vw,1.9rem);
  font-weight:400;
  line-height:1.2;
  letter-spacing:-.01em;
  margin:clamp(36px,5vh,56px) 0 14px;
  color:var(--tx);
  /* Anchor scroll offset for TOC clicks */
  scroll-margin-top:96px;
}
.post-body h2 em{font-style:italic;font-weight:500;color:var(--ac)}
.post-body h3{
  font-family:var(--fd);
  font-size:clamp(1.15rem,1.8vw,1.4rem);
  font-weight:500;
  line-height:1.3;
  margin:clamp(28px,4vh,40px) 0 10px;
  color:var(--tx);
  scroll-margin-top:96px;
}
.post-body strong,.post-body b{font-weight:500;color:var(--tx)}
.post-body em,.post-body i{font-style:italic}
.post-body a{
  color:var(--ac);
  border-bottom:1px solid var(--ac-g);
  transition:border-color .3s;
}
.post-body a:hover{border-bottom-color:var(--ac)}
.post-body ul,.post-body ol{
  margin:0 0 20px 22px;
  padding-left:6px;
}
.post-body li{
  font-family:var(--fu);
  font-size:.85rem;
  font-weight:300;
  line-height:1.85;
  color:var(--tx2);
  margin-bottom:6px;
}
.post-body li strong{font-weight:500;color:var(--tx)}
.post-body blockquote{
  font-family:var(--fd);
  font-style:italic;
  font-size:clamp(1.15rem,1.8vw,1.4rem);
  font-weight:300;
  line-height:1.5;
  color:var(--tx);
  padding:clamp(20px,3vh,28px) 0 clamp(20px,3vh,28px) clamp(20px,3vw,32px);
  margin:clamp(28px,4vh,40px) 0;
  border-left:3px solid var(--ac);
}
.post-body blockquote p{font-size:inherit;color:inherit;font-family:inherit}

/* IMPORTANT: Constrain images to the column - this was the original bug */
.post-body img{
  max-width:100%;
  width:100%;
  height:auto;
  border-radius:6px;
  margin:clamp(24px,3vh,32px) 0;
  display:block;
}
.post-body figure{
  margin:clamp(24px,3vh,32px) 0;
  max-width:100%;
}
.post-body figure img{margin:0}
.post-body figcaption{
  font-family:var(--fu);
  font-size:.65rem;
  font-style:italic;
  color:var(--tx3);
  text-align:center;
  margin-top:10px;
  font-weight:300;
}
.post-body hr{
  border:0;
  border-top:1px solid var(--bd);
  margin:clamp(40px,5vh,60px) 0;
}
.post-body pre{
  background:var(--bg3);
  padding:18px 22px;
  border-radius:6px;
  overflow-x:auto;
  margin:0 0 20px;
  font-size:.75rem;
  line-height:1.6;
}
.post-body code{
  font-family:'SF Mono','Monaco','Cascadia Code','Roboto Mono',monospace;
  font-size:.78em;
  background:var(--bg3);
  padding:2px 6px;
  border-radius:3px;
  color:var(--ac);
}
.post-body pre code{background:none;padding:0;color:inherit;font-size:inherit}

/* WordPress block fixes - prevent images from breaking out */
.post-body .wp-block-image{margin:clamp(24px,3vh,32px) 0}
.post-body .wp-block-image img{max-width:100%;height:auto}
.post-body .alignwide,.post-body .alignfull{
  max-width:100%;
  margin-left:0;
  margin-right:0;
}
.post-body .aligncenter{margin-left:auto;margin-right:auto;display:block}
.post-body .alignleft{float:none;display:block;margin-left:0;margin-right:0}
.post-body .alignright{float:none;display:block;margin-left:auto;margin-right:0}

/* Author box */
.post-author{
  margin:clamp(40px,5vh,56px) 0 0;
  padding:clamp(24px,3vh,32px) 0;
  border-top:1px solid var(--bd);
  display:flex;
  gap:18px;
  align-items:center;
}
.post-author-avatar{
  width:56px;
  height:56px;
  border-radius:50%;
  background:var(--bg3);
  flex-shrink:0;
  overflow:hidden;
}
.post-author-avatar img{width:100%;height:100%;object-fit:cover}
.post-author-info{flex:1}
.post-author-label{
  font-family:var(--fu);
  font-size:.5rem;
  font-weight:600;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--tx3);
  margin-bottom:4px;
}
.post-author-name{
  font-family:var(--fd);
  font-size:1.05rem;
  font-weight:500;
  color:var(--tx);
}

/* Product promo (used both in sidebar AND at bottom of content via shortcode/manual) */
.post-promo{
  padding:clamp(28px,4vh,40px) clamp(24px,3vw,32px);
  background:var(--navy);
  color:#fff;
  border-radius:8px;
  position:relative;
  overflow:hidden;
}
.post-promo::before{
  content:'';
  position:absolute;
  top:-80px;
  right:-80px;
  width:280px;
  height:280px;
  background:radial-gradient(circle,rgba(52,153,177,.22),transparent 60%);
  pointer-events:none;
}
.post-promo-tag{
  font-family:var(--fu);
  font-size:.5rem;
  font-weight:600;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ac);
  margin-bottom:10px;
  position:relative;
}
.post-promo-title{
  font-family:var(--fd);
  font-size:clamp(1.3rem,2.2vw,1.7rem);
  font-weight:400;
  line-height:1.2;
  margin-bottom:8px;
  position:relative;
  color:#fff;
}
.post-promo-title em{font-style:italic;color:var(--ac)}
.post-promo-body{
  font-family:var(--fu);
  font-size:.78rem;
  font-weight:300;
  line-height:1.7;
  color:rgba(255,255,255,.7);
  margin-bottom:18px;
  position:relative;
}
.post-promo-price{
  font-family:var(--fd);
  font-size:1.3rem;
  font-weight:500;
  color:#fff;
  margin-bottom:14px;
  position:relative;
}
.post-promo-price s{
  color:rgba(255,255,255,.4);
  font-size:.85rem;
  margin-left:8px;
  font-weight:400;
}
.post-promo-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--fu);
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:13px 28px;
  background:var(--ac);
  color:#fff;
  border-radius:100px;
  box-shadow:0 6px 20px var(--ac-g);
  transition:all .35s var(--e);
  position:relative;
}
.post-promo-cta:hover{background:var(--teal2);color:#fff;transform:translateY(-2px)}

/* Email capture (matches main site) */
.post-email{
  margin:clamp(40px,5vh,60px) 0 0;
  padding:clamp(28px,4vh,40px) clamp(24px,3vw,32px);
  background:var(--bg3);
  border-radius:8px;
  text-align:center;
}
.post-email-tag{
  font-family:var(--fu);
  font-size:.5rem;
  font-weight:700;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ac);
  margin-bottom:10px;
}
.post-email-title{
  font-family:var(--fd);
  font-size:clamp(1.3rem,2.2vw,1.7rem);
  font-weight:400;
  line-height:1.2;
  margin-bottom:8px;
  color:var(--tx);
}
.post-email-title em{font-style:italic;color:var(--ac)}
.post-email-body{
  font-family:var(--fu);
  font-size:.75rem;
  font-weight:300;
  line-height:1.6;
  color:var(--tx2);
  margin-bottom:18px;
  max-width:380px;
  margin-left:auto;
  margin-right:auto;
}
.post-email-form{
  display:flex;
  gap:8px;
  max-width:400px;
  margin:0 auto 10px;
  flex-wrap:wrap;
  justify-content:center;
}
.post-email-form input{
  flex:1;
  min-width:200px;
  padding:13px 18px;
  font-family:var(--fu);
  font-size:.78rem;
  font-weight:300;
  background:var(--bg2);
  border:1px solid var(--bd);
  border-radius:100px;
  color:var(--tx);
  outline:none;
  transition:border-color .3s;
}
.post-email-form input:focus{border-color:var(--ac)}
.post-email-form button{
  font-family:var(--fu);
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:13px 24px;
  background:var(--ac);
  color:#fff;
  border-radius:100px;
  transition:all .3s var(--e);
}
.post-email-form button:hover{background:var(--teal2);transform:translateY(-1px)}
.post-email-fine{
  font-family:var(--fu);
  font-size:.55rem;
  color:var(--tx3);
  font-weight:300;
  letter-spacing:.04em;
}

/* TABLET: 2-column (drop the TOC, keep product sidebar) */
@media(max-width:1100px){
  .post-layout{
    grid-template-columns:minmax(0,720px) 280px;
    gap:clamp(28px,3vw,40px);
  }
  .post-toc{
    grid-column:1 / -1;
    order:0;
    margin-bottom:24px;
  }
  .post-toc-sticky{
    position:relative;
    top:0;
    background:var(--bg3);
    border-radius:6px;
    padding:18px 22px;
  }
  .post-toc-toggle{
    border-bottom:none;
    margin-bottom:8px;
    padding-bottom:0;
    cursor:pointer;
  }
  .post-toc-chevron{
    display:block;
    transition:transform .3s;
  }
  .post-toc-toggle[aria-expanded="true"] .post-toc-chevron{
    transform:rotate(180deg);
  }
  .post-toc-list{
    max-height:0;
    overflow:hidden;
    transition:max-height .4s var(--e);
  }
  .post-toc-list.open{max-height:600px}
  .post-toc-list a{
    border-left:none;
    padding:6px 0;
  }
  .post-toc-list a.active{
    border-left:none;
    padding-left:0;
  }
}

/* MOBILE: single column, TOC collapsible at top, sidebar promo at bottom */
@media(max-width:768px){
  .post-layout{
    grid-template-columns:1fr;
    gap:24px;
  }
  .post-side{
    order:2;
    grid-column:1 / -1;
  }
  .post-side-sticky{
    position:relative;
    top:0;
  }
  .post-side .post-promo-cta{width:auto}
}

/* Related posts */
.related-posts{
  background:var(--bg3);
  padding:clamp(60px,8vh,90px) 0;
  border-top:1px solid var(--bd);
}
.related-posts-inner{
  max-width:1400px;
  margin:0 auto;
  padding:0 var(--px);
}
.related-posts-header{
  text-align:center;
  margin-bottom:clamp(36px,5vh,52px);
}
.related-posts-tag{
  font-family:var(--fu);
  font-size:.5rem;
  font-weight:600;
  letter-spacing:.4em;
  text-transform:uppercase;
  color:var(--ac);
  margin-bottom:12px;
}
.related-posts-header h2{
  font-family:var(--fd);
  font-size:clamp(1.6rem,2.8vw,2.2rem);
  font-weight:300;
  color:var(--tx);
}
.related-posts-header h2 em{font-style:italic;font-weight:400;color:var(--ac)}
.related-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,3vw,32px);
}
@media(max-width:960px){.related-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.related-grid{grid-template-columns:1fr}}
.related-grid .post-card{background:var(--bg2)}
[data-theme="dark"] .related-posts{background:var(--bg3)}
[data-theme="weird"] .related-posts{background:var(--bg3)}

/* ═══════════════════════════════════════
   404 / SEARCH
   ═══════════════════════════════════════ */
.page-404,.search-page{
  max-width:680px;
  margin:0 auto;
  padding:clamp(60px,10vh,100px) var(--px);
  text-align:center;
}
.page-404 h1,.search-page h1{
  font-family:var(--fd);
  font-size:clamp(2.5rem,5vw,4rem);
  font-weight:300;
  line-height:1;
  margin-bottom:18px;
  color:var(--tx);
}
.page-404 h1 em,.search-page h1 em{font-style:italic;color:var(--ac);font-weight:400}
.page-404 p,.search-page p{
  font-family:var(--fu);
  font-size:.85rem;
  color:var(--tx2);
  margin-bottom:24px;
  font-weight:300;
}
.page-404-cta,.search-page-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--fu);
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:14px 28px;
  background:var(--ac);
  color:#fff;
  border-radius:100px;
  box-shadow:0 6px 20px var(--ac-g);
  transition:all .35s var(--e);
}
.page-404-cta:hover,.search-page-cta:hover{background:var(--teal2);color:#fff;transform:translateY(-2px)}

/* Search form */
.search-form{
  max-width:520px;
  margin:0 auto 40px;
  display:flex;
  gap:8px;
}
.search-form input{
  flex:1;
  padding:13px 18px;
  font-family:var(--fu);
  font-size:.78rem;
  background:var(--bg2);
  border:1px solid var(--bd);
  border-radius:100px;
  color:var(--tx);
  outline:none;
}
.search-form input:focus{border-color:var(--ac)}
.search-form button{
  font-family:var(--fu);
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:13px 24px;
  background:var(--navy);
  color:#fff;
  border-radius:100px;
  transition:all .3s var(--e);
}
.search-form button:hover{background:var(--ac)}

/* ═══════════════════════════════════════
   FOOTER (simple, matching blog post template)
   ═══════════════════════════════════════ */
.sfoot{
  padding:32px var(--px);
  border-top:1px solid var(--bd);
  display:flex;
  justify-content:space-between;
  align-items:center;
  max-width:1400px;
  margin:0 auto;
  flex-wrap:wrap;
  gap:14px;
}
.sfoot span,.sfoot a{
  font-family:var(--fu);
  font-size:.6rem;
  color:var(--tx3);
  font-weight:300;
  letter-spacing:.04em;
}
.sfoot a{margin-left:18px;transition:color .3s}
.sfoot a:hover{color:var(--ac)}
@media(max-width:600px){
  .sfoot{flex-direction:column;text-align:center}
  .sfoot a{margin:0 10px}
}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
@media(max-width:768px){
  .nav-a{display:none}
  .nav-a.always-visible{display:inline}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}
