/* ============================================================
   FIDEI — launch site v2
   Hand-built. No frameworks, no build step, no CDNs.
   Palette + type per 05-brand/color-palette-type.md (locked):
     Cream  #F5EFE4   primary background
     Ivory  #FBF7EF   layered / pull-quote background
     Sand   #D9CFBE   neutral support
     Peach  #F4D5C0   Baedi accent   (never used as text)
     Sage   #A9B79E   Midei accent   (never used as text)
     Terra  #C96F4A   Today accent + CTA bg only (Cream text)
     Ink    #1F1C18   Fidei Black — all text
   Type: DM Serif Display (display) / Inter variable (body)
   ============================================================ */

:root{
  --cream:#F5EFE4;
  --ivory:#FBF7EF;
  --sand:#D9CFBE;
  --peach:#F4D5C0;
  --sage:#A9B79E;
  --terra:#C96F4A;
  --ink:#1F1C18;
  --muted:#5B5347;            /* warm gray — 6.2:1 on Cream (AA) */

  --serif:"DM Serif Display", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --maxw:1200px;
  --gutter:clamp(20px, 5vw, 64px);
  --sec-y:clamp(88px, 12vw, 176px);
  --radius:18px;
  --hairline:1px solid rgba(31,28,24,.10);
  --shadow-soft:0 30px 70px -45px rgba(31,28,24,.45);
}

/* ---------- Fonts (self-hosted, subset woff2) ---------- */
@font-face{
  font-family:"DM Serif Display";
  src:url("../fonts/dm-serif-display.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"DM Serif Display";
  src:url("../fonts/dm-serif-display-italic.woff2") format("woff2");
  font-weight:400; font-style:italic; font-display:swap;
}
@font-face{
  font-family:"Inter";
  src:url("../fonts/inter-var.woff2") format("woff2");
  font-weight:100 900; font-style:normal; font-display:swap;
}

/* ---------- Reset-ish ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,picture{max-width:100%; display:block}
button,input,select{font:inherit; color:inherit}
a{color:var(--ink); text-decoration:none}
main{display:block}

:focus-visible{outline:2px solid var(--terra); outline-offset:3px; border-radius:4px}

.skip-link{
  position:absolute; left:-9999px; top:0; z-index:200;
  background:var(--ink); color:var(--cream); padding:12px 20px; border-radius:0 0 8px 0;
}
.skip-link:focus{left:0}

/* ---------- Type ---------- */
h1,h2,h3{
  font-family:var(--serif);
  font-weight:400;
  line-height:1.08;
  letter-spacing:-0.005em;
  margin:0 0 .45em;
}
h1{font-size:clamp(2.55rem, 6.4vw, 5.4rem)}
h2{font-size:clamp(1.95rem, 4.1vw, 3.3rem)}
h3{font-size:clamp(1.3rem, 2.1vw, 1.7rem)}
p{margin:0 0 1.1em}
p:last-child{margin-bottom:0}

.eyebrow{
  display:flex; align-items:center; gap:12px;
  font-size:11.5px; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted); margin:0 0 1.6em;
}
.eyebrow::before{
  content:""; width:34px; height:2px; background:var(--ink); flex:none;
  background:var(--accent, var(--ink));
}
.lead{
  font-size:clamp(1.06rem, 1.5vw, 1.25rem);
  color:var(--muted); max-width:56ch; font-weight:450;
}
.smallprint{
  font-size:12.5px; color:var(--muted); letter-spacing:.01em; line-height:1.7;
}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.center .lead{margin-inline:auto}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter)}
section{padding-block:var(--sec-y); position:relative}
.bg-ivory{background:var(--ivory)}
.bg-sand{background:var(--sand)}

/* ---------- Reveal-on-scroll ---------- */
.rv{opacity:0; transform:translateY(26px);
  transition:opacity .95s cubic-bezier(.22,1,.36,1), transform .95s cubic-bezier(.22,1,.36,1);
  transition-delay:var(--d, 0s);
  will-change:opacity, transform;
}
.rv.on{opacity:1; transform:none}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .rv{opacity:1; transform:none; transition:none}
  *{animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important}
}

/* ---------- Header ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:90;
  background:rgba(245,239,228,.86);
  -webkit-backdrop-filter:blur(12px) saturate(130%);
  backdrop-filter:blur(12px) saturate(130%);
  border-bottom:1px solid transparent;
  transition:border-color .3s;
}
.site-header.scrolled{border-bottom-color:rgba(31,28,24,.08)}
.header-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter);
  display:flex; align-items:center; justify-content:space-between;
  height:72px;
}
.brand{display:flex; align-items:baseline; gap:10px; border:0}
.brand img{height:24px; width:auto}
.brand .say{
  font-size:11px; letter-spacing:.14em; color:var(--muted); font-weight:500;
  transform:translateY(-1px);
}
.site-nav{display:flex; align-items:center; gap:30px}
.site-nav a{
  font-size:14px; font-weight:500; letter-spacing:.02em; color:var(--ink);
  padding:10px 2px; border-bottom:1px solid transparent; transition:border-color .25s;
}
.site-nav a:hover{border-bottom-color:var(--ink)}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-height:48px; padding:13px 26px; border-radius:999px;
  background:var(--terra); color:var(--cream); border:1px solid var(--terra);
  font-size:14.5px; font-weight:600; letter-spacing:.02em; cursor:pointer;
  transition:background .25s, border-color .25s, transform .2s;
}
.btn:hover{background:var(--ink); border-color:var(--ink); color:var(--cream); transform:translateY(-1px)}
.site-nav .btn{min-height:44px; padding:11px 22px}

.menu-toggle{
  display:none; background:none; border:0; cursor:pointer;
  width:48px; height:48px; padding:12px; margin-right:-10px;
}
.menu-toggle span{display:block; width:24px; height:2px; background:var(--ink); margin:5px 0; transition:transform .25s, opacity .25s}
body.menu-open .menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .menu-toggle span:nth-child(2){opacity:0}
body.menu-open .menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:840px){
  .menu-toggle{display:block}
  /* NOTE: the header's backdrop-filter creates a containing block, so a
     position:fixed nav would size against the 72px header box. Anchor it
     absolutely to the header instead and give it an explicit height. */
  .site-nav{
    position:absolute; top:100%; left:0; right:0; z-index:80;
    height:calc(100svh - 72px);
    overflow:auto;
    background:var(--cream);
    border-top:1px solid rgba(31,28,24,.08);
    flex-direction:column; align-items:flex-start; gap:0;
    padding:24px var(--gutter) 40px;
    display:none;
  }
  body.menu-open .site-nav{display:flex}
  .site-nav a{
    font-family:var(--serif); font-size:30px; letter-spacing:0;
    padding:16px 0; width:100%; border-bottom:1px solid rgba(31,28,24,.08);
  }
  .site-nav a:hover{border-bottom-color:rgba(31,28,24,.08)}
  .site-nav .btn{
    font-family:var(--sans); font-size:16px; margin-top:28px;
    width:100%; min-height:54px; border-bottom:1px solid var(--terra);
  }
  .site-nav a.btn{color:var(--cream)} /* brand lock: Terracotta CTA always carries Cream text */
  body.menu-open{overflow:hidden}
}

/* ---------- Hero ---------- */
.hero{
  position:relative; padding:0;
  min-height:100svh;
  display:flex; flex-direction:column;
}
.hero-media{
  position:absolute; inset:0; overflow:hidden; z-index:0;
}
.hero-media img{
  width:100%; height:112%; object-fit:cover; object-position:center 82%;
  will-change:transform;
}
/* blend the render's cream into page cream at the top, under the header/headline */
.hero-media::before{
  content:""; position:absolute; left:0; right:0; top:0; height:42%;
  background:linear-gradient(to bottom, var(--cream) 0%, rgba(245,239,228,.55) 55%, rgba(245,239,228,0) 100%);
  z-index:1; pointer-events:none;
}
.hero-copy{
  position:relative; z-index:2;
  max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter);
  padding-top:clamp(132px, 19vh, 200px);
  text-align:center;
  width:100%;
}
.hero-copy .eyebrow{justify-content:center}
.hero-copy .eyebrow::before{display:none}
.hero-copy h1{max-width:15ch; margin-inline:auto; margin-bottom:.4em}
.hero-copy .lead{margin-inline:auto; max-width:62ch; color:var(--ink); opacity:.78}
.hero-ctas{margin-top:34px; display:flex; justify-content:center}
.hero-ctas .btn{min-height:54px; padding:15px 34px; font-size:15.5px}

.scroll-cue{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--ink);
  opacity:.62; border:0;
}
.scroll-cue::after{
  content:""; width:1px; height:34px; background:var(--ink);
  animation:cue 2.6s ease-in-out infinite;
  transform-origin:top;
}
@keyframes cue{
  0%,100%{transform:scaleY(.35); opacity:.3}
  50%{transform:scaleY(1); opacity:.8}
}
@media (prefers-reduced-motion: reduce){ .scroll-cue::after{animation:none} }

.render-tag{
  position:absolute; right:14px; bottom:12px; z-index:2;
  font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink); opacity:.75;
}

/* Mobile hero: copy on cream, full un-cropped render beneath (no accidental crops) */
@media (max-width:759px){
  .hero{min-height:0; padding-bottom:56px}
  .hero-media{
    position:relative; inset:auto; order:2; margin-top:34px;
  }
  .hero-media img{height:auto; aspect-ratio:2752/1536; object-fit:cover; object-position:center bottom}
  .hero-media::before{height:26%}
  .hero-copy{padding-top:118px; order:1}
  .scroll-cue{display:none}
  .render-tag{bottom:8px}
}

/* ---------- Thesis strip ---------- */
.thesis{background:var(--ivory)}
.thesis .container{max-width:980px}
.thesis blockquote{
  margin:0;
  font-family:var(--serif); font-style:italic;
  font-size:clamp(1.9rem, 4.6vw, 3.4rem);
  line-height:1.16; letter-spacing:-0.005em;
}
.thesis blockquote .q-mark{color:var(--terra)}
.thesis figcaption{
  margin-top:28px; font-size:13.5px; color:var(--muted); letter-spacing:.02em; line-height:1.7;
}
.thesis .after{
  margin-top:34px; font-size:clamp(1.05rem, 1.5vw, 1.2rem); color:var(--ink); max-width:46ch;
}

/* ---------- Product stories ---------- */
.product{padding-block:var(--sec-y)}
.product .grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(44px, 6.5vw, 104px);
  align-items:center;
}
.product.flip .grid > .p-media{order:2}
.product.flip .grid > .p-copy{order:1}

.p-copy h2{max-width:16ch}
.p-copy .story{max-width:52ch}
.p-copy .story strong{font-weight:600}

.p-media{position:relative}
.collage{position:relative; padding-bottom:clamp(56px, 9vw, 96px); padding-left:clamp(26px, 4vw, 48px)}
.collage .main{
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft);
  background:var(--sand);
}
.collage .main img{width:100%; height:auto}
.collage .side{
  position:absolute; left:0; bottom:0; width:42%;
  border-radius:14px; overflow:hidden;
  border:6px solid var(--cream);
  box-shadow:0 24px 50px -30px rgba(31,28,24,.5);
  background:var(--sand);
}
.collage .side img{width:100%; height:auto}
.p-media .render-note{
  position:absolute; right:4px; bottom:clamp(30px, 5vw, 64px);
  font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted);
}
.product.flip .collage{padding-left:0; padding-right:clamp(26px, 4vw, 48px)}
.product.flip .collage .side{left:auto; right:0}
.product.flip .p-media .render-note{right:auto; left:4px}

/* honest spec block */
.specs{
  margin:30px 0 0; padding:22px 0 4px;
  border-top:var(--hairline);
}
.specs h3{
  font-family:var(--sans); font-size:11.5px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--muted);
  margin:0 0 14px;
}
.specs ul{list-style:none; margin:0; padding:0; display:grid; gap:10px}
.specs li{
  position:relative; padding-left:22px;
  font-size:15px; line-height:1.55; color:var(--ink);
}
.specs li::before{
  content:""; position:absolute; left:2px; top:9px;
  width:7px; height:7px; border-radius:50%;
  background:var(--accent, var(--sand));
}
.buyline{
  margin-top:30px; display:flex; align-items:center; gap:18px; flex-wrap:wrap;
}
.price{font-family:var(--serif); font-size:clamp(1.9rem, 2.6vw, 2.5rem); line-height:1}
.chip{
  display:inline-flex; align-items:center; gap:9px;
  border:1px solid rgba(31,28,24,.22); border-radius:999px;
  padding:9px 16px; font-size:13px; font-weight:550; letter-spacing:.04em;
}
.chip::before{
  content:""; width:8px; height:8px; border-radius:50%;
  background:var(--accent, var(--ink));
}

/* per-SKU accents (decorative only — text stays Ink) */
.product.midei{--accent:var(--sage)}
.product.baedi{--accent:var(--peach)}
.product.today{--accent:var(--terra)}
.product.baedi{background:var(--ivory)}

@media (max-width:899px){
  .product .grid{grid-template-columns:1fr; gap:42px}
  .product.flip .grid > .p-media{order:1}
  .product.flip .grid > .p-copy{order:2}
  .p-copy h2{max-width:none}
}

/* ---------- Why now ---------- */
.why .stats{
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:clamp(28px, 4vw, 56px);
  margin-top:clamp(44px, 6vw, 72px);
  align-items:start;
}
.stat .num{
  font-family:var(--serif);
  font-size:clamp(2.7rem, 5.2vw, 4.6rem);
  line-height:1; letter-spacing:-0.01em;
  font-variant-numeric:tabular-nums;
  font-feature-settings:"tnum" 1;
  white-space:nowrap;
}
.stat .num .unit{font-size:.55em}
.stat .delta{
  display:inline-block; margin-top:10px;
  font-size:12px; font-weight:600; letter-spacing:.06em; color:var(--muted);
  border:1px solid rgba(31,28,24,.18); border-radius:999px; padding:5px 12px;
}
.stat .label{margin-top:14px; font-size:14.5px; color:var(--muted); line-height:1.55; max-width:24ch}
.stat .accent-rule{width:34px; height:3px; background:var(--terra); margin-bottom:18px}
.stat:nth-child(2) .accent-rule{background:var(--sage)}
.stat:nth-child(3) .accent-rule{background:var(--peach)}
.stat:nth-child(4) .accent-rule{background:var(--sand)}
.why .sources{
  margin-top:clamp(40px, 6vw, 64px); padding-top:22px; border-top:var(--hairline);
  max-width:880px;
}
@media (max-width:899px){
  .why .stats{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width:520px){
  .why .stats{grid-template-columns:1fr 1fr; gap:34px 20px}
  .stat .num{font-size:clamp(2.1rem, 9.4vw, 2.7rem)}
  .stat .label{max-width:none}
}

/* ---------- Family / system ---------- */
.family{background:var(--cream)}
.family .lockup{
  width:clamp(120px, 15vw, 168px); height:auto; margin:0 auto clamp(36px, 5vw, 56px);
}
.family h2{max-width:22ch; margin-inline:auto}
.family .lead{max-width:58ch}
.lifecycle{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:clamp(18px, 2.5vw, 32px);
  margin-top:clamp(48px, 7vw, 80px);
}
.stage{position:relative}
.stage .ph{border-radius:14px; overflow:hidden; background:var(--sand); box-shadow:var(--shadow-soft)}
.stage .ph img{width:100%; height:100%; object-fit:cover; aspect-ratio:4/3.4}
.stage figcaption{
  margin-top:16px; display:flex; flex-direction:column; gap:3px;
}
.stage .k{font-size:11px; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--muted)}
.stage .v{font-family:var(--serif); font-size:clamp(1.15rem, 1.6vw, 1.4rem)}
.lifecycle-arrow{color:var(--muted)}
@media (max-width:759px){
  .lifecycle{grid-template-columns:1fr; max-width:430px; margin-inline:auto}
}

/* ---------- Waitlist ---------- */
.waitlist{background:var(--sand)}
/* Sand is darker than Cream/Ivory — muted text needs extra depth for AA (4.5:1) */
.waitlist .eyebrow, .waitlist .lead{color:#48423A}
.waitlist .container{max-width:880px}
.wl-card{
  background:var(--ivory); border-radius:22px;
  padding:clamp(28px, 4.5vw, 52px);
  margin-top:clamp(34px, 5vw, 48px);
  box-shadow:0 36px 80px -55px rgba(31,28,24,.5);
}
.wl-form{display:grid; gap:20px}
.wl-form .two{display:grid; grid-template-columns:1fr 1fr; gap:20px}
@media (max-width:620px){ .wl-form .two{grid-template-columns:1fr} }
.wl-form label{
  display:block; font-size:11.5px; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted); margin-bottom:9px;
}
.wl-form input[type="email"],
.wl-form input[type="text"],
.wl-form select{
  width:100%; min-height:50px; padding:13px 16px;
  border-radius:12px; border:1px solid rgba(31,28,24,.22);
  background:#fff; color:var(--ink); font-size:16px;
  transition:border-color .2s, box-shadow .2s;
  appearance:none; -webkit-appearance:none;
}
.wl-form .select-wrap{position:relative}
.wl-form .select-wrap::after{
  content:""; position:absolute; right:18px; top:50%;
  width:8px; height:8px; border-right:1.6px solid var(--muted); border-bottom:1.6px solid var(--muted);
  transform:translateY(-70%) rotate(45deg); pointer-events:none;
}
.wl-form input:focus, .wl-form select:focus{
  outline:none; border-color:var(--terra);
  box-shadow:0 0 0 3px rgba(201,111,74,.22);
}
.wl-form input[aria-invalid="true"]{border-color:var(--terra)}
.field-err{display:none; margin-top:8px; font-size:13px; color:#8C3D1E; font-weight:500}
.field-err.show{display:block}
.wl-form .btn{min-height:54px; font-size:15.5px; justify-self:start; padding:15px 34px}
.hp-field{position:absolute !important; left:-9999px !important; width:1px; height:1px; overflow:hidden}
.form-note{font-size:13px; color:var(--muted); margin:0}
.form-status{
  display:none; border-radius:12px; padding:18px 20px; font-weight:500; font-size:15.5px;
  background:rgba(169,183,158,.35); border:1px solid var(--sage);
}
.form-status.show{display:block}
.form-status.err{background:rgba(201,111,74,.14); border-color:var(--terra)}

/* ---------- FAQ ---------- */
.faq .container{max-width:880px}
.faq-list{margin-top:clamp(34px, 5vw, 52px); border-top:var(--hairline)}
.faq-list details{border-bottom:var(--hairline)}
.faq-list summary{
  list-style:none; cursor:pointer;
  display:flex; align-items:baseline; justify-content:space-between; gap:24px;
  padding:24px 2px;
  font-family:var(--serif); font-size:clamp(1.2rem, 2vw, 1.5rem); line-height:1.25;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary .ind{
  flex:none; position:relative; width:14px; height:14px; transform:translateY(-1px);
}
.faq-list summary .ind::before,
.faq-list summary .ind::after{
  content:""; position:absolute; background:var(--terra); transition:transform .25s;
}
.faq-list summary .ind::before{left:0; right:0; top:6px; height:2px}
.faq-list summary .ind::after{top:0; bottom:0; left:6px; width:2px}
.faq-list details[open] summary .ind::after{transform:scaleY(0)}
.faq-list .a{
  padding:0 2px 26px; max-width:66ch;
  color:var(--ink); font-size:15.5px; line-height:1.7;
}
.faq-list .a p{margin-bottom:.9em}
.faq-list summary:hover{color:#3d362d}
.tag-placeholder{
  display:inline-block; margin-left:8px; vertical-align:2px;
  font-family:var(--sans); font-size:10px; font-weight:600; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted);
  border:1px solid rgba(31,28,24,.2); border-radius:999px; padding:3px 9px;
}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--ivory); border-top:var(--hairline);
  padding:clamp(64px, 9vw, 110px) var(--gutter) 40px;
  text-align:center;
}
.site-footer .lockup{width:104px; height:auto; margin:0 auto 30px; opacity:.92}
.site-footer .tagline{
  font-family:var(--serif); font-size:clamp(1.35rem, 2.4vw, 1.8rem); margin:0 0 26px;
}
.foot-meta{display:grid; gap:9px; justify-items:center; margin-bottom:34px}
.foot-meta p{margin:0; font-size:14px; color:var(--muted)}
.foot-meta a{border-bottom:1px solid rgba(31,28,24,.25); transition:border-color .2s; padding-bottom:1px}
.foot-meta a:hover{border-bottom-color:var(--ink)}
.foot-honesty{
  max-width:560px; margin:0 auto 36px; padding:14px 22px;
  border:1px solid rgba(31,28,24,.14); border-radius:12px;
  font-size:13px; color:var(--muted); line-height:1.65;
}
.foot-base{
  border-top:var(--hairline); padding-top:26px;
  display:flex; justify-content:center; gap:10px 28px; flex-wrap:wrap;
  font-size:12.5px; color:var(--muted);
}
.foot-base a{color:var(--muted); border-bottom:1px solid transparent}
.foot-base a:hover{border-bottom-color:var(--muted)}

/* ---------- Press page ---------- */
.press-hero{padding-top:calc(72px + clamp(64px, 9vw, 120px))}
.press-hero h1{max-width:14ch}
.press-section{padding-block:clamp(40px, 6vw, 72px)}
.press-section + .press-section{border-top:var(--hairline)}
.press-section h2{font-size:clamp(1.6rem, 2.8vw, 2.2rem)}
.boiler{max-width:68ch}
.boiler .k{
  font-size:11.5px; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); margin:26px 0 10px;
}
.facts{width:100%; border-collapse:collapse; max-width:880px; font-size:15px}
.facts th, .facts td{
  text-align:left; padding:13px 18px 13px 0; vertical-align:top;
  border-bottom:var(--hairline);
}
.facts th{
  white-space:nowrap; font-weight:600; font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--muted); width:200px; padding-right:28px;
}
.dl-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
  gap:20px; margin-top:30px;
}
.dl-card{
  border:1px solid rgba(31,28,24,.14); border-radius:14px; overflow:hidden;
  background:var(--ivory); transition:transform .25s, box-shadow .25s;
  display:flex; flex-direction:column;
}
.dl-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-soft)}
.dl-card .thumb{
  aspect-ratio:16/10; display:flex; align-items:center; justify-content:center;
  background:var(--cream); padding:18px; border-bottom:var(--hairline);
}
.dl-card .thumb img{max-height:100%; width:auto; max-width:100%; object-fit:contain}
.dl-card .thumb.photo{padding:0}
.dl-card .thumb.photo img{width:100%; height:100%; object-fit:cover}
.dl-card .meta{padding:14px 16px 16px; display:flex; flex-direction:column; gap:4px}
.dl-card .meta b{font-size:14.5px; font-weight:600}
.dl-card .meta span{font-size:12.5px; color:var(--muted)}
.press-note{
  max-width:660px; padding:18px 22px; border-left:3px solid var(--terra);
  background:var(--ivory); border-radius:0 12px 12px 0;
  font-size:14.5px; color:var(--ink); line-height:1.7;
}
