
:root{--bg:#fcfaf2;--ink:#12241d;--muted:#4a5f54;--card:#f5f2e6;--line:#dbd6c3;
  --accent:#c97a34;--on-accent:#fcfaf2;--thumb-bg:#ece7d4;
  --display:'Playfair Display',Georgia,serif;--body:'Lora',Georgia,serif;
  --maxw:1120px;--card-r:4px;--btn-r:4px;--h-weight:700;--wm-weight:800;
  --shadow:0 12px 30px rgba(18,36,29,.12);
  --pat:repeating-linear-gradient(0deg,#ece7d4 0 2px,transparent 2px 20px)}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--body);
  line-height:1.7;font-size:1.0625rem}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent)}
::selection{background:var(--accent);color:var(--bg)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* masthead */
.mast{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.mast-in{display:flex;align-items:center;justify-content:space-between;gap:16px;
  max-width:var(--maxw);margin:0 auto;padding:14px 24px}
.wordmark{font-family:var(--display);font-weight:var(--wm-weight,800);
  font-size:1.35rem;color:var(--ink);text-decoration:none;letter-spacing:var(--wm-track,0)}
.mast nav{display:flex;gap:20px;align-items:center}
.mast nav a{color:var(--muted);text-decoration:none;font-size:.92rem;font-weight:600}
.mast nav a:hover{color:var(--ink)}

/* hero */
.hero{position:relative;overflow:hidden;padding:72px 0 56px}
.hero .kicker{font-size:.8rem;font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);margin:0 0 14px}
.hero h1{font-family:var(--display);font-size:clamp(2.6rem,7vw,4.6rem);
  line-height:1.02;margin:0 0 20px;font-weight:var(--h-weight,800);color:var(--ink)}
.hero .about{max-width:620px;font-size:1.18rem;line-height:1.65;color:var(--muted);margin:0}
.hero-cta{margin-top:28px;display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-block;padding:12px 22px;border-radius:var(--btn-r,10px);
  font-weight:700;font-size:.95rem;text-decoration:none;
  background:var(--accent);color:var(--on-accent,#fff);border:1px solid var(--accent)}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn:hover{filter:brightness(1.08)}

/* video band */
.video-band{padding:8px 0 40px}
.video-band h2{font-family:var(--display);font-size:1.3rem;margin:0 0 14px;color:var(--ink)}
.frame{position:relative;aspect-ratio:16/9;border-radius:var(--card-r,14px);
  overflow:hidden;border:1px solid var(--line);background:#000;
  box-shadow:var(--shadow,0 18px 50px rgba(0,0,0,.18))}
.frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* search + filter */
.toolbar{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin:8px 0 26px}
.search{flex:1;min-width:240px;position:relative}
.search input{width:100%;padding:13px 18px 13px 44px;font:inherit;font-size:1rem;
  color:var(--ink);background:var(--card);border:1px solid var(--line);
  border-radius:var(--btn-r,10px);outline:none}
.search input:focus{border-color:var(--accent)}
.search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:18px;height:18px;stroke:var(--muted);fill:none;stroke-width:2}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:.8rem;font-weight:600;padding:7px 13px;border-radius:999px;cursor:pointer;
  background:var(--card);color:var(--muted);border:1px solid var(--line);
  text-decoration:none;transition:.15s}
.chip:hover,.chip.on{background:var(--accent);color:var(--on-accent,#fff);border-color:var(--accent)}
.count{color:var(--muted);font-size:.85rem;margin:0 0 18px}

/* grid + cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px;
  padding-bottom:64px}
.card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);
  border-radius:var(--card-r,14px);overflow:hidden;text-decoration:none;color:var(--ink);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s}
.card:hover{transform:translateY(-4px);border-color:var(--accent);
  box-shadow:var(--shadow,0 18px 40px rgba(0,0,0,.16))}
.card .thumb{aspect-ratio:16/9;overflow:hidden;background:var(--thumb-bg)}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .thumb img{transform:scale(1.045)}
.card .thumb.pat{display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:3rem;color:var(--accent);
  background:var(--pat,var(--thumb-bg))}
.card-b{padding:18px 20px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.card h3{margin:0;font-family:var(--display);font-size:1.18rem;line-height:1.3;
  font-weight:var(--h-weight,700)}
.card p{margin:0;color:var(--muted);font-size:.92rem;line-height:1.55;flex:1}
.card .meta{display:flex;gap:10px;align-items:center;color:var(--muted);
  font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.card.featured{grid-column:1/-1}
@media(min-width:760px){
  .card.featured{flex-direction:row}
  .card.featured .thumb{flex:0 0 54%;aspect-ratio:auto;min-height:320px}
  .card.featured .card-b{justify-content:center;padding:34px 38px}
  .card.featured h3{font-size:1.9rem}
  .card.featured p{font-size:1.05rem;flex:0}
}

/* article */
.post-head{padding:64px 0 8px;max-width:760px;margin:0 auto}
.post-head .ptags{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.post-head h1{font-family:var(--display);font-size:clamp(2rem,5.4vw,3.3rem);
  line-height:1.07;margin:0 0 18px;font-weight:var(--h-weight,800)}
.standfirst{font-size:1.22rem;line-height:1.6;color:var(--muted);margin:0 0 14px}
.byline{color:var(--muted);font-size:.85rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;margin:0 0 28px}
article{max-width:760px;margin:0 auto;padding-bottom:24px}
article .feat{border-radius:var(--card-r,14px);overflow:hidden;margin:0 0 34px;
  border:1px solid var(--line)}
article h1{display:none}
article h2{font-family:var(--display);font-size:1.65rem;line-height:1.25;
  margin:2em 0 .5em;font-weight:var(--h-weight,700)}
article h3{font-family:var(--display);font-size:1.25rem;margin:1.6em 0 .4em}
article p{margin:1.05em 0}
article figure{margin:2em 0}
article figcaption{font-size:.85rem;color:var(--muted);margin-top:10px;
  border-left:3px solid var(--accent);padding-left:12px}
article table{width:100%;border-collapse:collapse;margin:1.6em 0;font-size:.93rem;
  border:1px solid var(--line)}
article th{font-family:var(--body);text-align:left;font-weight:700;
  background:var(--card);border-bottom:2px solid var(--accent)}
article th,article td{border-bottom:1px solid var(--line);padding:10px 12px}
article tr:last-child td{border-bottom:none}
article blockquote{margin:1.8em 0;padding:4px 0 4px 22px;border-left:3px solid var(--accent);
  font-style:italic;color:var(--muted);font-size:1.1rem}
article ul,article ol{padding-left:1.3em}
article li{margin:.4em 0}

/* affiliate promo card (rebuilt clean from source fragments) */
.promo{display:flex;gap:18px;align-items:center;justify-content:space-between;
  flex-wrap:wrap;background:var(--card);border:1px solid var(--line);
  border-left:4px solid var(--accent);border-radius:var(--card-r,14px);
  padding:20px 22px;margin:2em 0;font-size:.95rem}
.promo h4{margin:0 0 4px;font-family:var(--display);font-size:1.05rem}
.promo p{margin:0;color:var(--muted);font-size:.9rem}
.promo .promo-btn{white-space:nowrap;padding:10px 18px;border-radius:var(--btn-r,10px);
  background:var(--accent);color:var(--on-accent,#fff);font-weight:700;
  text-decoration:none;font-size:.88rem}
.promo .promo-tag{flex-basis:100%;font-size:.68rem;color:var(--muted);
  text-transform:uppercase;letter-spacing:.14em;margin:-6px 0 0}

/* related */
.related{max-width:760px;margin:0 auto;padding:18px 0 70px}
.related h2{font-family:var(--display);font-size:1.4rem;margin:0 0 18px}
.related .grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));padding-bottom:0}

/* tag archive */
.tag-hero{padding:64px 0 24px}
.tag-hero h1{font-family:var(--display);font-size:clamp(2rem,5vw,3rem);margin:0 0 8px}
.tag-hero p{color:var(--muted);margin:0 0 6px}

footer{border-top:1px solid var(--line);padding:36px 0 46px;margin-top:20px;
  color:var(--muted);font-size:.88rem}
footer .wrap{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
footer a{color:var(--muted)}
footer a:hover{color:var(--ink)}

@media(max-width:640px){
  .hero{padding:48px 0 36px}
  .mast nav{gap:14px}
  .mast nav a.hide-s{display:none}
}

body{background-image:radial-gradient(rgba(74,95,84,.04) 1px,transparent 1px);
  background-size:30px 30px}
.hero h1{font-style:italic}
.hero{border-bottom:4px double var(--line)}
.wordmark{font-style:italic;text-transform:uppercase;letter-spacing:.02em}
article > p:first-of-type::first-letter{font-family:var(--display);font-style:italic;
  font-size:3.6em;float:left;line-height:.82;padding:4px 10px 0 0;color:var(--accent)}
.card h3{font-style:italic}
footer{border-top:4px double var(--line)}
