/* THE RED DOT MEDIA · shared site chrome
   Used by services.html, work.html, journal.html, contact.html, and detail pages.
   The home page (index.html) keeps its own inline styles. */

:root{
  --carmine:#d50c15;
  --ink:#16120F;
  --bg:#FFFFFF;
  --panel:#F1EFEA;
  --black:#000000;
  --stone:#5F6062;
  --cloud:#4A4845;
  --paper:#E9E6E0;
  --display: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --serif: "Instrument Serif", "Times New Roman", serif;
  --mono: "JetBrains Mono", ui-monospace, Menlo, monospace;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--cloud);font-family:var(--display);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:var(--carmine);color:var(--ink)}

/* ---------- film grain + scanlines ---------- */
.grain{position:fixed;inset:-50%;width:200%;height:200%;pointer-events:none;z-index:200;opacity:.10;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.7 0'/></filter><rect width='220' height='220' filter='url(%23n)'/></svg>");
  animation:grain 1.2s steps(6) infinite}
@keyframes grain{
  0%{transform:translate(0,0)} 20%{transform:translate(-3%,2%)}
  40%{transform:translate(2%,-1%)} 60%{transform:translate(-1%,3%)}
  80%{transform:translate(3%,1%)} 100%{transform:translate(0,0)}
}
.scanlines{position:fixed;inset:0;pointer-events:none;z-index:201;opacity:.05;
  background:repeating-linear-gradient(to bottom,transparent 0 2px,#000 2px 3px)}

/* ---------- custom cursor ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);transition:width .2s ease,height .2s ease,background .2s ease,border-color .2s ease,opacity .2s ease}
.cursor-dot{width:6px;height:6px;background:var(--carmine);border-radius:50%}
.cursor-ring{width:34px;height:34px;border:1px solid var(--cloud);border-radius:50%;mix-blend-mode:difference}
body.cursor-hover .cursor-ring{width:74px;height:74px;border-color:var(--carmine);background:rgba(213,12,21,.06)}
body.cursor-hover .cursor-dot{opacity:0}
@media(hover:none){body{cursor:auto}.cursor-dot,.cursor-ring{display:none}}

/* ---------- nav ---------- */
nav.top{position:fixed;top:0;left:0;right:0;z-index:120;display:flex;align-items:center;justify-content:space-between;
  padding:22px 32px;transition:background .4s ease,backdrop-filter .4s ease,border-color .4s ease;
  border-bottom:1px solid transparent}
nav.top.solid{background:rgba(255,255,255,.78);backdrop-filter:blur(10px);border-bottom-color:rgba(115,116,118,.25)}
nav.top .mark{font-weight:900;letter-spacing:-.04em;color:var(--ink);font-size:22px;white-space:nowrap}
nav.top .mark em{color:var(--carmine);font-style:normal}
nav.top ul{list-style:none;display:flex;gap:34px;margin:0;padding:0;font-family:var(--mono);font-size:13px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--cloud)}
nav.top ul a{position:relative;padding:6px 0}
nav.top ul a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--carmine);transition:right .35s ease}
nav.top ul a:hover,nav.top ul a.active{color:var(--ink)}
nav.top ul a:hover::after,nav.top ul a.active::after{right:0}
.nav-cta{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);border:1px solid var(--stone);padding:10px 14px;display:inline-flex;align-items:center;gap:10px;
  transition:border-color .3s,color .3s,background .3s}
.nav-cta:hover{background:var(--carmine);border-color:var(--carmine);color:var(--ink)}
.nav-cta .dot{width:6px;height:6px;border-radius:50%;background:var(--carmine);box-shadow:0 0 10px var(--carmine);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}
@media(max-width:900px){nav.top{padding:14px 18px}nav.top ul{display:none}}

/* ---------- mobile nav ---------- */
.nav-burger{display:none;width:44px;height:44px;border:1px solid var(--stone);background:transparent;border-radius:999px;cursor:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0;transition:border-color .3s}
.nav-burger span{display:block;width:18px;height:2px;background:var(--ink);transition:transform .35s cubic-bezier(.2,.7,.2,1),opacity .25s}
.nav-burger.active{border-color:var(--carmine)}
.nav-burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.active span:nth-child(2){opacity:0}
.nav-burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;z-index:118;background:#fff;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .45s ease,visibility .45s}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu-inner{display:flex;flex-direction:column;gap:8px;text-align:center;padding:40px;width:100%}
.mobile-menu-inner a{font-family:var(--display);font-weight:900;font-size:clamp(34px,9vw,52px);letter-spacing:-.03em;color:var(--ink);text-transform:none;line-height:1.05;transform:translateY(24px);opacity:0;transition:transform .5s cubic-bezier(.2,.7,.2,1),opacity .5s,color .3s}
.mobile-menu.open .mobile-menu-inner a{transform:none;opacity:1}
.mobile-menu-inner a:nth-child(1){transition-delay:.06s}
.mobile-menu-inner a:nth-child(2){transition-delay:.12s}
.mobile-menu-inner a:nth-child(3){transition-delay:.18s}
.mobile-menu-inner a:nth-child(4){transition-delay:.24s}
.mobile-menu-inner a:nth-child(5){transition-delay:.30s}
.mobile-menu-inner a:nth-child(6){transition-delay:.36s}
.mobile-menu-inner a:hover{color:var(--carmine)}
.mobile-menu-inner .mm-cta{font-family:var(--mono);font-weight:500;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--carmine);margin-top:22px}
@media(max-width:900px){.nav-burger{display:flex}}
@media(max-width:560px){nav.top .nav-cta{display:none}}

/* ---------- editorial chrome ---------- */
.meta{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--stone)}
.rule{height:1px;background:var(--stone);opacity:.35}
.section-tag{display:flex;align-items:center;gap:14px;padding:0 32px;margin-top:90px}
.section-tag .num{color:var(--carmine);font-family:var(--mono);font-weight:500}
.section-tag .line{flex:1;height:1px;background:var(--stone);opacity:.4}
.ribbon{padding:14px 32px;border-top:1px solid rgba(115,116,118,.35);border-bottom:1px solid rgba(115,116,118,.35);
  display:flex;justify-content:space-between;gap:24px;color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;flex-wrap:wrap}
.ribbon b{color:var(--ink);font-weight:500}

/* ---------- page hero (smaller than home) ---------- */
.page-hero{padding:160px 32px 80px;position:relative;border-bottom:1px solid rgba(115,116,118,.35)}
.page-hero .kicker{color:var(--carmine);font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase}
.page-hero h1{margin:18px 0 24px;font-family:var(--display);font-weight:900;color:var(--ink);letter-spacing:-.05em;line-height:.86;
  font-size:clamp(64px,11vw,180px)}
.page-hero h1 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--carmine)}
.page-hero .lede{max-width:60ch;color:var(--cloud);font-size:17px;line-height:1.55}
.page-hero .lede strong{color:var(--ink);font-weight:600}
.page-hero .crumbs{position:absolute;top:96px;right:32px;display:flex;gap:14px;color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.page-hero .crumbs a:hover{color:var(--carmine)}
@media(max-width:900px){.page-hero{padding:130px 22px 60px}.page-hero .crumbs{position:static;margin-bottom:14px;flex-wrap:wrap}}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-mask{overflow:visible}
.reveal-mask > *{display:block;transform:translateY(36px);opacity:0;transition:transform 1.1s cubic-bezier(.2,.7,.2,1),opacity .9s ease}
.reveal-mask.in > *{transform:translateY(0);opacity:1}

/* ---------- footer ---------- */
footer.site{padding:80px 32px 30px;border-top:1px solid rgba(115,116,118,.4);background:var(--bg);margin-top:80px}
footer.site .closer{font-weight:900;color:var(--ink);letter-spacing:-.04em;line-height:.88;font-size:clamp(56px,11vw,180px)}
footer.site .closer em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--carmine)}
footer.site .links{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:60px;padding-top:40px;border-top:1px solid rgba(115,116,118,.3)}
@media(max-width:900px){footer.site .links{grid-template-columns:1fr 1fr}}
footer.site .links h4{margin:0 0 14px;color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
footer.site .links ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:14px;color:var(--cloud)}
footer.site .links a:hover{color:var(--carmine)}
footer.site .row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:30px;margin-top:60px;color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
footer.site .row a:hover{color:var(--carmine)}
footer.site .colophon{margin-top:24px;color:var(--stone);font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;display:flex;justify-content:space-between;border-top:1px solid rgba(115,116,118,.3);padding-top:18px;flex-wrap:wrap;gap:12px}

/* ---------- shared buttons / CTAs ---------- */
.btn-line{display:inline-flex;align-items:center;gap:18px;padding:20px 26px;border:1px solid var(--stone);color:var(--ink);
  font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;transition:all .35s;background:transparent}
.btn-line:hover{background:var(--carmine);border-color:var(--carmine)}
.btn-line .arrow{font-family:var(--serif);font-size:22px}

/* ---------- project + article detail pages ---------- */
.detail-meta{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-top:1px solid rgba(115,116,118,.4);border-bottom:1px solid rgba(115,116,118,.4)}
@media(max-width:900px){.detail-meta{grid-template-columns:1fr 1fr}}
.detail-meta .cell{padding:24px 22px;border-right:1px solid rgba(115,116,118,.25)}
.detail-meta .cell:last-child{border-right:none}
.detail-meta .k{color:var(--stone);font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:10px}
.detail-meta .v{color:var(--ink);font-size:15px;line-height:1.4}
.detail-meta .v em{color:var(--carmine);font-family:var(--serif);font-style:italic;font-weight:400}

.full-hero{margin:0;border-top:1px solid rgba(115,116,118,.25);border-bottom:1px solid rgba(115,116,118,.25);background:var(--panel);overflow:hidden;position:relative}
.full-hero img{width:100%;height:auto;display:block;max-height:88vh;object-fit:cover}
.full-hero figcaption{position:absolute;left:24px;bottom:18px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--cloud);text-transform:uppercase;background:rgba(255,255,255,.6);padding:6px 12px;border:1px solid rgba(172,173,175,.2)}

.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(115,116,118,.35);border-bottom:1px solid rgba(115,116,118,.35)}
@media(max-width:1000px){.three-col{grid-template-columns:1fr}}
.three-col > div{padding:48px 36px;border-right:1px solid rgba(115,116,118,.3)}
.three-col > div:last-child{border-right:none}
.three-col h4{margin:0 0 16px;color:var(--carmine);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.three-col h3{margin:0 0 22px;color:var(--ink);font-family:var(--display);font-weight:800;font-size:30px;letter-spacing:-.02em;line-height:1.06}
.three-col h3 em{font-family:var(--serif);font-style:italic;color:var(--carmine);font-weight:400}
.three-col p{margin:0 0 14px;color:var(--cloud);font-size:14.5px;line-height:1.65}

.section-title{padding:120px 32px 30px}
.section-title .kicker{color:var(--carmine);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.section-title h2{margin:18px 0 0;font-weight:900;color:var(--ink);letter-spacing:-.04em;line-height:.9;font-size:clamp(48px,7.5vw,120px)}
.section-title h2 em{font-family:var(--serif);font-style:italic;color:var(--carmine);font-weight:400}

.split{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid rgba(115,116,118,.35);border-bottom:1px solid rgba(115,116,118,.35)}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.split > figure{margin:0;background:var(--panel);overflow:hidden;position:relative;min-height:420px}
.split > figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.4s cubic-bezier(.2,.7,.2,1)}
.split > figure:hover img{transform:scale(1.04)}
.split > figure figcaption{position:absolute;left:18px;bottom:16px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--cloud);text-transform:uppercase;background:rgba(255,255,255,.55);padding:5px 10px;border:1px solid rgba(172,173,175,.2)}
.split > div{padding:60px 44px;display:flex;flex-direction:column;justify-content:center;gap:22px;border-left:1px solid rgba(115,116,118,.3)}
.split > div .kicker{color:var(--carmine);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.split > div h3{margin:0;color:var(--ink);font-weight:900;letter-spacing:-.03em;line-height:.92;font-size:clamp(36px,4.5vw,64px)}
.split > div h3 em{font-family:var(--serif);font-style:italic;color:var(--carmine);font-weight:400}
.split > div p{margin:0;color:var(--cloud);font-size:15.5px;line-height:1.65;max-width:46ch}

/* No-crop variant — image keeps its natural ratio, figure auto-sizes, text column matches. */
.split.no-crop > figure{position:relative;min-height:0;display:flex;align-items:center;justify-content:center;padding:0;background:var(--panel)}
.split.no-crop > figure img{position:static;inset:auto;width:100%;height:auto;max-height:none;object-fit:contain;display:block}

.gallery{display:grid;gap:18px;padding:60px 32px}
.gallery figure{margin:0;background:var(--panel);overflow:hidden;position:relative;border:1px solid rgba(172,173,175,.16)}
.gallery figure img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.4s cubic-bezier(.2,.7,.2,1)}
.gallery figure:hover img{transform:scale(1.03)}
.gallery figure figcaption{position:absolute;left:16px;bottom:14px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--cloud);text-transform:uppercase;background:rgba(255,255,255,.55);padding:5px 10px;border:1px solid rgba(172,173,175,.2)}
.gallery.g-2{grid-template-columns:1fr 1fr}
.gallery.g-3{grid-template-columns:1.5fr 1fr 1fr}
.gallery.g-asym{grid-template-columns:2fr 1fr;grid-template-rows:auto auto;gap:18px}
.gallery.g-asym figure:first-child{grid-row:span 2}
@media(max-width:900px){.gallery.g-2,.gallery.g-3,.gallery.g-asym{grid-template-columns:1fr;grid-template-rows:auto}.gallery.g-asym figure:first-child{grid-row:auto}}

/* Full-bleed, no-crop image strip — used for campaign frames where the original composition matters. */
.strip{margin:0;padding:0;background:var(--panel);border-top:1px solid rgba(115,116,118,.25);border-bottom:1px solid rgba(115,116,118,.25);position:relative}
.strip > figure{margin:0;padding:0;position:relative;background:var(--panel);border-bottom:1px solid rgba(115,116,118,.18)}
.strip > figure:last-child{border-bottom:0}
.strip > figure img{display:block;width:100%;height:auto;object-fit:contain;background:var(--panel)}
.strip > figure figcaption{position:absolute;left:24px;bottom:18px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--cloud);text-transform:uppercase;background:rgba(255,255,255,.55);padding:6px 10px;border:1px solid rgba(172,173,175,.25)}
.strip-pair{display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--panel);border-top:1px solid rgba(115,116,118,.25);border-bottom:1px solid rgba(115,116,118,.25)}
.strip-pair > figure{margin:0;padding:0;position:relative;background:var(--panel);border-left:1px solid rgba(115,116,118,.18);display:flex;align-items:center;justify-content:center}
.strip-pair > figure:first-child{border-left:0}
.strip-pair > figure img{display:block;width:100%;height:auto;object-fit:contain;background:var(--panel)}
.strip-pair > figure figcaption{position:absolute;left:18px;bottom:14px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--cloud);text-transform:uppercase;background:rgba(255,255,255,.6);padding:5px 9px;border:1px solid rgba(172,173,175,.25)}
@media(max-width:900px){.strip-pair{grid-template-columns:1fr}.strip-pair > figure{border-left:0;border-top:1px solid rgba(115,116,118,.18)}.strip-pair > figure:first-child{border-top:0}}

/* Three-across, no-crop campaign strip */
.strip-trio{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;background:var(--panel);border-top:1px solid rgba(115,116,118,.25);border-bottom:1px solid rgba(115,116,118,.25)}
.strip-trio > figure{margin:0;padding:0;position:relative;background:var(--panel);border-left:1px solid rgba(115,116,118,.18);border-bottom:0;display:flex;align-items:center;justify-content:center}
.strip-trio > figure:first-child{border-left:0}
.strip-trio > figure img{display:block;width:100%;height:auto;object-fit:contain;background:var(--panel)}
@media(max-width:900px){.strip-trio{grid-template-columns:1fr}.strip-trio > figure{border-left:0;border-top:1px solid rgba(115,116,118,.18)}.strip-trio > figure:first-child{border-top:0}}

/* No-crop variant of full-hero — same chrome, but the image keeps its natural ratio. */
.full-hero.no-crop img{max-height:none;object-fit:contain;background:var(--panel)}

.pull-quote{padding:120px 32px;border-top:1px solid rgba(115,116,118,.35);border-bottom:1px solid rgba(115,116,118,.35)}
.pull-quote q{display:block;font-family:var(--serif);font-style:italic;color:var(--ink);font-size:clamp(40px,6vw,80px);letter-spacing:-.02em;line-height:1.06;max-width:26ch;quotes:"\201C" "\201D"}
.pull-quote q em{color:var(--carmine);font-style:italic}
.pull-quote .by{margin-top:30px;color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.pull-quote .by b{color:var(--ink);font-weight:500}

.deliv-block{padding:100px 32px;display:grid;grid-template-columns:1fr 2fr;gap:48px;border-top:1px solid rgba(115,116,118,.35)}
@media(max-width:900px){.deliv-block{grid-template-columns:1fr}}
.deliv-block h3{margin:0;color:var(--ink);font-weight:900;font-size:clamp(40px,5.5vw,80px);letter-spacing:-.03em;line-height:.95}
.deliv-block h3 em{font-family:var(--serif);font-style:italic;color:var(--carmine);font-weight:400}
.deliv-block ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:0;color:var(--cloud);font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase}
@media(max-width:700px){.deliv-block ul{grid-template-columns:1fr}}
.deliv-block ul li{padding:14px 0;border-bottom:1px solid rgba(115,116,118,.25);display:flex;justify-content:space-between;gap:10px}
.deliv-block ul li b{color:var(--carmine);font-weight:500}

.next-strip{padding:48px 32px;border-top:1px solid rgba(115,116,118,.35);display:flex;justify-content:space-between;align-items:center;gap:32px;background:var(--panel);transition:background .35s ease}
.next-strip:hover{background:rgba(213,12,21,.06)}
.next-strip .l{color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.next-strip h3{margin:8px 0 0;color:var(--ink);font-weight:900;font-size:clamp(40px,6vw,80px);letter-spacing:-.03em;line-height:.9}
.next-strip h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--carmine)}
.next-strip .arrow{color:var(--carmine);font-family:var(--serif);font-size:48px}

/* ---------- article reading layout ---------- */
.article-meta{display:flex;justify-content:space-between;gap:24px;padding:30px 32px;border-bottom:1px solid rgba(115,116,118,.35);color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;flex-wrap:wrap}
.article-meta b{color:var(--ink);font-weight:500}

.article-body{max-width:760px;margin:0 auto;padding:80px 32px;color:var(--cloud);font-size:18px;line-height:1.75;font-family:var(--display);font-weight:300}
.article-body > p{margin:0 0 26px}
.article-body > p strong{color:var(--ink);font-weight:600}
.article-body .lede{font-family:var(--serif);font-style:italic;color:var(--ink);font-size:26px;line-height:1.4;margin:0 0 40px;font-weight:400}
.article-body .lede em{color:var(--carmine)}
.article-body h2{margin:60px 0 22px;color:var(--ink);font-family:var(--display);font-weight:800;font-size:42px;letter-spacing:-.02em;line-height:1.05}
.article-body h2 em{font-family:var(--serif);font-style:italic;color:var(--carmine);font-weight:400}
.article-body h3{margin:40px 0 14px;color:var(--ink);font-weight:700;font-size:22px;letter-spacing:-.01em;line-height:1.2}
.article-body blockquote{margin:40px 0;padding:14px 0 14px 22px;border-left:2px solid var(--carmine);font-family:var(--serif);font-style:italic;color:var(--ink);font-size:24px;line-height:1.4}
.article-body blockquote em{color:var(--carmine)}
.article-body ul,.article-body ol{margin:0 0 26px;padding-left:22px}
.article-body li{margin:0 0 10px}
.article-body a{color:var(--ink);border-bottom:1px solid var(--carmine);transition:background .35s,color .35s}
.article-body a:hover{background:var(--carmine);color:var(--ink);padding:0 4px}
.article-body figure{margin:40px -120px;background:var(--panel);border:1px solid rgba(172,173,175,.18);overflow:hidden;position:relative}
@media(max-width:1100px){.article-body figure{margin:40px 0}}
.article-body figure img{width:100%;height:auto;display:block}
.article-body figcaption{padding:14px 18px;color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;border-top:1px solid rgba(172,173,175,.15)}

.article-toc{padding:28px 32px;border-bottom:1px solid rgba(115,116,118,.35);display:flex;gap:30px;align-items:center;flex-wrap:wrap;color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.article-toc b{color:var(--carmine);font-weight:500}
.article-toc a{color:var(--cloud);transition:color .3s}
.article-toc a:hover{color:var(--ink)}

.more-articles{padding:80px 32px;border-top:1px solid rgba(115,116,118,.35)}
.more-articles h3{margin:0 0 30px;color:var(--ink);font-weight:900;font-size:clamp(36px,5vw,72px);letter-spacing:-.03em;line-height:.95}
.more-articles h3 em{font-family:var(--serif);font-style:italic;color:var(--carmine);font-weight:400}
.more-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(115,116,118,.35);border-bottom:1px solid rgba(115,116,118,.35)}
@media(max-width:900px){.more-grid{grid-template-columns:1fr}}
.more-grid a{padding:30px 24px;border-right:1px solid rgba(115,116,118,.3);min-height:220px;display:flex;flex-direction:column;justify-content:space-between;gap:14px;transition:background .35s}
.more-grid a:last-child{border-right:none}
.more-grid a:hover{background:rgba(213,12,21,.06)}
.more-grid .ktag{color:var(--carmine);font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase}
.more-grid h4{margin:0;color:var(--ink);font-family:var(--serif);font-style:italic;font-weight:400;font-size:24px;line-height:1.15}
.more-grid h4 em{color:var(--carmine)}
.more-grid .read{color:var(--stone);font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase}

/* ---------- print niceties ---------- */
@media print{
  *,*::before,*::after{animation:none !important;transition:none !important}
  .grain,.scanlines,.cursor-dot,.cursor-ring,nav.top{display:none !important}
}

/* ===== light-theme overrides (carmine surfaces keep white text + nav logo) ===== */
::selection{color:#fff}
.nav-cta:hover,.contact-cta:hover,.btn-line:hover,.hero-cta a.primary,.hero-cta a.primary:hover,.hero-pill.p-1,.newsletter button,.newsletter button:hover,form.brief .pickrow label:hover,form.brief button.send,form.brief button.send:hover{color:#fff !important}
nav.top .mark{display:flex;align-items:center;transition:transform .3s ease}
nav.top .mark img,nav.top .mark svg{height:70px;width:auto;display:block}
nav.top .mark:hover img{transform:scale(1.04)}
