/* ============================================================================
   folkkb — "Calm botanical" (variant E).
   Soft sage + cream · forest green with a warm honey accent ·
   Newsreader (serif display) + Albert Sans (sans text) · airy, rounded, premium.
   Token-driven: the whole site (header, footer, plant & legal pages) inherits
   this palette/type; component layouts are unchanged from the original build.
   ========================================================================== */

:root{
  /* paper & ink (sage-cream) */
  --paper:#eef0e8; --paper-2:#e6e9dd; --paper-3:#dce8d8;
  --surface:#fbfcf8; --surface-2:#f3f5ec;
  --ink:#222a22; --ink-2:#46503f; --muted:#737c69; --faint:#9aa48d;
  --line:#dde0d2; --line-2:#cdd2bf; --hair:#d6dac8;
  /* botanical brand (forest / sage) */
  --pine:#2f4a32; --pine-d:#243a26; --pine-dd:#1b2c1d; --moss:#5b7a5a; --sage:#7d997a;
  /* accents — calm greens + one warm honey, used sparingly */
  --ochre:#b0823a; --gold:#c08a4a; --gold-l:#a9c7ad;
  --clay:#4f6f4d; --clay-d:#2f4a32; --rust:#9a5a2c; --slate:#4d6b66;
  /* type */
  --display:"Newsreader",Georgia,"Times New Roman",serif;
  --text:"Albert Sans",system-ui,-apple-system,Segoe UI,sans-serif;
  /* depth (green-tinted, soft) */
  --sh-1:0 1px 2px rgba(34,42,34,.05);
  --sh-2:0 2px 8px rgba(34,42,34,.06),0 18px 40px -26px rgba(34,42,34,.34);
  --sh-3:0 30px 60px -30px rgba(28,42,30,.45);
  --sh-plate:0 38px 70px -30px rgba(27,44,29,.55),0 6px 18px -10px rgba(27,44,29,.4);
  /* motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --r:16px; --r-lg:24px;
  --measure:65ch;
  --maxw:1160px; --readw:768px;
}

*{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;color:var(--ink);background:var(--paper);
  font:400 17.5px/1.66 var(--text);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  font-feature-settings:"liga" 1,"onum" 1,"kern" 1;
  overflow-x:hidden;
}
/* soft sage wash for quiet atmosphere (no paper grain — E is clean) */
body::after{
  content:"";position:fixed;inset:0 0 auto 0;height:62vh;z-index:-3;pointer-events:none;
  background:radial-gradient(120% 70% at 82% -12%,rgba(91,122,90,.14),transparent 62%),
             radial-gradient(90% 60% at 0% 0%,rgba(125,153,122,.10),transparent 58%);
}

a{color:var(--clay-d);text-decoration:none;transition:color .15s var(--ease)}
a:hover{color:var(--clay);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
img{max-width:100%}
::selection{background:rgba(29,71,51,.16)}

h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.14;margin:0;font-optical-sizing:auto;letter-spacing:-.005em}
strong{font-weight:600}

/* small-caps editorial label */
.kicker{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--text);font-weight:600;
  font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--clay-d);margin:0}
.kicker::before{content:"";width:1.7rem;height:1px;background:linear-gradient(90deg,transparent,var(--clay))}
.kicker.center{justify-content:center}
.kicker.bare::before{display:none}

/* reveal-on-scroll — JS hides+animates; without JS everything is visible & indexable.
   app.js has a load failsafe that reveals anything the observer misses, so the page
   can never get stuck blank. */
.js [data-reveal]{opacity:0;transform:translateY(14px);
  animation:reveal-fallback .6s var(--ease) 2.4s forwards}
.js [data-reveal].in{opacity:1;transform:none;animation:none;
  transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:calc(var(--i,0)*60ms)}
/* Pure-CSS safety net: if the JS reveal (observer/timer) never runs — throttled tab,
   blocked script, anything — content still appears. The page can never stay blank. */
@keyframes reveal-fallback{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.js [data-reveal]{opacity:1!important;transform:none!important;transition:none!important;animation:none!important}}

/* ---------------------------------------------------------------- header -- */
.site-header{
  position:sticky;top:0;z-index:40;display:flex;gap:1rem;align-items:center;flex-wrap:wrap;
  padding:.85rem clamp(1rem,4vw,2.4rem);
  background:rgba(238,240,232,.82);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s var(--ease),background .3s var(--ease);
}
.site-header.scrolled{background:rgba(241,243,236,.94);box-shadow:0 14px 30px -24px rgba(28,42,30,.5)}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--display);font-weight:500;
  font-size:1.6rem;color:var(--pine);letter-spacing:-.005em}
.brand:hover{text-decoration:none;color:var(--pine-d)}
.brand .logo{filter:drop-shadow(0 1px 2px rgba(29,71,51,.3));transition:transform .5s var(--ease)}
.brand:hover .logo{transform:rotate(-12deg)}
.brand .wordmark{position:relative}

.search{position:relative;display:flex;gap:.4rem;flex:1;max-width:440px;min-width:180px}
.search .s-ico{position:absolute;inset-inline-start:.95rem;top:50%;transform:translateY(-50%);
  color:var(--faint);pointer-events:none;display:flex;transition:color .2s var(--ease)}
.search:focus-within .s-ico{color:var(--clay)}
.search input{
  flex:1;width:100%;padding:.56rem 1rem;padding-inline-start:2.4rem;border:1px solid var(--line-2);
  border-radius:999px;background:#fffdf7;font:inherit;font-size:.96rem;color:var(--ink);outline:none;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease);
}
.search input::placeholder{color:#a99d83}
.search input:focus{border-color:var(--clay);box-shadow:0 0 0 3px rgba(181,86,46,.14);background:#fff}
.search button{
  padding:.56rem 1.25rem;border:0;border-radius:999px;background:var(--pine);color:#f6f1e2;
  font-family:var(--text);font-weight:600;font-size:.95rem;cursor:pointer;white-space:nowrap;
  transition:background .2s var(--ease),transform .12s var(--ease),box-shadow .2s var(--ease);
}
.search button:hover{background:var(--pine-d);transform:translateY(-1px);box-shadow:0 6px 16px -8px rgba(16,40,27,.7)}
.search button:active{transform:translateY(0)}

.lang-switch{position:relative}
.lang-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .85rem;border:1px solid var(--line-2);
  border-radius:999px;background:#fffdf7;font:inherit;font-size:.9rem;color:var(--ink);cursor:pointer;transition:.2s var(--ease)}
.lang-btn:hover{border-color:var(--clay);color:var(--clay-d)}
.lang-btn svg{color:var(--ochre)}
.lang-btn .cur{font-weight:600}
.lang-btn .chev{font-size:.66rem;color:var(--muted);transition:transform .2s var(--ease)}
.lang-switch.open .chev{transform:rotate(180deg)}
.lang-menu{position:absolute;inset-inline-end:0;top:calc(100% + .5rem);margin:0;padding:.35rem;list-style:none;
  min-width:178px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--sh-3);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.18s var(--ease);z-index:50}
.lang-switch.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-menu a{display:flex;align-items:center;justify-content:space-between;padding:.5rem .7rem;border-radius:7px;color:var(--ink);font-size:.94rem}
.lang-menu a:hover{background:var(--paper-2);text-decoration:none;color:var(--ink)}
.lang-menu a.active{color:var(--pine);font-weight:600;background:var(--paper-2)}
.lang-menu a.active::after{content:"✦";color:var(--ochre);font-size:.7rem}

/* --------------------------------------------------------------- layout --- */
.container{max-width:var(--readw);margin:0 auto;padding:clamp(1.6rem,4vw,3rem) clamp(1.1rem,4vw,1.6rem)}
.container.home{max-width:var(--maxw);padding-top:clamp(1rem,3vw,2rem)}
.block{margin:clamp(3.2rem,7vw,5.5rem) 0}
.sec-head{display:flex;align-items:flex-end;gap:1rem;margin-bottom:1.7rem;
  padding-bottom:.9rem;border-bottom:1px solid var(--line)}
.sec-no{font-family:var(--display);font-weight:600;font-style:italic;font-size:1.05rem;color:var(--gold);
  line-height:1;letter-spacing:.02em;flex:none;padding-bottom:.12rem}
.sec-head .block-h{margin:0}
.sec-head .grow{flex:1}
.sec-head .sec-link{font-family:var(--text);font-size:.92rem;color:var(--clay-d);white-space:nowrap;padding-bottom:.15rem}
.block-h{font-family:var(--display);font-weight:600;font-size:clamp(1.55rem,3.2vw,2.15rem);color:var(--ink);
  letter-spacing:-.02em;line-height:1.08}
.sec-sub{color:var(--muted);font-size:1rem;margin:.5rem 0 0;max-width:54ch}

/* ===================================================================== HERO */
.home-hero{position:relative;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;
  gap:clamp(1.5rem,5vw,4rem);padding:clamp(2rem,5vw,4rem) 0 clamp(2.4rem,5vw,4rem)}
.hero-copy{position:relative;z-index:1}
.hero-copy .kicker{margin-bottom:1.5rem}
.hero-display{font-size:clamp(2.5rem,5.6vw,4.3rem);line-height:1.0;letter-spacing:-.03em;color:var(--ink);margin:0}
.hero-display .em{font-style:italic;color:var(--pine);position:relative}
.hero-display .em::after{content:"";position:absolute;inset-inline:0;bottom:.08em;height:.07em;
  background:linear-gradient(90deg,var(--gold),rgba(199,154,62,0));border-radius:2px}
.lead{color:var(--ink-2);max-width:38rem;margin:1.5rem 0 0;font-size:clamp(1.08rem,1.5vw,1.24rem);line-height:1.55}
.lead .stop{display:block;margin-top:.5rem;font-style:italic;color:var(--clay-d);font-size:.96em}
.hero-search{max-width:530px;margin-top:1.9rem;box-shadow:var(--sh-2);border-radius:8px}
.hero-search input{padding:1rem 1.25rem;padding-inline-start:3rem;font-size:1.06rem;border:1px solid transparent;border-radius:8px;background:var(--surface)}
.hero-search .s-ico{inset-inline-start:1.1rem;color:var(--moss)}
.hero-search input:focus{background:#fff}
.hero-search button{padding:1rem 1.7rem;border-radius:8px}
.hero-hint{color:var(--muted);font-size:.94rem;margin-top:1.05rem;display:flex;align-items:baseline;gap:.5rem}
.hero-hint .mk{color:var(--gold);font-style:normal;flex:none}
.hero-hint em{color:var(--ink-2);font-style:italic}

/* atmosphere behind hero */
.home-hero::before{content:"";position:absolute;inset:-30% -20% auto 40%;height:560px;z-index:0;pointer-events:none;
  background:radial-gradient(closest-side,rgba(109,146,119,.20),transparent 70%)}

/* the signature: a dark herbarium "specimen plate" */
.hero-plate{position:relative;z-index:1;justify-self:center;width:min(100%,400px);aspect-ratio:4/5;
  background:linear-gradient(157deg,var(--pine) 0%,var(--pine-d) 62%,var(--pine-dd) 100%);
  border-radius:10px;box-shadow:var(--sh-plate);color:#eaf0e3;
  transform:rotate(1.4deg);transition:transform .5s var(--ease)}
.hero-plate:hover{transform:rotate(0deg) translateY(-4px)}
.hero-plate::before{content:"";position:absolute;inset:13px;border:1px solid rgba(230,207,146,.45);border-radius:5px;pointer-events:none}
.hero-plate::after{content:"";position:absolute;inset:18px;border:1px solid rgba(230,207,146,.18);border-radius:3px;pointer-events:none}
.plate-no{position:absolute;top:1.7rem;inset-inline-start:1.9rem;font-family:var(--display);font-style:italic;
  font-size:.92rem;letter-spacing:.12em;color:var(--gold-l)}
.plate-tag{position:absolute;top:1.75rem;inset-inline-end:1.9rem;font-family:var(--text);font-size:.6rem;
  letter-spacing:.24em;text-transform:uppercase;color:rgba(234,240,227,.6)}
.plate-art{position:absolute;inset:2.6rem 2rem 4.4rem;display:flex;align-items:center;justify-content:center}
.plate-art svg{width:100%;height:100%;overflow:visible}
.plate-cap{position:absolute;inset-inline:1.9rem;bottom:1.7rem;text-align:center;
  border-top:1px solid rgba(230,207,146,.35);padding-top:.8rem}
.plate-cap .lat{font-family:var(--display);font-style:italic;font-weight:500;font-size:1.12rem;color:#f4f0e4}
.plate-cap .fam{display:block;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(234,240,227,.62);margin-top:.3rem}
.plate-seal{position:absolute;bottom:-16px;inset-inline-end:24px;width:54px;height:54px;border-radius:50%;
  background:radial-gradient(circle at 38% 34%,var(--clay),var(--rust));color:#f4e3cf;
  display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:600;font-size:.62rem;
  letter-spacing:.06em;text-align:center;line-height:1.05;box-shadow:0 8px 18px -8px rgba(140,52,32,.8);
  border:2px solid rgba(244,227,207,.35);transform:rotate(-9deg)}

/* engraving line styling (shared by plate + feature marks) */
.engrave{fill:none;stroke:currentColor;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.engrave .fillsoft{fill:rgba(234,240,227,.07)}
.engrave .pip{fill:var(--gold-l);stroke:none}

/* ================================================================== LEDGER */
.ledger{display:grid;grid-template-columns:repeat(3,1fr);align-items:center;
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);
  box-shadow:var(--sh-2);position:relative;overflow:hidden}
.ledger::before{content:"";position:absolute;inset-inline:0;top:0;height:3px;
  background:linear-gradient(90deg,var(--pine),var(--ochre),var(--clay))}
.led-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.5rem 1rem;
  border-inline-end:1px solid var(--line)}
.led-item:last-child{border-inline-end:0}
.led-item .num{font-family:var(--display);font-weight:600;font-size:clamp(2rem,3.6vw,2.9rem);color:var(--pine);line-height:1}
.led-item .lbl{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:.5rem}
.ledger-note{grid-column:1/-1;text-align:center;color:var(--muted);font-style:italic;font-size:.94rem;
  padding:.85rem 1rem;border-top:1px dashed var(--line);background:var(--surface-2)}

/* ============================================================ SYMPTOM CHIPS */
.chips{display:flex;flex-wrap:wrap;gap:.7rem}
.chip{display:inline-flex;align-items:center;gap:.55rem;padding:.6rem 1.1rem;background:var(--surface);
  border:1px solid var(--line-2);border-radius:999px;color:var(--ink-2);font-size:.98rem;box-shadow:var(--sh-1);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease)}
.chip svg{width:17px;height:17px;color:var(--moss);transition:color .2s var(--ease)}
.chip:hover{text-decoration:none;border-color:var(--moss);color:var(--pine);transform:translateY(-2px);box-shadow:var(--sh-2)}
.chip:hover svg{color:var(--clay)}

/* ============================================================ HOW IT WORKS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border:1px solid var(--line-2);border-radius:var(--r-lg);overflow:hidden;background:var(--surface)}
.step{position:relative;padding:1.7rem 1.4rem 1.6rem;border-inline-end:1px solid var(--line)}
.step:last-child{border-inline-end:0}
.step::before{content:"";position:absolute;inset-inline:0;top:0;height:3px;background:var(--pine);transform:scaleX(0);transform-origin:inline-start;transition:transform .35s var(--ease)}
.step:hover::before{transform:scaleX(1)}
.step .f-no{display:block;font-family:var(--display);font-weight:600;font-size:1.6rem;color:var(--gold);
  line-height:1;margin-bottom:.9rem}
.step .f-no::after{content:"";display:block;width:1.5rem;height:1px;background:var(--line-2);margin-top:.7rem}
.step h3{font-family:var(--display);font-weight:600;font-size:1.12rem;color:var(--ink);margin:0 0 .45rem}
.step p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.55}

/* ============================================================ FEATURED ART */
.featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(178px,1fr));gap:1.1rem}
.feat-card{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.3rem;
  padding:1.8rem 1rem 1.4rem;background:var(--surface);border:1px solid var(--line-2);border-radius:14px;
  box-shadow:var(--sh-1);overflow:hidden;
  transition:transform .24s var(--ease),box-shadow .24s var(--ease),border-color .24s var(--ease)}
.feat-card::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% -10%,rgba(109,146,119,.14),transparent 60%);opacity:0;transition:opacity .24s var(--ease)}
.feat-card:hover{text-decoration:none;transform:translateY(-4px);box-shadow:var(--sh-3);border-color:var(--moss)}
.feat-card:hover::before{opacity:1}
.feat-art{position:relative;display:flex;align-items:center;justify-content:center;width:78px;height:78px;border-radius:50%;
  background:radial-gradient(circle at 38% 30%,#eef4ea,#dde8d6);color:var(--pine);margin-bottom:.65rem;
  box-shadow:inset 0 0 0 1px rgba(29,71,51,.10)}
.feat-art svg{width:40px;height:40px}
.feat-card:nth-child(3n+2) .feat-art{color:var(--moss)}
.feat-card:nth-child(3n) .feat-art{color:var(--clay);background:radial-gradient(circle at 38% 30%,#f8ece1,#f0dbca)}
.feat-latin{position:relative;font-family:var(--display);font-style:italic;font-weight:600;font-size:1.06rem;color:var(--ink)}
.feat-common{position:relative;color:var(--muted);font-size:.88rem;text-transform:capitalize}

/* ============================================================== TRADITIONS */
.tradition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.1rem}
.trad{position:relative;display:flex;flex-direction:column;gap:.3rem;padding:1.25rem 1.35rem;background:var(--surface);
  border:1px solid var(--line-2);border-radius:12px;box-shadow:var(--sh-1);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.trad:hover{transform:translateY(-3px);box-shadow:var(--sh-2)}
.trad .t-mk{display:flex;color:var(--moss);margin-bottom:.35rem}
.trad .t-mk svg{width:22px;height:22px}
.trad .t-name{font-family:var(--display);font-weight:600;font-size:1.08rem;color:var(--ink)}
.trad .t-desc{color:var(--muted);font-size:.9rem;line-height:1.5}

/* ===================================================== SPONSORED / PRODUCTS */
.commerce{margin:clamp(3rem,6vw,4.5rem) 0}
.commerce-rule{display:flex;align-items:center;gap:1rem;margin-bottom:1.3rem}
.commerce-rule .kicker{color:var(--muted)}
.commerce-rule .kicker::before{background:linear-gradient(90deg,transparent,var(--line-2))}
.commerce-rule .line{flex:1;height:1px;background:var(--line)}
.commerce-rule .disc{font-size:.8rem;color:var(--muted)}
.products{background:linear-gradient(180deg,var(--surface-2),#f1e8d6);border:1px solid var(--line-2);border-radius:var(--r-lg);
  padding:clamp(1.4rem,4vw,2.1rem);box-shadow:var(--sh-1)}
.products .ph-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:1.1rem}
.products .ph-head h3{font-family:var(--display);font-weight:600;font-size:1.22rem;color:var(--ink)}
.spon{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  border:1px dashed var(--line-2);border-radius:999px;padding:.24rem .7rem}
.product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1.1rem}
.product{background:var(--surface);border:1px solid var(--line);border-radius:12px;overflow:hidden;
  box-shadow:var(--sh-1);transition:transform .22s var(--ease),box-shadow .22s var(--ease)}
.product:hover{transform:translateY(-3px);box-shadow:var(--sh-2)}
.p-img{aspect-ratio:4/3;overflow:hidden}
.p-img img{width:100%;height:100%;object-fit:cover;display:block}
.p-img.ph,.ad-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;
  color:#ab9d80;font-size:.78rem;letter-spacing:.05em;
  background:
    repeating-linear-gradient(45deg,rgba(0,0,0,.012) 0 12px,transparent 12px 24px),
    var(--paper-2)}
.ph-ico{width:30px;height:30px;opacity:.5}
.p-body{padding:.95rem 1.05rem 1.15rem;display:flex;flex-direction:column;gap:.55rem}
.p-name{font-family:var(--display);font-weight:600;color:var(--ink)}
.p-meta{display:flex;align-items:center;justify-content:space-between}
.p-price{font-family:var(--display);font-weight:600;color:var(--pine)}
.p-btn{border:1px solid var(--line-2);background:var(--paper);color:var(--muted);border-radius:999px;
  padding:.32rem .85rem;font:inherit;font-size:.78rem;cursor:not-allowed}

/* ad banner */
.ad-banner{position:relative;margin:clamp(2rem,5vw,3rem) 0;border:1px dashed var(--line-2);border-radius:var(--r-lg);
  overflow:hidden;background:var(--surface)}
.ad-banner img{width:100%;height:auto;display:block}
.ad-ph{min-height:128px;border-radius:14px}
.ad-tag{position:absolute;inset-block-start:.55rem;inset-inline-start:.65rem;font-size:.6rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);background:rgba(252,249,241,.9);border-radius:5px;padding:.16rem .5rem}

/* ====================================================== MATERIA MEDICA list */
.listing h2,.search-title{font-family:var(--display);font-weight:600;font-size:clamp(1.4rem,2.6vw,1.7rem);color:var(--ink);
  margin:0 0 1.2rem;display:flex;align-items:baseline;gap:.7rem;padding-bottom:.6rem;border-bottom:1px solid var(--line)}
.count{font-family:var(--text);font-size:.74rem;color:var(--clay-d);border:1px solid var(--clay);
  border-radius:999px;padding:.08rem .6rem;font-weight:600;letter-spacing:.05em}
.plant-grid{list-style:none;margin:0;padding:0;display:grid;gap:.95rem;
  grid-template-columns:repeat(auto-fill,minmax(216px,1fr))}
.plant-grid a{position:relative;display:flex;flex-direction:column;gap:.22rem;height:100%;overflow:hidden;
  padding:1.1rem 1.15rem;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);
  box-shadow:var(--sh-1);transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease)}
.plant-grid a::before{content:"";position:absolute;inset-inline-start:0;top:0;bottom:0;width:3px;background:var(--moss);
  transform:scaleY(0);transform-origin:top;transition:transform .26s var(--ease)}
.plant-grid a:hover{transform:translateY(-3px);box-shadow:var(--sh-2);border-color:var(--moss);text-decoration:none}
.plant-grid a:hover::before{transform:scaleY(1)}
.plant-grid .latin{font-family:var(--display);font-style:italic;font-weight:600;font-size:1.12rem;color:var(--pine)}
.plant-grid .common{color:var(--muted);font-size:.9rem;text-transform:capitalize}
.plant-grid .go{position:absolute;inset-inline-end:1rem;top:1.15rem;color:var(--clay);opacity:0;transform:translateX(-6px);transition:.22s var(--ease)}
.plant-grid a:hover .go{opacity:1;transform:none}

/* ===================================================== ENTRY (plant page) -- */
.crumbs{font-size:.86rem;color:var(--muted);margin-bottom:1.3rem;letter-spacing:.01em}
.crumbs a{color:var(--clay-d)}
.crumbs .sep{margin:0 .5rem;color:var(--line-2)}
.entry{position:relative}
.entry-head{position:relative;padding:.4rem 0 1.5rem;border-bottom:1px solid var(--line);margin-bottom:1.5rem}
.entry-sprig{position:absolute;inset-inline-end:0;top:-.2rem;width:96px;height:96px;color:var(--sage);opacity:.5}
.entry-title{font-size:clamp(2.1rem,5.4vw,3.2rem);color:var(--ink);letter-spacing:-.025em;line-height:1.02;max-width:80%}
.entry-latin{margin:.4rem 0 0;color:var(--muted);font-style:italic;font-size:1.14rem;font-family:var(--display)}
.entry-lead{font-size:1.18rem;line-height:1.7;color:var(--ink-2);margin:1.3rem 0 0;max-width:var(--measure)}

.glance{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);
  padding:1.2rem 1.3rem;margin-bottom:1.6rem;box-shadow:var(--sh-1);position:relative;overflow:hidden}
.glance::before{content:"";position:absolute;inset-inline-start:0;top:0;bottom:0;width:3px;background:var(--gold)}
.glance-label{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--clay-d);font-weight:600;margin-bottom:.85rem}
.glance-label::before{content:"❧";color:var(--gold);font-size:.95rem}
.glance-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem 1.5rem;margin:0}
.glance-grid div{display:flex;flex-direction:column;gap:.25rem}
.glance-grid dt{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.glance-grid dd{margin:0;font-size:1rem;color:var(--ink);font-weight:500}
.cautions{display:flex;gap:.45rem;align-items:center;flex-wrap:wrap}
.cau{font-size:.82rem;font-weight:600;border-radius:5px;padding:.1rem .5rem}
.cau-int{background:rgba(63,111,106,.14);color:var(--slate)}
.cau-tox{background:rgba(168,129,46,.18);color:var(--ochre)}

.banner{display:flex;gap:.7rem;align-items:flex-start;background:#fbf3e0;
  border:1px solid #ecdcb0;border-inline-start:3px solid var(--ochre);border-radius:var(--r);
  padding:.9rem 1.1rem;margin:0 0 .8rem;font-size:.96rem;color:#6e5012;line-height:1.5}
.banner-ico{flex:none;color:var(--ochre);font-weight:700;font-size:1.05rem;line-height:1.3}
.scope{color:var(--muted);font-size:.92rem;font-style:italic;margin:0 0 1.7rem}

.panel{margin:1.9rem 0;padding-top:1.4rem;border-top:1px solid var(--line)}
.panel h2{font-size:1.34rem;color:var(--ink);margin-bottom:.95rem;display:flex;align-items:center;gap:.65rem}
.mark{width:.72rem;height:.72rem;border-radius:2px;flex:none;transform:rotate(45deg);box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.mark-use{background:var(--moss)}.mark-sci{background:var(--slate)}
.mark-warn{background:var(--ochre)}.mark-danger{background:var(--rust)}
.claims{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.9rem}
.claims li{display:flex;flex-wrap:wrap;gap:.5rem .9rem;align-items:baseline;justify-content:space-between;
  padding-bottom:.85rem;border-bottom:1px dotted var(--line-2)}
.claims li:last-child{border-bottom:0;padding-bottom:0}
.claim-text{flex:1;min-width:60%;color:var(--ink-2)}
.claim-text strong{color:var(--clay-d)}
.meta{display:flex;gap:.36rem;align-items:center;flex-wrap:wrap}

/* stamps & badges */
.tag{font-size:.72rem;color:var(--moss);border:1px solid rgba(63,115,85,.42);border-radius:999px;padding:.06rem .6rem;font-style:italic}
.tier{font-size:.64rem;font-weight:700;letter-spacing:.07em;border-radius:4px;padding:.16rem .44rem;color:#fbf6ea}
.tier-T0{background:var(--pine-d)}.tier-T1{background:var(--pine)}.tier-T2{background:var(--slate)}
.tier-T3{background:#8a7d61}.tier-T4{background:var(--clay)}
.grade{font-family:var(--display);font-size:.82rem;font-weight:700;border-radius:50%;width:1.6rem;height:1.6rem;flex:none;
  display:inline-flex;align-items:center;justify-content:center;color:#fbf6ea;box-shadow:var(--sh-1)}
.grade-A{background:var(--pine)}.grade-B{background:var(--moss)}.grade-C{background:var(--ochre)}.grade-D{background:#9a8f74}
.sev{font-size:.72rem;font-weight:600;border-radius:4px;padding:.12rem .52rem;text-transform:capitalize}
.sev-severe{background:rgba(140,52,32,.14);color:var(--rust)}
.sev-moderate{background:rgba(168,129,46,.18);color:var(--ochre)}
.sev-mild{background:rgba(63,115,85,.16);color:var(--moss)}
.sev-unknown{background:var(--paper-2);color:var(--muted)}
.cite{font-size:.64rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--clay-d);
  border:1px solid rgba(181,86,46,.42);border-radius:4px;padding:.12rem .38rem;transition:.15s var(--ease)}
.cite:hover{background:var(--clay);color:#fbf6ea;text-decoration:none;border-color:var(--clay)}

/* sources */
.sources{margin-top:2.2rem;border-top:2px solid var(--pine);padding-top:1.2rem}
.sources h2{font-size:1.22rem;margin-bottom:.9rem}
.sources ol{margin:0;padding-inline-start:1.5rem;display:flex;flex-direction:column;gap:.65rem;font-size:.93rem}
.sources li{padding-inline-start:.3rem}
.sources li::marker{color:var(--clay);font-weight:600}
.sources .lic{display:block;color:var(--muted);font-size:.78rem;font-style:italic}

.empty{color:var(--muted);background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);
  padding:1.6rem;box-shadow:var(--sh-1);font-size:1.02rem}

/* ================================================================== FOOTER */
.site-footer{margin-top:clamp(3rem,7vw,5rem);background:var(--pine-d);color:#cdd6c6;
  background-image:radial-gradient(110% 60% at 50% -20%,rgba(199,154,62,.10),transparent 60%)}
.foot-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(2.4rem,5vw,3.4rem) clamp(1.1rem,4vw,2rem) 1.6rem;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem}
.foot-brand .fb-top{display:flex;align-items:center;gap:.55rem;font-family:var(--display);font-weight:600;font-size:1.5rem;color:#f4f0e4}
.foot-brand .fb-top .logo path:first-child{fill:#e6cf92}
.foot-brand p{margin:.9rem 0 0;max-width:34ch;color:#b7c0ad;font-size:.94rem;line-height:1.6}
.foot-col h4{font-family:var(--text);font-weight:600;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-l);margin:0 0 .9rem}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.foot-col a{color:#d3dccb;font-size:.95rem}
.foot-col a:hover{color:#fff}
.foot-bar{border-top:1px solid rgba(230,207,146,.2)}
.foot-bar .fb-wrap{max-width:var(--maxw);margin:0 auto;padding:1.1rem clamp(1.1rem,4vw,2rem);
  display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;align-items:center;justify-content:space-between;
  font-size:.82rem;color:#9fa994}
.foot-bar .legal-line{display:inline-flex;align-items:center;gap:.5rem;color:#c2cbb6}
.foot-bar .legal-line .dot{color:var(--gold)}

/* ============================================================ LEGAL / ABOUT */
.legal{max-width:var(--readw);margin:.5rem auto}
.legal .kicker{margin-bottom:1rem}
.legal h1{font-family:var(--display);font-weight:600;font-size:clamp(2rem,4.4vw,2.9rem);color:var(--ink);
  margin:.4rem 0 1.1rem;letter-spacing:-.02em;line-height:1.06}
.legal h2{font-family:var(--display);font-weight:600;font-size:1.26rem;color:var(--pine);margin:2rem 0 .55rem;
  display:flex;align-items:baseline;gap:.6rem}
.legal h2 .n{font-style:italic;color:var(--gold);font-size:.92rem}
.legal p{color:var(--ink-2);line-height:1.74;margin:0 0 1rem}
.legal-lead{font-size:1.14rem;color:var(--ink-2)}
.legal-callout{background:#fbf3e0;border:1px solid #ecdcb0;border-inline-start:3px solid var(--ochre);
  border-radius:12px;padding:1.1rem 1.3rem;margin:1.6rem 0;color:#6e5012;font-size:1rem;line-height:1.62}
.legal-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.4rem 0}
.legal-card{background:var(--surface);border:1px solid var(--line-2);border-radius:12px;padding:1.1rem 1.2rem;box-shadow:var(--sh-1)}
.legal-card h3{font-family:var(--display);font-weight:600;font-size:1.04rem;color:var(--ink);margin:0 0 .4rem}
.legal-card p{margin:0;font-size:.93rem;color:var(--muted);line-height:1.55}
.legal-updated{color:var(--muted);font-style:italic;font-size:.9rem;margin:-.5rem 0 1.5rem}
.legal-list{margin:0 0 1rem;padding:0;list-style:none;display:flex;flex-direction:column;gap:.7rem}
.legal-list li{position:relative;padding-inline-start:1.4rem;color:var(--ink-2);line-height:1.66}
.legal-list li::before{content:"";position:absolute;inset-inline-start:.2rem;top:.62em;width:.42rem;height:.42rem;
  background:var(--moss);border-radius:1px;transform:rotate(45deg)}
.legal code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.86em;
  background:var(--paper-2);border:1px solid var(--line);border-radius:4px;padding:.02rem .35rem}
/* editable placeholders the operator should fill before launch (entity, jurisdiction, email) */
.fillin{color:var(--clay-d);background:rgba(181,86,46,.08);border:1px dashed rgba(181,86,46,.45);
  border-radius:4px;padding:0 .35rem;font-size:.94em;white-space:nowrap}
.legal-back{margin-top:2.4rem;border-top:1px solid var(--line);padding-top:1.4rem}

/* ============================================================== RESPONSIVE */
@media (max-width:880px){
  .home-hero{grid-template-columns:1fr;text-align:start}
  .home-hero::before{inset:-10% -20% auto 10%}
  .hero-plate{order:-1;width:min(86%,330px);transform:rotate(0deg);margin-bottom:.5rem}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step:nth-child(2){border-inline-end:0}
  .step:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .foot-inner{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media (max-width:560px){
  body{font-size:16.5px}
  .site-header{gap:.55rem}
  .search{order:3;max-width:100%;flex-basis:100%}
  .ledger{grid-template-columns:1fr}
  .led-item{border-inline-end:0;border-bottom:1px solid var(--line);padding:1.1rem}
  .ledger .led-item:nth-last-child(2){border-bottom:0}
  .steps{grid-template-columns:1fr}
  .step{border-inline-end:0;border-bottom:1px solid var(--line)}
  .step:last-child{border-bottom:0}
  .entry-title{max-width:100%}.entry-sprig{display:none}
  .claims li{flex-direction:column;gap:.4rem}
  .legal-grid,.foot-inner{grid-template-columns:1fr}
}

/* ===================================================================== RTL */
[dir="rtl"] .plant-grid a::before{inset-inline-start:0}
[dir="rtl"] .plant-grid .go{transform:scaleX(-1) translateX(-6px)}
[dir="rtl"] .plant-grid a:hover .go{transform:scaleX(-1)}
[dir="rtl"] .hero-display .em::after{background:linear-gradient(270deg,var(--gold),rgba(199,154,62,0))}
[dir="rtl"] .hero-plate{transform:rotate(-1.4deg)}
[dir="rtl"] .kicker::before{background:linear-gradient(270deg,transparent,var(--clay))}

/* lone trust line (homepage, after stats removed) */
.ledger--note{display:block;grid-template-columns:none;text-align:center;padding:1.6rem 1rem}
.ledger--note .ledger-note{margin:0}

/* data-thin plant pages: honest note + recorded common names */
.panel-thin .thin-note{color:var(--ink-2);font-size:1.02rem;line-height:1.6;max-width:60ch;margin:.2rem 0 1.2rem}
.vernaculars{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.55rem}
.vernaculars li{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .8rem;background:var(--surface);
  border:1px solid var(--line-2);border-radius:999px;font-size:.95rem;color:var(--ink)}
.vernaculars .vlang{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--clay-d);
  font-weight:600}

/* related (same-genus) plants — internal links for SEO + discovery */
.related{margin:2.1rem 0 .5rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.related h2{font-family:var(--display);font-size:1.24rem;color:var(--ink);margin:0 0 1rem}
.related-grid{list-style:none;margin:0;padding:0;display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.7rem}
.related-grid a{display:flex;flex-direction:column;gap:.15rem;padding:.7rem .95rem;background:var(--surface);
  border:1px solid var(--line-2);border-radius:var(--r-lg);transition:.18s var(--ease)}
.related-grid a:hover{border-color:var(--clay);text-decoration:none;box-shadow:var(--sh-2)}
.related-grid .rel-latin{font-family:var(--display);font-style:italic;color:var(--pine);font-size:1.02rem}
.related-grid .rel-common{color:var(--muted);font-size:.86rem}

/* ============================================================================
   VARIANT E — calm botanical home (centered hero, feature band, soft cards).
   Overrides/additions on top of the token remap above.
   ========================================================================== */
.hp-hero{max-width:54rem;margin:0 auto;text-align:center;padding:clamp(2.4rem,6vw,4.6rem) 0 clamp(1.5rem,4vw,2.6rem)}
.hp-eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-size:.9rem;font-weight:600;color:var(--moss);
  background:var(--surface);border:1px solid var(--line-2);padding:.46rem 1.05rem;border-radius:999px;box-shadow:var(--sh-1)}
.hp-eyebrow .lf{color:var(--gold)}
.hp-h{font-family:var(--display);font-weight:400;font-size:clamp(2.6rem,6vw,4.6rem);line-height:1.04;
  letter-spacing:-.01em;color:var(--ink);margin:1.5rem 0 0}
.hp-dek{font-size:clamp(1.1rem,1.6vw,1.26rem);color:var(--ink-2);max-width:36rem;margin:1.4rem auto 0;line-height:1.6}
.hp-dek .stop{display:block;margin-top:.45rem;font-family:var(--display);font-style:italic;color:var(--moss);font-size:1.06em}
.hp-hint{color:var(--muted);font-size:.96rem;margin:1.1rem auto 0}
.hp-hint em,.hp-hint b{color:var(--moss);font-style:normal;font-weight:600}

/* hero search → calm pill, centered & larger */
.hero-search{max-width:560px;margin:2.1rem auto 0;justify-content:center}
.hero-search input{padding:1rem 1.3rem;padding-inline-start:3.1rem;font-size:1.05rem;border:1px solid var(--line-2);
  border-radius:999px;background:var(--surface);box-shadow:var(--sh-2)}
.hero-search .s-ico{inset-inline-start:1.2rem;color:var(--moss)}
.hero-search input:focus{background:#fff;border-color:var(--moss);box-shadow:0 0 0 3px rgba(91,122,90,.16)}
.hero-search button{padding:1rem 1.7rem;border-radius:999px}

/* feature band — forest quote + leaf */
.hp-feature{max-width:var(--maxw);margin:1.5rem auto 0;background:var(--pine);color:#e3ecdf;border-radius:var(--r-lg);
  padding:clamp(1.8rem,4vw,2.8rem);display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;
  position:relative;overflow:hidden}
.hp-feature::after{content:"";position:absolute;inset-inline-end:-60px;top:-60px;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(169,199,173,.2),transparent 65%)}
.hp-quote{font-family:var(--display);font-style:italic;font-size:clamp(1.3rem,2.4vw,1.75rem);line-height:1.32;
  color:#eef4ea;max-width:32rem;margin:0;position:relative}
.hp-leaf{width:clamp(80px,12vw,120px);height:auto;color:#9fc7a3;position:relative}

/* centered section heads (home) */
.sec-head.center{display:block;text-align:center;border-bottom:0;padding-bottom:0;margin-bottom:1.8rem}
.sec-head.center .block-h{font-weight:400}
.chips.center{justify-content:center}

/* traditions — soft rounded tiles with a region tag (E) */
.tradition-grid{grid-template-columns:repeat(auto-fit,minmax(248px,1fr))}
.trad{border-radius:var(--r-lg);padding:1.5rem;gap:.4rem}
.trad:nth-child(3n+1){background:var(--paper-3);border-color:transparent}
.trad .t-tag{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--moss)}
.trad .t-name{font-family:var(--display);font-weight:500;font-size:1.24rem;color:var(--ink);line-height:1.15}
.trad .t-desc{color:var(--ink-2);font-size:.92rem;line-height:1.5}

/* soften the rest for the calm look */
.featured-grid{grid-template-columns:repeat(auto-fill,minmax(196px,1fr));gap:1.1rem}
.feat-card{border-radius:var(--r-lg);padding:1.6rem 1.1rem 1.4rem}
.feat-art{width:52px;height:52px;margin-bottom:.9rem}
.feat-art svg{width:28px;height:28px}
.step{border:1px solid var(--line)}

/* ====================================================== PREFOOTER (E) ======= */
.prefoot{margin-top:clamp(3rem,6vw,4.5rem)}
.prefoot-wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.1rem,4vw,2rem)}
.newsletter{background:var(--pine);color:#e3ecdf;border-radius:var(--r-lg);
  padding:clamp(2.4rem,5vw,3.7rem) clamp(1.4rem,4vw,2.6rem);
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.25rem;
  position:relative;overflow:hidden}
.newsletter::after{content:"";position:absolute;inset-inline-end:-70px;top:-70px;width:260px;height:260px;
  border-radius:50%;background:radial-gradient(circle,rgba(169,199,173,.18),transparent 65%)}
.newsletter::before{content:"";position:absolute;inset-inline-start:-60px;bottom:-80px;width:240px;height:240px;
  border-radius:50%;background:radial-gradient(circle,rgba(169,199,173,.12),transparent 65%)}
.nl-copy{position:relative;max-width:42rem}
.nl-eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-l);font-weight:700;margin:0 0 .55rem}
.nl-copy h2{font-family:var(--display);font-weight:500;font-size:clamp(1.8rem,3.4vw,2.6rem);color:#fff;margin:0;line-height:1.12}
.nl-copy p{color:#c2d4c5;margin:.6rem auto 0;max-width:36rem;font-size:1.05rem;line-height:1.5}
.nl-form{position:relative;display:flex;gap:.6rem;width:100%;max-width:33rem}
.nl-form input{flex:1;border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.1);color:#fff;border-radius:999px;
  padding:.95rem 1.4rem;font:inherit;font-size:1.05rem;min-width:0;outline:none;transition:.18s var(--ease)}
.nl-form input::placeholder{color:#9fb6a3}
.nl-form input:focus{border-color:var(--gold-l);background:rgba(255,255,255,.15)}
.nl-form button{border:0;background:#f3f6ef;color:var(--pine-d);font:inherit;font-weight:700;font-size:1.05rem;
  border-radius:999px;padding:.95rem 1.85rem;cursor:pointer;white-space:nowrap;transition:.18s var(--ease)}
.nl-form button:hover{background:#fff;transform:translateY(-1px)}
.nl-privacy{position:relative;color:#9fb6a3;font-size:.84rem;margin:0}
.nl-privacy a{color:#cfe0d3;text-decoration:underline}

/* A–Z browse nav */
.az-nav{margin-top:1.6rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.az-label{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700;flex:none}
.az-letters{display:flex;flex-wrap:wrap;gap:.35rem}
.az-letters a{display:grid;place-items:center;width:2rem;height:2rem;border-radius:8px;border:1px solid var(--line-2);
  background:var(--surface);color:var(--ink-2);font-size:.88rem;font-weight:600;transition:.15s var(--ease)}
.az-letters a:hover{border-color:var(--moss);color:var(--pine);text-decoration:none;background:var(--paper-3)}
.az-letters a.active{background:var(--pine);color:#fff;border-color:var(--pine)}
.az-top{justify-content:center;margin:1.2rem 0 2rem}

/* browse / listing CTA */
.listing-more{text-align:center;margin-top:1.6rem}
.more-link{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--pine);
  border:1px solid var(--line-2);border-radius:999px;padding:.6rem 1.3rem;background:var(--surface)}
.more-link:hover{border-color:var(--moss);text-decoration:none;background:var(--paper-3);color:var(--pine-d)}

/* ============================================================ FAQ (plant) === */
.faq{margin:2.2rem 0 .5rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.faq>h2{font-family:var(--display);font-weight:500;font-size:1.4rem;color:var(--ink);margin:0 0 1rem}
.faq-item{border:1px solid var(--line-2);border-radius:var(--r);background:var(--surface);margin-bottom:.7rem;
  padding:0 1.1rem;transition:border-color .15s var(--ease)}
.faq-item summary{cursor:pointer;list-style:none;padding:.95rem 0;font-weight:600;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--moss);font-size:1.4rem;font-weight:400;line-height:1;transition:transform .2s var(--ease)}
.faq-item[open]{border-color:var(--moss)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{margin:0 0 1rem;color:var(--ink-2);line-height:1.62;max-width:var(--measure)}

/* subscribe confirmation */
.confirm{max-width:34rem;margin:clamp(2rem,6vw,4rem) auto;text-align:center;background:var(--surface);
  border:1px solid var(--line-2);border-radius:var(--r-lg);padding:clamp(2rem,5vw,3.2rem);box-shadow:var(--sh-1)}
.confirm-ico{font-size:2.6rem;line-height:1}
.confirm h1{font-family:var(--display);font-weight:500;font-size:2rem;color:var(--ink);margin:.6rem 0 .5rem}
.confirm p{color:var(--ink-2);margin:0 0 1.5rem}

@media(max-width:560px){.nl-form{flex-direction:column}.nl-form button{width:100%}}

/* ==================================================== CONDITION pages (E) === */
.chip.active{background:var(--pine);color:#fff;border-color:var(--pine)}
.chip.active svg{color:#cfe0d3}
.cond-lead{text-align:center;max-width:46rem;margin:.2rem auto 0;color:var(--ink-2);font-size:1.08rem;line-height:1.6}
.cond-nav{margin:1.6rem 0 1rem}
.cond-count{text-align:center;color:var(--muted);font-size:.88rem;margin:0 0 1.4rem;letter-spacing:.05em;
  text-transform:uppercase;font-weight:600}
.use-link{color:var(--pine);text-decoration:none;border-bottom:1px dashed var(--line-2);transition:.15s var(--ease)}
.use-link:hover{color:var(--pine-d);border-color:var(--moss);text-decoration:none}

/* condition links row (prefoot) — auto-width pills, not square letters */
.az-letters.cond-row a{width:auto;height:auto;padding:.4rem .9rem;border-radius:999px;font-weight:600}

/* in-content (in-text) internal links — subtle, reads as prose */
.in-link{color:var(--pine);text-decoration:underline;text-decoration-color:var(--line-2);
  text-underline-offset:3px;text-decoration-thickness:1px;transition:.15s var(--ease)}
.in-link:hover{color:var(--pine-d);text-decoration-color:var(--moss)}

/* strong warning banner — non-traditional treatment topics */
.banner-warn{background:#fbe9e3;border-color:#e9c4b6;border-inline-start-color:var(--rust);color:#7a3318}
.banner-warn .banner-ico{color:var(--rust)}
