/* ============================================================
   MICHEL CREATIVE STUDIO — feuille de style partagée
   (index.html + portfolio.html)
   Direction : ivoire éditorial + culot. 1 studio, 6 savoir-faire.
   Type : Fraunces (display, soft & wonky) / Space Grotesk (UI)
   ============================================================ */

:root{
  --bg:        #f5edde;   /* ivoire chaud */
  --bg-2:      #fbf5ea;   /* surface claire */
  --bg-3:      #efe4cf;   /* surface creusée */
  --ink:       #1c1815;   /* presque noir chaud */
  --ink-2:     #2b241e;
  --soft:      rgba(28,24,21,.62);
  --soft-2:    rgba(28,24,21,.40);
  --line:      rgba(28,24,21,.14);
  --line-2:    rgba(28,24,21,.08);

  --red:       #e8362c;   /* signature Michel */
  --red-deep:  #c02018;
  --blue:      #2f5cff;
  --green:     #1e9e5a;
  --gold:      #c0871f;
  --violet:    #7a52e1;
  --terra:     #d8552e;

  /* bandes inversées (marquee / chiffres / contact) */
  --invert-bg:     #1c1815;
  --invert-bg-2:   #2a221b;
  --invert-fg:     #f5edde;
  --invert-soft:   rgba(245,237,222,.62);
  --invert-soft-2: rgba(245,237,222,.40);
  --invert-line:   rgba(245,237,222,.16);
  --invert-field:  rgba(245,237,222,.06);
  --invert-accent: #ff8079;
  --glass:         rgba(251,245,234,.78);

  --accent:    var(--red);

  --display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --sans: 'Space Grotesk', system-ui, -apple-system, sans-serif;

  --maxw: 1280px;
  --pad: clamp(20px, 5vw, 80px);
  --ease: cubic-bezier(.19,1,.22,1);
  --r: 26px;
}

/* ============================================================
   MODE SOMBRE
   (a) AUTO : suit le réglage clair/sombre de l'appareil,
       sauf si l'utilisateur a forcé le clair via le bouton.
   (b) MANUEL : l'utilisateur clique le bouton -> data-theme.
   Les deux déclencheurs partagent les mêmes valeurs.
   ============================================================ */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --bg:    #14110e;
    --bg-2:  #1e1812;
    --bg-3:  #29211a;
    --ink:   #f3ebdd;
    --ink-2: #e7ddcb;
    --soft:   rgba(243,235,221,.62);
    --soft-2: rgba(243,235,221,.40);
    --line:   rgba(243,235,221,.14);
    --line-2: rgba(243,235,221,.07);
    --red:    #f1473c;
    --blue:   #6088ff;
    --green:  #36c772;
    --gold:   #e2a83c;
    --violet: #9d7bf2;
    --terra:  #f0744b;
    --invert-bg:     #f4ecdd;
    --invert-bg-2:   #fbf5ea;
    --invert-fg:     #1c1815;
    --invert-soft:   rgba(28,24,21,.62);
    --invert-soft-2: rgba(28,24,21,.42);
    --invert-line:   rgba(28,24,21,.14);
    --invert-field:  rgba(28,24,21,.04);
    --invert-accent: #cf392f;
    --glass:         rgba(20,17,14,.72);
  }
  :root:not([data-theme="light"]) body::after{ mix-blend-mode:overlay; opacity:.06; }
}
:root[data-theme="dark"]{
  --bg:    #14110e;
  --bg-2:  #1e1812;
  --bg-3:  #29211a;
  --ink:   #f3ebdd;
  --ink-2: #e7ddcb;
  --soft:   rgba(243,235,221,.62);
  --soft-2: rgba(243,235,221,.40);
  --line:   rgba(243,235,221,.14);
  --line-2: rgba(243,235,221,.07);
  --red:    #f1473c;
  --blue:   #6088ff;
  --green:  #36c772;
  --gold:   #e2a83c;
  --violet: #9d7bf2;
  --terra:  #f0744b;
  --invert-bg:     #f4ecdd;
  --invert-bg-2:   #fbf5ea;
  --invert-fg:     #1c1815;
  --invert-soft:   rgba(28,24,21,.62);
  --invert-soft-2: rgba(28,24,21,.42);
  --invert-line:   rgba(28,24,21,.14);
  --invert-field:  rgba(28,24,21,.04);
  --invert-accent: #cf392f;
  --glass:         rgba(20,17,14,.72);
}
:root[data-theme="dark"] body::after{ mix-blend-mode:overlay; opacity:.06; }

*{ 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(--bg);
  color:var(--ink);
  line-height:1.55;
  font-size:18px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  transition:background .4s var(--ease), color .4s var(--ease);
}
::selection{ background:var(--red); color:#fff; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
svg{ display:block; }

/* subtle paper grain */
body::after{
  content:""; position:fixed; inset:0; z-index:9990; pointer-events:none;
  opacity:.04; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
section{ position:relative; }

.display{ font-family:var(--display); font-weight:600; line-height:.96; letter-spacing:-.02em;
  font-optical-sizing:auto; }
.display em{ font-style:italic; font-weight:500; }
h1.display{ font-size:clamp(52px, 9.4vw, 138px); }
h2.display{ font-size:clamp(38px, 6.6vw, 104px); }
h3.display{ font-size:clamp(30px, 4.4vw, 64px); }
.ital{ font-style:italic; }
.txt-red{ color:var(--red); }
.txt-acc{ color:var(--accent); }

.eyebrow{ font-family:var(--sans); font-weight:600; font-size:13px; letter-spacing:.24em;
  text-transform:uppercase; color:var(--accent); display:inline-flex; align-items:center; gap:.7em; }
.eyebrow::before{ content:""; width:26px; height:2px; background:currentColor; display:inline-block; }

.lead{ color:var(--soft); font-size:clamp(18px,1.5vw,21px); }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:11px; font-weight:600; font-size:16px;
  padding:16px 28px; border-radius:999px; border:1.5px solid transparent; line-height:1;
  transition:transform .35s var(--ease), background .35s, color .35s, border-color .35s, box-shadow .35s;
  will-change:transform; }
.btn .arr{ transition:transform .35s var(--ease); }
.btn:hover .arr{ transform:translateX(5px); }
.btn-ink{ background:var(--ink); color:var(--bg); }
.btn-ink:hover{ background:var(--red); color:#fff; box-shadow:0 14px 30px -12px rgba(232,54,44,.6); }
.btn-red{ background:var(--red); color:#fff; }
.btn-red:hover{ background:var(--ink); color:var(--bg); }
.btn-ghost{ border-color:var(--ink); color:var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--bg); }
.btn-lg{ font-size:18px; padding:20px 36px; }

/* ============================================================
   HEADER
   ============================================================ */
.site-head{ position:fixed; inset:0 0 auto 0; z-index:1000; display:flex; align-items:center;
  justify-content:space-between; gap:24px; padding:16px var(--pad);
  transition:padding .5s var(--ease); }
.site-head.scrolled .head-inner{ background:var(--glass); backdrop-filter:blur(16px) saturate(1.3);
  border-color:var(--line); box-shadow:0 10px 30px -18px rgba(28,24,21,.4); }
.head-inner{ width:100%; max-width:var(--maxw); margin:0 auto; display:flex; align-items:center;
  justify-content:space-between; gap:20px; padding:10px 12px 10px 18px; border-radius:999px;
  border:1.5px solid transparent; transition:background .5s var(--ease), border-color .5s, box-shadow .5s; }
.logo{ display:flex; align-items:center; gap:11px; }
.brandmark{ height:26px; width:auto; fill:var(--ink); transition:fill .4s; }
.logo:hover .brandmark{ fill:var(--red); }
.logo-word{ font-family:var(--display); font-weight:600; font-size:18px; line-height:.9;
  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:.32em; color:var(--soft); text-transform:uppercase; }
.nav{ display:flex; align-items:center; gap:2px; }
.nav a{ font-weight:500; font-size:14.5px; padding:9px 14px; border-radius:999px; position:relative;
  transition:background .3s, color .3s; }
.nav a:hover{ background:var(--bg-3); }
.nav a.active{ color:var(--red); }
.head-right{ display:flex; align-items:center; gap:10px; }
.head-cta{ display:inline-flex; align-items:center; gap:9px; background:var(--ink); color:var(--bg);
  font-weight:600; font-size:14.5px; padding:12px 20px; border-radius:999px;
  transition:transform .3s var(--ease), background .3s; }
.head-cta:hover{ background:var(--red); color:#fff; }
.head-cta .dot{ width:8px; height:8px; border-radius:50%; background:#46d27e; box-shadow:0 0 0 0 rgba(70,210,126,.6);
  animation:pulse 1.8s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(70,210,126,.55);} 70%{ box-shadow:0 0 0 7px rgba(70,210,126,0);} 100%{ box-shadow:0 0 0 0 rgba(70,210,126,0);} }

/* theme toggle button */
.theme-btn{ width:44px; height:44px; flex:none; border-radius:50%; border:1.5px solid var(--line);
  background:var(--bg-2); color:var(--ink); display:grid; place-items:center; position:relative;
  transition:transform .4s var(--ease), border-color .3s, color .3s, background .3s; }
.theme-btn:hover{ border-color:var(--ink); color:var(--red); transform:rotate(18deg); }
.theme-btn svg{ width:19px; height:19px; }
.theme-btn .i-sun{ display:none; }
.theme-btn.is-dark .i-sun{ display:block; }
.theme-btn.is-dark .i-moon{ display:none; }

.burger{ display:none; width:46px; height:46px; border:1.5px solid var(--line); border-radius:50%;
  background:var(--bg-2); position:relative; }
.burger span{ position:absolute; left:13px; right:13px; height:2px; background:var(--ink); 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); }

.drawer{ position:fixed; inset:0; z-index:999; background:var(--bg-2);
  display:flex; flex-direction:column; justify-content:center; gap:4px; 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-weight:600; font-size:clamp(34px,9vw,64px);
  line-height:1.05; color:var(--ink); transition:color .3s, transform .3s; }
.drawer a:hover{ color:var(--red); transform:translateX(12px); }
.drawer .d-foot{ margin-top:30px; color:var(--soft); font-size:15px; display:flex; flex-direction:column; gap:6px; }

@media (max-width:940px){
  .nav, .head-cta{ display:none; }
  .burger{ display:block; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{ min-height:100svh; display:flex; flex-direction:column; justify-content:center;
  padding-top:160px; padding-bottom:60px; position:relative; overflow:hidden; }
.hero-blob{ position:absolute; border-radius:50%; filter:blur(70px); z-index:0; opacity:.5; }
.hero-blob.b1{ width:44vw; height:44vw; background:var(--red); top:-14vw; right:-10vw; opacity:.20; }
.hero-blob.b2{ width:32vw; height:32vw; background:var(--gold); bottom:-12vw; left:-8vw; opacity:.18; }
.hero-blob.b3{ width:22vw; height:22vw; background:var(--violet); top:32%; left:42%; opacity:.10; }
.hero .wrap{ position:relative; z-index:2; }
.hero-eyebrow{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-bottom:26px; }
.avail{ display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600;
  color:var(--soft); border:1.5px solid var(--line); padding:7px 14px; border-radius:999px; background:var(--bg-2); }
.avail .dot{ width:8px; height:8px; border-radius:50%; background:#34c46e; }
.hero h1{ max-width:15ch; }
.hero h1 .l{ display:block; }
.hero-sub{ max-width:50ch; margin-top:30px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:38px; }
.hero-foot{ display:flex; align-items:center; gap:24px; flex-wrap:wrap; margin-top:44px;
  padding-top:26px; border-top:1px solid var(--line); }
.ticker{ display:inline-flex; align-items:center; gap:12px; font-size:14px; color:var(--soft); font-weight:500; }
.ticker b{ color:var(--ink); font-weight:700; }
.ticker .rot{ position:relative; display:inline-grid; }
.ticker .rot span{ grid-area:1/1; opacity:0; transform:translateY(8px); transition:opacity .5s, transform .5s;
  font-family:var(--display); font-style:italic; font-weight:600; color:var(--red); font-size:19px; white-space:nowrap; }
.ticker .rot span.on{ opacity:1; transform:none; }
.scroll-cue{ margin-left:auto; display:inline-flex; align-items:center; gap:10px; font-size:12px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--soft-2); }
.scroll-cue .ln{ width:42px; height:1px; background:var(--soft-2); position:relative; overflow:hidden; }
.scroll-cue .ln::after{ content:""; position:absolute; inset:0; background:var(--red);
  animation:slidein 2s var(--ease) infinite; }
@keyframes slidein{ 0%{ transform:translateX(-100%);} 60%,100%{ transform:translateX(100%);} }

/* floating stickers */
.sticker{ position:absolute; z-index:1; font-family:var(--sans); font-weight:700; font-size:13px;
  letter-spacing:.02em; padding:9px 15px; border-radius:999px; background:var(--bg-2);
  border:1.5px solid var(--ink); box-shadow:4px 5px 0 var(--ink); white-space:nowrap;
  display:inline-flex; align-items:center; gap:7px; animation:float 6s ease-in-out infinite; }
.sticker .em{ font-size:15px; }
.sticker.s1{ top:20%; right:8%; --tilt:7deg; color:var(--red); animation-delay:0s; }
.sticker.s2{ top:46%; right:4%; --tilt:-6deg; color:var(--violet); animation-delay:1.1s; }
.sticker.s3{ bottom:20%; right:14%; --tilt:5deg; color:var(--green); animation-delay:.5s; }
.sticker{ transform:rotate(var(--tilt)); }
@keyframes float{ 0%,100%{ transform:rotate(var(--tilt)) translateY(0);} 50%{ transform:rotate(var(--tilt)) translateY(-12px);} }
@media (max-width:940px){ .sticker{ display:none; } .scroll-cue{ display:none; } }

/* subpage hero (portfolio…) */
.page-hero{ padding-top:clamp(140px,20vw,200px); padding-bottom:clamp(10px,3vw,34px); position:relative; overflow:hidden; }
.page-hero .hero-blob.b1{ opacity:.16; }

/* ============================================================
   MARQUEE
   ============================================================ */
.band{ border-block:1.5px solid var(--invert-bg); padding-block:18px; background:var(--invert-bg); color:var(--invert-fg);
  overflow:hidden; }
.marquee{ display:flex; white-space:nowrap; user-select:none; }
.marquee__track{ display:flex; flex-shrink:0; animation:scrollx 34s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
@keyframes scrollx{ to{ transform:translateX(-50%); } }
.marquee__item{ font-family:var(--display); font-weight:600; text-transform:uppercase; letter-spacing:-.01em;
  font-size:clamp(26px,3.8vw,46px); padding:0 .5em; display:inline-flex; align-items:center; gap:.5em; }
.marquee__item .st{ color:var(--red); font-size:.6em; }
.marquee__item.o{ -webkit-text-stroke:1.2px color-mix(in srgb, var(--invert-fg) 55%, transparent); color:transparent; }
@media (prefers-reduced-motion: reduce){ .marquee__track{ animation:none; } }

/* ============================================================
   MANIFESTO
   ============================================================ */
.mani{ padding-block:clamp(90px,14vw,180px); }
.mani-q{ max-width:20ch; }
.mani-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:50px; margin-top:54px; align-items:start; }
.mani-grid .lead{ max-width:46ch; }
.mani-tags{ display:flex; flex-wrap:wrap; gap:10px; margin-top:30px; }
.tag{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:600;
  padding:8px 14px; border:1.5px solid var(--line); border-radius:999px; color:var(--soft); background:var(--bg-2); }
.tag b{ color:var(--ink); }
@media (max-width:820px){ .mani-grid{ grid-template-columns:1fr; gap:30px; } }

/* ============================================================
   CRAFTS (savoir-faire)
   ============================================================ */
.crafts{ padding-block:clamp(40px,6vw,80px); }
.sec-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap;
  margin-bottom:clamp(50px,7vw,90px); }
.sec-head .lead{ max-width:34ch; }

.craft{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,80px); align-items:center;
  padding-block:clamp(46px,6vw,84px); border-top:1px solid var(--line); }
.craft:nth-child(even) .craft-media{ order:2; }
.craft-num{ font-family:var(--display); font-weight:600; font-size:15px; color:var(--accent);
  display:inline-flex; align-items:center; gap:10px; letter-spacing:.04em; }
.craft-num::after{ content:""; width:34px; height:1.5px; background:var(--accent); display:inline-block; }
.craft-kicker{ font-size:13px; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color:var(--soft); margin-top:18px; display:block; }
.craft h3{ margin-top:8px; }
.craft h3 em{ color:var(--accent); }
.craft-desc{ color:var(--soft); margin-top:18px; max-width:46ch; font-size:17.5px; }
.craft-list{ list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:10px 22px; margin-top:26px; }
.craft-list li{ font-size:15px; font-weight:500; display:flex; align-items:center; gap:9px; color:var(--ink-2); }
.craft-list li::before{ content:""; width:7px; height:7px; border-radius:2px; background:var(--accent); flex:none;
  transform:rotate(45deg); }
.craft-cta{ display:inline-flex; align-items:center; gap:8px; margin-top:28px; font-weight:600; font-size:15px;
  color:var(--accent); }
.craft-cta .arr{ transition:transform .35s var(--ease); }
.craft-cta:hover .arr{ transform:translateX(5px); }

.craft-media{ position:relative; }
.vig-card{ --vbg:#fbf5ea; --vbg-2:#efe4cf; --vink:#211c17;
  border-radius:var(--r); padding:clamp(26px,4vw,46px); aspect-ratio:4/3.2; display:grid; place-items:center;
  background:color-mix(in srgb, var(--accent) 13%, var(--vbg));
  border:1.5px solid color-mix(in srgb, var(--accent) 32%, rgba(28,24,21,.12));
  overflow:hidden; position:relative; transition:transform .6s var(--ease), box-shadow .6s; }
.craft:hover .vig-card{ transform:translateY(-6px); box-shadow:0 28px 50px -28px color-mix(in srgb, var(--accent) 50%, transparent); }
.vig{ width:100%; height:auto; max-height:100%; }
.vig .a{ fill:var(--accent); }
.vig .ad{ fill:color-mix(in srgb, var(--accent) 70%, #000 30%); }
.vig .al{ fill:color-mix(in srgb, var(--accent) 22%, var(--vbg)); }
.vig .ink{ fill:var(--vink); }
.vig .pp{ fill:var(--vbg); }
.vig .ppd{ fill:var(--vbg-2); }
.vig .ln{ fill:none; stroke:var(--vink); stroke-width:3.5; stroke-linecap:round; stroke-linejoin:round; }
.vig .lna{ fill:none; stroke:var(--accent); stroke-width:3.5; stroke-linecap:round; stroke-linejoin:round; }
.vig-badge{ position:absolute; top:16px; right:16px; font-size:12px; font-weight:700; letter-spacing:.02em;
  padding:7px 13px; border-radius:999px; background:var(--ink); color:var(--bg); box-shadow:3px 4px 0 var(--accent);
  transform:rotate(4deg); }
@media (max-width:840px){
  .craft{ grid-template-columns:1fr; gap:30px; }
  .craft:nth-child(even) .craft-media{ order:0; }
  .craft-list{ grid-template-columns:1fr; }
}
@media (max-width:480px){ .craft-list{ grid-template-columns:1fr 1fr; } }

/* PLUS strip */
.plus{ padding-block:clamp(70px,10vw,120px); }
.plus-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px; }
.plus-cell{ background:var(--bg-2); border:1.5px solid var(--line); border-radius:18px; padding:24px 24px 26px;
  transition:transform .4s var(--ease), border-color .4s; }
.plus-cell:hover{ transform:translateY(-5px); border-color:var(--ink); }
.plus-cell .pi{ font-size:24px; }
.plus-cell h4{ font-family:var(--display); font-weight:600; font-size:22px; margin-top:12px; }
.plus-cell p{ color:var(--soft); font-size:14.5px; margin-top:6px; }
@media (max-width:760px){ .plus-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .plus-grid{ grid-template-columns:1fr; } }

/* ============================================================
   PROOF
   ============================================================ */
.proof{ background:var(--invert-bg); color:var(--invert-fg); padding-block:clamp(64px,9vw,110px); }
.proof-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.proof-cell{ position:relative; }
.proof-num{ font-family:var(--display); font-weight:600; font-size:clamp(48px,6vw,86px); line-height:.9;
  color:var(--invert-fg); }
.proof-num span{ color:var(--red); }
.proof-lab{ font-weight:600; font-size:14px; margin-top:14px; }
.proof-sub{ color:var(--invert-soft); font-size:13.5px; margin-top:5px; }
@media (max-width:820px){ .proof-grid{ grid-template-columns:1fr 1fr; gap:40px 24px; } }
@media (max-width:460px){ .proof-grid{ grid-template-columns:1fr; gap:34px; } }

/* ============================================================
   PORTFOLIO
   ============================================================ */
.port{ padding-block:clamp(80px,12vw,150px); }
.port-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.case{ position:relative; border-radius:var(--r); overflow:hidden; background:var(--bg-3);
  aspect-ratio:4/3.1; display:flex; align-items:flex-end; border:1.5px solid var(--line); }
.case.tall{ aspect-ratio:4/4.5; }
.case-img{ position:absolute; inset:0; background-size:cover; background-position:center;
  transition:transform .9s var(--ease); }
.case:hover .case-img{ transform:scale(1.05); }
.case::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(20,16,12,.86) 4%, rgba(20,16,12,0) 56%); }
.case-body{ position:relative; z-index:2; padding:28px; width:100%; color:#f5edde; }
.case-loc{ font-size:12.5px; letter-spacing:.12em; text-transform:uppercase; color:#ffd9a3; font-weight:700; }
.case-name{ font-family:var(--display); font-weight:600; font-size:clamp(26px,3vw,44px); line-height:1; margin-top:8px; }
.case-tags{ font-size:12.5px; letter-spacing:.04em; color:rgba(245,237,222,.72); margin-top:12px; font-weight:600; }
.case-cta{ position:absolute; top:20px; right:20px; z-index:3; width:48px; height:48px; border-radius:50%;
  background:rgba(255,255,255,.14); backdrop-filter:blur(6px); display:grid; place-items:center;
  color:#fff; transform:scale(0) rotate(-30deg); transition:.5s var(--ease); border:1px solid rgba(255,255,255,.25); }
.case:hover .case-cta{ transform:scale(1) rotate(0); }
/* invite card */
.case.invite{ background:var(--bg-2); border:1.5px dashed var(--ink); display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; padding:34px; }
.case.invite::after{ display:none; }
.case.invite .iv-plus{ font-family:var(--display); font-weight:600; font-size:64px; color:var(--red); line-height:1; }
.case.invite h4{ font-family:var(--display); font-weight:600; font-size:26px; margin-top:8px; color:var(--ink); }
.case.invite p{ color:var(--soft); font-size:14.5px; margin-top:8px; max-width:26ch; }
.case.invite .btn{ margin-top:18px; }
/* emote-cluster card (Pigloo) */
.case.emotes{ background:radial-gradient(125% 95% at 50% 16%, #6f40c8, #3a1f73 48%, #17102e);
  border-color:color-mix(in srgb, #9d7bf2 45%, var(--line)); }
.case.emotes::after{ background:linear-gradient(to top, rgba(13,7,26,.92) 2%, rgba(13,7,26,0) 52%); }
.emote-cluster{ position:absolute; inset:0; z-index:1; padding:9% 8% 28%;
  display:grid; grid-template-columns:repeat(3,1fr); gap:7% 4%; align-content:center; }
.emote-cluster img{ width:100%; aspect-ratio:1; object-fit:contain; background:none;
  filter:drop-shadow(0 6px 9px rgba(0,0,0,.4)); transition:transform .5s var(--ease); }
.emote-cluster img:nth-child(3n+1){ transform:rotate(-7deg); }
.emote-cluster img:nth-child(3n){ transform:rotate(7deg); }
.case.emotes:hover .emote-cluster img{ transform:scale(1.07) rotate(0); }
@media (max-width:720px){ .port-grid{ grid-template-columns:1fr; } .case,.case.tall{ aspect-ratio:4/3.3; } }

/* ============================================================
   PROCESS
   ============================================================ */
.proc{ padding-block:clamp(40px,6vw,70px); }
.proc-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:54px; }
.pstep{ border-top:2px solid var(--ink); padding-top:22px; }
.pstep .pn{ font-family:var(--display); font-weight:600; font-size:42px; color:var(--red); line-height:1; }
.pstep h4{ font-size:19px; font-weight:700; margin:12px 0 9px; }
.pstep p{ color:var(--soft); font-size:15px; }
@media (max-width:860px){ .proc-grid{ grid-template-columns:1fr 1fr; gap:36px 24px; } }
@media (max-width:480px){ .proc-grid{ grid-template-columns:1fr; } }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi{ padding-block:clamp(80px,12vw,140px); }
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:54px; }
.tcard{ background:var(--bg-2); border:1.5px solid var(--line); border-radius:var(--r); padding:32px;
  display:flex; flex-direction:column; gap:18px; transition:transform .5s var(--ease), box-shadow .5s; }
.tcard:hover{ transform:translateY(-7px); box-shadow:0 24px 44px -28px rgba(28,24,21,.5); }
.tcard .stars{ color:var(--red); letter-spacing:3px; font-size:16px; }
.tcard p{ font-size:16.5px; line-height:1.55; color:var(--ink-2); }
.tcard .who{ margin-top:auto; display:flex; align-items:center; gap:12px; }
.tcard .av{ width:42px; height:42px; border-radius:50%; background:var(--red); color:#fff;
  display:grid; place-items:center; font-family:var(--display); font-weight:600; font-size:19px; }
.tcard .who b{ font-size:14.5px; } .tcard .who span{ display:block; font-size:12.5px; color:var(--soft-2); }
@media (max-width:880px){ .testi-grid{ grid-template-columns:1fr; } }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ padding-block:clamp(80px,12vw,150px); }
.contact-card{ background:var(--invert-bg); color:var(--invert-fg); border-radius:clamp(26px,4vw,46px);
  padding:clamp(34px,5vw,68px); display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,64px);
  position:relative; overflow:hidden; }
.contact-card .glow{ position:absolute; width:36vw; height:36vw; border-radius:50%; background:var(--red);
  filter:blur(90px); opacity:.28; top:-12vw; right:-8vw; pointer-events:none; }
.contact-left{ position:relative; z-index:2; }
.contact-left .eyebrow{ color:var(--invert-accent); }
.contact-left h2{ margin-top:18px; }
.contact-left .lead{ color:var(--invert-soft); margin-top:22px; max-width:36ch; }
.contact-info{ margin-top:34px; display:flex; flex-direction:column; gap:14px; }
.contact-info a, .contact-info span{ display:inline-flex; align-items:center; gap:12px; color:var(--invert-fg);
  font-size:16px; font-weight:500; max-width:100%; overflow-wrap:anywhere; word-break:break-word; }
.contact-info .ic{ width:38px; height:38px; border-radius:50%; border:1.5px solid var(--invert-line);
  display:grid; place-items:center; flex:none; color:var(--invert-accent); }
.contact-info a:hover{ color:var(--invert-accent); }

.cform{ position:relative; z-index:2; display:flex; flex-direction:column; gap:16px; }
.cform .row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-size:12.5px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--invert-soft); }
.field input, .field textarea{ font-family:inherit; font-size:15.5px; color:var(--invert-fg);
  background:var(--invert-field); border:1.5px solid var(--invert-line); border-radius:14px;
  padding:14px 16px; transition:border-color .3s, background .3s; }
.field input::placeholder, .field textarea::placeholder{ color:var(--invert-soft-2); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--invert-accent); background:color-mix(in srgb, var(--invert-fg) 8%, transparent); }
.field textarea{ resize:vertical; min-height:104px; }
.chips{ display:flex; flex-wrap:wrap; gap:9px; }
.chip{ position:relative; }
.chip input{ position:absolute; opacity:0; pointer-events:none; }
.chip span{ display:inline-block; font-size:13px; font-weight:600; padding:9px 15px; border-radius:999px;
  border:1.5px solid var(--invert-line); color:var(--invert-soft); cursor:pointer; transition:.25s; }
.chip input:checked + span{ background:var(--red); border-color:var(--red); color:#fff; }
.cform .btn-red{ align-self:flex-start; }
.cform .note{ font-size:12.5px; color:var(--invert-soft-2); }
.cform.sent .form-body{ display:none; }
.form-ok{ display:none; flex-direction:column; gap:12px; align-items:flex-start; padding:20px 0; }
.cform.sent .form-ok{ display:flex; }
.form-ok .big{ font-family:var(--display); font-weight:600; font-size:30px; }
@media (max-width:900px){ .contact-card{ grid-template-columns:1fr; } }
@media (max-width:520px){ .cform .row{ grid-template-columns:1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ border-top:1px solid var(--line); padding-top:clamp(60px,9vw,110px); padding-bottom:40px; }
.foot-cta{ font-family:var(--display); font-weight:600; line-height:.95; font-size:clamp(44px,11vw,150px);
  display:block; letter-spacing:-.02em; }
.foot-cta em{ color:var(--red); font-style:italic; }
.foot-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:40px;
  padding-block:clamp(46px,7vw,84px); margin-top:clamp(40px,6vw,70px); border-top:1px solid var(--line); }
.foot-grid p{ color:var(--soft); max-width:34ch; font-size:15px; margin-top:14px; }
.foot h5{ font-weight:700; font-size:12.5px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--soft-2); margin-bottom:16px; }
.foot ul{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.foot ul a:hover{ color:var(--red); }
.foot-bar{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
  padding-top:24px; border-top:1px solid var(--line); color:var(--soft-2); font-size:13px; }
@media (max-width:760px){ .foot-grid{ grid-template-columns:1fr 1fr; } }

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); 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; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1!important; transform:none!important; } }
html.no-anim .reveal{ opacity:1!important; transform:none!important; transition:none!important; }
