/* ============================================================
   VICTORIA "VORTEX" ANTHONY — "Star-Spangled Whirlwind"
   Bespoke skin (NOT the template look). Magazine-cover masthead
   hero on a warm bone base, single USA-red accent + navy whisper.
   Type: Anton (display) · Fraunces (serif accent) · Barlow (body).
   Motion signature: the "vortex" — spiral swirl reveal of the
   cover figure. Engine (entrance gate, IO reveals, card flash,
   newsletter) is unchanged; only the skin is redesigned.
   ============================================================ */

/* ---------- DESIGN TOKENS --------------------------------- */
:root{
  --paper:#f4efe3;          /* bone base                    */
  --paper-2:#eee6d6;        /* raised surface / cards       */
  --paper-3:#e6dcc7;        /* hover surface                */
  --ink:#181510;           /* primary text (warm near-black)*/
  --muted:#585247;          /* secondary text               */
  --faint:#8c8578;          /* tertiary / labels            */
  --red:#c8102e;            /* USA red — the one accent      */
  --red-2:#9d0b22;          /* deep red (hover)             */
  --navy:#0b1f44;           /* whisper of navy              */
  --line:rgba(24,21,16,.16);
  --line-2:rgba(24,21,16,.30);

  --font-d:"Anton","Arial Narrow",system-ui,sans-serif;
  --font-b:"Barlow",system-ui,sans-serif;
  --font-s:"Fraunces",Georgia,serif;

  --gutter:clamp(1.25rem,5vw,4.5rem);
  --maxw:1280px;
  --radius:4px;
  --header-h:72px;
}

/* ---------- RESET / BASE ---------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-b);
  font-size:clamp(1rem,.55vw + .9rem,1.12rem);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* faint paper wash — a whisper of navy + red at opposite corners */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.55;
  background:
    radial-gradient(120% 80% at 100% 0%,color-mix(in srgb,var(--navy) 7%,transparent),transparent 55%),
    radial-gradient(110% 70% at 0% 100%,color-mix(in srgb,var(--red) 5%,transparent),transparent 55%);
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer}
h1,h2,h3{margin:0;font-family:var(--font-d);font-weight:400;line-height:.9;letter-spacing:.01em}
:focus-visible{outline:2px solid var(--red);outline-offset:3px;border-radius:2px}
::selection{background:var(--red);color:#fff}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.u-accent{color:var(--red)}
/* accent word inside a display heading → Fraunces italic, editorial tension */
.about__title .u-accent,.soon__title .u-accent{
  font-family:var(--font-s);font-style:italic;font-weight:400;
  text-transform:none;letter-spacing:-.01em;font-size:1.02em;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-b);font-weight:600;
  font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--red)}
.star{display:inline-block;color:var(--red)}

/* ---------- HEADER / NAV --------------------------------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:60;height:var(--header-h);
  display:flex;align-items:center;justify-content:space-between;padding-inline:var(--gutter);
  background:linear-gradient(180deg,color-mix(in srgb,var(--paper) 80%,transparent),transparent);
  transition:background .35s ease,border-color .35s ease,backdrop-filter .35s ease;
  border-bottom:1px solid transparent;
}
.site-header.is-stuck{
  background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom-color:var(--line);
}
.brand{display:inline-flex;align-items:center;gap:.55ch;font-family:var(--font-d);letter-spacing:.02em}
.brand__mark{display:inline-grid;place-items:center;width:2em;height:2em;font-size:1rem;line-height:1;border-radius:5px;background:var(--red);color:#fff}
.brand__name{font-size:1.05rem;letter-spacing:.06em;text-transform:uppercase}

.nav{display:flex;align-items:center;gap:clamp(1rem,1.8vw,2.1rem)}
.nav a{position:relative;font-family:var(--font-b);font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);transition:color .2s ease;padding:.2em 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:0;background:var(--red);transition:width .25s ease}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{width:100%}
.nav-toggle{display:none}
.nav-scrim{display:none}

@media (max-width:860px){
  .nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;background:transparent;border:0;padding:10px;z-index:70}
  .nav-toggle span{display:block;height:2px;width:100%;background:var(--ink);border-radius:2px;transition:transform .3s ease,opacity .2s ease}
  body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.nav-open .nav-toggle span:nth-child(2){opacity:0}
  body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav{position:fixed;inset:0 0 0 auto;z-index:65;width:min(84vw,340px);flex-direction:column;align-items:flex-start;justify-content:center;gap:1.3rem;padding:var(--gutter);background:var(--paper-2);border-left:1px solid var(--line);transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.1,1)}
  body.nav-open .nav{transform:translateX(0)}
  .nav a{font-family:var(--font-d);font-size:1.55rem;color:var(--ink);letter-spacing:.02em}
  .nav a::after{bottom:-4px}
  .nav-scrim{display:block;position:fixed;inset:0;z-index:62;background:rgba(24,21,16,.4);opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease}
  body.nav-open .nav-scrim{opacity:1;visibility:visible}
}

/* ---------- HERO — MAGAZINE COVER ------------------------ */
.hero{position:relative;min-height:min(100svh,1040px);display:flex;overflow:hidden}
.hero__frame{
  position:relative;z-index:2;display:flex;flex-direction:column;
  width:100%;max-width:var(--maxw);margin-inline:auto;
  padding:calc(var(--header-h) + .6rem) var(--gutter) clamp(1.4rem,3vh,2.4rem);
}

/* top hairline row — the "issue line" */
.cover__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-bottom:clamp(.5rem,1.4vh,1rem)}
.cover__top span{font-family:var(--font-b);font-weight:600;font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}
.cover__top .r{color:var(--faint)}

/* the masthead nameplate */
.masthead{
  font-family:var(--font-d);text-transform:uppercase;color:var(--ink);
  font-size:clamp(4.2rem,22vw,17rem);line-height:.82;letter-spacing:.005em;
  text-align:center;position:relative;z-index:1;margin:0;display:flex;justify-content:center;
}
.masthead .ch{display:inline-block;will-change:transform}
.masthead .ch--accent{color:var(--red)}
.masthead__sub{
  display:block;text-align:center;margin-top:.55rem;
  font-family:var(--font-b);font-weight:600;font-size:clamp(.72rem,1.5vw,1rem);
  letter-spacing:.62em;text-indent:.62em;text-transform:uppercase;color:var(--ink);
}

/* cover body: coverlines | figure | index */
.cover__body{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:clamp(1rem,3vw,2.6rem);margin-top:clamp(-1rem,-1vw,-.2rem);flex:1;min-height:0}

/* left coverlines */
.cover__lines{display:flex;flex-direction:column;gap:1.1rem;max-width:34ch}
.cover__lines--l{align-items:flex-start;text-align:left}
.cover__lines--r{align-items:flex-end;text-align:right}
.cover__id{font-family:var(--font-s);font-style:italic;font-weight:400;font-size:clamp(1.2rem,1.8vw,1.7rem);line-height:1.18;color:var(--ink)}
.cover__id em{color:var(--red);font-style:italic}
.coverline{position:relative;display:block;font-size:.92rem;line-height:1.35;color:var(--muted);max-width:30ch}
.coverline b{color:var(--ink);font-weight:600}
.coverline .ix{font-family:var(--font-d);font-size:.72rem;letter-spacing:.1em;color:var(--red);display:inline-block;margin-right:.5em;vertical-align:.05em}

/* right side: the index of headline numbers */
.cover__index{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem;width:100%;max-width:16rem}
.cover__index li{display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:.6rem;padding-bottom:.85rem;border-bottom:1px solid var(--line)}
.cover__index li:last-child{border-bottom:0;padding-bottom:0}
.cover__index .n{font-family:var(--font-d);font-size:clamp(1.9rem,3vw,2.7rem);line-height:.85;color:var(--ink)}
.cover__index .n .u-accent{color:var(--red)}
.cover__index .t{font-family:var(--font-b);font-weight:600;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);text-align:right;max-width:11ch}

/* the cover figure — contained, framed, with a rotating vortex ring */
.cover__figure{position:relative;margin:0;justify-self:center;align-self:end;width:clamp(240px,34vw,384px);aspect-ratio:746/1000}
.cover__ring{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:152%;height:152%;pointer-events:none;z-index:0;color:var(--red);opacity:.5}
.cover__ring svg{width:100%;height:100%;display:block;animation:vspin 46s linear infinite}
@keyframes vspin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.cover__ring svg{animation:none}}
.cover__figure .plate{position:relative;z-index:1;height:100%;margin:0;overflow:hidden;border-radius:2px;border:1px solid var(--line-2);background:var(--navy);box-shadow:0 30px 60px -30px rgba(24,21,16,.5)}
.cover__figure img{width:100%;height:100%;object-fit:cover;object-position:52% 20%;filter:contrast(1.04) saturate(1.02);will-change:transform,opacity}
.cover__figure .plate::after{content:"";position:absolute;inset:6px;border:1px solid color-mix(in srgb,var(--red) 55%,transparent);pointer-events:none}
.cover__cap{position:absolute;z-index:2;left:0;bottom:-.4rem;transform:translateY(100%);font-family:var(--font-b);font-weight:600;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}

/* foot bar: CTAs + issue/barcode */
.cover__foot{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;flex-wrap:wrap;margin-top:clamp(1rem,2.4vh,1.7rem);padding-top:clamp(.9rem,2vh,1.3rem);border-top:1px solid var(--line)}
.cover__meta{display:flex;align-items:center;gap:1.2rem}
.issue{font-family:var(--font-b);font-weight:600;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--faint)}
.barcode{display:flex;align-items:flex-end;gap:2px;height:26px}
.barcode i{display:block;width:2px;height:100%;background:var(--ink)}
.barcode i:nth-child(2n){height:70%}
.barcode i:nth-child(3n){height:88%}
.barcode i:nth-child(5n){height:60%;width:3px}

.hero__actions{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
.btn{display:inline-flex;align-items:center;gap:.7ch;font-family:var(--font-b);font-weight:600;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;padding:.95em 1.5em;border-radius:2px;border:1px solid transparent;transition:transform .25s ease,background .25s ease,color .25s ease,border-color .25s ease;will-change:transform}
.btn--primary{background:var(--red);color:#fff}
.btn--primary:hover{background:var(--red-2)}
.btn--ghost{background:transparent;border-color:var(--line-2);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink);background:rgba(24,21,16,.05)}
.btn__arrow{transition:transform .25s ease}
.btn:hover .btn__arrow{transform:translateX(4px)}

.hero__scrollcue{position:absolute;z-index:3;right:var(--gutter);bottom:clamp(1.4rem,4vh,3rem);display:inline-flex;align-items:center;gap:.7ch;writing-mode:vertical-rl;font-family:var(--font-b);font-weight:600;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--faint)}
.hero__scrollcue i{display:block;width:1px;height:40px;background:linear-gradient(var(--faint),transparent);animation:cue 2.2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}
@media (prefers-reduced-motion:reduce){.hero__scrollcue i{animation:none}}

/* hero responsive */
@media (max-width:960px){
  .cover__body{grid-template-columns:1fr;gap:1.3rem;text-align:center;margin-top:.5rem}
  .cover__lines{max-width:none;align-items:center;text-align:center;order:2}
  .cover__lines--r{order:3}
  .cover__figure{order:1;align-self:center;width:min(70vw,320px)}
  .cover__index{max-width:22rem;margin-inline:auto}
  .cover__cap{display:none}
}
@media (max-width:560px){
  .cover__top .r{display:none}
  .hero__scrollcue{display:none}
  .masthead__sub{letter-spacing:.4em;text-indent:.4em}
}

/* ---------- ACCOLADE MARQUEE ----------------------------- */
.marquee{position:relative;z-index:2;border-block:1px solid var(--line);background:var(--paper-2);overflow:hidden;white-space:nowrap}
.marquee__track{display:inline-flex;gap:2.5rem;padding:.85rem 0;animation:scroll 38s linear infinite;will-change:transform}
.marquee span{font-family:var(--font-d);font-size:.92rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.marquee span::after{content:"\2605";margin-left:2.5rem;color:var(--red);font-size:.7em;vertical-align:.15em}
@keyframes scroll{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}

/* ---------- ABOUT ---------------------------------------- */
.about{padding:clamp(4.5rem,11vh,9rem) 0}
.about__grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,5vw,5rem);align-items:start}
@media (max-width:900px){.about__grid{grid-template-columns:1fr}}
.about__head{margin:0 0 1.6rem}
.about__title{font-size:clamp(2.4rem,5.4vw,4.2rem);text-transform:uppercase;margin:.6rem 0 0;letter-spacing:.01em}
.about__bio p{color:var(--muted);font-size:clamp(1rem,1.05vw,1.14rem);margin:0 0 1.1rem;max-width:62ch}
.about__bio p strong{color:var(--ink);font-weight:600}

.honors{list-style:none;margin:2.2rem 0 0;padding:0;display:grid;gap:.1rem}
.honors li{display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:baseline;padding:.85rem 0;border-top:1px solid var(--line)}
.honors li:last-child{border-bottom:1px solid var(--line)}
.honors .yr{font-family:var(--font-d);color:var(--red);font-size:1rem;letter-spacing:.03em}
.honors .txt{color:var(--ink);font-weight:500}

/* editorial plates — dark training photos framed like magazine figures */
.about__media{display:grid;gap:1.1rem}
.about__media figure{position:relative;margin:0;overflow:hidden;border-radius:2px;border:1px solid var(--line-2);background:var(--navy)}
.about__media img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:contrast(1.04) saturate(.98)}
.about__media figure:nth-child(2){margin-left:clamp(1rem,5vw,3.5rem)}
.about__media figcaption{position:absolute;left:0;bottom:0;padding:.5em .8em;font-family:var(--font-b);font-weight:600;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:#f4efe3;background:color-mix(in srgb,var(--navy) 82%,transparent)}
.about__media figcaption .star{color:var(--red);margin-right:.4em}

/* ---------- COMING SOON ---------------------------------- */
.soon{padding:clamp(4rem,10vh,8rem) 0 clamp(4.5rem,11vh,9rem);background:linear-gradient(180deg,var(--paper),var(--paper-2))}
.soon__head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1.2rem;margin-bottom:2.6rem}
.soon__title{font-size:clamp(2.4rem,5.4vw,4.2rem);text-transform:uppercase;letter-spacing:.01em}
.soon__lede{color:var(--muted);max-width:42ch;margin:0}

.soon__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;counter-reset:soon}
@media (max-width:900px){.soon__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.soon__grid{grid-template-columns:1fr}}

.card{position:relative;display:flex;flex-direction:column;gap:.8rem;padding:1.7rem 1.6rem 1.8rem;border-radius:var(--radius);background:var(--paper-2);border:1px solid var(--line);overflow:hidden;transition:transform .3s ease,border-color .3s ease,background .3s ease;scroll-margin-top:100px}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.card:hover{transform:translateY(-4px);border-color:var(--line-2);background:var(--paper-3)}
.card:hover::before{transform:scaleX(1)}
.card::after{counter-increment:soon;content:"0" counter(soon);position:absolute;top:1.15rem;right:1.35rem;pointer-events:none;font-family:var(--font-d);font-size:1rem;letter-spacing:.04em;color:var(--faint);opacity:.6;transition:color .3s ease,opacity .3s ease}
.card:hover::after{color:var(--red);opacity:1}
.card__icon{width:38px;height:38px;color:var(--red)}
.card__icon svg{width:100%;height:100%}
.card__title{font-family:var(--font-d);font-size:1.5rem;text-transform:uppercase;letter-spacing:.01em}
.card__desc{color:var(--muted);font-size:.94rem;margin:0}
.card__tag{margin-top:auto;align-self:flex-start;font-family:var(--font-b);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;font-weight:600;color:var(--red);padding:.42em .8em;border:1px solid color-mix(in srgb,var(--red) 42%,transparent);border-radius:999px}
.card.is-flash{animation:flash 1.15s ease}
@keyframes flash{0%,100%{box-shadow:0 0 0 0 transparent}18%{box-shadow:0 0 0 2px var(--red),0 24px 60px -20px color-mix(in srgb,var(--red) 55%,transparent);transform:translateY(-4px)}}

.card--news .mini{display:flex;gap:.4rem;margin-top:.4rem}
.card--news input{flex:1;min-width:0;background:var(--paper);border:1px solid var(--line-2);color:var(--ink);border-radius:2px;padding:.6em .9em;font:inherit;font-size:.85rem}
.card--news input.is-bad{border-color:var(--red)}
.card--news button{background:var(--red);color:#fff;border:0;border-radius:2px;padding:.6em .95em;font-size:.85rem;font-weight:600}
.card--news .done{color:var(--red-2);font-size:.85rem;margin:.2rem 0 0;font-weight:600}

/* ---------- FOOTER --------------------------------------- */
.site-footer{background:var(--paper-2);border-top:1px solid var(--line);padding:clamp(2.5rem,6vh,4rem) 0}
.footer__row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.2rem}
.footer__brand{font-family:var(--font-d);text-transform:uppercase;letter-spacing:.03em;font-size:1.25rem}
.footer__ig{display:inline-flex;align-items:center;gap:.6ch;color:var(--muted);font-size:.9rem;transition:color .2s ease}
.footer__ig:hover{color:var(--ink)}
.footer__ig svg{width:18px;height:18px}
.footer__credit{width:100%;margin-top:1.6rem;padding-top:1.4rem;border-top:1px solid var(--line);color:var(--faint);font-size:.78rem}
.footer__credit a{color:var(--muted)}
.footer__credit a:hover{color:var(--ink)}

/* ---------- REVEAL / ENTRANCE ---------------------------- */
[data-reveal]{opacity:1}
html[data-io] [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);transition-delay:var(--reveal-delay,0ms)}
html[data-io] [data-reveal].is-in{opacity:1;transform:none}

.rise{opacity:1}
html[data-entrance="js"] .rise{opacity:0}
@media (prefers-reduced-motion:reduce){
  html[data-entrance="js"] .rise,html[data-io] [data-reveal]{opacity:1;transform:none}
}
