/* ================================================================
   DIGISTORIES — Shared Stylesheet
   Editorial · Social-first · Senior consultancy
================================================================ */

/* ----- Tokens ----- */
:root{
  --black:#0A0A0A;
  --off-black:#141414;
  --white:#FFFFFF;
  --warm-white:#FBF9F5;
  --warm-cream:#F2EDE5;
  --vogue-red:#C8102E;
  --deep-red:#8A0E22;
  --green:#4ADE80;

  --text:#1a1a1a;
  --text-soft:#3a3a3a;
  --text-muted:#6b6b6b;
  --divider:rgba(0,0,0,0.06);
  --divider-strong:rgba(0,0,0,0.12);

  --serif:'Fraunces', 'Times New Roman', serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:'JetBrains Mono', 'Courier New', monospace;

  --r-card:16px;
  --r-pill:100px;

  --pad-section:140px;
  --pad-section-sm:90px;

  --maxw:1280px;
  --maxw-narrow:1080px;
  --maxw-text:920px;

  --ease:cubic-bezier(.22,1,.36,1);
}

/* ----- Reset ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  font-family:var(--sans);
  font-weight:300;
  font-size:17px;
  line-height:1.7;
  color:var(--text);
  background:var(--warm-white);
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto}
button{font:inherit;border:none;background:none;cursor:pointer;color:inherit}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* ----- Typography utilities ----- */
.serif{font-family:var(--serif);font-variation-settings:"opsz" 144}
.mono{font-family:var(--mono);text-transform:uppercase;letter-spacing:.25em;font-weight:500}
.italic-red{font-family:var(--serif);font-style:italic;color:var(--vogue-red);font-weight:500;font-variation-settings:"opsz" 144}

.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--vogue-red);
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.eyebrow::before{
  content:"—";
  color:var(--vogue-red);
  letter-spacing:0;
}
.eyebrow.no-dash::before{content:none}

h1,h2,h3,h4{
  font-family:var(--serif);
  font-variation-settings:"opsz" 144;
  font-weight:300;
  line-height:.98;
  letter-spacing:-.035em;
  color:var(--text);
}
h1{font-size:clamp(54px,8vw,110px);line-height:.95;letter-spacing:-.045em}
h2{font-size:clamp(40px,5.4vw,80px);letter-spacing:-.035em}
h3{font-size:clamp(26px,3vw,42px);font-weight:400;letter-spacing:-.025em}
p{font-weight:300;color:var(--text-soft)}

/* ----- Layout ----- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 60px}
.container-narrow{max-width:var(--maxw-narrow);margin:0 auto;padding:0 60px}
.container-text{max-width:var(--maxw-text);margin:0 auto;padding:0 32px}
section{padding:var(--pad-section) 0}
.section-cream{background:var(--warm-cream)}
.section-black{background:var(--black);color:var(--white)}
.section-black h1,.section-black h2,.section-black h3{color:var(--white)}
.section-black p{color:rgba(255,255,255,.72)}
.section-red{background:var(--vogue-red);color:var(--white)}
.section-red h1,.section-red h2,.section-red h3{color:var(--white)}

/* ----- Announcement bar ----- */
.announce{
  background:var(--vogue-red);
  color:#fff;
  text-align:center;
  padding:11px 24px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:500;
}

/* ----- Navigation ----- */
.nav{
  position:sticky;top:0;z-index:50;
  background:var(--warm-white);
  border-bottom:1px solid var(--divider);
  padding:22px 60px;
  display:flex;align-items:center;justify-content:space-between;
  backdrop-filter:saturate(1.2) blur(8px);
}
.logo{
  font-family:var(--serif);
  font-size:30px;
  font-weight:400;
  letter-spacing:-.02em;
  color:var(--text);
  font-variation-settings:"opsz" 144;
}
.logo em{
  font-style:italic;
  color:var(--vogue-red);
  font-weight:500;
}
.nav-links{
  display:flex;align-items:center;gap:42px;
}
.nav-links a{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.25em;
  font-weight:500;
  text-transform:uppercase;
  position:relative;
  transition:color .2s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--vogue-red)}
.nav-links .cta{
  background:var(--vogue-red);
  color:#fff;
  padding:12px 22px;
  border-radius:var(--r-pill);
  letter-spacing:.2em;
}
.nav-links .cta:hover{background:var(--deep-red);color:#fff}

/* ----- Buttons ----- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;
  border-radius:var(--r-pill);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.28em;
  font-weight:500;
  text-transform:uppercase;
  transition:all .25s var(--ease);
  border:1px solid transparent;
  cursor:pointer;
}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-black{background:var(--black);color:var(--white)}
.btn-black:hover{background:var(--off-black);transform:scale(1.02);box-shadow:0 12px 30px rgba(0,0,0,.18)}
.btn-red{background:var(--vogue-red);color:var(--white)}
.btn-red:hover{background:var(--deep-red);transform:scale(1.02);box-shadow:0 12px 30px rgba(200,16,46,.28)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--divider-strong)}
.btn-ghost:hover{background:var(--text);color:var(--warm-white);transform:scale(1.02)}
.btn-white{background:var(--white);color:var(--text)}
.btn-white:hover{background:var(--warm-cream);transform:scale(1.02)}

/* ----- Glass badge ----- */
.glass-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 18px;
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(20px);
  border-radius:var(--r-pill);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.25em;
  font-weight:500;
  text-transform:uppercase;
}
.glass-badge.light{
  background:rgba(255,255,255,.85);
  color:var(--text);
  border-color:rgba(0,0,0,.06);
}
.dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 0 0 rgba(74,222,128,.6);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(74,222,128,.5)}
  50%{box-shadow:0 0 0 8px rgba(74,222,128,0)}
}

/* ----- Section header pattern ----- */
.section-head{margin-bottom:68px}
.section-head .eyebrow{margin-bottom:24px}
.section-head h2{max-width:14ch}
.section-head.center{text-align:center}
.section-head.center h2{margin:0 auto;max-width:18ch}
.section-head.split{
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:80px;align-items:end;
}
.section-head.split .deck{font-size:18px;color:var(--text-muted)}

/* ----- Star separator ----- */
.star{color:var(--vogue-red);display:inline-block;margin:0 .35em}

/* ----- Cards ----- */
.card{
  background:var(--white);
  border:1px solid var(--divider);
  border-radius:var(--r-card);
  padding:36px 30px;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.card:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(0,0,0,.06)}
.section-black .card{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.08);
  backdrop-filter:blur(20px);
}

/* ----- Marquee ----- */
.marquee{
  background:var(--black);
  color:#fff;
  padding:24px 0;
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.marquee-track{
  display:flex;
  gap:60px;
  white-space:nowrap;
  animation:marquee 40s linear infinite;
  font-family:var(--serif);
  font-style:italic;
  font-size:26px;
  font-weight:300;
  font-variation-settings:"opsz" 144;
}
.marquee:hover .marquee-track{animation-duration:60s}
@keyframes marquee{
  to{transform:translateX(-50%)}
}
.marquee-track span{display:inline-flex;align-items:center;gap:60px}

/* ----- Footer ----- */
.footer{
  background:var(--black);
  color:#fff;
  padding:90px 60px 40px;
}
.footer-inner{max-width:var(--maxw);margin:0 auto}
.footer .logo{
  font-size:64px;color:#fff;display:block;margin-bottom:60px;
}
.footer-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:50px;
  padding-bottom:60px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-col h4{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--vogue-red);
  margin-bottom:20px;
  font-weight:500;
}
.footer-col a{
  display:block;
  font-family:var(--serif);
  font-size:18px;
  font-weight:400;
  margin-bottom:10px;
  color:rgba(255,255,255,.78);
  transition:color .2s var(--ease);
}
.footer-col a:hover{color:var(--vogue-red)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:30px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
}

/* ----- Reveal animation ----- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-stagger.in>*{opacity:1;transform:none}
.reveal-stagger.in>*:nth-child(1){transition-delay:.05s}
.reveal-stagger.in>*:nth-child(2){transition-delay:.15s}
.reveal-stagger.in>*:nth-child(3){transition-delay:.25s}
.reveal-stagger.in>*:nth-child(4){transition-delay:.35s}
.reveal-stagger.in>*:nth-child(5){transition-delay:.45s}
.reveal-stagger.in>*:nth-child(6){transition-delay:.55s}

/* ----- Final CTA (shared) ----- */
.final-cta{
  background:var(--black);
  color:#fff;
  padding:140px 0;
  position:relative;
  overflow:hidden;
  text-align:center;
}
.final-cta::before{
  content:"";position:absolute;top:50%;left:50%;
  width:900px;height:900px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(200,16,46,.28),transparent 60%);
  pointer-events:none;
}
.final-cta .inner{position:relative;z-index:1}
.final-cta h2{font-size:clamp(54px,8vw,110px);line-height:.95;color:#fff;margin:24px auto 40px;max-width:14ch}
.final-cta .email-pill{
  display:inline-flex;align-items:center;gap:14px;
  background:var(--vogue-red);
  padding:22px 40px;
  border-radius:var(--r-pill);
  font-family:var(--serif);
  font-style:italic;
  font-size:22px;
  font-weight:400;
  font-variation-settings:"opsz" 144;
  transition:all .3s var(--ease);
}
.final-cta .email-pill:hover{background:var(--deep-red);transform:scale(1.03);box-shadow:0 20px 50px rgba(200,16,46,.4)}
.final-cta .status{
  display:flex;justify-content:center;gap:30px;
  margin-top:36px;
  font-family:var(--mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}
.final-cta .status .dot{display:inline-block;margin-right:8px;vertical-align:middle}

/* ----- Responsive ----- */
@media (max-width:1024px){
  :root{--pad-section:100px}
  .container,.container-narrow,.nav,.footer{padding-left:32px;padding-right:32px}
  .nav-links{gap:24px}
  .section-head.split{grid-template-columns:1fr;gap:30px}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  :root{--pad-section:70px}
  body{font-size:16px}
  .container,.container-narrow,.nav,.footer{padding-left:22px;padding-right:22px}
  h1{font-size:clamp(44px,12vw,68px)}
  h2{font-size:clamp(34px,8vw,52px)}
  .nav{padding:18px 22px}
  .nav-links{gap:18px}
  .nav-links a:not(.cta){display:none}
  .nav-links .cta{padding:10px 16px;font-size:10px}
  .logo{font-size:24px}
  .marquee-track{font-size:20px;gap:40px}
  .marquee-track span{gap:40px}
  .footer{padding:60px 22px 30px}
  .footer .logo{font-size:42px;margin-bottom:40px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:14px;text-align:center}
}
