:root{
  --ink:#070807; --ink-2:#0d0f0e;
  --panel:#141714; --panel-2:#1a1d1a;
  --hair:rgba(255,255,255,.08); --hair-2:rgba(255,255,255,.14);
  --white:#fff; --cream:#ECEAE5; --mute:#9AA39C; --mute-2:#C2C9C3;
  --green:#1FDF67; --green-soft:#42EB81;
  --gold:#e6c574; --gold-soft:#f0d68a;
  --purple:#A78BFA; --purple-glow:#B9A6FF;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --serif:'Fraunces',Georgia,serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --glass:blur(16px) saturate(1.4);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--ink); color:var(--cream); font-family:var(--sans); -webkit-font-smoothing:antialiased; line-height:1.6; overflow-x:hidden}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font:inherit; cursor:pointer; border:0; background:none; color:inherit}
body::before{content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(900px 600px at 78% -8%, rgba(31,223,103,.08), transparent 60%),
            radial-gradient(720px 520px at 6% 62%, rgba(230,197,116,.05), transparent 60%)}

.wrap{position:relative; z-index:1; max-width:1240px; margin:0 auto; padding:0 28px}
h1,h2,h3,h4,h5,h6{font-family:var(--serif); font-weight:600; letter-spacing:-.015em; color:var(--white); line-height:1.12}

/* ============== BANNER + STICKY HEADER (shared shell) ============== */
.banner-ad{background:var(--ink-2); border-bottom:1px solid var(--hair); overflow:hidden; max-height:320px; opacity:1; transition:max-height .35s cubic-bezier(.22,1,.36,1), opacity .25s ease, border-color .35s ease; position:relative}
.banner-ad.collapsed{max-height:0; opacity:0; border-bottom-color:transparent; pointer-events:none}
.featured-carousel{position:relative; height:clamp(180px, 22vw, 280px); overflow:hidden}
.fc-track{position:absolute; inset:0; background:#000}
.fc-slide{position:absolute; inset:0; display:block; text-decoration:none; opacity:0; visibility:hidden; transition:opacity .55s cubic-bezier(.22,1,.36,1), visibility 0s linear .55s; background:#000}
.fc-slide.on{opacity:1; visibility:visible; transition:opacity .55s cubic-bezier(.22,1,.36,1), visibility 0s linear 0s}
.fc-slide video, .fc-slide img{width:100%; height:100%; object-fit:cover; display:block; background:#000}
.fc-arrow{position:absolute; top:50%; transform:translateY(-50%); z-index:5; width:42px; height:42px; border-radius:999px; background:rgba(7,8,7,.55); backdrop-filter:blur(8px); border:1px solid var(--hair-2); display:flex; align-items:center; justify-content:center; color:var(--white); cursor:pointer; transition:all .2s ease; opacity:0}
.featured-carousel:hover .fc-arrow{opacity:1}
.fc-arrow:hover{background:var(--green); color:var(--ink); border-color:var(--green)}
.fc-arrow.prev{left:18px} .fc-arrow.next{right:18px}
.fc-arrow svg{width:14px; height:14px}
.fc-bottom{position:absolute; left:0; right:0; bottom:10px; z-index:5; display:flex; align-items:center; justify-content:space-between; padding:0 clamp(60px, 6vw, 90px); pointer-events:none}
.fc-dots{display:flex; gap:6px; pointer-events:auto}
.fc-dot{width:7px; height:7px; border-radius:999px; background:rgba(255,255,255,.3); border:0; cursor:pointer; transition:all .2s; padding:0}
.fc-dot.on{background:var(--white); width:20px}
.fc-sponsor{font-family:var(--mono); font-size:9.5px; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.45); background:rgba(0,0,0,.35); backdrop-filter:blur(6px); padding:5px 10px; border-radius:4px; pointer-events:auto}

.sticky-stack{position:sticky; top:0; z-index:60}
nav.main{background:rgba(7,8,7,.78); backdrop-filter:var(--glass); -webkit-backdrop-filter:var(--glass); border-bottom:1px solid var(--hair)}
nav.main .wrap{display:flex; align-items:center; justify-content:space-between; padding-top:14px; padding-bottom:14px; gap:24px}
.nav-links{display:flex; gap:20px; align-items:center}
.nav-links a{font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--mute-2); transition:color .2s}
.nav-links a:hover{color:var(--white)}
.nav-burger{display:none; width:28px; height:28px; flex-direction:column; gap:5px; padding:6px 0; align-items:flex-end; justify-content:center}
.nav-burger span{display:block; width:22px; height:1.5px; background:var(--cream)}
@media(max-width:980px){.nav-links{display:none}.nav-burger{display:flex}}

.nav-cta{display:inline-flex; align-items:center; gap:10px; padding:8px 8px 8px 14px; background:rgba(255,255,255,.04); border:1px solid var(--hair-2); border-radius:999px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:700; color:var(--white); transition:all .2s; position:relative; overflow:hidden}
.nav-cta::before{content:""; position:absolute; inset:0; background:radial-gradient(60% 100% at 100% 50%, rgba(31,223,103,.18), transparent 70%); opacity:0; transition:opacity .25s}
.nav-cta:hover{border-color:var(--green); transform:translateY(-1px)}
.nav-cta:hover::before{opacity:1}
.nav-cta .mc-pin{position:relative; width:18px; height:18px; flex:0 0 auto}
.nav-cta .mc-pin svg{width:100%; height:100%; color:var(--green); filter:drop-shadow(0 0 4px rgba(31,223,103,.5))}
.nav-cta .mc-pin::after{content:""; position:absolute; left:50%; top:50%; width:6px; height:6px; border-radius:50%; background:var(--green); transform:translate(-50%, -50%); animation:mcPinPulse 2.4s ease-out infinite; opacity:0}
@keyframes mcPinPulse{0%{transform:translate(-50%,-50%) scale(.5); opacity:.8}80%{transform:translate(-50%,-50%) scale(3.6); opacity:0}100%{opacity:0}}
.nav-cta .mc-label{position:relative; z-index:1}
.nav-cta .mc-sep{width:1px; height:14px; background:var(--hair-2); position:relative; z-index:1}
.nav-cta .mc-count{display:inline-flex; align-items:center; gap:6px; padding:5px 10px; background:rgba(31,223,103,.12); border:1px solid rgba(31,223,103,.32); border-radius:999px; color:var(--green); font-size:10.5px; letter-spacing:.06em; font-weight:700; position:relative; z-index:1}
.nav-cta .mc-count .mc-dot{width:5px; height:5px; border-radius:50%; background:var(--green); box-shadow:0 0 6px var(--green); animation:tdot 1.6s ease-in-out infinite}
@keyframes tdot{0%,100%{opacity:1}50%{opacity:.35}}
@media(max-width:1180px){.nav-cta .mc-count{display:none}.nav-cta .mc-sep{display:none}}

/* TMW logo */
.tmw-logo-lockup{display:flex; align-items:center; gap:10px}
.tmw-hex-badge{flex:0 0 auto; width:22px; height:22px}
.tmw-hex-badge svg{width:100%; height:100%; display:block; overflow:visible}
.tmw-hex-spinner{transform-origin:50% 50%; animation:tmw-hardspin 4.2s cubic-bezier(.16,1,.3,1) infinite}
@keyframes tmw-hardspin{0%{transform:rotate(0)}55%{transform:rotate(810deg)}70%{transform:rotate(900deg)}100%{transform:rotate(1080deg)}}
.tmw-hex-core{animation:tmw-hexpulse 4.2s ease-in-out infinite; transform-origin:50% 50%}
@keyframes tmw-hexpulse{0%,45%{stroke:var(--purple)}70%{stroke:var(--purple-glow); filter:drop-shadow(0 0 6px rgba(185,166,255,.9))}100%{stroke:var(--purple)}}
.tmw-hex-ring{transform-origin:50% 50%; animation:tmw-ring 4.2s ease-out infinite}
@keyframes tmw-ring{0%,60%{transform:scale(1);opacity:0}72%{opacity:.55}100%{transform:scale(1.7);opacity:0}}
.tmw-wordmark{flex:0 1 auto; width:108px}
.tmw-wordmark svg{width:100%; height:auto; display:block}
.tmw-wordmark .wm-fill{fill:#fff}
@media (prefers-reduced-motion: reduce){.tmw-hex-spinner,.tmw-hex-ring{animation:none}.tmw-hex-ring{opacity:0}}

/* Ticker */
.ticker{background:var(--ink); border-bottom:1px solid var(--hair); height:40px; display:flex; align-items:center; overflow:hidden; position:relative}
.ticker-label{flex:0 0 auto; display:flex; align-items:center; gap:9px; padding:0 16px 0 20px; height:100%; font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; font-weight:700; color:var(--cream); white-space:nowrap}
.ticker-label .live-dot{width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--green); animation:tdot 1.6s ease-in-out infinite}
.ticker-label .newcount{font-family:var(--mono); font-size:10px; font-weight:700; letter-spacing:.1em; padding:3px 8px; background:rgba(255,255,255,.08); color:var(--mute-2); border-radius:4px; margin-left:4px}
.ticker-label .newcount.has{background:rgba(31,223,103,.15); color:var(--green); border:1px solid rgba(31,223,103,.35); padding:2px 7px}
.ticker-viewport{flex:1; min-width:0; overflow:hidden; display:flex; align-items:center; height:100%; -webkit-mask-image:linear-gradient(90deg, transparent, #000 24px, #000 calc(100% - 32px), transparent); mask-image:linear-gradient(90deg, transparent, #000 24px, #000 calc(100% - 32px), transparent)}
.ticker-track{display:flex; align-items:center; gap:28px; white-space:nowrap; animation:tickerScroll 60s linear infinite; padding-left:8px; will-change:transform}
.ticker:hover .ticker-track{animation-play-state:paused}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{display:inline-flex; align-items:center; gap:10px; font-size:13px; color:var(--cream); transition:color .15s}
.ticker-item:hover{color:var(--green-soft)}
.ticker-item .pdot{width:5px; height:5px; border-radius:50%; background:var(--green); flex:0 0 auto; box-shadow:0 0 6px rgba(31,223,103,.5)}
.ticker-item .pdot.article{background:var(--gold); box-shadow:0 0 6px rgba(230,197,116,.5)}
.ticker-item .tage{font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; color:var(--mute); font-weight:500; padding:2px 7px; background:rgba(255,255,255,.04); border-radius:3px}
.ticker-cta{flex:0 0 auto; display:flex; align-items:center; gap:7px; padding:0 20px 0 18px; height:100%; border-left:1px solid var(--hair); font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; font-weight:700; color:var(--green); background:linear-gradient(90deg, transparent, rgba(31,223,103,.06)); transition:all .2s; white-space:nowrap}
.ticker-cta:hover{background:linear-gradient(90deg, transparent, rgba(31,223,103,.16))}
.ticker-cta svg{width:13px; height:13px; transition:transform .2s}
.ticker-cta:hover svg{transform:translateX(3px)}
@media (prefers-reduced-motion: reduce){.ticker-track{animation:none}}

/* ============== ARTICLE HERO ============== */
.article-hero{padding:54px 0 36px; position:relative; border-bottom:1px solid var(--hair)}
.article-hero .wrap{max-width:920px}
.article-hero .crumbs{font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--mute); margin-bottom:18px}
.article-hero .crumbs a:hover{color:var(--green)}
.article-hero .crumbs .sep{opacity:.4; margin:0 10px}
.article-hero .cat-row{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:18px}
.article-hero .main-cat{font-family:var(--mono); font-size:12px; letter-spacing:.2em; text-transform:uppercase; font-weight:700; color:var(--gold-soft); text-shadow:0 0 14px rgba(230,197,116,.55), 0 0 3px rgba(230,197,116,.35)}
.article-hero h1{font-size:clamp(34px, 5.4vw, 64px); font-weight:700; letter-spacing:-.025em; line-height:1.04; color:var(--white); text-wrap:balance; max-width:24ch}
.article-hero .deck{font-family:var(--serif); font-weight:300; font-style:italic; font-size:clamp(17px, 1.9vw, 22px); color:var(--mute-2); margin-top:20px; line-height:1.45; max-width:60ch}
.article-hero .byline{display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:28px; padding-top:24px; border-top:1px solid var(--hair); font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--mute-2)}
.article-hero .byline .by{color:var(--green)}
.article-hero .byline .dot{width:3px; height:3px; border-radius:50%; background:var(--mute); opacity:.6}
.article-hero .byline .share{margin-left:auto; display:flex; gap:8px}
.article-hero .byline .share .share-ico{width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center; padding:0; border-radius:999px; border:1px solid var(--hair-2); color:var(--cream); background:transparent; cursor:pointer; transition:all .2s}
.article-hero .byline .share .share-ico svg{width:16px; height:16px}
.article-hero .byline .share .share-ico:hover{border-color:var(--green); color:var(--green); transform:translateY(-1px)}
.article-hero .byline .share .share-ico.copied{border-color:var(--green); color:var(--green)}

.article-cover{margin:0 auto; max-width:1240px; padding:0 28px}
.article-cover-img{width:100%; aspect-ratio:16/9; object-fit:cover; border-radius:16px; background:var(--panel-2); margin-top:14px}

/* ============== ARTICLE BODY ============== */
.article-body{padding:60px 0 80px}
.article-body .wrap{max-width:760px}
.article-body-content{font-family:var(--sans); font-size:18px; line-height:1.75; color:var(--cream)}
.article-body-content > * + *{margin-top:1.2em}
.article-body-content p{font-size:18px; line-height:1.75; color:var(--cream); font-weight:300; max-width:64ch}
.article-body-content p:first-of-type::first-letter{font-family:var(--serif); font-size:3.6em; font-weight:600; float:left; line-height:.92; padding-right:14px; padding-top:4px; color:var(--white)}
.article-body-content a{color:var(--green); text-decoration:underline; text-decoration-color:rgba(31,223,103,.4); text-underline-offset:3px; transition:color .15s, text-decoration-color .15s}
.article-body-content a:hover{color:var(--green-soft); text-decoration-color:var(--green-soft)}
.article-body-content h1,
.article-body-content h2,
.article-body-content h3,
.article-body-content h4{font-family:var(--serif); color:var(--white); font-weight:600; line-height:1.15; letter-spacing:-.015em; margin-top:1.6em; margin-bottom:.4em}
.article-body-content h2{font-size:clamp(26px,3.4vw,38px)}
.article-body-content h3{font-size:clamp(22px,2.6vw,28px)}
.article-body-content h4{font-size:20px}
.article-body-content blockquote{font-family:var(--serif); font-style:italic; font-weight:300; font-size:clamp(22px,2.4vw,28px); line-height:1.4; color:var(--gold-soft); border-left:3px solid var(--gold); padding:6px 0 6px 26px; margin:2em 0 !important}
.article-body-content blockquote p{font-size:inherit; color:inherit; line-height:inherit; font-weight:inherit; font-family:inherit; max-width:none}
.article-body-content ul,
.article-body-content ol{padding-left:26px; color:var(--cream); font-weight:300}
.article-body-content li{margin:.4em 0}
.article-body-content figure{margin:2em 0 !important}
.article-body-content figure img{border-radius:12px}
.article-body-content figcaption{font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--mute); margin-top:10px; text-align:center}
.article-body-content img{max-width:100%; height:auto; border-radius:12px; background:var(--panel-2)}
.article-body-content iframe{max-width:100%; aspect-ratio:16/9; height:auto; border-radius:12px; border:0; background:#000}
.article-body-content hr{border:0; height:1px; background:var(--hair); margin:2.4em 0}
.article-body-content strong{color:var(--white); font-weight:600}

/* ---- Gallery slideshow (rendered from Wix GALLERY nodes) ---- */
.tmw-gallery{position:relative; margin:2em 0 !important; aspect-ratio:16/10; overflow:hidden; border-radius:12px; background:#0a0a0a; padding:0}
.tmw-gallery-track{display:flex; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; -ms-overflow-style:none; height:100%; scroll-behavior:smooth}
.tmw-gallery-track::-webkit-scrollbar{display:none}
.tmw-gallery-slide{flex:0 0 100%; width:100%; height:100%; position:relative; scroll-snap-align:start}
.tmw-gallery-slide img{width:100%; height:100%; object-fit:cover; border-radius:0; display:block; margin:0}
.tmw-gallery-caption{position:absolute; left:0; right:0; bottom:0; padding:30px 22px 18px; background:linear-gradient(transparent, rgba(7,8,7,.78) 60%, rgba(7,8,7,.92)); color:var(--white); font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; line-height:1.5; pointer-events:none}
.tmw-gallery-arrow{position:absolute; top:50%; transform:translateY(-50%); width:44px; height:44px; border-radius:999px; background:rgba(7,8,7,.65); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border:1px solid var(--hair-2); color:var(--white); display:flex; align-items:center; justify-content:center; cursor:pointer; opacity:0; transition:opacity .2s, background .2s, border-color .2s, transform .2s; z-index:3; padding:0}
.tmw-gallery:hover .tmw-gallery-arrow{opacity:1}
.tmw-gallery-arrow.prev{left:14px} .tmw-gallery-arrow.next{right:14px}
.tmw-gallery-arrow:hover{background:var(--green); color:var(--ink); border-color:var(--green); transform:translateY(-50%) scale(1.05)}
.tmw-gallery-arrow:disabled{opacity:0 !important; cursor:default}
.tmw-gallery-arrow svg{width:16px; height:16px}
.tmw-gallery-counter{position:absolute; top:14px; right:14px; font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; color:var(--white); background:rgba(7,8,7,.65); backdrop-filter:blur(10px); padding:5px 10px; border-radius:999px; z-index:3; font-weight:700}
@media (hover: none){.tmw-gallery-arrow{opacity:.65}}
.article-body-content code{background:rgba(255,255,255,.06); padding:2px 6px; border-radius:4px; font-family:var(--mono); font-size:.9em}
.article-body-content pre{background:var(--panel); border:1px solid var(--hair); border-radius:10px; padding:18px; overflow-x:auto; font-family:var(--mono); font-size:13.5px; line-height:1.6}

/* Empty / error states */
.art-empty{padding:120px 28px; text-align:center; max-width:680px; margin:0 auto}
.art-empty h2{font-size:32px; margin-bottom:14px}
.art-empty p{color:var(--mute-2); margin-bottom:24px}
.art-empty .legacy-link{display:inline-flex; align-items:center; gap:8px; padding:12px 22px; background:var(--green); color:var(--ink); border-radius:999px; font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; font-weight:700}
.art-empty .err{background:rgba(158,59,27,.12); border:1px solid rgba(158,59,27,.35); border-radius:10px; padding:16px 22px; color:#f5a98e; font-family:var(--mono); font-size:12px; margin-top:24px; text-align:left}

/* ============== READ NEXT ============== */
.read-next{padding:70px 0 80px; border-top:1px solid var(--hair); background:var(--ink-2)}
.read-next h3{font-size:clamp(22px,2.8vw,32px); margin-bottom:30px}
.rn-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
@media(max-width:880px){.rn-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.rn-grid{grid-template-columns:1fr}}
.rn-card{background:var(--panel); border:1px solid var(--hair); border-radius:14px; overflow:hidden; transition:transform .25s ease, border-color .25s ease}
.rn-card:hover{transform:translateY(-3px); border-color:var(--hair-2)}
.rn-card-img{aspect-ratio:16/10; background:var(--panel-2); overflow:hidden}
.rn-card-img img{width:100%; height:100%; object-fit:cover; transition:transform .6s ease}
.rn-card:hover .rn-card-img img{transform:scale(1.04)}
.rn-card-body{padding:18px 20px 20px}
.rn-card-date{font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--mute); margin-bottom:8px}
.rn-card-title{font-family:var(--serif); font-weight:600; font-size:18px; line-height:1.22; color:var(--white)}

/* Skeleton */
.skel-block{background:linear-gradient(90deg, #161916, #1f231f, #161916); background-size:200% 100%; animation:shimmer 1.8s linear infinite; border-radius:6px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Footer */
footer{background:var(--ink-2); color:var(--mute-2); padding:60px 0 30px; border-top:1px solid var(--hair)}
footer .ft-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:30px; border-bottom:1px solid var(--hair)}
@media(max-width:780px){footer .ft-grid{grid-template-columns:1fr}}
footer h4{font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--white); margin-bottom:14px; font-weight:600}
footer ul{list-style:none; display:flex; flex-direction:column; gap:9px; font-size:14px}
footer ul a{color:var(--mute); transition:color .2s}
footer ul a:hover{color:var(--green)}
footer .blurb{color:var(--mute); font-size:13px; line-height:1.55; margin-top:14px; max-width:32ch}
footer .ft-bot{padding-top:22px; font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--mute); display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px}
footer .tmw-wordmark{width:118px}
