/* =========================================================
   Asana Still Water — main stylesheet
   Mobile-first. One file, no framework, no jQuery.
   ========================================================= */

:root{
  --paper:#EFEDE5; --paper-2:#E6E4DA; --surface:#F7F6F1;
  --ink:#1E241F; --ink-soft:#41493F; --muted:#7E837A; --line:#D4D1C5;
  --sage:#5E6E55; --sage-soft:#8A977E; --sage-tint:#DCE0D2;
  --clay:#9E6B4A; --marigold:#C18A2B;
  /* always-dark editorial bands (do NOT flip in dark mode) */
  --ground:#1E241F; --on-ground:#EFEDE5; --header-bg:rgba(247,246,241,.9);
  color-scheme:light;
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,"Hoefler Text",Georgia,"Times New Roman",serif;
  --sans:ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  --deva:"Noto Serif Devanagari","Tiro Devanagari Sanskrit","Nirmala UI","Mangal",var(--serif);
  --tamil:"Noto Serif Tamil","Latha","Nirmala UI","Tamil Sangam MN",var(--serif);
  --maxw:1240px; --read:680px; --art-max:1160px;
  --pad:clamp(20px,5vw,56px);
  --sp:clamp(56px,8vw,120px);
}

/* Night mode — calm, green-biased dark for evening reading */
[data-theme="dark"]{
  --paper:#171A15; --paper-2:#1E221C; --surface:#1E221C;
  --ink:#E8E6DD; --ink-soft:#B8BCB0; --muted:#8C9184; --line:#2E342B;
  --sage:#9DAE90; --sage-soft:#869377; --sage-tint:#222A21;
  --clay:#C5885F; --marigold:#D2A24A;
  --ground:#10130F; --on-ground:#EFEDE5; --header-bg:rgba(20,23,18,.9);
  color-scheme:dark;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-size:clamp(1rem,.95rem + .25vw,1.0625rem);
  line-height:1.65;-webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%;display:block;height:auto}
a{color:inherit}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.12;margin:0;text-wrap:balance}
p{margin:0 0 1rem}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:var(--sp)}
.section--rule{border-top:1px solid var(--line)}

/* honeypot (anti-spam) — visually + a11y hidden */
.asana-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

/* cookie consent */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:250;background:var(--ground);color:var(--on-ground);
  padding:1rem clamp(16px,4vw,40px);display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:center;
  box-shadow:0 -10px 30px rgba(16,19,15,.18)}
.cookie-banner[hidden]{display:none}
.cookie-banner p{margin:0;font-size:.85rem;color:#C9CBC0;max-width:60ch}
.cookie-banner a{color:var(--sage-soft)}
.cookie-banner button{background:var(--sage);color:#fff;border:0;padding:.6rem 1.2rem;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;cursor:pointer}

/* accessibility */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:.7rem 1rem;z-index:200}
.skip-link:focus{left:8px;top:8px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}
:focus-visible{outline:2px solid var(--sage);outline-offset:3px}

/* type helpers */
.sa{font-family:var(--deva);line-height:1.5}
.ta{font-family:var(--tamil);line-height:1.5}
.translit{font-style:italic;color:var(--muted)}
.eyebrow{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--sage);margin:0 0 1rem}
.eyebrow--light{color:var(--sage-soft)}
.kicker{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0 0 .9rem;display:flex;align-items:center;gap:.7rem}
.kicker::before{content:"";width:30px;height:1px;background:var(--sage)}
.kicker--light{color:#9AA093}
.kicker--center{justify-content:center}
.kicker--center::before{display:none}

/* buttons & links */
.btn{display:inline-block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  padding:.7rem 1.2rem;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:background .2s,color .2s}
.btn--solid{background:var(--ink);color:var(--paper)}
.btn--solid:hover{background:#2c352c}
.btn--ghost{border-color:var(--ink);color:var(--ink)}
.btn--sage{background:var(--sage);color:#fff}
.readmore{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.4rem;font-size:.74rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--sage);text-decoration:none;font-weight:600}
.readmore::after{content:"→";transition:transform .25s}
.readmore:hover::after{transform:translateX(5px)}
.readmore--light{color:#fff}
.all-link{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);text-decoration:none;font-weight:600;white-space:nowrap}

/* media helpers */
.media-cover{position:relative;overflow:hidden;background:var(--paper-2)}
.media-cover img{width:100%;height:100%;object-fit:cover}
.media-ph{display:block;width:100%;height:100%;background:linear-gradient(135deg,#cfd3c4,#aab09a 45%,#7f8a72)}
.media-ph--warm{background:linear-gradient(135deg,#e4d8c8,#c8a987 55%,#9e6b4a)}
.media-ph--cool{background:linear-gradient(150deg,#d7dcd2,#9aa791 60%,#5e6e55)}
.media-ph--dim{background:linear-gradient(160deg,#3a4338,#222a22)}

/* yogic backdrop */
.asana-mandala{position:absolute;pointer-events:none;z-index:0;inset:auto}
.asana-mandala svg{width:100%;height:100%;overflow:visible}
.asana-mandala :where(path,circle,line,polygon){fill:none;vector-effect:non-scaling-stroke}
@media (prefers-reduced-motion: no-preference){
  .asana-mandala--spin svg{animation:asana-spin 240s linear infinite;transform-origin:center}
}
@keyframes asana-spin{to{transform:rotate(360deg)}}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:var(--header-bg);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-header__inner{max-width:var(--maxw);margin-inline:auto;padding:14px var(--pad);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.wordmark{font-family:var(--serif);font-size:1.35rem;text-decoration:none;letter-spacing:.01em}
.wordmark span{color:var(--sage)}
.wordmark--light{color:var(--on-ground)}
.custom-logo-link{display:inline-block}
.custom-logo{max-height:48px;width:auto}

/* ---------- brand logo lockup ---------- */
.asana-logo{display:inline-flex;align-items:center;gap:.62rem;text-decoration:none;color:var(--ink);line-height:1}
.asana-logo__mark{flex:none;width:40px;height:40px;color:var(--sage);transition:transform .5s cubic-bezier(.22,1,.36,1)}
.asana-logo__mark svg{display:block;width:100%;height:100%;overflow:visible}
.asana-logo__petal{fill:var(--sage);fill-opacity:.14}
.asana-logo:hover .asana-logo__mark{transform:rotate(-4deg) scale(1.04)}
.asana-logo__text{display:flex;flex-direction:column;justify-content:center}
.asana-logo__name{font-family:var(--serif);font-size:1.5rem;line-height:.96;letter-spacing:.005em;color:var(--ink)}
.asana-logo__tag{margin-top:.32rem;font-size:.5rem;letter-spacing:.34em;text-transform:uppercase;font-weight:600;color:var(--muted)}
/* light variant — on dark grounds (footer, mobile panel) */
.asana-logo--light .asana-logo__name{color:var(--on-ground)}
.asana-logo--light .asana-logo__tag{color:var(--sage-soft)}
.asana-logo--light .asana-logo__mark{color:var(--sage-soft)}
/* larger footer lockup */
.asana-logo--footer{gap:.78rem}
.asana-logo--footer .asana-logo__mark{width:50px;height:50px}
.asana-logo--footer .asana-logo__name{font-size:1.85rem}
.asana-logo--footer .asana-logo__tag{font-size:.56rem;letter-spacing:.3em;margin-top:.42rem}
@media (max-width:540px){
  .site-header .asana-logo__mark{width:34px;height:34px}
  .site-header .asana-logo__name{font-size:1.3rem}
  .site-header .asana-logo__tag{font-size:.46rem;letter-spacing:.26em}
}
.site-nav{display:none}
.site-nav ul{list-style:none;margin:0;padding:0}
.site-nav__list{display:flex;gap:1.9rem}
.site-nav__list > li{position:relative}
.site-nav__list > li > a{text-decoration:none;color:var(--ink-soft);white-space:nowrap;
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;padding-block:.4rem;display:inline-block}
.site-nav__list > li > a:hover{color:var(--sage)}
.site-nav__list .current-menu-item > a,.site-nav__list .current-menu-parent > a{color:var(--ink)}
/* top-level items with children get a caret */
.site-nav__list .menu-item-has-children > a::after{content:"";display:inline-block;width:.38em;height:.38em;margin-left:.5em;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:translateY(-2px) rotate(45deg);opacity:.55}
/* dropdown submenus: hidden until hover/focus */
.site-nav .sub-menu{position:absolute;top:100%;left:0;min-width:210px;background:var(--surface);
  border:1px solid var(--line);padding:.5rem 0;display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .18s,transform .18s,visibility .18s;
  box-shadow:0 14px 34px rgba(30,36,31,.10);z-index:120}
.site-nav__list li:hover > .sub-menu,
.site-nav__list li:focus-within > .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.site-nav .sub-menu a{display:block;padding:.5rem 1.1rem;font-size:.8rem;color:var(--ink-soft)}
.site-nav .sub-menu a:hover{color:var(--sage);background:var(--paper)}
.site-header__actions{display:flex;align-items:center;gap:.7rem}
.theme-toggle{display:inline-grid;place-content:center;width:38px;height:38px;background:none;border:0;cursor:pointer;color:var(--ink-soft);border-radius:50%}
.theme-toggle:hover{color:var(--sage)}
.theme-toggle .ic-sun{display:none}
[data-theme="dark"] .theme-toggle .ic-moon{display:none}
[data-theme="dark"] .theme-toggle .ic-sun{display:block}
.icon-btn{display:none;background:none;border:0;font:inherit;font-size:.78rem;letter-spacing:.05em;color:var(--ink-soft);cursor:pointer}
.icon-btn:hover{color:var(--sage)}
.site-header__actions .btn{display:none}
.nav-toggle{width:42px;height:42px;display:grid;place-content:center;gap:5px;background:none;border:0;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);transition:transform .25s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.search-bar{border-top:1px solid var(--line);background:var(--surface)}
.search-bar__inner{max-width:var(--maxw);margin-inline:auto;padding:14px var(--pad)}
.search-bar input[type=search]{width:100%;padding:.8rem 1rem;border:1px solid var(--line);background:var(--paper);font:inherit}

/* mobile slide-in */
.mobile-panel{position:fixed;inset:0;z-index:150;background:var(--ground);color:var(--on-ground);
  padding:96px var(--pad) 40px;display:flex;flex-direction:column;gap:1.4rem;overflow:auto}
.mobile-panel[hidden]{display:none}
.mobile-panel__close{position:absolute;top:16px;right:16px;width:44px;height:44px;background:none;border:0;
  color:var(--on-ground);font-size:2rem;line-height:1;cursor:pointer;display:grid;place-content:center}
.nav-toggle{position:relative;z-index:200}
.mobile-panel ul{list-style:none;margin:0;padding:0}
.mobile-panel__list{display:grid;gap:1rem}
.mobile-panel__list > li > a{font-family:var(--serif);font-size:1.5rem;text-decoration:none;color:var(--on-ground)}
.mobile-panel__list a:hover{color:var(--sage-soft)}
.mobile-panel .sub-menu{margin-top:.6rem;display:grid;gap:.5rem;padding-left:1rem;border-left:1px solid rgba(255,255,255,.18)}
.mobile-panel .sub-menu a{font-family:var(--sans);font-size:.95rem;text-decoration:none;color:#C9CBC0;letter-spacing:.02em}
.mobile-panel .btn{align-self:flex-start}

/* ---------- sections on ink ---------- */
.section--ink{position:relative;overflow:hidden;background:var(--ground);color:var(--on-ground)}
.section--ink h1,.section--ink h2,.section--ink h3{color:var(--on-ground)}
.sec-head__title--light{color:var(--on-ground)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--ground);color:var(--on-ground);padding-block:clamp(48px,9vw,120px)}
.hero__inner{position:relative;z-index:1;display:grid;gap:clamp(24px,4vw,56px)}
.hero__media{order:-1;aspect-ratio:4/5;border-radius:2px}
.hero__media .media-ph{aspect-ratio:4/5}
/* text-only banner (no clean image set): single column, given presence */
.hero__slide--text .hero__inner{grid-template-columns:1fr;min-height:clamp(240px,32vh,380px);align-content:center}
.hero__slide--text .hero__text{max-width:62ch}
.hero__title{font-size:clamp(2.2rem,1.4rem + 3.6vw,4.4rem);letter-spacing:-.02em}
.hero__title a{text-decoration:none;color:var(--on-ground)}
.hero__lede{font-size:clamp(1.1rem,1rem + .5vw,1.35rem);color:#C9CBC0;line-height:1.5;margin-top:1.2rem;max-width:48ch}
.hero__by{margin-top:1.4rem;font-size:.82rem;letter-spacing:.04em;color:#9AA093}
.hero__by b{color:var(--sage-soft);font-weight:600}
/* rotating feature banner */
.hero__slides{display:grid}
.hero__slide{grid-area:1/1;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .9s ease,visibility 0s linear .9s}
.hero__slide.is-active{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .9s ease}
.hero__controls{position:relative;z-index:2;display:flex;align-items:center;gap:1rem;margin-top:clamp(22px,3.5vw,40px)}
.hero__dots{flex:1;display:flex;justify-content:center;gap:.55rem;flex-wrap:wrap}
.hero__dot{width:9px;height:9px;padding:0;border:0;border-radius:50%;cursor:pointer;background:rgba(239,237,229,.28);transition:background .3s,transform .3s}
.hero__dot:hover{background:rgba(239,237,229,.6)}
.hero__dot.is-active{background:var(--sage-soft);transform:scale(1.3)}
.hero__nav{width:42px;height:42px;flex:none;border-radius:50%;border:1px solid rgba(239,237,229,.22);background:transparent;color:var(--on-ground);font-size:1.6rem;line-height:1;cursor:pointer;display:grid;place-content:center;transition:background .3s,border-color .3s}
.hero__nav:hover{background:rgba(239,237,229,.1);border-color:rgba(239,237,229,.5)}
@media (prefers-reduced-motion:reduce){.hero__slide{transition:opacity .25s ease}}

/* ---------- feature / lineage ---------- */
.feature__inner{display:grid;gap:clamp(24px,4vw,56px);align-items:center}
.feature__media{aspect-ratio:16/11}
.feature__media--portrait{aspect-ratio:4/5}
.feature__title{font-size:clamp(1.7rem,1.3rem + 1.8vw,2.8rem);letter-spacing:-.01em;margin:.4rem 0 1rem}
.feature__title a{text-decoration:none}
.feature__title a:hover{color:var(--sage)}
.lineage__deva{font-size:1.5rem;color:var(--sage);margin:0 0 .2rem}
.lineage__translit{margin:0 0 1.1rem}

/* ---------- section head ---------- */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:2.2rem;flex-wrap:wrap}
.sec-head__title{font-size:clamp(1.6rem,1.2rem + 1.5vw,2.4rem)}

/* ---------- grid + cards ---------- */
.grid{display:grid;gap:clamp(24px,3vw,40px)}
.grid > *{min-width:0}
.grid--3{grid-template-columns:1fr}
.card{display:flex;flex-direction:column}
.card__link{text-decoration:none;color:inherit}
.card__thumb{aspect-ratio:3/2;margin-bottom:1rem}
.card__cat{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);font-weight:600}
.card__title{font-size:1.3rem;margin:.5rem 0;line-height:1.2}
.card__link:hover .card__title{color:var(--sage)}
.card__excerpt{color:var(--ink-soft);font-size:.92rem;line-height:1.55;margin:0}
.card__meta{margin-top:.8rem;font-size:.74rem;letter-spacing:.04em;color:var(--muted)}

/* ---------- topics ---------- */
.topics .wrap{position:relative;z-index:1}
.topic-grid{display:grid;grid-template-columns:1fr;gap:1px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12)}
.topic{background:var(--ground);padding:28px 24px;min-height:150px;display:flex;flex-direction:column;justify-content:space-between;gap:1rem;text-decoration:none;color:var(--paper);transition:background .3s}
.topic:hover{background:#262e25}
.topic__scripts{display:flex;gap:.7rem;flex-wrap:wrap;align-items:baseline}
.topic__sa{font-size:1.1rem;color:#B9C3AC}
.topic__title{font-size:1.45rem;color:var(--on-ground)}
.topic__count{font-size:.78rem;color:#9AA093;letter-spacing:.03em}

/* ---------- spotlight ---------- */
.spotlight{position:relative;overflow:hidden;color:var(--on-ground)}
.spotlight__bg{position:absolute;inset:0}
.spotlight__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,24,20,.85),rgba(20,24,20,.35))}
.spotlight__inner{position:relative;z-index:1;padding-block:clamp(64px,12vw,150px)}
.spotlight__col{max-width:560px}
.spotlight__title{font-size:clamp(1.9rem,1.4rem + 2.6vw,3.4rem);letter-spacing:-.01em;color:var(--on-ground)}
.spotlight__title a{text-decoration:none;color:var(--on-ground)}
.spotlight__col p{color:#D6D8CE;font-size:1.05rem;margin-top:.8rem}

/* ---------- contributors ---------- */
.contribs{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,36px)}
.contrib__av{display:block;width:84px;aspect-ratio:1;border-radius:50%;overflow:hidden;margin-bottom:.9rem}
.contrib__av img{width:100%;height:100%;object-fit:cover}
.contrib__name{font-size:1.05rem}
.contrib__name a{text-decoration:none}
.contrib__name a:hover{color:var(--sage)}
.contrib__bio{font-size:.85rem;color:var(--ink-soft);margin:.5rem 0 0}

/* ---------- newsletter ---------- */
.newsletter{position:relative;overflow:hidden;background:var(--sage-tint)}
.newsletter__inner{position:relative;z-index:1;display:grid;gap:clamp(20px,3vw,48px);align-items:center}
.newsletter__title{font-size:clamp(1.7rem,1.3rem + 1.8vw,2.8rem);max-width:18ch}
.newsletter__body{color:var(--ink-soft);margin-top:.8rem;max-width:42ch}
.newsletter__form{display:flex;flex-direction:column;gap:10px}
.newsletter__form input{flex:1;padding:.85rem 1rem;border:1px solid var(--sage-soft);background:var(--surface);font:inherit;color:var(--ink)}
.newsletter__note{display:block;margin-top:1rem;color:var(--muted);font-size:.76rem}

/* ---------- footer ---------- */
.site-footer{background:var(--ground);color:#C9CBC0;padding:clamp(48px,7vw,84px) var(--pad) 32px}
.site-footer__inner{max-width:var(--maxw);margin-inline:auto;display:grid;gap:clamp(28px,4vw,48px);grid-template-columns:1fr}
.site-footer__brand p{font-size:.86rem;max-width:36ch;line-height:1.6;margin-top:1rem}
.social-links{display:flex;gap:.6rem;list-style:none;margin:1.4rem 0 0;padding:0}
.social-links a{display:grid;place-content:center;width:38px;height:38px;border:1px solid rgba(239,237,229,.22);border-radius:50%;color:var(--on-ground);transition:background .2s,border-color .2s,color .2s}
.social-links a:hover{background:var(--sage);border-color:var(--sage);color:#fff}
.social-links svg{width:17px;height:17px;display:block}
.site-footer__heading{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#828A7C;font-weight:600;margin:0 0 1rem}
.site-footer__list{list-style:none;margin:0;padding:0;display:grid;gap:.6rem;font-size:.88rem}
.site-footer__list a{color:#C9CBC0;text-decoration:none}
.site-footer__list a:hover{color:var(--paper)}
.site-footer__base{max-width:var(--maxw);margin:clamp(32px,5vw,56px) auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.8rem;font-size:.76rem;color:#828A7C}

/* ---------- archive / pagination ---------- */
.archive-head{margin-bottom:2.6rem;max-width:46rem}
.archive-head__title{font-size:clamp(1.8rem,1.3rem + 2vw,3rem)}
.archive-head__desc{margin-top:1rem;color:var(--ink-soft);max-width:60ch}
.archive-head__desc p{margin:0}
.pagination{margin-top:clamp(2.6rem,5vw,4rem)}
.pagination .nav-links{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}
.pagination .page-numbers{display:inline-grid;place-content:center;min-width:44px;height:44px;padding:0 .8rem;text-decoration:none;border:1px solid var(--line);font-size:.85rem;letter-spacing:.02em;color:var(--ink-soft);transition:background .2s,color .2s,border-color .2s}
.pagination a.page-numbers:hover{border-color:var(--sage);color:var(--sage)}
.pagination .current{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.pagination .dots{border-color:transparent;min-width:0;padding:0 .2rem}
.pagination .prev,.pagination .next{letter-spacing:.1em;text-transform:uppercase;font-size:.72rem;font-weight:600}

/* =========================================================
   Article / single post — the reading experience
   ========================================================= */
.reading-progress{position:sticky;top:0;left:0;height:3px;z-index:120;background:transparent}
.reading-progress span{display:block;height:100%;width:0;background:var(--sage)}

/* Composition tokens for the article */
.article{--art-max:1160px;--rail:190px;--railgap:clamp(28px,4vw,60px)}
.article__head,.article__hero,.article__layout,.article-comments-wrap{
  width:min(var(--art-max),calc(100% - 2 * var(--pad)));margin-inline:auto}

.article__head{padding:clamp(28px,4.5vw,56px) 0 0}
.article__head-inner{max-width:42rem;text-align:left}
.article__cat{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--clay);font-weight:600;margin:0 0 1.2rem}
.article__cat a{text-decoration:none;color:inherit}
.article__cat .sa{color:var(--sage);letter-spacing:0}
.article__title{font-size:clamp(2.2rem,1.5rem + 3.4vw,4rem);letter-spacing:-.02em;margin:0 0 1.1rem;max-width:16ch}
.article__dek{font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,1.05rem + .6vw,1.5rem);
  color:var(--ink-soft);line-height:1.45;max-width:46ch;margin:0}
/* compact byline shown on mobile (desktop uses the rail) */
.article__meta-mobile{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin-top:1.6rem;font-size:.82rem;color:var(--muted)}
.article__meta-mobile a{color:var(--ink-soft);text-decoration:none}
.article__meta-mobile b{color:var(--ink)}

.article__hero{margin-block:clamp(32px,4.5vw,52px) 0}
.article__hero[hidden]{display:none}
.article__hero-img{display:block;aspect-ratio:16/9}
.article__hero-cap{font-size:.78rem;color:var(--muted);padding-top:.7rem;text-align:left;max-width:46rem}

/* The two-track reading grid */
.article__layout{margin-top:clamp(32px,4.5vw,52px);display:grid;gap:var(--railgap);grid-template-columns:1fr}
.article__main{min-width:0}

/* Sticky metadata / share rail */
.article__rail{display:none}
.rail__sticky{position:sticky;top:96px;display:flex;flex-direction:column;gap:1.1rem}
.rail__label{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0}
.rail__author{display:flex;flex-direction:column;gap:.5rem;text-decoration:none;color:var(--ink)}
.rail__author-av{width:56px;height:56px;border-radius:50%}
.rail__author-name{font-family:var(--serif);font-size:1.1rem;line-height:1.2}
.rail__author:hover .rail__author-name{color:var(--sage)}
.rail__meta{font-size:.78rem;color:var(--muted);line-height:1.6;margin:0}
.rail__updated{color:var(--sage);font-weight:600}
.rail__reviewed{margin:0;display:flex;flex-direction:column;gap:.15rem}
.rail__reviewed-badge{font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--clay);font-weight:700}
.rail__reviewed-name{font-size:.84rem;color:var(--ink-soft)}
/* Table of contents */
.rail__toc{border-top:1px solid var(--line);padding-top:1rem}
.rail__toc-label{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0 0 .7rem}
.rail__toc-list{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.rail__toc-list a{display:block;font-size:.82rem;line-height:1.35;color:var(--ink-soft);text-decoration:none;
  padding-left:.8rem;border-left:2px solid transparent;transition:color .2s,border-color .2s}
.rail__toc-list a:hover{color:var(--sage)}
.rail__toc-list .is-current a{color:var(--ink);border-left-color:var(--sage);font-weight:600}
.rail__toc-list .toc-h3 a{padding-left:1.5rem;font-size:.78rem;color:var(--muted)}

/* Health disclaimer */
.health-note{max-width:42rem;margin-top:2.4rem;padding:1.1rem 1.3rem;background:var(--sage-tint);
  border-left:2px solid var(--sage-soft);font-size:.86rem;line-height:1.6;color:var(--ink-soft)}

/* Contribute CTA (replaces newsletter) */
.newsletter__action--cta{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}

/* Search + 404 + topic links */
.topic-hero__search{margin-top:1.4rem;max-width:30rem}
.topic-hero__search input[type=search]{width:100%;padding:.8rem 1rem;border:1px solid var(--line);background:var(--surface);font:inherit;color:var(--ink)}
.error404{padding-block:clamp(56px,9vw,120px)}
.error404__inner{max-width:42rem}
.error404__title{font-size:clamp(2rem,1.4rem + 3vw,3.4rem);letter-spacing:-.02em;margin:.6rem 0 1rem;max-width:16ch}
.error404__lede{color:var(--ink-soft);font-size:1.1rem;max-width:46ch}
.error404__search{margin:1.8rem 0;max-width:30rem}
.error404__search input[type=search]{width:100%;padding:.8rem 1rem;border:1px solid var(--line);background:var(--surface);font:inherit;color:var(--ink)}
.error404__actions{margin-bottom:2.4rem}
.topic-links{margin-top:2.4rem;border-top:1px solid var(--line);padding-top:1.6rem}
.topic-links__list{list-style:none;margin:1rem 0 0;padding:0;display:flex;flex-wrap:wrap;gap:.7rem}
.topic-links__list a{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--line);
  padding:.5rem .9rem;text-decoration:none;color:var(--ink-soft);font-size:.85rem;background:var(--surface)}
.topic-links__list a:hover{color:var(--sage);border-color:var(--sage)}
.topic-links__list span{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.78rem}

/* Generic page (About, Privacy, etc.) */
.page-doc__head{width:min(var(--art-max),calc(100% - 2 * var(--pad)));margin-inline:auto;padding:clamp(40px,6vw,80px) 0 clamp(20px,3vw,30px)}
.page-doc__title{font-size:clamp(2.2rem,1.5rem + 3vw,3.6rem);letter-spacing:-.02em;max-width:18ch}
.page-doc__dek{font-family:var(--serif);font-style:italic;color:var(--ink-soft);font-size:clamp(1.15rem,1.05rem + .5vw,1.4rem);max-width:46ch;margin:1rem 0 0}
.page-doc__hero{width:min(var(--art-max),calc(100% - 2 * var(--pad)));margin:clamp(24px,3vw,40px) auto 0;text-align:center}
.page-doc__hero img{display:block;width:auto;max-width:100%;height:auto;max-height:560px;margin-inline:auto}
.page-doc__body.article-body{max-width:42rem;margin:clamp(28px,4vw,48px) auto 0;padding-inline:var(--pad)}
/* no drop cap on document pages */
.page-doc .article-body > p:first-of-type::first-letter{font-family:inherit;font-size:inherit;float:none;padding:0;color:inherit;line-height:inherit}

/* Listen / audio narration */
.listen{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap;margin:0 0 clamp(28px,4vw,40px);
  max-width:42rem;padding-bottom:clamp(20px,3vw,28px);border-bottom:1px solid var(--line)}
.listen__heading{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0;width:100%}
.listen__native{width:100%;height:40px}
.listen__btn{display:inline-flex;align-items:center;gap:.7rem;background:none;border:0;cursor:pointer;font-family:inherit;color:var(--ink);padding:0}
.listen__icon{flex:0 0 auto;width:38px;height:38px;border-radius:50%;background:var(--sage);position:relative;transition:background .2s}
.listen__icon::before{content:"";position:absolute;top:50%;left:54%;transform:translate(-50%,-50%);
  border-style:solid;border-width:7px 0 7px 11px;border-color:transparent transparent transparent #fff}
.listen[data-state="playing"] .listen__icon::before{border:0;width:10px;height:11px;left:50%;
  border-left:3px solid #fff;border-right:3px solid #fff;box-sizing:border-box}
.listen__btn:hover .listen__icon{background:#4f5d47}
.listen__text{font-size:.9rem;letter-spacing:.02em;font-weight:600}
.listen__time{font-size:.8rem;color:var(--muted)}
.listen__rate{background:none;border:1px solid var(--line);border-radius:999px;padding:.3rem .7rem;
  font:inherit;font-size:.74rem;color:var(--ink-soft);cursor:pointer;letter-spacing:.04em}
.listen__rate:hover{border-color:var(--sage);color:var(--sage)}

/* In brief */
.in-brief{margin:0 0 clamp(28px,4vw,44px);background:var(--sage-tint);border-left:2px solid var(--sage);padding:1.5rem 1.7rem}
.in-brief__label{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage);font-weight:600;margin:0 0 .7rem}
.in-brief__list{margin:0;padding-left:1.1rem;display:grid;gap:.5rem;color:var(--ink-soft)}
.in-brief__list li{line-height:1.5}

/* Article body — the reading column */
.article-body{max-width:42rem;font-size:clamp(1.075rem,1rem + .35vw,1.18rem);line-height:1.75}
.article-body > p,.article-body > ul,.article-body > ol,.article-body > h2,.article-body > h3,
.article-body > blockquote,.article-body > figure,.article-body > .wp-block-image{margin:0 0 1.5rem}
.article-body > p:first-of-type::first-letter{font-family:var(--serif);font-size:3.4em;line-height:.78;float:left;padding:.05em .12em 0 0;color:var(--sage)}
.article-body h2{font-size:clamp(1.5rem,1.2rem + 1vw,2rem);margin-top:2.6rem}
.article-body h3{font-size:1.3rem;margin-top:2rem}
.article-body h4{font-family:var(--serif);font-size:1.12rem;font-weight:600;margin:1.9rem 0 .7rem}
.article-body h5{font-family:var(--serif);font-size:1rem;font-weight:600;margin:1.7rem 0 .6rem}
.article-body h6{font-size:.78rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin:1.7rem 0 .6rem}
.article-body :is(h2,h3,h4,h5,h6) span{color:inherit;background:none}
/* legacy imported-article classes: section headings (.h50) and lead/standfirst (.spec) */
.article-body p.h50{font-family:var(--serif);font-size:1.3rem;line-height:1.32;font-weight:600;color:var(--ink);margin:2.4rem 0 .9rem}
.article-body p.spec{font-size:1.2rem;line-height:1.62;color:var(--ink-soft);margin:0 0 1.7rem;padding-left:1.1rem;border-left:3px solid var(--sage)}
.article-body > p.spec:first-of-type::first-letter{font-family:inherit;font-size:inherit;float:none;padding:0;color:inherit;line-height:inherit}
.article-body a{color:var(--sage);text-underline-offset:3px}
.article-body ul,.article-body ol{padding-left:1.3rem}
.article-body li{margin-bottom:.5rem}
.article-body img{height:auto}
.article-body figure{margin-inline:0}
.article-body figcaption,.wp-element-caption{font-size:.82rem;color:var(--muted);margin-top:.6rem;text-align:left}
.article-body .alignwide,.article-body .alignfull{width:100%}
.article-body mark,.article-body .su-highlight{background:var(--sage-tint);color:inherit;padding:.05em .25em}
.article-body .su-note{background:var(--sage-tint);border-left:2px solid var(--sage);padding:1rem 1.2rem;margin:1.5rem 0}
.article-body table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.95rem}
.article-body th,.article-body td{border:1px solid var(--line);padding:.6rem .8rem;text-align:left}
.article-body img{border-radius:0}

/* Pull quotes — refined, hairline-bounded, sage */
.article-body blockquote,.article-body .wp-block-quote{margin:2.4rem 0;padding:0 0 0 1.4rem;border-left:2px solid var(--sage);
  font-family:var(--serif);font-size:1.25rem;line-height:1.45;color:var(--ink-soft);font-style:italic;max-width:30rem}
.article-body blockquote cite{display:block;margin-top:.8rem;font-size:.82rem;font-style:normal;color:var(--muted);letter-spacing:.04em}
.article-body .wp-block-pullquote{border:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:1.8rem 0;margin:2.6rem 0;text-align:left}
.article-body .wp-block-pullquote p{font-family:var(--serif);font-size:clamp(1.5rem,1.2rem + 1.4vw,2.2rem);
  line-height:1.28;color:var(--sage);margin:0;font-style:normal;max-width:22ch}
.article-body .wp-block-pullquote cite{color:var(--muted);font-size:.82rem;letter-spacing:.06em}

/* Article footer */
.article__footer{margin-top:clamp(40px,5vw,56px)}
.share{display:flex;align-items:center;gap:.4rem 1rem;flex-wrap:wrap}
.share--inline{padding-top:1.4rem;border-top:1px solid var(--line)}
.share--rail{flex-direction:column;align-items:flex-start;gap:.55rem;border-top:1px solid var(--line);padding-top:1rem}
.share__label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.share--rail .share__label{margin-bottom:.15rem}
.share__link,.share__native{font-size:.8rem;color:var(--ink-soft);text-decoration:none;background:none;border:0;cursor:pointer;font-family:inherit;padding:0}
.share__link:hover,.share__native:hover{color:var(--sage)}
.article__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.6rem}
.tag-pill{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
  border:1px solid var(--line);padding:.4rem .8rem;text-decoration:none;background:var(--surface)}
.tag-pill:hover{color:var(--sage);border-color:var(--sage)}

/* Author trust box */
.author-bio{display:flex;gap:1.4rem;align-items:flex-start;margin-top:2.6rem;padding-top:2rem;border-top:1px solid var(--line);max-width:42rem}
.author-bio__av{flex:0 0 auto;width:84px;height:84px;border-radius:50%;overflow:hidden}
.author-bio__av img{width:100%;height:100%;object-fit:cover}
.author-bio__eyebrow{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 .3rem;font-weight:600}
.author-bio__name{font-size:1.3rem;margin:0 0 .5rem}
.author-bio__name a{text-decoration:none}
.author-bio__name a:hover{color:var(--sage)}
.author-bio__desc{font-size:.92rem;color:var(--ink-soft);margin:0 0 .7rem}
.author-bio__more{font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sage);text-decoration:none;font-weight:600}

/* Comments — quiet, aligned under the reading column */
.article-comments-wrap{margin-block:clamp(40px,6vw,72px)}
.article-comments{max-width:42rem}
.article-comments .comment-list{list-style:none;padding:0;margin:0;display:grid;gap:1.6rem}
.article-comments .comment-body{border-top:1px solid var(--line);padding-top:1.2rem}
.article-comments .comment-author{font-weight:600}
.article-comments .comment-form input[type=text],.article-comments .comment-form input[type=email],
.article-comments .comment-form input[type=url],.article-comments .comment-form textarea{
  width:100%;padding:.7rem .9rem;border:1px solid var(--line);background:var(--surface);font:inherit;margin-bottom:1rem}

/* =========================================================
   WISDOM — Masters' Quotes (reusable; used later on home/issue/article)
   ========================================================= */
.masters-quote{margin:0;max-width:var(--read);margin-inline:auto}
.masters-quote__body{margin:0;border:0}
.masters-quote__deva{font-size:1.6rem;color:var(--sage);margin:0 0 .3rem;line-height:1.4}
.masters-quote__translit{margin:0 0 1rem}
.masters-quote__text{font-family:var(--serif);font-size:clamp(1.4rem,1.1rem + 1.2vw,2rem);line-height:1.35;color:var(--ink);margin:0}
.masters-quote__cite{margin-top:1.2rem;font-size:.82rem;letter-spacing:.04em;color:var(--muted);display:flex;gap:.6rem;flex-wrap:wrap}
.masters-quote__author{color:var(--clay);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.74rem}
.masters-quote__source{font-style:italic}
/* feature variant — for a full-bleed wisdom interlude on dark grounds */
.masters-quote--feature{text-align:center;max-width:760px}
.masters-quote--feature .masters-quote__cite{justify-content:center}
.masters-quote--feature .masters-quote__text{font-size:clamp(1.6rem,1.2rem + 1.6vw,2.6rem)}
.section--ink .masters-quote__text{color:var(--on-ground)}
.section--ink .masters-quote__deva{color:var(--sage-soft)}
/* inline variant — within an article body */
.masters-quote--inline{margin-block:2.4rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding-block:1.8rem}

/* =========================================================
   Archive / category — curated editorial
   ========================================================= */
.topic-hero{padding:clamp(48px,7vw,96px) 0 clamp(28px,4vw,44px);border-bottom:1px solid var(--line)}
.topic-hero__inner{max-width:var(--maxw)}
.topic-hero__title{font-size:clamp(2.2rem,1.5rem + 3.4vw,4rem);letter-spacing:-.02em;margin:0;max-width:20ch;display:flex;align-items:baseline;gap:.5em;flex-wrap:wrap}
.topic-hero__sa{font-size:.5em;color:var(--sage);font-weight:400}
.topic-hero__translit{margin-top:.7rem;color:var(--muted);font-style:italic}
.topic-hero__desc{margin-top:1.2rem;color:var(--ink-soft);max-width:62ch;font-size:1.075rem}
.topic-hero__desc p{margin:0}

.topic-lead{padding-block:clamp(40px,5vw,72px)}
.topic-lead__inner{display:grid;gap:clamp(24px,4vw,56px);align-items:center}
.topic-lead__media{display:block;aspect-ratio:3/2;order:-1}
.topic-lead__title{font-size:clamp(1.8rem,1.3rem + 2.4vw,3rem);letter-spacing:-.015em;margin:.4rem 0 1rem}
.topic-lead__title a{text-decoration:none}
.topic-lead__title a:hover{color:var(--sage)}
.topic-lead__excerpt{color:var(--ink-soft);max-width:52ch}
.topic-lead__meta{font-size:.78rem;letter-spacing:.04em;color:var(--muted);margin-top:1rem}
.topic-grid-posts{align-items:start}

/* =========================================================
   Image robustness — never show a broken-image glyph
   ========================================================= */
.media-cover img{transition:opacity .4s ease}
.media-cover img[data-broken]{opacity:0}
.media-cover.is-broken{background:linear-gradient(150deg,#d7dcd2,#9aa791 60%,#5e6e55)}

/* =========================================================
   Contribute / packages page
   ========================================================= */
.contribute__hero{position:relative;overflow:hidden;padding-block:clamp(56px,9vw,120px)}
.contribute__hero-inner{position:relative;z-index:1;max-width:48rem}
.contribute__title{font-size:clamp(2.2rem,1.5rem + 3.4vw,4rem);letter-spacing:-.02em;margin:.4rem 0 1.2rem}
.contribute__lede{color:#C9CBC0;font-size:clamp(1.1rem,1rem + .5vw,1.35rem);line-height:1.5;max-width:46ch}
.contribute__hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}
.btn--ghost-light{border-color:#C9CBC0;color:var(--on-ground)}
.trust-band__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem 2rem}
.trust-band__n{display:block;font-family:var(--serif);font-size:clamp(1.6rem,1.2rem + 1.2vw,2.2rem);line-height:1}
.trust-band__l{display:block;font-size:.72rem;letter-spacing:.06em;color:var(--muted);margin-top:.4rem;text-transform:uppercase}
.why__n{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);font-weight:600}
.why__t{font-size:1.3rem;margin:.6rem 0 .5rem}
.why p{color:var(--ink-soft);font-size:.95rem;margin:0}
.pkg-section{background:var(--sage-tint)}
.pkg-grid{display:grid;grid-template-columns:1fr;gap:20px}
.pkg{background:var(--surface);border:1px solid var(--line);padding:30px;display:flex;flex-direction:column;position:relative}
.pkg--featured{background:var(--ground);color:#C9CBC0;border-color:var(--ground)}
.pkg--featured .pkg__name{color:var(--on-ground)}
.pkg__tag{position:absolute;top:-1px;right:-1px;background:var(--sage);color:#fff;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;padding:.35rem .7rem;font-weight:700}
.pkg__name{font-size:1.4rem}
.pkg__for{color:var(--muted);font-size:.86rem;margin:.3rem 0 1rem}
.pkg--featured .pkg__for{color:#9AA093}
.pkg__price{font-family:var(--serif);font-size:2.2rem;margin:0 0 1rem}
.pkg__price span{font-family:var(--sans);font-size:.85rem;color:var(--muted)}
.pkg--featured .pkg__price span{color:#9AA093}
.pkg__list{list-style:none;margin:0 0 1.4rem;padding:1rem 0 0;border-top:1px solid var(--line);display:grid;gap:.55rem;font-size:.92rem;color:var(--ink-soft)}
.pkg--featured .pkg__list{border-color:rgba(255,255,255,.14);color:#C9CBC0}
.pkg__list li::before{content:"✦ ";color:var(--sage)}
.pkg .btn{margin-top:auto;text-align:center}
.pkg-note{margin-top:1.6rem;font-size:.84rem;color:var(--muted);font-style:italic;max-width:70ch}
/* submission CTA + guidelines — page's own UI font (no article drop-cap/reading style) */
.contribute__submit{max-width:46rem}
.contribute__submit > p{color:var(--ink-soft);line-height:1.7;margin:0}
.contribute__submit-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.3rem}
.contribute__doc{max-width:46rem;margin-top:2.4rem;padding-top:2rem;border-top:1px solid var(--line);color:var(--ink-soft);line-height:1.7}
.contribute__doc p{margin:0 0 1rem}
.contribute__doc ul,.contribute__doc ol{padding-left:1.2rem;margin:0 0 1.2rem}
.contribute__doc li{margin-bottom:.4rem}
.contribute__doc strong{color:var(--ink)}
.contribute__doc a{color:var(--sage)}
.twocol-doc{display:grid;gap:clamp(28px,4vw,56px)}
.doc-list{margin:1rem 0 0;padding-left:1.2rem;color:var(--ink-soft);line-height:1.8}
.doc-list--num{list-style:decimal}

/* =========================================================
   Contributor pages
   ========================================================= */
.contributor__head{display:grid;gap:clamp(20px,3vw,40px);padding-block:clamp(40px,6vw,80px) clamp(20px,3vw,32px)}
.contributor__photo{width:160px;aspect-ratio:1;border-radius:50%;overflow:hidden}
.contributor__name{font-size:clamp(2rem,1.4rem + 2.6vw,3.2rem);letter-spacing:-.02em;margin:.3rem 0 .5rem}
.contributor__role{color:var(--clay);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;margin:0}
.contributor__creds{color:var(--muted);margin:.5rem 0 0}
.contributor__bio{max-width:42rem;margin-block:clamp(20px,3vw,32px)}
.contribs--archive{grid-template-columns:1fr 1fr}
.contrib__role{color:var(--clay);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;margin:.25rem 0 0}

/* Author profile hero */
.author-hero{display:grid;gap:clamp(20px,3vw,40px);align-items:center}
.author-hero__av{width:128px;height:128px;border-radius:50%;overflow:hidden}
.author-hero__role{color:var(--clay);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;margin:.4rem 0 0}
.author-hero__bio{color:var(--ink-soft);max-width:60ch;margin:1rem 0 .6rem}
.author-hero__creds{color:var(--muted);font-size:.9rem;margin:0 0 .6rem}
.author-hero__count{color:var(--muted);font-size:.82rem;letter-spacing:.04em;margin:0}

/* =========================================================
   Magazine issues + viewer
   ========================================================= */
.issue__head{padding-block:clamp(40px,6vw,80px) 0}
.issue__head-inner{display:grid;gap:clamp(24px,4vw,56px);align-items:start}
.issue__cover{aspect-ratio:3/4;max-width:360px}
.issue__title{font-size:clamp(2rem,1.4rem + 3vw,3.6rem);letter-spacing:-.02em;margin:.4rem 0 .6rem}
.issue__date{color:var(--muted);margin:0 0 1.2rem}
.issue__intro{max-width:42rem;padding:0}
.mag-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2vw,28px)}
.mag-page{padding:0;border:1px solid var(--line);background:var(--surface);cursor:zoom-in;display:block}
.mag-page img{width:100%;height:auto;display:block} /* magazine pages shown uncropped */
.mag-page:hover{border-color:var(--sage)}

.issue-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,40px)}
.issue-card{text-decoration:none;color:inherit}
.issue-card__cover{aspect-ratio:3/4;margin-bottom:.9rem}
.issue-card__no{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--clay);font-weight:600}
.issue-card__title{font-size:1.2rem;margin:.3rem 0 0}
.issue-card:hover .issue-card__title{color:var(--sage)}

/* Lightbox / magazine viewer */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(16,19,15,.95);display:flex;align-items:center;justify-content:center;padding:clamp(12px,4vw,48px)}
.lightbox[hidden]{display:none}
.lightbox__stage{margin:0;max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center;overflow:auto}
.lightbox__img{max-width:100%;max-height:88vh;object-fit:contain;cursor:zoom-in;background:#fff}
.lightbox__img.is-zoomed{max-width:none;max-height:none;width:auto;cursor:zoom-out}
.lightbox__btn{position:absolute;background:rgba(239,237,229,.12);color:#fff;border:0;cursor:pointer;
  width:48px;height:48px;font-size:1.6rem;line-height:1;display:grid;place-content:center;border-radius:50%}
.lightbox__btn:hover{background:rgba(239,237,229,.24)}
.lightbox__close{top:18px;right:18px}
.lightbox__prev{left:14px;top:50%;transform:translateY(-50%)}
.lightbox__next{right:14px;top:50%;transform:translateY(-50%)}

/* =========================================================
   Membership / account dashboard
   ========================================================= */
.account{padding-block:clamp(40px,6vw,80px)}
.account__head{margin-bottom:2rem}
.account__title{font-size:clamp(2rem,1.4rem + 2.6vw,3.2rem);letter-spacing:-.02em}
.account__auth{display:grid;gap:clamp(20px,3vw,40px);max-width:880px}
.account__card{background:var(--surface);border:1px solid var(--line);padding:clamp(22px,3vw,32px)}
.account__card-title{font-family:var(--serif);font-size:1.4rem;margin:0 0 1rem}
.account__small{font-size:.85rem;color:var(--muted)}
.account__alert{padding:.9rem 1.1rem;margin:0 0 1.4rem;border-left:2px solid var(--sage);background:var(--sage-tint);font-size:.92rem}
.account__alert--error{border-left-color:var(--clay)}
.account__form{display:grid;gap:1rem;max-width:34rem}
.account__form--wide{max-width:48rem}
.account__form label{display:grid;gap:.4rem;font-size:.85rem;color:var(--ink-soft)}
.account__form input,.account__form textarea,.account__form select{border:1px solid var(--line);background:var(--surface);padding:.75rem .9rem;font:inherit;color:var(--ink);width:100%;box-sizing:border-box}
.account__form input:focus,.account__form textarea:focus,.account__form select:focus{border-color:var(--sage);outline:none}
/* WordPress login form — match the register card */
.account__card #loginform p{margin:0 0 1.1rem}
.account__card #loginform label[for=user_login],.account__card #loginform label[for=user_pass]{display:block;font-size:.85rem;color:var(--ink-soft);margin-bottom:.4rem}
.account__card #loginform input[type=text],.account__card #loginform input[type=password]{width:100%;box-sizing:border-box;border:1px solid var(--line);background:var(--surface);padding:.75rem .9rem;font:inherit;color:var(--ink)}
.account__card #loginform input:focus{border-color:var(--sage);outline:none}
.account__card #loginform .login-remember label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--ink-soft)}
.account__card #loginform .login-remember input{width:auto;margin:0}
.account__card #loginform .login-submit input,.account__card #loginform .button{display:inline-block;background:var(--ink);color:var(--paper);border:0;border-radius:0;padding:.85rem 1.7rem;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;cursor:pointer;width:auto}
.account__card #loginform .login-submit input:hover{background:#2c352c}
/* profile photo + article image uploads */
.profile-photo{display:flex;align-items:center;gap:1.1rem;margin:.2rem 0 .4rem}
.profile-photo__img{width:72px;height:72px;border-radius:50%;object-fit:cover;flex:none}
.profile-photo__field{display:grid;gap:.35rem;flex:1}
.img-uploads{border:1px dashed var(--line);padding:1rem 1.1rem;margin:.2rem 0;display:grid;gap:.7rem}
.img-uploads legend{font-size:.9rem;color:var(--ink);font-weight:600;padding:0 .4rem;font-family:var(--serif)}
.img-upload-row{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}
.img-upload-row input[type=file]{flex:1 1 58%;font-size:.85rem;min-width:0}
.img-upload-row input[type=text]{flex:1 1 32%;min-width:0}
.account__tabs{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;border-bottom:1px solid var(--line);padding-bottom:1rem;margin-bottom:1.8rem;font-size:.8rem;letter-spacing:.04em}
.account__tab{text-decoration:none;color:var(--ink-soft)}
.account__tab:hover{color:var(--sage)}
.account__tab.is-active{color:var(--ink);font-weight:600;border-bottom:2px solid var(--sage);padding-bottom:calc(1rem - 2px);margin-bottom:-1rem}
.account__tab--out{margin-left:auto;color:var(--muted)}
.account__h2{font-family:var(--serif);font-size:1.6rem;margin:0 0 1rem}
.account__hint{color:var(--ink-soft);max-width:60ch}
/* credits */
.credits{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:1.4rem}
.credit-stat{background:var(--surface);padding:1.4rem 1.2rem;text-align:center}
.credit-stat__n{display:block;font-family:var(--serif);font-size:2.4rem;line-height:1;color:var(--sage)}
.credit-stat__l{display:block;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:.5rem}
/* submissions */
.sub-list{list-style:none;margin:0;padding:0;display:grid;gap:.2rem}
.sub-list__item{display:grid;grid-template-columns:1fr auto auto;gap:1rem;align-items:center;padding:.9rem 0;border-bottom:1px solid var(--line)}
.sub-list__title a{text-decoration:none;color:var(--ink)}
.sub-list__title a:hover{color:var(--sage)}
.sub-list__status{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .6rem;background:var(--surface);border:1px solid var(--line);color:var(--muted);white-space:nowrap}
.sub-list__status.status--publish{color:var(--sage);border-color:var(--sage)}
.sub-list__status.status--pending{color:var(--clay);border-color:var(--clay)}
.sub-list__status.status--asana_revision{color:var(--clay)}
.sub-list__date{font-size:.78rem;color:var(--muted);white-space:nowrap}
/* AI form */
.ai-form{display:grid;gap:1.4rem;max-width:42rem}
.ai-form__modes{border:0;padding:0;margin:0;display:grid;gap:.6rem}
.ai-form__modes legend{font-size:.85rem;color:var(--ink-soft);margin-bottom:.4rem;padding:0}
.ai-mode{display:flex;gap:.7rem;align-items:flex-start;border:1px solid var(--line);background:var(--surface);padding:.9rem 1rem;cursor:pointer}
.ai-mode input{margin-top:.25rem}
.ai-mode span{display:grid;gap:.15rem;font-size:.88rem;color:var(--muted)}
.ai-mode strong{color:var(--ink);font-weight:600;font-size:.95rem}
.ai-form__field{display:grid;gap:.4rem;font-size:.85rem;color:var(--ink-soft)}
.ai-form__field textarea,.ai-form__field input{border:1px solid var(--line);background:var(--surface);padding:.75rem .9rem;font:inherit;color:var(--ink)}

/* =========================================================
   WooCommerce — re-skinned to Still Water
   ========================================================= */
.woocommerce .woo{padding-top:clamp(32px,5vw,56px)}
.woocommerce a{color:var(--sage)}
/* buttons */
.woocommerce .button,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce #respond input#submit,.woocommerce .wp-element-button,.wc-block-components-button{
  background:var(--ink)!important;color:var(--paper)!important;border:0!important;border-radius:0!important;
  font-size:.74rem!important;letter-spacing:.12em!important;text-transform:uppercase!important;font-weight:600!important;
  padding:.85rem 1.4rem!important;transition:background .2s!important}
.woocommerce .button:hover,.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,.wc-block-components-button:hover{background:#2c352c!important}
.woocommerce .button.alt,.woocommerce button.button.alt,.woocommerce .single_add_to_cart_button{background:var(--sage)!important}
.woocommerce .button.alt:hover{background:#4f5d47!important}
/* product grid */
.woocommerce ul.products{display:grid!important;grid-template-columns:1fr 1fr;gap:clamp(24px,3vw,40px);margin:0!important;list-style:none}
.woocommerce ul.products::before,.woocommerce ul.products::after{display:none!important}
.woocommerce ul.products li.product{width:auto!important;margin:0!important;float:none!important;text-align:left}
.woocommerce ul.products li.product a img{margin:0 0 1rem!important;border:1px solid var(--line)}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-family:var(--serif)!important;font-size:1.2rem!important;font-weight:400!important;padding:0!important;line-height:1.25;color:var(--ink)}
.woocommerce ul.products li.product .price{color:var(--ink-soft)!important;font-size:1rem!important;font-weight:600;font-family:var(--sans)}
.woocommerce ul.products li.product .price del{color:var(--muted)!important;font-weight:400;opacity:.7}
.woocommerce ul.products li.product .price ins{text-decoration:none;color:var(--clay)!important}
/* shop pagination — match the site's clean pagination */
.woocommerce nav.woocommerce-pagination{margin-top:clamp(2.6rem,5vw,4rem);text-align:left}
.woocommerce nav.woocommerce-pagination ul{display:flex;flex-wrap:wrap;gap:.5rem;border:0!important;margin:0;padding:0}
.woocommerce nav.woocommerce-pagination ul li{border:0!important;margin:0!important;overflow:visible}
.woocommerce nav.woocommerce-pagination ul li a.page-numbers,
.woocommerce nav.woocommerce-pagination ul li span.page-numbers{display:inline-grid!important;place-content:center;min-width:44px;height:44px;padding:0 .8rem!important;border:1px solid var(--line)!important;font-size:.85rem;color:var(--ink-soft);background:transparent!important;transition:background .2s,color .2s,border-color .2s}
.woocommerce nav.woocommerce-pagination ul li a.page-numbers:hover{border-color:var(--sage)!important;color:var(--sage)}
.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--ink)!important;color:var(--paper)!important;border-color:var(--ink)!important}
.woocommerce .onsale{background:var(--clay)!important;color:#fff!important;border-radius:0!important;
  font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;min-height:0;min-width:0;padding:.3rem .6rem;line-height:1.4;top:.6rem;right:.6rem;margin:0}
.woocommerce .star-rating span::before,.woocommerce .star-rating::before{color:var(--sage)}
/* single product */
.single-product div.product{display:grid;gap:clamp(28px,4vw,56px)}
.single-product div.product .product_title{font-family:var(--serif);font-size:clamp(1.5rem,1.2rem + 1.2vw,2rem);line-height:1.15;letter-spacing:-.01em;text-wrap:balance}
.single-product div.product p.price,.single-product div.product span.price{color:var(--ink);font-size:1.5rem;font-weight:600}
.single-product .woocommerce-product-gallery img{border:1px solid var(--line)}
.single-product div.product form.cart{margin-top:1.6rem;display:flex;flex-wrap:wrap;align-items:center;gap:1rem}
.single-product div.product form.cart .quantity{margin:0}
.single-product div.product form.cart .button{margin:0}
.woocommerce .quantity .qty{border:1px solid var(--line);background:var(--surface);padding:.6rem;width:4rem;font:inherit;color:var(--ink)}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:var(--surface);border:1px solid var(--line);border-radius:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{background:var(--paper);border-bottom-color:var(--paper)}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{border-color:var(--line)}
.woocommerce-tabs h2,.related h2,.up-sells h2{font-family:var(--serif);font-weight:400}
/* tables (cart, account) */
.woocommerce table.shop_table{border:1px solid var(--line);border-radius:0}
.woocommerce table.shop_table th{font-family:var(--sans);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.woocommerce table.shop_table td{border-top:1px solid var(--line);color:var(--ink-soft)}
/* forms / checkout */
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.woocommerce form .form-row select,
.woocommerce-cart .input-text,.wc-block-components-text-input input{
  border:1px solid var(--line)!important;background:var(--surface)!important;padding:.75rem .9rem!important;font:inherit!important;color:var(--ink)!important;border-radius:0!important}
.woocommerce form .form-row label,.woocommerce-checkout label{color:var(--ink-soft);font-size:.85rem}
.woocommerce .cart_totals,.woocommerce-checkout-review-order{background:var(--surface);border:1px solid var(--line);padding:clamp(18px,2.5vw,28px)}
.woocommerce-checkout #payment{background:var(--surface);border:1px solid var(--line);border-radius:0}
.woocommerce-checkout #payment div.payment_box{background:var(--sage-tint);border-radius:0}
/* My Account */
.woocommerce-account .woocommerce-MyAccount-navigation ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem;border-bottom:1px solid var(--line);padding-bottom:1rem;margin-bottom:1.6rem}
.woocommerce-account .woocommerce-MyAccount-navigation a{font-size:.8rem;letter-spacing:.04em;color:var(--ink-soft);text-decoration:none}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a{color:var(--sage);font-weight:600}
/* notices */
.woocommerce-message,.woocommerce-info,.woocommerce-error,.woocommerce-noreviews{
  border-top:2px solid var(--sage)!important;background:var(--sage-tint)!important;color:var(--ink)!important;border-radius:0}
.woocommerce-error{border-top-color:var(--clay)!important}
/* breadcrumb */
.woocommerce-breadcrumb{font-size:.78rem;color:var(--muted);letter-spacing:.03em;margin-bottom:1.6rem}
/* result count / ordering */
.woocommerce .woocommerce-result-count,.woocommerce .woocommerce-ordering{color:var(--muted);font-size:.82rem}
.woocommerce .woocommerce-ordering select{border:1px solid var(--line);background:var(--surface);padding:.5rem;font:inherit}

/* ---------- Paid Memberships Pro (checkout / account) ---------- */
.pmpro{max-width:760px;margin-inline:auto}
.pmpro .pmpro_card{background:var(--surface)!important;border:1px solid var(--line)!important;border-radius:2px!important;box-shadow:none!important;padding:clamp(20px,3vw,30px)!important;margin-bottom:1.4rem}
.pmpro .pmpro_card_title,.pmpro .pmpro_form_heading,.pmpro .pmpro_form_legend{font-family:var(--serif)!important;font-weight:400!important;color:var(--ink)!important}
.pmpro .pmpro_level_name_text{font-family:var(--serif)!important;font-size:1.35rem!important;color:var(--ink)!important}
.pmpro .pmpro_level_cost_text,.pmpro .pmpro_level_description_text{color:var(--ink-soft)!important}
.pmpro .pmpro_form_label{font-size:.82rem!important;letter-spacing:.02em;color:var(--ink-soft)!important;font-weight:600!important}
.pmpro .pmpro_form_input input,.pmpro .pmpro_form_input select,.pmpro .pmpro_form_input textarea,
.pmpro input[type=text],.pmpro input[type=email],.pmpro input[type=password],.pmpro input[type=tel]{border:1px solid var(--line)!important;background:var(--surface)!important;color:var(--ink)!important;padding:.75rem .9rem!important;font:inherit!important;border-radius:2px!important;box-shadow:none!important}
.pmpro .pmpro_form_input input:focus,.pmpro input:focus{border-color:var(--sage)!important;outline:none!important}
.pmpro .pmpro_btn,.pmpro .pmpro_btn-submit-checkout,.pmpro button[type=submit]{background:var(--ink)!important;color:var(--paper)!important;border:0!important;border-radius:2px!important;font-size:.76rem!important;letter-spacing:.1em!important;text-transform:uppercase!important;font-weight:600!important;padding:.9rem 1.7rem!important;cursor:pointer;transition:background .2s}
.pmpro .pmpro_btn-submit-checkout{background:var(--sage)!important}
.pmpro .pmpro_btn:hover,.pmpro .pmpro_btn-submit-checkout:hover{filter:brightness(1.06)}
.pmpro .pmpro_btn-plain{background:none!important;color:var(--muted)!important;padding:.4rem!important;letter-spacing:0!important;text-transform:none!important}
.pmpro a{color:var(--sage)}
.pmpro .pmpro_card_actions{margin-top:1.4rem}

/* ---------- submission list thumbnails ---------- */
.sub-list__thumb{width:56px;height:56px;flex:none;background:var(--paper-2)}
.sub-list__thumb img{width:100%;height:100%;object-fit:cover}
.sub-list--media .sub-list__item{grid-template-columns:56px 1fr auto auto}
@media (max-width:560px){.sub-list--media .sub-list__item{grid-template-columns:56px 1fr;row-gap:.4rem}.sub-list--media .sub-list__status,.sub-list--media .sub-list__date{grid-column:2}}

/* =========================================================
   Breakpoints (mobile-first enhancements)
   ========================================================= */
@media (min-width:600px){
  .grid--3{grid-template-columns:1fr 1fr}
  .newsletter__form{flex-direction:row}
  .topic-grid{grid-template-columns:1fr 1fr}
}
@media (min-width:880px){
  .site-nav{display:block}
  .icon-btn{display:inline-block}
  .site-header__actions .btn{display:inline-block}
  .nav-toggle{display:none}
  .mobile-panel{display:none!important}
  .hero__inner{grid-template-columns:1.05fr .95fr;align-items:center}
  .hero__media{order:0}
  .feature__inner{grid-template-columns:1.4fr 1fr}
  .grid--3{grid-template-columns:repeat(3,1fr)}
  .topic-grid{grid-template-columns:repeat(4,1fr)}
  .contribs{grid-template-columns:repeat(4,1fr)}
  .site-footer__inner{grid-template-columns:1.6fr 1fr 1fr 1fr}
  .topic-lead__inner{grid-template-columns:1.5fr 1fr}
  .topic-lead__media{order:0}
  .newsletter__inner{grid-template-columns:1.1fr .9fr}
  .newsletter__form{flex-direction:row}
  .contributor__head{grid-template-columns:160px 1fr;align-items:center}
  .contribs--archive{grid-template-columns:repeat(4,1fr)}
  .issue__head-inner{grid-template-columns:340px 1fr}
  .author-hero{grid-template-columns:128px 1fr}
  .mag-grid{grid-template-columns:repeat(3,1fr)}
  .issue-grid{grid-template-columns:repeat(4,1fr)}
  .trust-band__grid{grid-template-columns:repeat(4,1fr)}
  .account__auth{grid-template-columns:1fr 1fr}
  .credits{grid-template-columns:repeat(4,1fr)}
  .woocommerce ul.products{grid-template-columns:repeat(3,1fr)!important}
  .single-product div.product{grid-template-columns:1fr 1fr;align-items:start}
  .single-product div.product .woocommerce-tabs,.single-product div.product .related,.single-product div.product .up-sells{grid-column:1 / -1}
  .pkg-grid{grid-template-columns:repeat(3,1fr)}
  .twocol-doc{grid-template-columns:1fr 1fr}
}

/* Article — asymmetric reading grid on larger screens */
@media (min-width:1000px){
  .article__layout{grid-template-columns:var(--rail) minmax(0,42rem);justify-content:start}
  .article__rail{display:block}
  .article__meta-mobile{display:none}
  .share--inline{display:none}
  .article-comments{margin-left:calc(var(--rail) + var(--railgap))}
  /* images & pull quotes break rightward into the margin */
  .article-body .alignwide{width:calc(100% + 230px);max-width:none}
  .article-body .wp-block-pullquote{width:calc(100% + 150px)}
}

/* Large editorial refinements */
@media (min-width:1100px){
  .topic-lead__inner{grid-template-columns:1.6fr 1fr;gap:64px}
  .article{--art-max:1200px;--rail:210px}
}

/* Hide Google reCAPTCHA v3 floating badge (keep attribution text on forms) */
.grecaptcha-badge{visibility:hidden!important}

/* Sponsor / banner slots — discreet label, reserved space, never crowds. */
.ad-slot{margin:2.4rem auto;text-align:center}
.ad-slot__label{display:block;font-size:.58rem;line-height:1;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);opacity:.7;margin:0 0 .55rem}
.ad-slot__body img{max-width:100%;height:auto;display:block;margin:0 auto;border-radius:4px}
.ad-slot--homepage .ad-slot__body img,.ad-slot--footer .ad-slot__body img,.ad-slot--archive .ad-slot__body img,.ad-slot--article_incontent .ad-slot__body img,.ad-slot--issue .ad-slot__body img{max-width:970px}
.ad-slot--article_rail{margin:1.4rem 0 0}
.ad-slot--article_rail .ad-slot__label{text-align:left}
.ad-slot--article_rail .ad-slot__body img{max-width:100%;margin:0}

/* Topic-hero script accent — compact two lines (scripts, then transliteration). */
.topic-hero__accent{margin:.5rem 0 0;font-size:clamp(1rem,.9rem + .5vw,1.35rem);color:var(--sage);font-weight:400;line-height:1.3}
.topic-hero__accent .ta{margin-left:.15em}
.ad-footer-wrap{margin:0 auto 2.2rem}
.ad-archive-wrap{margin:1.6rem auto 0}
.ad-dev--both{display:block}
.ad-dev--desktop{display:block}
.ad-dev--mobile{display:none}
@media(max-width:768px){.ad-dev--desktop{display:none}.ad-dev--mobile{display:block}.ad-slot--article_rail{display:none}}

/* form honeypot (spam trap) — visually removed */
.asana-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

/* contact form */
.contact-form-wrap{max-width:38rem;margin-top:1.6rem}
.contact-form .btn{justify-self:start}

/* back-to-top button */
.to-top{position:fixed;right:clamp(14px,3vw,28px);bottom:clamp(14px,3vw,28px);z-index:120;width:44px;height:44px;display:grid;place-content:center;border:0;border-radius:50%;background:var(--ink);color:var(--paper);cursor:pointer;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .25s,transform .25s,background .2s;box-shadow:0 4px 14px rgba(30,36,31,.25)}
.to-top.is-visible{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:var(--sage)}
@media print{.to-top{display:none}}
