/* ============================================================
   MICHEL CREATIVE STUDIO — Design System
   Palette: warm black + signature red + cream/gold
   Type: Anton (display poster) / Space Grotesk (UI/body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root{
  color-scheme: dark;
  --ink:        #0c0a09;
  --ink-2:      #14110f;
  --ink-3:      #1d1815;
  --paper:      #f3ebdd;
  --paper-2:    #e9e0cb;
  --red:        #e8362c;
  --red-deep:   #b9221a;
  --gold:       #f0d98c;
  --cream:      #f3ebdd;
  --muted:      rgba(243,235,221,.56);
  --muted-2:    rgba(243,235,221,.34);
  --line:       rgba(243,235,221,.14);

  --display: 'Anton', 'Arial Narrow', sans-serif;
  --sans: 'Space Grotesk', system-ui, sans-serif;

  --maxw: 1320px;
  --pad: clamp(20px, 5vw, 84px);
  --ease: cubic-bezier(.19,1,.22,1);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--cream);
  line-height:1.5;
  font-size:18px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none;
}
@media (hover:none),(pointer:coarse){ body{ cursor:auto; } }

::selection{ background:var(--red); color:#fff; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:none; }
@media (hover:none){ button{ cursor:pointer; } }

/* grain overlay */
body::after{
  content:""; position:fixed; inset:0; z-index:9990; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay;
  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='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
section{ position:relative; }
.eyebrow{
  font-family:var(--sans); font-weight:700; font-size:13px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--red);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:30px; height:2px; background:var(--red); display:inline-block; }
.eyebrow.gold{ color:var(--gold); }
.eyebrow.gold::before{ background:var(--gold); }
.eyebrow.ink{ color:var(--ink); }
.eyebrow.ink::before{ background:var(--ink); }

/* ---------- display type ---------- */
.display{
  font-family:var(--display); font-weight:400; line-height:.9;
  text-transform:uppercase; letter-spacing:-.005em; padding-bottom:.06em;
}
h1.display{ font-size:clamp(56px, 12vw, 188px); }
h2.display{ font-size:clamp(44px, 8vw, 132px); }
h3.display{ font-size:clamp(34px, 5vw, 76px); }
.stretch{ transform:scaleY(1.08); transform-origin:bottom; display:inline-block; }
.outline{
  -webkit-text-stroke:2px var(--cream); color:transparent;
}
.outline.red{ -webkit-text-stroke-color:var(--red); }
.txt-red{ color:var(--red); }
.txt-gold{ color:var(--gold); }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-head{
  position:fixed; inset:0 0 auto 0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding:18px var(--pad);
  transition:background .5s var(--ease), padding .5s var(--ease), border-color .5s;
  border-bottom:1px solid transparent;
}
.site-head.scrolled{
  background:rgba(12,10,9,.72); backdrop-filter:blur(14px);
  padding-top:12px; padding-bottom:12px; border-bottom-color:var(--line);
}
.logo{ display:flex; align-items:center; gap:12px; z-index:1002; }
.brandmark{ height:30px; width:auto; fill:var(--cream); transition:fill .4s; }
.logo:hover .brandmark{ fill:var(--red); }
.logo-word{
  font-family:var(--display); font-size:19px; line-height:.86; text-transform:uppercase;
  display:flex; flex-direction:column; letter-spacing:.01em;
}
.logo-word em{ font-style:normal; font-family:var(--sans); font-weight:600;
  font-size:8.5px; letter-spacing:.34em; color:var(--muted); }

.nav{ display:flex; align-items:center; gap:6px; }
.nav a{
  font-weight:500; font-size:14.5px; letter-spacing:.02em; padding:9px 15px;
  border-radius:999px; position:relative; transition:color .3s, background .3s;
  text-transform:capitalize;
}
.nav a::after{
  content:""; position:absolute; left:15px; right:15px; bottom:4px; height:2px;
  background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease);
}
.nav a:hover::after, .nav a.active::after{ transform:scaleX(1); }
.nav a.active{ color:var(--gold); }

.head-cta{
  display:inline-flex; align-items:center; gap:9px;
  background:var(--red); color:#fff; font-weight:600; font-size:14.5px;
  padding:11px 20px; border-radius:999px; transition:transform .3s var(--ease), background .3s;
}
.head-cta:hover{ background:var(--cream); color:var(--ink); }
.head-cta .dot{ width:8px; height:8px; border-radius:50%; background:currentColor; animation:pulse 1.6s infinite; }
@keyframes pulse{ 0%,100%{ opacity:1; transform:scale(1);} 50%{ opacity:.4; transform:scale(.6);} }

.burger{ display:none; width:46px; height:46px; border:1px solid var(--line); border-radius:50%;
  background:transparent; position:relative; z-index:1002; }
.burger span{ position:absolute; left:13px; right:13px; height:2px; background:var(--cream); transition:.35s var(--ease); }
.burger span:nth-child(1){ top:18px; } .burger span:nth-child(2){ bottom:18px; }
.menu-open .burger span:nth-child(1){ top:22px; transform:rotate(45deg); }
.menu-open .burger span:nth-child(2){ bottom:22px; transform:rotate(-45deg); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:1001; background:var(--ink-2);
  display:flex; flex-direction:column; justify-content:center; gap:6px; padding:var(--pad);
  transform:translateY(-100%); transition:transform .6s var(--ease); opacity:0; visibility:hidden;
}
.menu-open .drawer{ transform:translateY(0); opacity:1; visibility:visible; }
.drawer a{ font-family:var(--display); font-size:clamp(40px,11vw,84px); text-transform:uppercase;
  line-height:1; color:var(--cream); transition:color .3s, transform .3s; }
.drawer a:hover, .drawer a:active{ color:var(--red); transform:translateX(14px); }
.drawer .d-foot{ margin-top:34px; font-family:var(--sans); color:var(--muted); font-size:15px; display:flex; flex-direction:column; gap:6px; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; gap:12px;
  font-weight:600; font-size:16px; letter-spacing:.01em;
  padding:17px 30px; border-radius:999px; border:1px solid transparent;
  transition:transform .35s var(--ease), background .35s, color .35s, border-color .35s;
  will-change:transform;
}
.btn .arr{ transition:transform .35s var(--ease); }
.btn:hover .arr{ transform:translateX(5px); }
.btn-red{ background:var(--red); color:#fff; }
.btn-red:hover{ background:var(--cream); color:var(--ink); }
.btn-cream{ background:var(--cream); color:var(--ink); }
.btn-cream:hover{ background:var(--red); color:#fff; }
.btn-ghost{ border-color:var(--line); color:var(--cream); }
.btn-ghost:hover{ border-color:var(--cream); background:var(--cream); color:var(--ink); }
.btn-ink{ background:var(--ink); color:var(--cream); }
.btn-ink:hover{ background:var(--red); color:#fff; }
.btn-lg{ font-size:18px; padding:21px 38px; }

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor-dot,.cursor-ring{ position:fixed; top:0; left:0; z-index:9999; pointer-events:none;
  border-radius:50%; mix-blend-mode:difference; }
.cursor-dot{ width:7px; height:7px; background:#fff; transform:translate(-50%,-50%); }
.cursor-ring{ width:38px; height:38px; border:1.5px solid #fff; transform:translate(-50%,-50%);
  transition:width .3s var(--ease), height .3s var(--ease), background .3s, opacity .3s; }
.cursor-ring.hover{ width:62px; height:62px; background:rgba(255,255,255,.1); }
.cursor-ring.hidden{ opacity:0; }
@media (hover:none),(pointer:coarse){ .cursor-dot,.cursor-ring{ display:none; } }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{ display:flex; overflow:hidden; white-space:nowrap; user-select:none; }
.marquee__track{ display:flex; gap:0; flex-shrink:0; animation:scrollx 32s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee.rev .marquee__track{ animation-direction:reverse; }
@keyframes scrollx{ to{ transform:translateX(-50%); } }
.marquee__item{ font-family:var(--display); text-transform:uppercase; padding:0 .35em;
  display:inline-flex; align-items:center; gap:.4em; }
.marquee__star{ color:var(--red); font-size:.6em; }
@media (prefers-reduced-motion: reduce){ .marquee__track{ animation:none; } }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{ opacity:0; transform:translateY(40px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
.line-mask{ overflow:hidden; display:block; }
.line-mask > span{ display:block; transform:translateY(105%); transition:transform 1s var(--ease); }
.line-mask.in > span{ transform:none; }
.line-mask.d1>span{ transition-delay:.1s;} .line-mask.d2>span{ transition-delay:.2s;}
.line-mask.d3>span{ transition-delay:.3s;} .line-mask.d4>span{ transition-delay:.4s;}
@media (prefers-reduced-motion: reduce){
  .reveal,.line-mask>span{ opacity:1!important; transform:none!important; }
}
/* escape hatch: when the timeline can't animate (frozen/backgrounded), show end-state */
html.no-anim .reveal,
html.no-anim .line-mask>span{ opacity:1!important; transform:none!important; transition:none!important; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:var(--ink-2); border-top:1px solid var(--line); padding-top:clamp(64px,9vw,120px); }
.foot-cta{ font-family:var(--display); text-transform:uppercase; line-height:.9;
  font-size:clamp(48px,12vw,168px); }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px;
  padding-block:clamp(48px,7vw,90px); border-top:1px solid var(--line); margin-top:clamp(48px,7vw,90px); }
.foot h4{ font-family:var(--sans); font-weight:700; font-size:13px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted-2); margin-bottom:18px; }
.foot ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
.foot ul a:hover{ color:var(--red); }
.foot-bar{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
  padding-block:26px; border-top:1px solid var(--line); color:var(--muted-2); font-size:13.5px; }
@media (max-width:760px){ .foot-grid{ grid-template-columns:1fr 1fr; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .nav, .head-cta{ display:none; }
  .burger{ display:block; }
}
.tag{ display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600;
  letter-spacing:.04em; padding:7px 14px; border:1px solid var(--line); border-radius:999px;
  text-transform:uppercase; color:var(--muted); }
.tag.red{ border-color:var(--red); color:var(--red); }

/* ============================================================
   THEME TOGGLE BUTTON
   ============================================================ */
.theme-btn{
  width:46px; height:46px; flex:none; border-radius:50%;
  border:1px solid var(--line); background:transparent; color:var(--cream);
  display:grid; place-items:center; position:relative; z-index:1002;
  transition:transform .4s var(--ease), border-color .3s, color .3s, background .3s;
}
.theme-btn:hover{ border-color:var(--cream); color:var(--red); transform:rotate(18deg); }
.theme-btn svg{ width:20px; height:20px; }
@media (max-width:980px){ .theme-btn{ margin-right:6px; } }

/* ============================================================
   LIGHT THEME — manual toggle ([data-theme]) + system fallback
   Light page + warm-dark inverted accent bands (proof / testi / cream CTA)
   ============================================================ */
html[data-theme="light"]{
  color-scheme: light;
  --ink:     #f4efe6;   /* page background (light) */
  --ink-2:   #ece4d5;   /* raised light surface */
  --ink-3:   #e3d9c6;   /* hover light surface */
  --paper:   #100d0b;   /* inverted accent bands (dark) */
  --paper-2: #181310;
  --cream:   #1a1512;   /* primary text (dark) */
  --muted:   rgba(26,21,18,.64);
  --muted-2: rgba(26,21,18,.42);
  --line:    rgba(26,21,18,.16);
}
/* no-JS fallback: follow system until JS assigns data-theme */
@media (prefers-color-scheme: light){
  html:not([data-theme]){
    color-scheme: light;
    --ink:#f4efe6; --ink-2:#ece4d5; --ink-3:#e3d9c6; --paper:#100d0b; --paper-2:#181310;
    --cream:#1a1512; --muted:rgba(26,21,18,.64); --muted-2:rgba(26,21,18,.42); --line:rgba(26,21,18,.16);
  }
}
/* light-mode component fixes (manual light) */
html[data-theme="light"] .site-head.scrolled{ background:rgba(244,239,230,.82); border-bottom-color:var(--line); }
html[data-theme="light"] .eyebrow.gold,
html[data-theme="light"] .txt-gold,
html[data-theme="light"] .phero-price,
html[data-theme="light"] .svc-price{ color:#9c7a1c; }
html[data-theme="light"] .eyebrow.gold::before{ background:#9c7a1c; }
html[data-theme="light"] .tier-badge{ color:#16110d; }
html[data-theme="light"] .proof-sub{ color:rgba(243,235,221,.6); }
html[data-theme="light"] .ctastrip.cream .sub{ color:rgba(243,235,221,.62); }
html[data-theme="light"] .tcard,
html[data-theme="light"] .tcard .who b{ color:#241d18; }
html[data-theme="light"] .hero-bg .b1,
html[data-theme="light"] .phero-bg .b1{ opacity:.15; }
html[data-theme="light"] .hero-bg .b2,
html[data-theme="light"] .phero-bg .b2{ opacity:.10; }
