/* ============================================================
   AIRFLYER — magazin design system
   ============================================================ */
:root{
  --paper:#F7F4EE;
  --paper-2:#F1ECE2;
  --surface:#FFFFFF;
  --ink:#16110D;
  --ink-2:#4C4339;
  --ink-3:#8C8275;
  --line:#E4DDD0;
  --line-2:#D6CCBB;
  --red:#E01E13;
  --red-deep:#B01209;
  --red-soft:#FBE9E7;
  --night:#171311;
  --night-2:#221C18;

  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-sans:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;

  --wrap:1240px;
  --gut:clamp(16px,4vw,40px);
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--font-sans);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
  opacity:.05;mix-blend-mode:multiply;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gut);position:relative;z-index:1;}

.mono{font-family:var(--font-mono);font-weight:500;letter-spacing:.08em;text-transform:uppercase;}
.kicker{font-family:var(--font-mono);font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--red-deep);display:inline-flex;align-items:center;gap:8px;}
.kicker::before{content:"";width:18px;height:2px;background:var(--red);display:inline-block;}
.kicker--ink{color:var(--ink-2);}
.kicker--ink::before{background:var(--ink);}

.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:200;}
.skip:focus{left:8px;top:8px;}

a:focus-visible,button:focus-visible,input:focus-visible{outline:2.5px solid var(--red);outline-offset:3px;border-radius:2px;}

/* ---------- reading progress ---------- */
.progress{position:fixed;left:0;top:0;height:3px;width:0;background:var(--red);z-index:90;transition:width .1s linear;}

/* ---------- Top utility bar ---------- */
.util{border-bottom:1px solid var(--line);background:var(--paper);font-family:var(--font-mono);}
.util__row{display:flex;align-items:center;justify-content:space-between;gap:16px;height:38px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.util__left{display:flex;gap:22px;align-items:center;}
.util__live{display:inline-flex;align-items:center;gap:7px;color:var(--ink-2);}
.util__dot{width:7px;height:7px;border-radius:50%;background:var(--red);position:relative;}
.util__dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1.5px solid var(--red);animation:ping 2.4s ease-out infinite;}
.util__deftech{color:var(--ink-2);transition:color .2s;}
.util__deftech:hover{color:var(--red-deep);}
.util__deftech span{color:var(--red-deep);}
@media(max-width:720px){.util__left .hide-sm{display:none;}}

/* ---------- Masthead ---------- */
.masthead{border-bottom:2px solid var(--ink);background:var(--paper);position:sticky;top:0;z-index:60;}
.masthead__row{display:flex;align-items:center;justify-content:space-between;gap:24px;height:84px;}
.brand{display:flex;align-items:center;gap:14px;}
.brand__mark{width:42px;height:42px;flex:0 0 auto;}
.brand__mark .sweep{animation:spin 4.5s linear infinite;transform-origin:24px 24px;}
.brand__name{font-family:var(--font-display);font-weight:900;font-size:30px;letter-spacing:-.02em;line-height:1;color:var(--ink);font-variation-settings:"opsz" 120;}
.brand__name b{color:var(--red);}
.brand__sub{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);margin-top:3px;}

.nav{display:flex;align-items:center;gap:30px;}
.nav a{font-family:var(--font-sans);font-weight:600;font-size:14.5px;color:var(--ink);position:relative;padding:6px 0;letter-spacing:.01em;}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--red);transition:right .25s ease;}
.nav a:hover::after,.nav a[aria-current="page"]::after{right:0;}
.nav a[aria-current="page"]{color:var(--red-deep);}

.mast__actions{display:flex;align-items:center;gap:14px;}
.btn-sub{background:var(--red);color:#fff;font-weight:700;font-size:13.5px;padding:11px 18px;border:none;border-radius:2px;letter-spacing:.01em;transition:background .2s,transform .1s;}
.btn-sub:hover{background:var(--red-deep);}
.btn-sub:active{transform:translateY(1px);}
.icon-btn{width:42px;height:42px;border:1px solid var(--line-2);background:transparent;border-radius:2px;display:none;align-items:center;justify-content:center;color:var(--ink);}
@media(max-width:980px){.nav{display:none;}.icon-btn{display:inline-flex;}.btn-sub{display:none;}}

.mobile-menu{display:none;border-bottom:1px solid var(--line);background:var(--paper);}
.mobile-menu.open{display:block;}
.mobile-menu a{display:block;padding:15px var(--gut);border-top:1px solid var(--line);font-weight:600;font-size:16px;}
.mobile-menu a:first-child{border-top:none;}
.mobile-menu .btn-sub{display:inline-block;margin:14px var(--gut);}

/* ---------- Hero ---------- */
.hero{padding:clamp(36px,6vw,64px) 0 clamp(40px,6vw,72px);border-bottom:1px solid var(--line);}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,5vw,64px);align-items:center;}
.hero__eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:22px;}
.hero__cat{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--red-deep);font-weight:600;}
.hero__rule{height:1px;background:var(--line-2);flex:1;}
.hero__coord{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;color:var(--ink-3);}
.hero h1{font-family:var(--font-display);font-weight:600;font-size:clamp(38px,5.6vw,72px);line-height:1.02;letter-spacing:-.022em;margin:0 0 24px;color:var(--ink);font-variation-settings:"opsz" 144;}
.hero h1 em{font-style:italic;color:var(--red);font-weight:600;}
.hero__dek{font-size:clamp(17px,1.5vw,20px);line-height:1.55;color:var(--ink-2);max-width:34ch;margin:0 0 30px;}
.hero__meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;font-size:13.5px;color:var(--ink-2);}
.hero__byline b{font-weight:700;color:var(--ink);}
.hero__sep{width:4px;height:4px;border-radius:50%;background:var(--ink-3);}
.hero__read{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;color:var(--ink-3);text-transform:uppercase;}
.hero__cta{display:inline-flex;align-items:center;gap:10px;margin-top:30px;font-weight:700;font-size:15px;color:var(--ink);border-bottom:2px solid var(--red);padding-bottom:4px;transition:gap .2s,color .2s;}
.hero__cta:hover{gap:16px;color:var(--red-deep);}
.hero__cta svg{transition:transform .2s;}
.hero__cta:hover svg{transform:translateX(3px);}

/* ---------- Radar scope (3D) ---------- */
.scope-wrap{position:relative;perspective:1300px;}
.scope-float{animation:floaty 8s ease-in-out infinite;will-change:transform;}
.scope-frame{position:relative;background:var(--night);border-radius:4px;padding:26px;
  box-shadow:0 30px 70px -30px rgba(20,15,12,.65),inset 0 0 0 1px rgba(255,255,255,.05);
  transform-style:preserve-3d;transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
  transition:transform .5s cubic-bezier(.22,1,.36,1);will-change:transform;}
.scope-frame.is-tilting{transition:transform .1s ease-out;}
.scope-frame__bar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:18px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.42);transform:translateZ(45px);}
.scope-frame__bar b{color:rgba(255,255,255,.78);font-weight:600;}
.scope-frame__live{display:inline-flex;align-items:center;gap:7px;color:var(--red);font-weight:600;}
.scope-frame__dot{width:7px;height:7px;border-radius:50%;background:var(--red);position:relative;}
.scope-frame__dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1.5px solid var(--red);animation:ping 2.4s ease-out infinite;}
.scope{position:relative;width:100%;aspect-ratio:1/1;border-radius:50%;transform-style:preserve-3d;
  background:radial-gradient(circle at 50% 50%, rgba(224,30,19,.05), transparent 70%),var(--night-2);
  box-shadow:inset 0 0 40px rgba(0,0,0,.6),inset 0 0 0 1px rgba(255,255,255,.05);}
.scope__depth{position:absolute;inset:0;border-radius:50%;}
.scope__depth--rings{transform:translateZ(12px);}
.scope__depth--sweep{transform:translateZ(34px);}
.scope__depth--blips{transform:translateZ(64px);}
.scope__rings{position:absolute;inset:0;width:100%;height:100%;}
.scope__sweep{position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg, rgba(224,30,19,.55) 0deg, rgba(224,30,19,.14) 22deg, transparent 60deg, transparent 360deg);
  animation:spin 4s linear infinite;mix-blend-mode:screen;}
.blip{position:absolute;width:9px;height:9px;border-radius:50%;background:#ff5a4d;transform:translate(-50%,-50%);box-shadow:0 0 10px 2px rgba(255,90,77,.7);}
.blip::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(255,90,77,.7);animation:ping 3s ease-out infinite;}
.blip.b2{animation-delay:1s;}
.blip.b3{animation-delay:2s;}
.scope__readout{position:absolute;left:14px;bottom:12px;font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;color:rgba(255,255,255,.5);text-transform:uppercase;line-height:1.5;}
.scope__glare{position:absolute;inset:0;border-radius:50%;pointer-events:none;mix-blend-mode:screen;transform:translateZ(80px);
  background:radial-gradient(150px 150px at var(--gx,30%) var(--gy,25%), rgba(255,255,255,.16), transparent 70%);opacity:0;transition:opacity .3s;}
.scope-wrap:hover .scope__glare{opacity:1;}
@media(max-width:880px){.hero__grid{grid-template-columns:1fr;}.scope-wrap{max-width:440px;margin:0 auto;order:-1;}}

/* ---------- Section heads ---------- */
.sec{padding:clamp(44px,6vw,72px) 0;}
.sec--alt{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:36px;border-bottom:2px solid var(--ink);padding-bottom:14px;}
.sec-head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(24px,3vw,34px);letter-spacing:-.02em;margin:0;color:var(--ink);}
.sec-head .more{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--red-deep);font-weight:600;display:inline-flex;gap:8px;align-items:center;white-space:nowrap;transition:gap .2s;}
.sec-head .more:hover{gap:13px;}

/* ---------- Article grid ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,34px);}
.grid-feat{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(24px,3vw,44px);}
@media(max-width:880px){.grid-3{grid-template-columns:1fr 1fr;}.grid-feat{grid-template-columns:1fr;}}
@media(max-width:580px){.grid-3{grid-template-columns:1fr;}}

.card{display:flex;flex-direction:column;background:transparent;perspective:1000px;}
.card__cover{position:relative;aspect-ratio:16/11;border-radius:3px;overflow:hidden;margin-bottom:18px;background:var(--night);
  transform-style:preserve-3d;transform:rotateX(var(--crx,0deg)) rotateY(var(--cry,0deg));
  transition:transform .5s cubic-bezier(.22,1,.36,1),box-shadow .3s;box-shadow:0 4px 16px -10px rgba(20,15,12,.4);will-change:transform;}
.card__cover.is-tilting{transition:transform .1s ease-out;}
.card:hover .card__cover{box-shadow:0 26px 44px -22px rgba(20,15,12,.55);}
.card__cover svg{position:absolute;inset:0;width:100%;height:100%;transition:transform .5s cubic-bezier(.22,1,.36,1);}
.card:hover .card__cover svg{transform:scale(1.05);}
.card__num{position:absolute;left:14px;top:12px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:rgba(255,255,255,.55);}
.card__badge{position:absolute;left:14px;bottom:14px;background:var(--red);color:#fff;font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:6px 11px;border-radius:2px;}
.card__cat{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--red-deep);margin-bottom:11px;}
.card h3{font-family:var(--font-display);font-weight:600;letter-spacing:-.015em;line-height:1.12;margin:0 0 11px;color:var(--ink);font-size:clamp(20px,1.7vw,24px);transition:color .2s;}
.card a:hover h3{color:var(--red-deep);}
.card p{font-size:15px;line-height:1.55;color:var(--ink-2);margin:0 0 14px;}
.card__meta{margin-top:auto;display:flex;align-items:center;gap:12px;font-size:12.5px;color:var(--ink-3);}
.card__meta b{color:var(--ink-2);font-weight:600;}
.card__meta .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-3);}

.feat .card__cover{aspect-ratio:16/10;}
.feat h3{font-size:clamp(26px,3.2vw,40px);font-weight:700;line-height:1.05;}
.feat .card__dek{font-size:17px;color:var(--ink-2);max-width:52ch;}

.list{display:flex;flex-direction:column;}
.list__item{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:20px 0;border-top:1px solid var(--line-2);}
.list__item:first-child{border-top:none;padding-top:0;}
.list__rank{font-family:var(--font-display);font-weight:900;font-size:30px;line-height:1;color:var(--line-2);font-variation-settings:"opsz" 144;width:34px;transition:color .2s;}
.list__item:hover .list__rank{color:var(--red);}
.list__cat{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--red-deep);margin-bottom:6px;}
.list__item h4{font-family:var(--font-display);font-weight:600;font-size:18px;line-height:1.15;letter-spacing:-.01em;margin:0 0 6px;transition:color .2s;}
.list__item a:hover h4{color:var(--red-deep);}
.list__meta{font-size:12px;color:var(--ink-3);}

/* ---------- Topic chips ---------- */
.topics{display:flex;flex-wrap:wrap;gap:10px;}
.chip{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line-2);padding:9px 15px;border-radius:2px;transition:all .2s;background:var(--surface);}
.chip:hover{border-color:var(--red);color:var(--red-deep);transform:translateY(-2px);}
.chip b{color:var(--red-deep);}

/* ---------- Partner / lead-gen ---------- */
.partner{background:var(--night);color:#fff;border-radius:4px;padding:clamp(28px,4vw,48px);position:relative;overflow:hidden;}
.partner::after{content:"";position:absolute;right:-120px;top:50%;transform:translateY(-50%);width:380px;height:380px;border-radius:50%;border:1px solid rgba(255,255,255,.07);box-shadow:0 0 0 60px rgba(255,255,255,.03),0 0 0 120px rgba(255,255,255,.02);}
.partner__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;position:relative;z-index:1;}
.partner__tag{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#ff6f63;margin-bottom:16px;display:inline-flex;align-items:center;gap:9px;}
.partner__tag::before{content:"";width:18px;height:2px;background:var(--red);}
.partner h2{font-family:var(--font-display);font-weight:600;font-size:clamp(24px,3vw,36px);line-height:1.08;letter-spacing:-.02em;margin:0 0 16px;}
.partner h2 em{font-style:italic;color:#ff6f63;}
.partner p{color:rgba(255,255,255,.72);font-size:16px;line-height:1.55;margin:0 0 26px;max-width:46ch;}
.partner__btn{display:inline-flex;align-items:center;gap:11px;background:var(--red);color:#fff;font-weight:700;font-size:15px;padding:14px 24px;border-radius:2px;transition:background .2s,gap .2s;}
.partner__btn:hover{background:#ff3326;gap:16px;}
.partner__aside{border-left:1px solid rgba(255,255,255,.12);padding-left:34px;}
.partner__stat{margin-bottom:22px;}
.partner__stat:last-child{margin-bottom:0;}
.partner__stat b{font-family:var(--font-display);font-weight:700;font-size:34px;display:block;line-height:1;font-variation-settings:"opsz" 144;}
.partner__stat span{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);}
@media(max-width:780px){.partner__grid{grid-template-columns:1fr;}.partner__aside{border-left:none;border-top:1px solid rgba(255,255,255,.12);padding-left:0;padding-top:28px;}}

/* ---------- Newsletter ---------- */
.news{text-align:center;max-width:620px;margin:0 auto;}
.news h2{font-family:var(--font-display);font-weight:600;font-size:clamp(28px,3.6vw,44px);line-height:1.06;letter-spacing:-.02em;margin:18px 0 14px;}
.news h2 em{font-style:italic;color:var(--red);}
.news p{color:var(--ink-2);font-size:17px;margin:0 0 28px;}
.news__form{display:flex;gap:10px;max-width:480px;margin:0 auto;}
.news__form input{flex:1;font-family:var(--font-sans);font-size:16px;padding:15px 18px;border:1.5px solid var(--line-2);border-radius:2px;background:var(--surface);color:var(--ink);}
.news__form input::placeholder{color:var(--ink-3);}
.news__form button{background:var(--ink);color:#fff;font-weight:700;font-size:15px;padding:15px 26px;border:none;border-radius:2px;white-space:nowrap;transition:background .2s;}
.news__form button:hover{background:var(--red-deep);}
.news__note{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:var(--ink-3);margin-top:16px;text-transform:uppercase;}
.news__ok{display:none;color:var(--red-deep);font-weight:700;margin-top:22px;font-size:17px;}
.news__count{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);}
.news__count b{color:var(--red-deep);}
@media(max-width:520px){.news__form{flex-direction:column;}}

/* ---------- Footer ---------- */
.foot{background:var(--night);color:rgba(255,255,255,.7);padding:60px 0 30px;}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:46px;}
.foot__brand .brand__name{color:#fff;}
.foot__brand p{font-size:14px;line-height:1.6;color:rgba(255,255,255,.55);max-width:34ch;margin:18px 0 0;}
.foot h5{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#ff6f63;margin:0 0 16px;font-weight:600;}
.foot ul{list-style:none;margin:0;padding:0;}
.foot li{margin-bottom:11px;}
.foot li a{font-size:14.5px;color:rgba(255,255,255,.7);transition:color .2s;}
.foot li a:hover{color:#fff;}
.foot__bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.45);}
.foot__bottom a{color:rgba(255,255,255,.6);}
.foot__bottom a:hover{color:#fff;}
@media(max-width:780px){.foot__grid{grid-template-columns:1fr 1fr;gap:30px;}}
@media(max-width:480px){.foot__grid{grid-template-columns:1fr;}}

/* ---------- Cookie / GDPR ---------- */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:120;max-width:560px;margin:0 auto;background:var(--surface);border:1px solid var(--line-2);border-left:4px solid var(--red);border-radius:3px;padding:18px 20px;box-shadow:0 20px 50px -20px rgba(20,15,12,.4);display:flex;gap:18px;align-items:center;}
.cookie.hide{display:none;}
.cookie p{margin:0;font-size:13.5px;line-height:1.5;color:var(--ink-2);}
.cookie p a{color:var(--red-deep);text-decoration:underline;text-underline-offset:2px;}
.cookie__btns{display:flex;gap:8px;flex:0 0 auto;}
.cookie button{font-size:13px;font-weight:700;padding:10px 16px;border-radius:2px;white-space:nowrap;}
.cookie .acc{background:var(--red);color:#fff;border:none;}
.cookie .acc:hover{background:var(--red-deep);}
.cookie .dec{background:transparent;color:var(--ink-2);border:1px solid var(--line-2);}
@media(max-width:560px){.cookie{flex-direction:column;align-items:stretch;}.cookie__btns{justify-content:flex-end;}}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}

/* ============================================================
   ARTICLE PAGE
   ============================================================ */
.crumb{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);padding:26px 0 0;display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.crumb a{color:var(--ink-2);transition:color .2s;}
.crumb a:hover{color:var(--red-deep);}
.crumb span{color:var(--line-2);}

.art-head{padding:30px 0 0;max-width:880px;}
.art-head .kicker{margin-bottom:20px;}
.art-head h1{font-family:var(--font-display);font-weight:600;font-size:clamp(34px,5vw,64px);line-height:1.04;letter-spacing:-.022em;margin:0 0 22px;color:var(--ink);font-variation-settings:"opsz" 144;}
.art-head h1 em{font-style:italic;color:var(--red);}
.art-head .dek{font-family:var(--font-display);font-weight:400;font-size:clamp(19px,2.1vw,25px);line-height:1.4;color:var(--ink-2);margin:0;max-width:60ch;}

.art-meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin:30px 0 8px;padding-bottom:26px;border-bottom:1px solid var(--line);}
.art-author{display:flex;align-items:center;gap:12px;}
.art-avatar{width:46px;height:46px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:18px;flex:0 0 auto;}
.art-author b{display:block;font-size:15px;font-weight:700;color:var(--ink);}
.art-author span{font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);}
.art-meta__sep{width:1px;height:34px;background:var(--line-2);}
.art-info{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);line-height:1.6;}
.art-share{margin-left:auto;display:flex;gap:8px;}
.art-share a,.art-share button{width:40px;height:40px;border:1px solid var(--line-2);background:var(--surface);border-radius:2px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-2);transition:all .2s;}
.art-share a:hover,.art-share button:hover{border-color:var(--red);color:var(--red-deep);}

/* lead figure (3D) */
.figure{margin:34px 0 10px;perspective:1400px;}
.figure__stage{transform-style:preserve-3d;transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));transition:transform .5s cubic-bezier(.22,1,.36,1);will-change:transform;border-radius:4px;overflow:hidden;background:var(--night);box-shadow:0 30px 70px -34px rgba(20,15,12,.6);}
.figure__stage.is-tilting{transition:transform .1s ease-out;}
.figure__stage svg{display:block;width:100%;height:auto;}
.figure figcaption{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.04em;color:var(--ink-3);margin-top:14px;padding-left:16px;border-left:2px solid var(--red);line-height:1.5;text-transform:none;}
.figure figcaption b{color:var(--ink-2);text-transform:uppercase;letter-spacing:.1em;font-size:10.5px;display:block;margin-bottom:3px;}

/* prose */
.prose{max-width:680px;margin:0 auto;padding:8px 0 0;}
.prose>p{font-size:19px;line-height:1.72;color:var(--ink);margin:0 0 26px;}
.prose>p a{color:var(--red-deep);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;}
.prose>p:first-of-type::first-letter{font-family:var(--font-display);font-weight:900;float:left;font-size:5.4em;line-height:.78;padding:6px 14px 0 0;color:var(--red);font-variation-settings:"opsz" 144;}
.prose h2{font-family:var(--font-display);font-weight:700;font-size:clamp(24px,3vw,32px);line-height:1.12;letter-spacing:-.018em;margin:46px 0 18px;color:var(--ink);}
.prose h2 .num{font-family:var(--font-mono);font-size:13px;color:var(--red);font-weight:600;letter-spacing:.1em;display:block;margin-bottom:8px;}
.prose h3{font-family:var(--font-display);font-weight:600;font-size:22px;margin:34px 0 12px;letter-spacing:-.01em;}
.prose ul{margin:0 0 26px;padding:0;list-style:none;}
.prose ul li{position:relative;padding-left:28px;margin-bottom:13px;font-size:18px;line-height:1.6;color:var(--ink);}
.prose ul li::before{content:"";position:absolute;left:2px;top:11px;width:9px;height:9px;background:var(--red);border-radius:50%;}
.pull{margin:40px 0;padding:6px 0 6px 28px;border-left:4px solid var(--red);}
.pull p{font-family:var(--font-display);font-weight:500;font-style:italic;font-size:clamp(22px,2.6vw,30px);line-height:1.3;color:var(--ink);margin:0;letter-spacing:-.01em;}

/* inline CTA in article */
.inline-cta{background:var(--night);color:#fff;border-radius:4px;padding:28px 30px;margin:40px 0;display:flex;align-items:center;gap:24px;position:relative;overflow:hidden;}
.inline-cta::after{content:"";position:absolute;right:-60px;top:50%;transform:translateY(-50%);width:180px;height:180px;border-radius:50%;border:1px solid rgba(255,255,255,.08);box-shadow:0 0 0 30px rgba(255,255,255,.03);}
.inline-cta__txt{position:relative;z-index:1;}
.inline-cta .t{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#ff6f63;font-weight:600;margin-bottom:8px;}
.inline-cta p{margin:0;font-family:var(--font-display);font-size:20px;font-weight:500;line-height:1.3;}
.inline-cta a{flex:0 0 auto;position:relative;z-index:1;display:inline-flex;align-items:center;gap:9px;background:var(--red);color:#fff;font-weight:700;font-size:14.5px;padding:13px 20px;border-radius:2px;transition:background .2s,gap .2s;white-space:nowrap;}
.inline-cta a:hover{background:#ff3326;gap:14px;}
@media(max-width:620px){.inline-cta{flex-direction:column;align-items:flex-start;}}

/* author box */
.authorbox{max-width:680px;margin:50px auto 0;padding:28px 30px;background:var(--paper-2);border:1px solid var(--line);border-radius:4px;display:flex;gap:20px;align-items:flex-start;}
.authorbox .art-avatar{width:58px;height:58px;font-size:22px;}
.authorbox b{font-size:17px;}
.authorbox .role{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--red-deep);margin:3px 0 10px;}
.authorbox p{margin:0;font-size:15px;line-height:1.6;color:var(--ink-2);}
@media(max-width:520px){.authorbox{flex-direction:column;}}

@keyframes spin{to{transform:rotate(360deg);}}
@keyframes ping{0%{transform:scale(.6);opacity:.9;}100%{transform:scale(2.1);opacity:0;}}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(-.4deg);}50%{transform:translateY(-12px) rotate(.4deg);}}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation:none!important;transition:none!important;}
  .reveal{opacity:1;transform:none;}
  .scope-frame,.card__cover,.figure__stage{transform:none!important;}
}
