/* =====================================================================
   ToursZoom — Magazine design system (mockup)
   Playfair Display (display) × Inter (text) · navy + coral
   This stylesheet is authored to migrate cleanly into the child theme.
   ===================================================================== */

:root{
  /* brand */
  --tz-navy:#103D62;
  --tz-navy-dk:#0C2E49;
  --tz-coral:#FF6B4A;
  --tz-ink:#1F1F1F;
  --tz-ink-2:#3A3A3A;
  --tz-muted:#6B7280;
  --tz-line:#E6E1D8;
  --tz-warm:#FAF7F2;
  --tz-photo:#D9D5CE;
  --tz-photo-2:#CFC9C0;
  --tz-white:#fff;

  /* type */
  --tz-serif:"Playfair Display", Georgia, "Times New Roman", serif;
  --tz-sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  /* layout */
  --tz-measure:720px;   /* reading column — never squeezed */
  --tz-rail:300px;      /* slim sidebar */
  --tz-gap:56px;
  --tz-hero:1120px;
}

*{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  margin:0;background:var(--tz-white);color:var(--tz-ink);
  font-family:var(--tz-sans);font-size:17px;line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---- placeholder "photo" block (mockup only) ---- */
.tz-photo{
  background:linear-gradient(135deg,var(--tz-photo) 0%,var(--tz-photo-2) 100%);
  border-radius:3px;display:flex;align-items:center;justify-content:center;
  color:#968d82;font-family:var(--tz-sans);font-weight:500;
  font-size:13px;letter-spacing:.08em;text-transform:uppercase;
}

/* ---- shared bits ---- */
.tz-eyebrow{
  font-family:var(--tz-sans);font-weight:600;font-size:13px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--tz-coral);margin:0;
}
.tz-credit{font-style:italic;font-size:13px;color:var(--tz-muted);margin:8px auto 0}
.tz-rule{height:1px;background:var(--tz-line);border:0;margin:0}

/* =====================================================================
   NAV
   ===================================================================== */
.tz-nav{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);
  backdrop-filter:saturate(1.2) blur(6px);
  border-bottom:1px solid var(--tz-line);
}
.tz-nav__in{
  max-width:1320px;margin:0 auto;padding:18px 40px;
  display:flex;align-items:center;justify-content:space-between;
}
.tz-logo{font-family:var(--tz-serif);font-weight:600;font-size:24px;color:var(--tz-navy)}
.tz-nav__links{display:flex;align-items:center;gap:28px}
.tz-nav__links a{font-weight:500;font-size:14px;color:var(--tz-ink)}
.tz-nav__links a:hover{color:var(--tz-coral)}
.tz-btn{
  display:inline-block;background:var(--tz-coral);color:#fff;font-weight:600;
  font-size:13px;letter-spacing:.02em;padding:9px 18px;border-radius:2px;border:0;cursor:pointer;
}
.tz-btn--lg{font-size:15px;padding:14px 26px;letter-spacing:.03em}

/* =====================================================================
   ARTICLE HEADER (centered)
   ===================================================================== */
.tz-head{max-width:780px;margin:0 auto;padding:64px 20px 36px;text-align:center}
.tz-breadcrumb{
  font-weight:500;font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--tz-muted);margin:0 0 18px;
}
.tz-head .tz-eyebrow{margin-bottom:16px}
.tz-title{
  font-family:var(--tz-serif);font-weight:600;color:var(--tz-navy);
  font-size:clamp(34px,5vw,52px);line-height:1.08;margin:0 0 18px;letter-spacing:-.01em;
}
.tz-dek{
  font-size:20px;line-height:1.5;color:var(--tz-ink-2);max-width:660px;margin:0 auto 22px;
}
.tz-byline{font-size:14px;color:var(--tz-muted);margin:0}
.tz-byline b{color:var(--tz-ink);font-weight:600}

/* hero */
.tz-hero{max-width:var(--tz-hero);margin:8px auto 0;padding:0 20px;text-align:center}
.tz-hero .tz-photo{height:560px}

/* =====================================================================
   TWO-COLUMN LAYOUT (main + slim sticky sidebar)
   Reading column stays 720px; sidebar drops into the right margin.
   ===================================================================== */
.tz-layout{
  max-width:calc(var(--tz-measure) + var(--tz-gap) + var(--tz-rail));
  margin:0 auto;padding:40px 20px 0;
  display:grid;grid-template-columns:var(--tz-measure) var(--tz-rail);
  gap:var(--tz-gap);align-items:start;
}
.tz-main{min-width:0}
.tz-aside{position:sticky;top:90px}

/* =====================================================================
   PROSE
   ===================================================================== */
.tz-prose{color:var(--tz-ink)}
.tz-prose p{font-size:19px;line-height:1.76;margin:0 0 26px}
.tz-prose .tz-lede{font-size:21px;line-height:1.68}
.tz-prose .tz-lede::first-letter{
  float:left;font-family:var(--tz-serif);font-weight:600;color:var(--tz-navy);
  font-size:4.4em;line-height:.78;padding:6px 12px 0 0;
}
.tz-prose h2{
  font-family:var(--tz-serif);font-weight:600;color:var(--tz-navy);
  font-size:30px;line-height:1.22;margin:14px 0 4px;
}
.tz-prose figure{margin:8px 0 26px}
.tz-prose figure .tz-photo{height:420px}
.tz-prose figcaption{font-style:italic;font-size:13px;color:var(--tz-muted);margin-top:8px}

.tz-pullquote{
  margin:8px 0 28px;padding:6px 0 6px 24px;border-left:4px solid var(--tz-coral);
  font-family:var(--tz-serif);font-style:italic;font-weight:500;color:var(--tz-navy);
  font-size:29px;line-height:1.38;
}

/* tasteful partner box inside body */
.tz-stay{
  background:var(--tz-warm);border-left:3px solid var(--tz-coral);border-radius:4px;
  padding:26px 28px;margin:6px 0 30px;
}
.tz-stay h3{font-family:var(--tz-serif);font-weight:600;color:var(--tz-navy);font-size:21px;line-height:1.24;margin:8px 0 8px}
.tz-stay p{font-size:16px;line-height:1.6;margin:0 0 12px}
.tz-stay a{font-weight:600;font-size:15px;color:var(--tz-coral)}

.tz-tips{list-style:none;padding:0;margin:0 0 8px}
.tz-tips li{position:relative;padding-left:22px;font-size:17px;line-height:1.6;margin:0 0 14px}
.tz-tips li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:2px;background:var(--tz-coral)}

/* =====================================================================
   SIDEBAR MODULES
   ===================================================================== */
.tz-rail{margin:0 0 36px}
.tz-rail__h{
  font-family:var(--tz-sans);font-weight:600;font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--tz-navy);margin:0 0 14px;
  padding-bottom:10px;border-bottom:2px solid var(--tz-navy);
}
/* TOC */
.tz-toc{list-style:none;margin:0;padding:0}
.tz-toc li{margin:0 0 11px}
.tz-toc a{font-size:14px;line-height:1.45;color:var(--tz-ink);border-left:2px solid var(--tz-line);padding-left:12px;display:block}
.tz-toc a:hover{color:var(--tz-coral);border-color:var(--tz-coral)}
/* trending */
.tz-trend{display:flex;flex-direction:column;gap:16px}
.tz-trend__item{display:flex;gap:12px;align-items:flex-start}
.tz-trend__thumb{width:72px;height:54px;flex:0 0 72px}
.tz-trend__t{font-family:var(--tz-serif);font-weight:600;font-size:15px;line-height:1.25;color:var(--tz-navy)}
.tz-trend__m{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--tz-muted);margin-top:4px}
/* partner card */
.tz-partner{background:var(--tz-navy);border-radius:4px;padding:22px;color:#fff}
.tz-partner .tz-eyebrow{color:#f0a895;margin-bottom:8px}
.tz-partner h4{font-family:var(--tz-serif);font-weight:600;font-size:18px;line-height:1.25;margin:0 0 10px}
.tz-partner p{font-size:13.5px;line-height:1.55;color:#c7d3de;margin:0 0 14px}
.tz-partner .tz-btn{width:100%;text-align:center}

/* =====================================================================
   ARTICLE FOOTER: tags + bio
   ===================================================================== */
.tz-foot{max-width:var(--tz-measure);margin:0 auto;padding:28px 20px}
.tz-tags{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 24px}
.tz-tags span{background:#F4F1EC;border-radius:999px;padding:7px 14px;font-weight:500;font-size:13px}
.tz-bio{display:flex;gap:18px;align-items:center;padding:24px 0;border-top:1px solid var(--tz-line);border-bottom:1px solid var(--tz-line)}
.tz-bio__av{width:64px;height:64px;border-radius:999px;flex:0 0 64px}
.tz-bio__n{font-family:var(--tz-serif);font-weight:600;font-size:18px;color:var(--tz-navy);margin:0 0 4px}
.tz-bio__b{font-size:15px;line-height:1.55;color:var(--tz-muted);margin:0}

/* =====================================================================
   RECIRC — "Keep reading"
   ===================================================================== */
.tz-recirc{background:var(--tz-warm);padding:48px 20px 56px;margin-top:24px}
.tz-recirc__in{max-width:var(--tz-hero);margin:0 auto}
.tz-recirc h2{font-family:var(--tz-serif);font-weight:600;font-size:28px;color:var(--tz-navy);margin:0 0 24px}
.tz-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.tz-card .tz-photo{height:220px;margin-bottom:12px}
.tz-card .tz-eyebrow{font-size:11px;margin-bottom:6px}
.tz-card h3{font-family:var(--tz-serif);font-weight:600;font-size:21px;line-height:1.2;color:var(--tz-navy);margin:0 0 6px}
.tz-card .tz-m{font-size:13px;color:var(--tz-muted);font-weight:500}

/* =====================================================================
   NEWSLETTER + FOOTER
   ===================================================================== */
.tz-news{background:var(--tz-navy);color:#fff;text-align:center;padding:64px 20px}
.tz-news h2{font-family:var(--tz-serif);font-weight:600;font-size:34px;margin:0 0 14px}
.tz-news p{color:#bfcedb;font-size:16px;margin:0 auto 22px;max-width:560px}
.tz-news__form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.tz-news input{width:360px;max-width:80vw;border:0;border-radius:2px;padding:0 18px;height:50px;font-family:var(--tz-sans);font-size:15px}

.tz-footer{background:var(--tz-navy-dk);color:#9fb1c0;padding:56px 20px 36px}
.tz-footer__in{max-width:var(--tz-hero);margin:0 auto}
.tz-footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.tz-footer__brand .tz-logo{color:#fff;display:block;margin-bottom:10px}
.tz-footer__brand p{font-size:14px;line-height:1.55;max-width:300px;margin:0}
.tz-footer h5{font-weight:600;font-size:13px;letter-spacing:.06em;color:#fff;margin:0 0 12px}
.tz-footer ul{list-style:none;margin:0;padding:0}
.tz-footer li{margin:0 0 12px;font-size:14px}
.tz-footer__bar{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.14);margin-top:32px;padding-top:20px;font-size:13px}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1040px){
  .tz-layout{grid-template-columns:minmax(0,720px);justify-content:center}
  .tz-aside{position:static;display:grid;grid-template-columns:1fr 1fr;gap:24px 32px;margin-top:16px}
  .tz-partner{grid-column:1 / -1}
}
@media (max-width:760px){
  body{font-size:16px}
  .tz-nav__links a:not(:last-child){display:none}
  .tz-prose p{font-size:18px}
  .tz-hero .tz-photo{height:300px}
  .tz-cards{grid-template-columns:1fr;gap:28px}
  .tz-footer__top{grid-template-columns:1fr 1fr}
  .tz-aside{grid-template-columns:1fr}
}

/* =====================================================================
   INDEX (magazine front) + ARCHIVE + LISTICLE additions
   ===================================================================== */
.tz-wrap{max-width:var(--tz-hero);margin:0 auto;padding:0 20px}

/* lead feature on index */
.tz-feature{max-width:var(--tz-hero);margin:0 auto;padding:48px 20px 8px;text-align:center}
.tz-feature .tz-photo{height:520px;margin-bottom:22px}
.tz-feature .tz-eyebrow{margin-bottom:14px}
.tz-feature h2{font-family:var(--tz-serif);font-weight:600;color:var(--tz-navy);
  font-size:clamp(30px,4.4vw,46px);line-height:1.1;margin:0 auto 14px;max-width:840px;letter-spacing:-.01em}
.tz-feature .tz-dek{margin-bottom:14px}

/* section band */
.tz-section{max-width:var(--tz-hero);margin:0 auto;padding:46px 20px}
.tz-section + .tz-section{border-top:1px solid var(--tz-line)}
.tz-section__head{display:flex;align-items:baseline;justify-content:space-between;margin:0 0 26px;gap:16px}
.tz-section__head h2{font-family:var(--tz-serif);font-weight:600;font-size:28px;color:var(--tz-navy);margin:0}
.tz-section__head a{font-weight:600;font-size:14px;color:var(--tz-coral)}
.tz-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.tz-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.tz-grid-4 .tz-photo{height:180px}

/* archive header */
.tz-archive{max-width:880px;margin:0 auto;padding:64px 20px 28px;text-align:center}
.tz-archive .tz-eyebrow{margin-bottom:14px}
.tz-archive h1{font-family:var(--tz-serif);font-weight:600;color:var(--tz-navy);
  font-size:clamp(40px,6vw,64px);line-height:1.04;margin:0 0 16px}
.tz-archive p{font-size:18px;line-height:1.6;color:var(--tz-ink-2);max-width:620px;margin:0 auto 14px}
.tz-archive .tz-count{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--tz-muted)}

/* archive 2-col + sidebar layout */
.tz-archive-layout{
  max-width:var(--tz-wide);margin:0 auto;padding:24px 20px 0;
  display:grid;grid-template-columns:minmax(0,1fr) var(--tz-rail);gap:var(--tz-gap);align-items:start;
}
.tz-archive-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px 32px}
.tz-archive-grid .tz-card .tz-photo{height:240px}

/* pagination */
.tz-pager{display:flex;gap:8px;justify-content:center;align-items:center;padding:48px 20px}
.tz-pager a,.tz-pager span{min-width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--tz-line);border-radius:2px;font-weight:500;font-size:14px;color:var(--tz-ink)}
.tz-pager .is-active{background:var(--tz-navy);color:#fff;border-color:var(--tz-navy)}

/* =====================================================================
   LISTICLE (/best/) entries
   ===================================================================== */
.tz-ftc{font-size:13px;color:var(--tz-muted);max-width:660px;margin:14px auto 0;
  padding-top:14px;border-top:1px solid var(--tz-line)}
.tz-xlinks{background:var(--tz-warm);border-radius:4px;padding:20px 24px;margin:8px 0 30px}
.tz-xlinks p{font-weight:600;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--tz-muted);margin:0 0 10px}
.tz-xlinks ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px 24px}
.tz-xlinks a{font-weight:600;color:var(--tz-navy);font-size:15px}
.tz-xlinks a:hover{color:var(--tz-coral)}

.tz-entry{margin:0 0 48px}
.tz-entry__top{display:flex;align-items:baseline;gap:16px;margin:0 0 14px}
.tz-entry__num{font-family:var(--tz-serif);font-weight:700;font-size:40px;color:var(--tz-coral);line-height:1;flex:0 0 auto}
.tz-entry__name{font-family:var(--tz-serif);font-weight:600;font-size:30px;line-height:1.15;color:var(--tz-navy);margin:0}
.tz-entry .tz-photo{height:480px;margin:0 0 8px;position:relative}
.tz-entry__save{position:absolute;top:14px;right:14px;width:40px;height:40px;border-radius:999px;
  background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--tz-navy);font-size:18px}
.tz-entry__credit{font-style:italic;font-size:13px;color:var(--tz-muted);margin:8px 0 16px}
.tz-entry p.tz-body{font-size:18px;line-height:1.72;margin:0 0 18px}
.tz-pills{display:flex;flex-wrap:wrap;gap:12px}
.tz-pill{display:inline-flex;align-items:center;gap:8px;background:var(--tz-navy);color:#fff;
  font-weight:600;font-size:14px;letter-spacing:.02em;padding:13px 22px;border-radius:2px}
.tz-pill--ghost{background:#fff;color:var(--tz-navy);border:1.5px solid var(--tz-navy)}
.tz-pill:hover{background:var(--tz-coral);color:#fff;border-color:var(--tz-coral)}

/* =====================================================================
   MAGAZINE FLOW — wide + full-bleed varied blocks (index / fronts)
   ===================================================================== */
:root{ --tz-wide:1400px; }
.tz-wide{max-width:var(--tz-wide);margin:0 auto;padding:0 40px}

/* full-bleed overlay hero: big image, headline laid over a bottom scrim */
.tz-bighero{position:relative;width:100%;height:min(78vh,680px);background:linear-gradient(135deg,var(--tz-photo),var(--tz-photo-2));overflow:hidden}
.tz-bighero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,28,45,.78) 0%,rgba(8,28,45,.15) 45%,rgba(8,28,45,0) 70%)}
.tz-bighero__ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#b7afa4;font-size:13px;letter-spacing:.1em;text-transform:uppercase}
.tz-bighero__in{position:absolute;left:0;right:0;bottom:0;z-index:2}
.tz-bighero__in .tz-wide{padding-bottom:48px}
.tz-bighero .tz-eyebrow{color:#ffb59f;margin-bottom:14px}
.tz-bighero h1{font-family:var(--tz-serif);font-weight:600;color:#fff;font-size:clamp(36px,5.2vw,60px);line-height:1.06;margin:0 0 14px;max-width:760px;letter-spacing:-.01em}
.tz-bighero p{color:#e7eef4;font-size:19px;line-height:1.5;max-width:600px;margin:0 0 12px}
.tz-bighero .tz-byline{color:#bcd0e0}

/* asymmetric: one big feature + stacked list */
.tz-split{display:grid;grid-template-columns:1.55fr 1fr;gap:48px;align-items:start;padding:64px 0}
.tz-bigcard .tz-photo{height:440px;margin-bottom:18px}
.tz-bigcard h2{font-family:var(--tz-serif);font-weight:600;font-size:34px;line-height:1.12;color:var(--tz-navy);margin:0 0 12px}
.tz-bigcard p.tz-dek{font-size:18px;text-align:left;margin:0 0 10px}
.tz-list{display:flex;flex-direction:column;gap:22px;border-left:1px solid var(--tz-line);padding-left:32px}
.tz-list__item{display:flex;gap:16px;align-items:flex-start}
.tz-list__thumb{width:96px;height:72px;flex:0 0 96px}
.tz-list__t{font-family:var(--tz-serif);font-weight:600;font-size:18px;line-height:1.22;color:var(--tz-navy)}
.tz-list__m{font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--tz-muted);margin-top:6px}

/* full-bleed bands */
.tz-band{width:100%;padding:72px 0}
.tz-band--warm{background:var(--tz-warm)}
.tz-band__head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:0 0 30px}
.tz-band__head h2{font-family:var(--tz-serif);font-weight:600;font-size:30px;color:var(--tz-navy);margin:0}
.tz-band__head a{font-weight:600;font-size:14px;color:var(--tz-coral)}
.tz-grid-w4{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.tz-grid-w4 .tz-photo{height:240px}

/* full-bleed dark feature: text + image */
.tz-darkfeat{width:100%;background:var(--tz-navy)}
.tz-darkfeat .tz-wide{display:grid;grid-template-columns:1fr 1.1fr;gap:0;align-items:stretch;min-height:420px;padding:0 0 0 40px}
.tz-darkfeat__txt{align-self:center;padding:56px 48px 56px 0;color:#fff}
.tz-darkfeat .tz-eyebrow{color:#ffb59f;margin-bottom:14px}
.tz-darkfeat h2{font-family:var(--tz-serif);font-weight:600;font-size:38px;line-height:1.12;margin:0 0 16px;max-width:440px}
.tz-darkfeat p{color:#c7d3de;font-size:17px;line-height:1.6;max-width:440px;margin:0 0 22px}
.tz-darkfeat__img{background:linear-gradient(135deg,#2a526f,#1b3d56);display:flex;align-items:center;justify-content:center;color:#7d97ac;font-size:13px;letter-spacing:.1em;text-transform:uppercase}

/* horizontal carousel band (runs to the edge) */
.tz-carousel{display:flex;gap:28px;overflow-x:auto;padding:4px 40px 16px;scroll-snap-type:x mandatory}
.tz-carousel .tz-card{flex:0 0 320px;scroll-snap-align:start}
.tz-carousel .tz-card .tz-photo{height:220px}
.tz-carousel::-webkit-scrollbar{height:8px}
.tz-carousel::-webkit-scrollbar-thumb{background:var(--tz-line);border-radius:4px}

@media (max-width:900px){
  .tz-split{grid-template-columns:1fr;gap:36px}
  .tz-list{border-left:0;padding-left:0}
  .tz-grid-w4{grid-template-columns:1fr 1fr;gap:28px}
  .tz-darkfeat .tz-wide{grid-template-columns:1fr;padding:0}
  .tz-darkfeat__txt{padding:40px 24px}
  .tz-darkfeat__img{min-height:240px}
}
@media (max-width:560px){ .tz-grid-w4{grid-template-columns:1fr} }

/* ---- real images: cover any block that gets an inline background-image ---- */
.tz-photo{background-size:cover;background-position:center;background-repeat:no-repeat}
.tz-bighero{background-size:cover;background-position:center}
.tz-darkfeat__img{background-size:cover;background-position:center}
.tz-bighero[style*="url"] .tz-bighero__ph{display:none}

/* =====================================================================
   ROUND 3 — photo collage, alternating feature rows, related mosaic,
   category overlay hero
   ===================================================================== */

/* wide photo collage inside an article */
.tz-gallery{width:100%;padding:36px 0 4px}
.tz-gallery__grid{max-width:var(--tz-wide);margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:175px;gap:12px}
.tz-gallery__grid .tz-photo{width:100%;height:100%;border-radius:3px}
.g-2x2{grid-column:span 2;grid-row:span 2}
.g-2x1{grid-column:span 2}
.g-4x1{grid-column:1 / -1}
.tz-gallery .tz-credit{max-width:var(--tz-wide);margin:12px auto 0;padding:0 40px;text-align:left}

/* article continuation (single centered column after a full-bleed break) */
.tz-cont{max-width:var(--tz-measure);margin:0 auto;padding:36px 20px 0}

/* alternating big feature rows (index) */
.tz-featrows{max-width:var(--tz-wide);margin:0 auto;padding:4px 40px 8px;display:flex;flex-direction:column;gap:52px}
.tz-featrow{display:grid;grid-template-columns:1.15fr 1fr;gap:44px;align-items:center}
.tz-featrow--flip .tz-featrow__media{order:2}
.tz-featrow__media .tz-photo{height:380px;border-radius:3px}
.tz-featrow .tz-eyebrow{margin-bottom:12px}
.tz-featrow h2{font-family:var(--tz-serif);font-weight:600;font-size:32px;line-height:1.14;color:var(--tz-navy);margin:0 0 12px}
.tz-featrow p.tz-dek{text-align:left;font-size:18px;margin:0 0 12px}

/* related "more stories" mosaic (overlay cards, varied sizes) */
.tz-mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:198px;gap:18px}
.tz-mcard{position:relative;overflow:hidden;border-radius:3px;display:block}
.tz-mcard .tz-photo{position:absolute;inset:0;height:100%;border-radius:0}
.tz-mcard::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,28,45,.85),rgba(8,28,45,.08) 62%)}
.tz-mcard__cap{position:absolute;left:0;right:0;bottom:0;padding:18px;z-index:2}
.tz-mcard__cap .tz-eyebrow{color:#ffc6b4;margin-bottom:6px;font-size:11px}
.tz-mcard__cap h3{font-family:var(--tz-serif);font-weight:600;font-size:18px;line-height:1.2;color:#fff;margin:0}
.tz-tall{grid-row:span 2}
.tz-tall .tz-mcard__cap h3{font-size:22px}
.tz-wide2{grid-column:span 2}

/* category overlay hero */
.tz-bighero--mid{height:min(46vh,360px)}

@media (max-width:900px){
  .tz-featrow{grid-template-columns:1fr;gap:18px}
  .tz-featrow--flip .tz-featrow__media{order:0}
  .tz-gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .g-2x2{grid-column:span 2;grid-row:span 2}.g-2x1{grid-column:span 2}.g-4x1{grid-column:1/-1}
  .tz-mosaic{grid-template-columns:repeat(2,1fr)}
  .tz-wide2,.tz-tall{grid-column:span 2;grid-row:span 1}
}
@media (max-width:560px){
  .tz-gallery__grid,.tz-mosaic{grid-template-columns:1fr}
  .g-2x2,.g-2x1,.g-4x1,.tz-wide2,.tz-tall{grid-column:auto;grid-row:auto}
}

/* byline relocated to the end of the article */
.tz-byline--end{margin:0 0 22px;padding-bottom:18px;border-bottom:1px solid var(--tz-line);font-size:14px;color:var(--tz-muted)}
.tz-byline--end b{color:var(--tz-ink)}

/* From-the-magazine rows → solid two-tone blocks (image + colored panel) */
.tz-featrows{gap:32px}
.tz-featrow{grid-template-columns:1fr 1fr;gap:0;align-items:stretch;overflow:hidden;border-radius:4px;min-height:430px}
.tz-featrow__media .tz-photo{height:100%;min-height:430px;border-radius:0}
.tz-featrow__body{padding:52px 50px;display:flex;flex-direction:column;justify-content:center}
.tz-featrow--cream .tz-featrow__body{background:var(--tz-warm)}
.tz-featrow--navy .tz-featrow__body{background:var(--tz-navy)}
.tz-featrow--navy h2,.tz-featrow--navy .tz-byline{color:#fff}
.tz-featrow--navy .tz-eyebrow{color:#ffb59f}
.tz-featrow--navy p.tz-dek{color:#c7d3de}
@media (max-width:900px){
  .tz-featrow{grid-template-columns:1fr;min-height:0;gap:0}
  .tz-featrow__media .tz-photo{min-height:280px}
  .tz-featrow__body{padding:34px 26px}
}
