/* ============================================================
   NU YOU — hair & art  ·  Beverly Hills
   Concept: "the studio as a gallery"
   Palette sampled from Nu's own hair (wine) + her art (scarlet)
   ============================================================ */

:root{
  --wine:    #2A0713;   /* primary dark world (her curls) */
  --wine-2:  #1C040C;   /* gallery wall / footer */
  --wine-soft:#3B0E1E;
  --bone:    #F4EFE7;   /* light breathing room */
  --bone-2:  #ECE4D7;
  --ink:     #1A1310;
  --ink-soft:#675C54;
  --scarlet: #D81F2C;   /* her art red — the single bold note */
  --scarlet-deep:#A8121E;/* accent text on bone (contrast-safe) */
  --rose:    #D9A39B;

  --serif: 'Bodoni Moda', 'Didot', Georgia, serif;
  --sans:  'Archivo', system-ui, -apple-system, Segoe UI, sans-serif;

  --wrap: 1240px;
  --gut: clamp(20px, 5vw, 64px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--wine);
  color:var(--bone);
  line-height:1.6;
  font-weight:400;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--scarlet); color:var(--bone); }

.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gut); }

/* skip link */
.skip{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--scarlet); color:#fff; padding:.7em 1.1em; font:600 .8rem/1 var(--sans);
}
.skip:focus{ left:12px; top:12px; }

/* ---------- type primitives ---------- */
.eyebrow{
  font:600 .72rem/1 var(--sans);
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--scarlet);
  display:flex; align-items:center; gap:.6em;
}
.eyebrow.eyebrow-bone{ color:var(--scarlet-deep); }
.eyebrow .sep{ color:var(--rose); }

h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.02; letter-spacing:-.01em; }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--scarlet); --fg:#fff;
  display:inline-flex; align-items:center; gap:.5em;
  background:var(--bg); color:var(--fg);
  font:600 .8rem/1 var(--sans); letter-spacing:.12em; text-transform:uppercase;
  padding:1.05em 1.7em; border:1px solid var(--bg); border-radius:2px;
  cursor:pointer; transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease);
}
.btn:hover{ background:transparent; color:var(--scarlet); }
.btn:focus-visible{ outline:2px solid var(--scarlet); outline-offset:3px; }
.btn-ghost{ background:transparent; color:var(--bone); border-color:rgba(244,239,231,.4); }
.btn-ghost:hover{ background:var(--bone); color:var(--ink); border-color:var(--bone); }
.btn-ghost-bone{ background:transparent; color:var(--bone); border-color:rgba(244,239,231,.45); }
.btn-ghost-bone:hover{ background:var(--bone); color:var(--wine); border-color:var(--bone); }
.btn-lg{ padding:1.25em 2em; font-size:.86rem; }
.btn-lg .btn-k{ font-family:var(--serif); text-transform:none; letter-spacing:0; font-size:1.25em; font-weight:500; margin-right:.15em; }
.btn-mini{ padding:.7em 1.2em; font-size:.7rem; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .35s var(--ease), box-shadow .35s var(--ease), padding .35s var(--ease);
  padding-block:18px;
}
.nav.scrolled{ background:rgba(28,4,12,.92); backdrop-filter:blur(10px); box-shadow:0 1px 0 rgba(244,239,231,.08); padding-block:12px; }
.nav-inner{ display:flex; align-items:center; gap:24px; }
.brand{
  font-family:var(--serif); font-weight:600; font-size:1.7rem; letter-spacing:-.02em; color:var(--bone);
  line-height:1; margin-right:auto;
}
.brand-dot{ color:var(--scarlet); padding-inline:.04em; }
.nav-links{ display:flex; gap:30px; }
.nav-links a{
  font:500 .78rem/1 var(--sans); letter-spacing:.16em; text-transform:uppercase; color:var(--bone);
  position:relative; padding:.4em 0; opacity:.85; transition:opacity .2s var(--ease);
}
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0; background:var(--scarlet); transition:width .28s var(--ease); }
.nav-links a:hover{ opacity:1; } .nav-links a:hover::after{ width:100%; }

.burger{ display:none; flex-direction:column; gap:5px; width:30px; height:24px; justify-content:center; background:none; border:0; cursor:pointer; }
.burger span{ height:1.5px; width:100%; background:var(--bone); transition:transform .3s var(--ease), opacity .3s var(--ease); }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(3.2px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ transform:translateY(-3.2px) rotate(-45deg); }

.mobnav{
  position:fixed; inset:0 0 auto 0; z-index:90; background:var(--wine-2);
  display:flex; flex-direction:column; gap:6px; padding:96px var(--gut) 36px;
  transform:translateY(-100%); transition:transform .42s var(--ease); visibility:hidden;
}
.mobnav.open{ transform:translateY(0); visibility:visible; }
.mobnav a{ font:500 .9rem/1 var(--sans); letter-spacing:.16em; text-transform:uppercase; padding:16px 0; border-bottom:1px solid rgba(244,239,231,.1); }
.mobnav .btn{ margin-top:18px; justify-content:center; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding:clamp(120px,18vh,200px) 0 clamp(64px,9vh,110px); background:var(--wine); }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,6vw,84px); align-items:center; }
.hero-title{
  font-size:clamp(3.1rem,9vw,6.6rem); font-weight:700; margin:.18em 0 .42em;
  letter-spacing:-.025em;
}
.hero-lede{ font-size:clamp(1.02rem,1.35vw,1.18rem); max-width:34ch; color:rgba(244,239,231,.86); }
.hero-lede strong{ color:var(--bone); font-weight:600; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin:2.2em 0 1.3em; }
.hero-foot{ font:400 .82rem/1.5 var(--sans); letter-spacing:.02em; color:var(--rose); }

.hero-art{ position:relative; }
.hero-art img{ width:100%; aspect-ratio:4/5; object-fit:cover; object-position:50% 30%; border-radius:2px; position:relative; z-index:2; }
.frame-offset{ position:absolute; inset:0; border:1px solid var(--scarlet); transform:translate(18px,18px); z-index:1; border-radius:2px; pointer-events:none; }
.tag{
  position:absolute; left:0; bottom:18px; z-index:3; transform:translateX(-18px);
  background:var(--wine-2); color:var(--bone); font:600 .68rem/1 var(--sans);
  letter-spacing:.2em; text-transform:uppercase; padding:.85em 1.1em; border-left:2px solid var(--scarlet);
}
.tag span{ color:var(--rose); font-weight:400; text-transform:none; letter-spacing:.04em; }

.scroll-cue{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); }
.scroll-cue span{ font:500 .64rem/1 var(--sans); letter-spacing:.34em; text-transform:uppercase; color:rgba(244,239,231,.5); }

/* ============================================================
   GALLERY / EXHIBITION
   ============================================================ */
.gallery{ background:var(--wine-2); padding:clamp(72px,11vh,140px) 0; border-top:1px solid rgba(244,239,231,.07); }
.gallery-head{ text-align:center; max-width:60ch; }
.gallery-head .eyebrow{ justify-content:center; }
.gallery-head h2{ font-size:clamp(2.3rem,5.5vw,4rem); margin:.28em 0 .4em; }
.section-lede{ color:rgba(244,239,231,.74); font-size:1.02rem; max-width:52ch; margin-inline:auto; }

.stage{ max-width:760px; margin:clamp(36px,6vh,64px) auto 0; padding-inline:var(--gut); }
.plate{
  font-family:var(--serif); font-weight:500; font-size:1.05rem; color:var(--rose);
  display:flex; align-items:baseline; justify-content:center; gap:.35em; margin-bottom:18px; letter-spacing:.02em;
}
.plate [data-cur]{ color:var(--bone); font-size:1.3em; }
.plate .slash{ color:var(--scarlet); }

.frame{ position:relative; }
.frame .frame-offset{ transform:translate(-16px,16px); border-color:rgba(216,31,44,.65); }
.slides{ list-style:none; position:relative; aspect-ratio:4/5; background:#120308; overflow:hidden; border-radius:2px; z-index:2; }
.slide{ position:absolute; inset:0; opacity:0; transition:opacity .7s var(--ease); pointer-events:none; }
.slide.is-active{ opacity:1; pointer-events:auto; }
.slide img{ width:100%; height:100%; object-fit:cover; object-position:50% 28%; }

.arrow{
  position:absolute; top:50%; transform:translateY(-50%); z-index:5;
  width:52px; height:52px; display:grid; place-items:center;
  background:rgba(28,4,12,.55); color:var(--bone); border:1px solid rgba(244,239,231,.25);
  font-size:1.7rem; line-height:1; cursor:pointer; border-radius:50%;
  transition:background .25s var(--ease), border-color .25s var(--ease);
  backdrop-filter:blur(4px);
}
.arrow:hover{ background:var(--scarlet); border-color:var(--scarlet); }
.arrow:focus-visible{ outline:2px solid var(--bone); outline-offset:2px; }
.arrow.prev{ left:14px; } .arrow.next{ right:14px; }

.wall-label{ text-align:center; margin-top:24px; min-height:48px; }
.wl-name{ font-family:var(--serif); font-weight:500; font-size:1.5rem; color:var(--bone); }
.wl-sub{ font:500 .72rem/1 var(--sans); letter-spacing:.24em; text-transform:uppercase; color:var(--scarlet); margin-top:.6em; }

.dots{ display:flex; justify-content:center; gap:10px; margin-top:22px; }
.dots button{ width:8px; height:8px; border-radius:50%; border:1px solid rgba(244,239,231,.4); background:transparent; cursor:pointer; padding:0; transition:background .2s, border-color .2s, transform .2s; }
.dots button[aria-selected="true"]{ background:var(--scarlet); border-color:var(--scarlet); transform:scale(1.25); }
.dots button:focus-visible{ outline:2px solid var(--bone); outline-offset:2px; }

/* ============================================================
   SERVICES / THE WORK   (light)
   ============================================================ */
.work{ background:var(--bone); color:var(--ink); padding:clamp(80px,12vh,150px) 0; }
.work .eyebrow{ color:var(--scarlet-deep); }
.work h2{ font-size:clamp(2.2rem,5vw,3.6rem); margin:.3em 0 1.4em; max-width:16ch; }
.work-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,4vw,56px); }
.svc{ border-top:1px solid rgba(26,19,16,.18); padding-top:22px; }
.svc h3{ font-size:1.7rem; font-weight:600; margin-bottom:.55em; }
.svc p{ color:var(--ink-soft); font-size:1rem; max-width:38ch; }
.work-note{
  display:flex; flex-wrap:wrap; align-items:center; gap:18px; margin-top:clamp(48px,7vh,80px);
  font:600 .78rem/1 var(--sans); letter-spacing:.22em; text-transform:uppercase; color:var(--ink);
}
.work-note i{ width:5px; height:5px; border-radius:50%; background:var(--scarlet); display:inline-block; }

/* ============================================================
   THE ARTIST   (light)
   ============================================================ */
.artist{ background:var(--bone-2); color:var(--ink); padding:clamp(80px,12vh,150px) 0; }
.artist-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(40px,7vw,96px); align-items:center; }
.artist-portrait{ position:relative; max-width:380px; }
.artist-portrait > img{ width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:2px; position:relative; z-index:2; filter:saturate(1.02); }
.artist-portrait .frame-offset{ border-color:var(--scarlet); transform:translate(-16px,-16px); }
.art-piece{ position:absolute; right:-26px; bottom:-44px; width:42%; z-index:3; }
.art-piece img{ width:100%; border-radius:2px; box-shadow:0 18px 40px rgba(26,19,16,.28); border:4px solid var(--bone); }
.art-piece figcaption{ font:500 .6rem/1.3 var(--sans); letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); margin-top:8px; text-align:right; }

.artist-copy h2{ font-size:clamp(2.2rem,5vw,3.6rem); margin:.3em 0 .7em; }
.artist-copy p{ color:var(--ink-soft); font-size:1.05rem; margin-bottom:1.1em; max-width:50ch; }
.artist-aside{ font-style:italic; }
.artist-aside a{ color:var(--scarlet-deep); border-bottom:1px solid currentColor; }
.artist-copy .btn-ghost{ color:var(--ink); border-color:rgba(26,19,16,.35); margin-top:.6em; }
.artist-copy .btn-ghost:hover{ background:var(--ink); color:var(--bone); border-color:var(--ink); }

/* ============================================================
   BOOK / CONTACT   (dark close)
   ============================================================ */
.book{ background:var(--wine); padding:clamp(84px,13vh,160px) 0; position:relative; }
.book::before{ content:""; position:absolute; inset:0 0 auto 0; height:1px; background:linear-gradient(90deg,transparent,var(--scarlet),transparent); opacity:.5; }
.book-inner{ max-width:780px; }
.book-title{ font-size:clamp(2.6rem,7vw,5.2rem); font-weight:700; margin:.25em 0 .5em; letter-spacing:-.02em; }
.book-lede{ font-size:1.1rem; color:rgba(244,239,231,.82); max-width:46ch; }
.book-cta{ display:flex; flex-wrap:wrap; gap:16px; margin:2.4em 0; }
.book-meta{ list-style:none; display:grid; grid-template-columns:repeat(2,1fr); gap:20px 48px; border-top:1px solid rgba(244,239,231,.14); padding-top:34px; }
.book-meta li{ font-size:1rem; color:rgba(244,239,231,.86); }
.book-meta a:hover{ color:var(--scarlet); }
.bm-k{ display:block; font:600 .68rem/1 var(--sans); letter-spacing:.24em; text-transform:uppercase; color:var(--rose); margin-bottom:.7em; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:var(--wine-2); padding:34px 0; border-top:1px solid rgba(244,239,231,.07); }
.foot-inner{ display:flex; flex-wrap:wrap; align-items:center; gap:16px; justify-content:space-between; }
.brand-sm{ font-size:1.3rem; }
.foot-tag{ font:500 .72rem/1 var(--sans); letter-spacing:.2em; text-transform:uppercase; color:var(--rose); }
.foot-c{ font:400 .78rem/1 var(--sans); color:rgba(244,239,231,.5); letter-spacing:.04em; }

/* ============================================================
   REVEAL + MOTION
   ============================================================ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; transition:none; }
  .slide{ transition:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .nav-links{ display:none; }
  .btn-mini{ display:none; }
  .burger{ display:flex; }
  .hero-grid{ grid-template-columns:1fr; gap:48px; }
  .hero-art{ max-width:440px; }
  .work-grid{ grid-template-columns:1fr; gap:0; }
  .svc{ padding-block:26px; }
  .artist-grid{ grid-template-columns:1fr; gap:72px; }
  .artist-portrait{ margin-inline:auto; }
  .book-meta{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .arrow{ width:42px; height:42px; font-size:1.4rem; }
  .arrow.prev{ left:8px; } .arrow.next{ right:8px; }
  .foot-inner{ flex-direction:column; text-align:center; gap:12px; }
  .hero-cta .btn{ flex:1 1 auto; justify-content:center; }
}

/* ============================================================
   FAQ  (light) — featured-snippet / AI-answer friendly
   ============================================================ */
.faq{ background:var(--bone); color:var(--ink); padding:clamp(72px,11vh,140px) 0; }
.faq .eyebrow{ color:var(--scarlet-deep); }
.faq-grid{ display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(36px,6vw,84px); align-items:start; }
.faq-intro h2{ font-size:clamp(2.1rem,4.6vw,3.3rem); margin:.3em 0 .5em; }
.faq-note{ color:var(--ink-soft); font-size:1rem; max-width:32ch; }
.faq-list details{ border-top:1px solid rgba(26,19,16,.16); }
.faq-list details:last-child{ border-bottom:1px solid rgba(26,19,16,.16); }
.faq-list summary{
  list-style:none; display:flex; align-items:center; justify-content:space-between; gap:1.2em;
  padding:22px 0; font-family:var(--serif); font-weight:500; font-size:clamp(1.12rem,2vw,1.4rem); color:var(--ink);
}
.faq-list summary::-webkit-details-marker{ display:none; }
.faq-list summary::after{ content:"+"; font-family:var(--sans); font-weight:300; font-size:1.5rem; line-height:1; color:var(--scarlet-deep); transition:transform .3s var(--ease); flex:none; }
.faq-list details[open] summary::after{ transform:rotate(45deg); }
.faq-a{ padding:0 0 24px; }
.faq-a p{ color:var(--ink-soft); font-size:1.02rem; max-width:62ch; }
.faq-a a{ color:var(--scarlet-deep); border-bottom:1px solid currentColor; }
.faq-list details[open] .faq-a{ animation:faqopen .42s var(--ease) both; }
@keyframes faqopen{ from{ opacity:0; transform:translateY(-6px) } to{ opacity:1; transform:none } }
@media (max-width:900px){ .faq-grid{ grid-template-columns:1fr; gap:32px; } }

/* ============================================================
   SCISSORS CURSOR  (desktop pointers only)
   ============================================================ */
@media (hover:hover) and (pointer:fine){
  html, body{ cursor:url('images/scissors.png') 10 10, auto; }
  a, button, summary, label, .dots button, [role="tab"], .arrow{ cursor:url('images/scissors.png') 10 10, pointer; }
  html:active, a:active, button:active, summary:active, .arrow:active, .dots button:active{
    cursor:url('images/scissors-closed.png') 10 10, pointer;
  }
}

/* ============================================================
   SIGNATURE ANIMATIONS
   ============================================================ */
/* hero entrance — staggered rise */
.seq > *{ animation:rise .85s var(--ease) both; }
.seq > *:nth-child(1){ animation-delay:.05s; }
.seq > *:nth-child(2){ animation-delay:.16s; }
.seq > *:nth-child(3){ animation-delay:.28s; }
.seq > *:nth-child(4){ animation-delay:.40s; }
.seq > *:nth-child(5){ animation-delay:.52s; }
@keyframes rise{ from{ opacity:0; transform:translateY(20px); } to{ opacity:1; transform:none; } }

/* hero image — clip unveil */
.hero-art img{ animation:unveil 1.15s var(--ease) .18s both; }
@keyframes unveil{ from{ opacity:0; clip-path:inset(0 0 100% 0); } to{ opacity:1; clip-path:inset(0 0 0 0); } }

/* gallery — slow Ken Burns on the active slide */
.slide.is-active img{ animation:kenburns 7s var(--ease) both; }
@keyframes kenburns{ from{ transform:scale(1.001); } to{ transform:scale(1.075); } }

/* scroll cue — drawing line */
.scroll-cue{ display:flex; flex-direction:column; align-items:center; gap:12px; }
.scroll-cue::after{ content:""; width:1px; height:48px; background:linear-gradient(var(--scarlet),transparent); transform-origin:top; animation:cue 2.2s var(--ease) infinite; }
@keyframes cue{ 0%{ transform:scaleY(0); opacity:0; } 45%{ opacity:1; } 100%{ transform:scaleY(1); opacity:0; } }

/* artwork — gentle hang */
.art-piece{ animation:hang 6.5s ease-in-out infinite; }
@keyframes hang{ 0%,100%{ transform:translateY(0) rotate(-.5deg); } 50%{ transform:translateY(-8px) rotate(.5deg); } }
