/* Bebop Ink — v1 "Atelier" : dark, cinematic, quiet gallery */
:root{
  --ink:#0a0a0c; --ink2:#121012; --bone:#ece9e4; --mute:#9a948a;
  --line:#221f1a; --rust:#d98e6b; --gold:#e7c89b; --oxblood:#8a3b32;
  --serif:"Cormorant Garamond",Georgia,serif; --sans:"Inter",system-ui,sans-serif; --mono:"Space Mono",monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--ink);color:var(--bone);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
img{display:block;max-width:100%}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px}
h1,h2,h3{font-family:var(--serif);font-weight:500;letter-spacing:.005em;margin:0}
em{font-style:italic;color:var(--gold)}
.img-fail{background:repeating-linear-gradient(45deg,#1a1714,#1a1714 14px,#241f1a 14px,#241f1a 28px);min-height:200px}

/* NAV */
.nav{position:sticky;top:0;z-index:40;background:rgba(10,10,12,.72);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{max-width:1120px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:22px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:21px;color:var(--bone);text-decoration:none;letter-spacing:.01em}
.seal{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--rust);border-radius:50%;color:var(--rust);font-size:15px;font-family:var(--serif)}
.nav-links{margin-left:auto;display:flex;gap:26px}
.nav-links a{color:var(--mute);text-decoration:none;font-size:14px;letter-spacing:.02em;transition:color .15s}
.nav-links a:hover{color:var(--bone)}
.nav-cta{background:var(--rust);color:#1a0f0a;padding:9px 16px;border-radius:999px;font-size:13.5px;font-weight:600;text-decoration:none;white-space:nowrap;transition:transform .15s,background .15s}
.nav-cta:hover{transform:translateY(-1px);background:var(--gold)}
.burger{display:none;background:none;border:0;width:34px;height:34px;cursor:pointer;margin-left:auto;position:relative}
.burger span,.burger span::before,.burger span::after{content:"";position:absolute;left:6px;width:22px;height:2px;background:var(--bone);transition:.2s}
.burger span{top:16px}.burger span::before{top:-7px}.burger span::after{top:7px}
.drawer{display:none;flex-direction:column;background:var(--ink2);border-bottom:1px solid var(--line)}
.drawer a{padding:14px 28px;color:var(--bone);text-decoration:none;border-top:1px solid var(--line)}

/* HERO */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media video,.hero-still{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-still{background-size:cover;background-position:center;transition:opacity 1s ease}
.hero-media video{opacity:0;transition:opacity 1s ease}
.hero-media video.on{opacity:1}
.hero-grade{position:absolute;inset:0;background:radial-gradient(120% 90% at 30% 40%,rgba(10,10,12,.35),rgba(10,10,12,.86) 75%),linear-gradient(180deg,rgba(10,10,12,.5),rgba(10,10,12,.2) 30%,rgba(10,10,12,.9))}
.hero-in{position:relative;z-index:2;max-width:1120px;margin:0 auto;padding:0 28px;width:100%}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--rust);display:flex;align-items:center;gap:12px;margin-bottom:20px}
.eyebrow .rule,.tag .rule{width:34px;height:1px;background:var(--rust)}
.hero h1{font-size:clamp(42px,8vw,82px);line-height:1.02;letter-spacing:-.01em;max-width:14ch}
.hero-lede{max-width:54ch;color:#cfcabf;font-size:16px;margin:24px 0 28px}
.hero-row{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.btn{display:inline-block;background:var(--rust);color:#1a0f0a;padding:13px 24px;border-radius:999px;font-weight:600;font-size:15px;text-decoration:none;transition:transform .15s,background .15s}
.btn:hover{transform:translateY(-2px);background:var(--gold)}
.btn.ghost{background:transparent;color:var(--bone);border:1px solid var(--rust)}
.btn.ghost:hover{background:var(--rust);color:#1a0f0a}
.hero-stars{font-size:14px;color:#cfcabf}.hero-stars .st{color:var(--gold);letter-spacing:1px}.hero-stars b{color:var(--bone)}
.award-line{margin-top:26px;font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;color:var(--gold);display:flex;align-items:center;gap:10px}
.award-line .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold)}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);display:flex;flex-direction:column;align-items:center;gap:8px}
.scrollcue .ln{width:1px;height:40px;background:linear-gradient(var(--rust),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* shared section bits */
section{padding:96px 0}
.tag{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--rust);display:flex;align-items:center;gap:12px;margin-bottom:30px}
.tag .num{color:var(--mute)}
.tag.light{color:var(--ink)}.tag.light .rule{background:var(--ink)}.tag.light .num{color:#6b5f4f}
h2{font-size:clamp(30px,5vw,50px);line-height:1.05;max-width:18ch}
.lede{font-size:18px;color:#cfcabf;max-width:60ch;margin:18px 0}
.cap{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--mute);margin-top:18px;text-align:center}

/* THE ROOM */
.room{background:linear-gradient(180deg,var(--ink),var(--ink2))}
.room-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
.room-copy p{color:#bfb9af}
.pull{font-family:var(--serif);font-style:italic;font-size:26px;line-height:1.3;color:var(--gold);border-left:2px solid var(--oxblood);padding-left:20px;margin:28px 0 0;max-width:30ch}
.room-fig{margin:0}
.room-fig img{width:100%;height:520px;object-fit:cover;border-radius:6px}
.room-fig figcaption,.visit-fig figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--mute);margin-top:10px}
.strip{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:54px}
.strip figure{margin:0}
.strip img{width:100%;height:240px;object-fit:cover;border-radius:6px;filter:saturate(.95)}

/* ARTISTS */
.artists{background:var(--ink2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.port-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:40px}
.port{margin:0}
.port-slot{aspect-ratio:3/4;border:1.5px dashed #3a3026;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;background:repeating-linear-gradient(45deg,rgba(217,142,107,.03),rgba(217,142,107,.03) 12px,transparent 12px,transparent 24px);color:var(--gold);padding:18px}
.port-slot .ph-mark{font-size:26px;color:var(--rust)}
.port-slot span:not(.ph-mark){font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.port-slot small{color:var(--mute);font-size:12px;font-family:var(--sans);letter-spacing:.01em;text-transform:none}
.port figcaption{font-size:12.5px;color:var(--mute);margin-top:10px;text-align:center}

/* CONSULT */
.consult{background:var(--bone);color:var(--ink)}
.consult h2{color:var(--ink)}
.consult .lede{color:#4a4338}
.consult-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:start}
.steps{list-style:none;margin:30px 0 0;padding:0;display:grid;gap:18px}
.steps li{display:flex;gap:18px;align-items:flex-start;border-top:1px solid #d8d2c6;padding-top:18px}
.snum{font-family:var(--mono);font-size:14px;color:var(--oxblood);font-weight:700;min-width:30px}
.steps b{font-family:var(--serif);font-size:22px;font-weight:600}
.steps p{margin:4px 0 0;color:#5a5247;font-size:15px}
.consult-card{background:var(--ink);color:var(--bone);border-radius:12px;padding:28px;position:sticky;top:90px}
.cc-eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--rust);margin-bottom:8px}
.cc-note{font-size:13px;color:var(--mute);margin:0 0 18px}
.cc-form label{display:block;font-size:13px;color:#cfcabf;margin-bottom:14px}
.cc-form input,.cc-form textarea{width:100%;margin-top:6px;background:var(--ink2);border:1px solid var(--line);border-radius:8px;padding:11px 13px;color:var(--bone);font-family:var(--sans);font-size:14px;resize:vertical}
.cc-form input::placeholder,.cc-form textarea::placeholder{color:#6b655b}
.cc-btn{width:100%;background:var(--rust);color:#1a0f0a;border:0;border-radius:999px;padding:13px;font-weight:600;font-size:15px;cursor:pointer;transition:background .15s}
.cc-btn:hover{background:var(--gold)}
.cc-foot{margin-top:16px;font-size:13px;color:var(--mute)}.cc-foot b{color:var(--gold)}

/* VISIT */
.visit{background:linear-gradient(180deg,var(--ink2),var(--ink))}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.vrows{margin:24px 0 32px;display:grid;gap:0}
.vrow{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:18px 0;border-top:1px solid var(--line)}
.vrow .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);padding-top:3px}
.vrow .val{font-family:var(--serif);font-size:21px;color:var(--bone)}
.vrow .sub{display:block;font-family:var(--sans);font-size:12.5px;color:var(--mute);margin-top:4px}
.visit-fig{margin:0}
.visit-fig img{width:100%;height:440px;object-fit:cover;border-radius:6px}

/* FOOTER */
.foot{background:var(--ink);border-top:1px solid var(--line);padding:48px 0}
.foot-in{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot-mark{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:22px}
.foot-line{color:var(--mute);font-size:14px;margin:8px 0 0}.foot-line b{color:var(--gold)}
.foot-credit{font-size:13px;color:var(--mute);text-align:right}.foot-credit a{color:var(--rust);text-decoration:none}

/* REVEAL */
@media (prefers-reduced-motion:no-preference){
  html.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
  html.js .reveal.d1{transition-delay:.1s}html.js .reveal.d2{transition-delay:.2s}html.js .reveal.d3{transition-delay:.3s}
  html.js .reveal.in{opacity:1;transform:none}
}

/* MOBILE */
@media (max-width:880px){
  .room-grid,.consult-grid,.visit-grid{grid-template-columns:1fr;gap:36px}
  .consult-card{position:static}
  .port-grid{grid-template-columns:repeat(2,1fr)}
  .room-fig img{height:380px}
}
@media (max-width:640px){
  body{font-size:16px}
  .nav-links,.nav-cta{display:none}
  .burger{display:block}
  .drawer.open{display:flex}
  .wrap{padding:0 18px}
  .nav-in{padding:12px 18px}
  section{padding:64px 0}
  .hero{min-height:90vh}
  .hero-in{padding:0 18px}
  .hero h1{font-size:clamp(36px,11vw,52px)}
  .strip{grid-template-columns:1fr;gap:14px}
  .strip img{height:220px}
  .vrow{grid-template-columns:1fr;gap:4px}
  .room-fig img,.visit-fig img{height:300px}
  .scrollcue{display:none}
}
