:root{
  --bg:#f7f3e6;
  --text:#161411;
  --muted:#69645b;
  --line:#fff;
  --accent:#b72926;
  --dark:#11100e;
}
*{box-sizing:border-box}
html,body{margin:0;width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:Arial,sans-serif}
button,a{font:inherit}
button{cursor:pointer}
.experience{position:fixed;inset:0;overflow:hidden;background:var(--bg)}
.experience-track{height:100dvh;display:flex;will-change:transform;touch-action:pan-y}
.screen{flex:0 0 100vw;width:100vw;height:100dvh;position:relative;overflow:hidden;padding:28px;display:grid;place-items:center}
.screen:nth-of-type(1){background:#efe7d6}
.screen:nth-of-type(2){background:#dde8f0}
.screen:nth-of-type(4){background:#e7eddc}
.screen:nth-of-type(5){background:#f2e6dd}
.eyebrow{letter-spacing:.22em;text-transform:uppercase;font-size:11px;color:var(--muted)}
h1,h2{font-size:clamp(42px,10vw,108px);line-height:.88;margin:.1em 0;font-weight:900;letter-spacing:-.06em;text-wrap:balance}
.lead{font-size:clamp(18px,4vw,36px);margin:0}
.center{text-align:center;max-width:960px}
.home-screen{display:block;padding:0;background:#efe7d6;isolation:isolate}
.home-screen::before{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,rgba(255,255,255,.28),rgba(239,231,214,0) 42%),radial-gradient(circle at 50% 72%,rgba(183,41,38,.08),rgba(183,41,38,0) 42%);pointer-events:none}
.home-copy{position:absolute;left:28px;right:28px;bottom:calc(env(safe-area-inset-bottom,0px) + 200px);z-index:3;text-align:center;pointer-events:none}
.home-copy .eyebrow{margin:0 0 10px}
.home-copy h1{font-size:clamp(38px,7.2vw,94px);line-height:.86;margin:0 auto;max-width:1180px;color:#161411}
.home-copy .lead{margin:12px 0 0;font-size:clamp(16px,2vw,23px)}
.personality-gallery{--card-w:clamp(182px,23.4vw,366px);--card-h:calc(var(--card-w) * 1.34);position:absolute;left:0;right:0;top:clamp(86px,13dvh,136px);height:min(54dvh,590px);z-index:4;overflow:visible;touch-action:none;cursor:grab;perspective:1200px;user-select:none}
.personality-gallery:active{cursor:grabbing}
.personality-gallery::before,.personality-gallery::after{content:"";position:absolute;top:-80px;bottom:-160px;width:13vw;z-index:2;pointer-events:none}
.personality-gallery::before{left:0;background:linear-gradient(90deg,#efe7d6,rgba(239,231,214,0))}
.personality-gallery::after{right:0;background:linear-gradient(270deg,#efe7d6,rgba(239,231,214,0))}
.personality-gallery-ring{position:absolute;left:50%;top:54%;width:0;height:0;transform-style:preserve-3d}
.personality-card{position:absolute;left:0;top:0;width:var(--card-w);height:var(--card-h);margin-left:calc(var(--card-w) / -2);margin-top:calc(var(--card-h) / -2);border-radius:8px;overflow:hidden;background:#d8cfbd;box-shadow:0 28px 70px rgba(22,20,17,.2);backface-visibility:hidden;transform-style:preserve-3d;will-change:transform,opacity}
.personality-card::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.42);border-radius:inherit;pointer-events:none}
.personality-card img{display:block;width:100%;height:100%;object-fit:cover;object-position:center}
.worlds,.credits{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.credit-card{border-radius:24px;text-align:left;max-width:260px}
.play{width:120px;height:120px;border-radius:50%;border:0;background:var(--text);color:var(--bg);font-size:36px;transition:transform 220ms ease}
.play:hover{transform:scale(1.03)}
.play:active{transform:scale(.98)}
.cta{display:inline-block;margin-top:18px;padding:14px 20px;border-radius:999px;background:var(--text);color:var(--bg);text-decoration:none;transition:transform 220ms ease,background 220ms ease}
.cta:hover{transform:translateY(-1px);background:#2a251f}
.cta:active{transform:translateY(1px)}
.legal{display:flex;gap:18px;justify-content:center;margin-top:26px}
.legal a{color:var(--muted)}
.booking-screen{
  background:#efe6d2;
  position:relative;
  overflow:auto;
  overscroll-behavior:contain;
}
.booking-screen::before{
  content:"";
  position:absolute;
  inset:-1px;
  pointer-events:none;
  background:
    radial-gradient(circle at 16% -4%, rgba(183,41,38,.12), rgba(183,41,38,0) 46%),
    radial-gradient(circle at 86% -6%, rgba(22,20,17,.10), rgba(22,20,17,0) 44%);
  z-index:0;
}
.booking-page{
  --line:rgba(22,20,17,.16);
  --line-soft:rgba(22,20,17,.10);
  width:min(1120px,100%);
  align-self:start;       /* override .screen place-items:center -> no vertical clipping on overflow */
  justify-self:center;
  position:relative;
  z-index:1;
  padding:clamp(26px,5vw,40px) clamp(2px,2vw,10px) 150px;
}

/* intro */
.booking-intro{max-width:18ch}
.booking-intro .eyebrow{margin:0}
.booking-title{
  margin:.18em 0 0;
  font-weight:900;
  letter-spacing:-.055em;
  line-height:.9;
  font-size:clamp(40px,7vw,76px);
  text-wrap:balance;
}

/* section: hairline rule + small label */
.booking-row{
  margin-top:clamp(30px,4.5vw,52px);
  padding-top:22px;
  border-top:1px solid var(--line);
}
.booking-row-label{
  letter-spacing:.2em;
  text-transform:uppercase;
  font-size:10px;
  color:var(--muted);
  margin:0 0 18px;
}

/* socials */
.socials{display:flex;flex-wrap:wrap;gap:14px 34px}
.social{
  display:inline-flex;align-items:center;gap:11px;
  text-decoration:none;color:var(--text);
  font-size:16px;font-weight:700;letter-spacing:-.01em;
  padding:4px 0;position:relative;
  transition:color .25s ease;
}
.social svg{width:21px;height:21px;flex:0 0 auto;transition:transform .3s cubic-bezier(.16,1,.3,1)}
.social .handle{color:var(--muted);font-weight:400;font-size:14px}
.social::after{
  content:"";position:absolute;left:32px;right:100%;bottom:0;
  height:1.5px;background:var(--accent);
  transition:right .35s cubic-bezier(.16,1,.3,1);
}
.social:hover{color:var(--accent)}
.social:hover svg{transform:translateY(-2px)}
.social:hover::after{right:0}

/* agencies — containerless, hairline split */
.agencies{display:grid;grid-template-columns:1fr;gap:59px}
.agency h3{margin:0;font-size:clamp(28px,3.6vw,38px);line-height:.98;letter-spacing:-.03em}
.agency-kicker{letter-spacing:.2em;text-transform:uppercase;font-size:10px;color:var(--muted);margin:0 0 8px}
.agency address{font-style:normal;color:#3a352e;line-height:1.5;margin:12px 0 0;font-size:15px}
.agency dl{margin:16px 0 0;display:grid;grid-template-columns:auto 1fr;gap:9px 18px;align-items:baseline}
.agency dt{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#7a746a}
.agency dd{margin:0;font-size:15px}
.agency dd a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:1px;transition:border-color .25s ease,color .25s ease}
.agency dd a:hover{color:var(--accent);border-color:var(--accent)}

/* direct form — underlined fields, no box */
.bookme-form{display:block}
.fields{display:grid;grid-template-columns:1fr;gap:24px 30px}
.field{display:flex;flex-direction:column;gap:9px}
.field.full{grid-column:1/-1}
.field span{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#7a746a}
.field span em{font-style:normal;text-transform:none;letter-spacing:0;color:#a89f90}
.field input,
.field textarea{
  font:inherit;font-size:16px;color:var(--text);
  background:transparent;border:0;border-bottom:1px solid var(--line);
  padding:8px 2px;transition:border-color .3s ease;resize:none;
}
.field textarea{min-height:96px;line-height:1.5}
.field input::placeholder,
.field textarea::placeholder{color:#a89f90}
.field input:focus,
.field textarea:focus{outline:none;border-color:var(--accent)}

.bookme-status{margin:16px 0 0;color:#2f2b24;font-size:14px;line-height:1.35;min-height:20px}
.bookme-status:empty{display:none}
.bookme-status.is-error{color:#7a271f}
.bookme-status.is-success{color:#1f5b30}

.booking-submit{
  margin-top:28px;
  display:inline-flex;align-items:center;gap:11px;
  background:transparent;border:0;cursor:pointer;
  color:var(--text);font:inherit;font-weight:700;font-size:16px;letter-spacing:-.01em;padding:0;
}
.booking-submit .arrow{color:var(--accent);transition:transform .3s cubic-bezier(.16,1,.3,1)}
.booking-submit .txt{
  background-image:linear-gradient(var(--accent),var(--accent));
  background-size:0% 1.5px;background-repeat:no-repeat;background-position:0 100%;
  padding-bottom:3px;transition:background-size .35s cubic-bezier(.16,1,.3,1);
}
.booking-submit:hover .txt{background-size:100% 1.5px}
.booking-submit:hover .arrow{transform:translateX(5px)}
.booking-submit:active{transform:translateY(1px)}
.booking-submit:disabled{opacity:.55;cursor:default}

/* legal footer */
.booking-legal{
  margin-top:clamp(32px,4.5vw,52px);
  padding-top:20px;
  border-top:1px solid var(--line-soft);
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
}
.booking-legal a{color:var(--muted);text-decoration:none;font-size:13px;transition:color .25s ease}
.booking-legal a:hover{color:var(--text)}
.booking-legal .copy{color:#9a9183;font-size:12px;letter-spacing:.02em}

/* desktop: agencies side by side + 2-col form */
@media(min-width:760px){
  .agencies{grid-template-columns:1fr 1fr;gap:0 25px}
  .agency{padding:0 clamp(20px,3vw,44px)}
  .agency:first-child{padding-left:0}
  .agency:last-child{padding-right:0;border-left:1px solid var(--line)}
  .fields{grid-template-columns:1fr 1fr}
}

/* staggered reveal — armed by JS only (no-JS / reduced-motion => fully visible) */
.booking-page.reveal-armed [data-reveal]{opacity:0;transform:translateY(16px)}
.booking-page.reveal-armed.reveal-play [data-reveal]{
  animation:bookingRise .8s cubic-bezier(.16,1,.3,1) forwards;
  animation-delay:calc(var(--i,0) * 90ms + 80ms);
}
@keyframes bookingRise{to{opacity:1;transform:none}}

/* experimental photo-wipe transition overlay (toggled in script.js: PHOTO_WIPE.enabled) */
.photo-wipe{
  position:fixed;
  inset:0;
  z-index:26;            /* above the screens, below the nav-counter (z-30) and modal */
  pointer-events:none;
  visibility:hidden;
  opacity:0;
  overflow:hidden;
  background:#11100e;
  will-change:transform;
}
.photo-wipe img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 35%;
  /* grade towards the warm paper aesthetic so it doesn't clash */
  filter:grayscale(.18) contrast(1.03) brightness(.9) sepia(.1);
}
.photo-wipe::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(183,41,38,.12), rgba(17,16,14,.22));
  mix-blend-mode:multiply;
}
.nav-progress{
  position:fixed;
  left:50%;
  bottom:calc(env(safe-area-inset-bottom,0px) + 14px);
  transform:translateX(-50%);
  display:flex;
  gap:8px;
  z-index:30;
}
.nav-progress button{
  position:relative;
  width:38px;
  height:24px;          /* generous tap target, visual bar stays tiny */
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
}
.nav-progress button::before{
  content:"";
  position:absolute;
  left:0;right:0;top:50%;
  height:3px;
  margin-top:-1.5px;
  border-radius:2px;
  background:rgba(22,20,17,.22);
  box-shadow:0 0 0 .5px rgba(247,243,230,.5);
  transition:background .3s ease,transform .25s ease;
}
.nav-progress button.is-active::before{background:var(--text)}
.nav-progress button:active::before{transform:scaleY(1.8)}
.audio-screen{background:#dde8f0}
.audio-stage{width:min(560px,100%);margin-inline:auto;display:grid;gap:8px}
.audio-player{
  display:grid;
  gap:36px;
  background:linear-gradient(180deg,#f8f8f5,#ecece7);
  border:1px solid rgba(17,20,26,.18);
  border-radius:28px;
  padding:24px 20px 84px;
  box-shadow:0 22px 40px rgba(20,23,28,.17), inset 0 1px 0 rgba(255,255,255,.75);
  max-height:calc(100dvh - 228px);
}
.audio-main{display:grid;gap:34px;min-height:0}
.audio-cover{
  position:relative;
  border-radius:0;
  aspect-ratio:auto;
  min-height:420px;
  background:transparent;
  overflow:visible;
  display:grid;
  place-items:center;
  box-shadow:none;
  border:0;
  outline:0;
}
.audio-cover::before,
.audio-cover::after,
.audio-cover-fallback::before,
.audio-cover-fallback::after{
  content:none !important;
  display:none !important;
}
.audio-cover img{width:100%;height:100%;object-fit:cover;display:none !important;filter:saturate(0.86) contrast(1.02)}
.audio-cover-fallback{
  position:absolute;inset:0;display:grid;place-items:center;
  background:transparent;
}
.audio-cover-fallback::before{
  content:none;
}
.audio-cover-symbol{
  width:min(718px,90%);
  max-width:718px;
  height:auto;
  display:block;
  fill:none;
  stroke:rgba(41,43,47,.94);
  stroke-width:2.25;
  stroke-linecap:round;
  vector-effect:non-scaling-stroke;
  opacity:.92;
}
.audio-cover-symbol line{stroke:inherit;stroke-linecap:inherit;stroke-width:inherit}
.audio-cover-ring{display:none}
.audio-hud{
  position:absolute;left:14px;right:14px;top:12px;display:flex;justify-content:space-between;gap:12px;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(238,242,248,.82)
}
.audio-display-footer{
  position:absolute;
  left:16px;
  right:16px;
  bottom:16px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:end;
  gap:14px;
}
.audio-timecode{
  margin:0;
  color:rgba(242,244,247,.95);
  font-size:clamp(28px,4.8vw,42px);
  font-weight:300;
  letter-spacing:.02em;
  font-variant-numeric:tabular-nums;
}
.audio-miniwave{
  width:100%;
  height:54px;
  border-radius:8px;
  background:rgba(2,4,8,.26);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}
.audio-mini-poster{
  width:58px;
  height:58px;
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(8,11,16,.55);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
}
.audio-mini-poster img{width:100%;height:100%;object-fit:cover;display:none}
.audio-hud,
.audio-display-footer{display:none}
.audio-meta{display:grid;align-content:start;justify-items:center;gap:4px;text-align:center}
.audio-meta h3{
  margin:0;
  font-size:clamp(16px,2.8vw,24px);
  line-height:1.08;
  letter-spacing:.01em;
  color:#161411;
  font-weight:700;
  max-width:92%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.audio-meta-inline{
  margin:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:20px;
}
.audio-author,
.audio-position{
  margin:0;
  font-size:14px;
  line-height:1.2;
  color:#4b5568;
  font-weight:600;
  letter-spacing:0;
  text-transform:none;
}
.audio-controls{display:grid;gap:18px;padding:8px 20px 2px}
.audio-buttons{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.audio-cover + .audio-meta{margin-top:50px}
.audio-btn{
  position:relative;
  border:1px solid rgba(30,34,42,.22);
  border-radius:999px;
  background:linear-gradient(180deg,#f8f8f4,#d9dbdb);
  color:#151820;
  padding:10px 16px;
  font-size:15px;
  font-weight:700;
  min-height:44px;
  min-width:62px;
  box-shadow:
    inset 0 2px 2px rgba(255,255,255,.9),
    inset 0 -2px 3px rgba(118,124,132,.35),
    0 5px 10px rgba(18,22,28,.18);
  transition:transform 120ms ease, box-shadow 120ms ease;
}
.audio-btn:active{
  transform:translateY(2px);
  box-shadow:
    inset 0 2px 2px rgba(255,255,255,.7),
    inset 0 -1px 2px rgba(78,84,93,.42),
    0 1px 2px rgba(18,22,28,.2);
}
.audio-btn-primary{
  min-width:104px;
  background:#dc5430;
  color:#f8fbff;
  border-color:#c34a2a;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28),0 5px 10px rgba(93,38,24,.34);
}
.audio-btn-primary:active{box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 2px 4px rgba(102,62,8,.28)}
.audio-btn-ghost{
  width:54px;
  height:54px;
  min-width:54px;
  padding:0;
  font-size:28px;
  font-weight:500;
}
.audio-btn-knob{
  min-width:54px;
  padding:0;
  width:54px;
  height:54px;
  display:grid;
  place-items:center;
  font-size:30px;
  line-height:1;
  font-weight:500;
}
.audio-btn:disabled{opacity:.45;cursor:not-allowed}
.audio-progress-row{
  width:min(520px,100%);
  margin:8px auto 24px;
  display:block;
}
.audio-timeline{display:flex;align-items:center;justify-content:flex-start}
.audio-timeline-solo{width:100%}
.audio-timeline span{font-size:13px;font-weight:700;color:#5c6270;min-width:34px}
.audio-timeline input[type="range"]{width:100%;accent-color:#151820}
.audio-duration-hidden{display:none}
.projects-stage{position:absolute;inset:0;background:var(--bg);color:var(--text);overflow:hidden}
.projects-copy{position:absolute;left:28px;top:28px;z-index:3;max-width:min(680px,70vw)}
.projects-copy .eyebrow{color:rgba(22,20,17,.62)}
.projects-copy h2{font-size:clamp(34px,5.6vw,72px);color:var(--text)}
.slider-wrapper{position:absolute;inset:0;overflow:hidden}
#projectsSlider{position:absolute;inset:0;width:100%;height:100%;display:block;touch-action:none}
.slider-vignette{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 48% 42%,rgba(247,243,230,0) 76%,rgba(247,243,230,.06) 100%),linear-gradient(90deg,rgba(247,243,230,.06),rgba(247,243,230,0) 16%,rgba(247,243,230,.05) 100%)}
.modal[hidden]{display:none}
.modal{position:fixed;inset:0;z-index:50}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.72);animation:modalFadeIn 320ms ease both}
.modal-sheet{position:absolute;left:14px;right:14px;bottom:14px;max-height:88dvh;background:#090909;border:1px solid rgba(255,255,255,.08);border-radius:28px;overflow:auto;box-shadow:0 30px 100px rgba(0,0,0,.56);animation:modalSlideUp 360ms cubic-bezier(.2,.9,.2,1) both}
.modal.modal-closing .modal-overlay{animation:modalFadeOut 260ms ease both}
.modal.modal-closing .modal-sheet{animation:modalSlideDown 300ms cubic-bezier(.7,0,.3,1) both}
/* close button removed from view — tapping the overlay or pressing Escape closes the modal */
.modal-close{display:none}
.modal-media{height:260px;background:#11100e;color:#fff;display:grid;place-items:center;text-align:center;padding:0}
.modal-video{width:100%;height:100%;display:block;object-fit:contain;background:#11100e}
.modal-embed{width:100%;height:100%;display:block;border:0;background:#11100e}
.modal-media.is-portrait .modal-video,
.modal-media.is-portrait .modal-embed{
  width:min(420px,100%);
  height:min(74dvh,860px);
  aspect-ratio:9/16;
  margin-inline:auto;
}
.modal-sheet.has-portrait-media{
  max-height:94dvh;
}
.modal-sheet.has-portrait-media .modal-media{
  height:auto;
  min-height:min(74dvh,860px);
  align-content:start;
  padding-top:20px;
}
.modal-sheet.has-portrait-media .modal-content{
  padding-top:20px;
}
.modal-content{padding:30px 18px 40px;background:rgba(10,10,10,.92);border-top:1px solid rgba(255,255,255,.08)}
.modal-content .eyebrow{display:none}
.modal-content h2{
  display:block;
  margin:0 0 20px;
  font-size:clamp(28px,5.2vw,42px);
  line-height:.95;
  letter-spacing:-.025em;
  color:#f2f2ee;
}
.modal-content p{font-size:13px;line-height:1.35;margin:0}
#modalMeta{
  display:block;
  font-size:clamp(15px,2.3vw,20px);
  font-weight:600;
  color:rgba(240,240,240,.9);
}
#modalRole{display:none}
#modalMeta::after{content:"";display:inline}
#modalRole{margin-left:10px}
#modalDescription,#modalTags,#modalImdb{display:none !important}
#modalDescription:empty,.tags:empty{display:none}
.tags{display:flex;gap:8px;flex-wrap:wrap}
.tag{font-size:12px;padding:8px 10px;border-radius:999px;background:#fff}
body.modal-open{overflow:hidden}
@media(max-width:720px){
  .screen{padding:18px}
  .home-screen{padding:0}
  /* copy clearly below the gallery, just above the slim progress nav */
  .home-copy{left:18px;right:18px;bottom:calc(env(safe-area-inset-bottom,0px) + 96px)}
  .home-copy h1{font-size:clamp(34px,12.8vw,58px)}
  .home-copy .eyebrow{font-size:10px;letter-spacing:.19em}
  .home-copy .lead{margin-top:9px;font-size:clamp(15px,4vw,18px)}
  /* taller container so Safari's perspective clipping never cuts the 3D cards;
     ring top compensates so the visual center stays where it was */
  .personality-gallery{--card-w:clamp(155px,57.6vw,232px);top:clamp(24px,5dvh,58px);height:62dvh}
  .personality-gallery-ring{top:40%}
  .projects-copy{left:18px;right:18px;top:22px;max-width:none}
  /* audio player must fit the visual viewport incl. Safari's bottom bar:
     definite height, flexible cover, controls always visible */
  .audio-stage{gap:0;height:calc(100dvh - 76px - env(safe-area-inset-bottom,0px))}
  .audio-player{
    padding:16px 14px 18px;
    gap:14px;
    height:100%;
    max-height:none;
    border-radius:22px;
    grid-template-rows:minmax(0,1fr);
    min-height:0;
  }
  .audio-main{gap:14px;grid-template-rows:minmax(0,1fr) auto auto;min-height:0}
  .audio-cover{aspect-ratio:auto;min-height:0;height:100%}
  /* the artwork has built-in viewBox margins — scale up so it fills its cell properly */
  .audio-cover-symbol{width:100%;height:100%;max-width:none;transform:scale(1.18);transform-origin:center}
  .audio-cover + .audio-meta{margin-top:0}
  .audio-meta h3{font-size:clamp(15px,4.4vw,20px)}
  .audio-author,.audio-position{font-size:12px}
  .audio-meta-inline{gap:14px}
  .audio-buttons{justify-content:center;gap:10px}
  .audio-btn{padding:9px 14px}
  .audio-timecode{font-size:clamp(22px,8vw,34px)}
  .audio-miniwave{height:48px}
  .audio-mini-poster{width:46px;height:46px;border-radius:8px}
  .audio-display-footer{left:12px;right:12px;bottom:12px;gap:10px}
  .audio-hud{font-size:10px}
  .audio-controls{padding:6px 4px 2px;gap:14px}
  .audio-btn-knob{font-size:26px}
  .audio-progress-row{
    width:min(420px,100%);
    margin:6px auto 14px;
  }
  .audio-timeline span{font-size:12px}
}
@media(min-width:721px) and (max-width:1199px){
  .personality-gallery{--card-w:clamp(230px,30vw,320px)}
}
/* short desktop windows: keep gallery and copy from overlapping (after the width rules so it wins) */
@media(min-width:721px) and (max-height:760px){
  .personality-gallery{--card-w:clamp(160px,18vw,250px);height:44dvh}
  .home-copy{bottom:calc(env(safe-area-inset-bottom,0px) + 90px)}
}
@media(min-width:1200px){
  .personality-gallery{top:clamp(96px,12dvh,150px);height:min(54dvh,620px)}
}
@media(min-width:768px) and (max-width:1199px){
  .modal-sheet{
    left:50%;
    top:50%;
    right:auto;
    bottom:auto;
    transform:translate(-50%,-50%);
    width:min(980px,94vw);
    max-height:92dvh;
    display:block;
    animation:modalCenterIn 320ms cubic-bezier(.2,.9,.2,1) both;
  }
  .modal.modal-closing .modal-sheet{
    animation:modalCenterOut 240ms cubic-bezier(.7,0,.3,1) both;
  }
  .modal-media{
    height:auto;
    min-height:min(56dvh,620px);
  }
  .modal-content{
    max-width:900px;
    margin:0 auto;
    padding:30px 28px 40px;
  }
}
@media(min-width:1200px){
  .modal-sheet{
    left:50%;
    top:50%;
    right:auto;
    bottom:auto;
    transform:translate(-50%,-50%);
    width:min(1140px,92vw);
    max-height:90dvh;
    display:block;
    animation:modalCenterIn 320ms cubic-bezier(.2,.9,.2,1) both;
  }
  .modal.modal-closing .modal-sheet{
    animation:modalCenterOut 240ms cubic-bezier(.7,0,.3,1) both;
  }
  .modal-media{
    height:auto;
    min-height:min(64dvh,760px);
  }
  .modal-content{
    max-width:940px;
    margin:0 auto;
    padding:30px 34px 40px;
  }
  .modal-sheet.has-portrait-media{
    display:block;
    width:min(860px,92vw);
  }
  .modal-sheet.has-portrait-media .modal-media{
    min-height:min(72dvh,860px);
  }
  .legal{position:fixed;right:24px;bottom:28px;z-index:25}
}
@keyframes modalFadeIn{from{opacity:0}to{opacity:1}}
@keyframes modalFadeOut{from{opacity:1}to{opacity:0}}
@keyframes modalSlideUp{from{opacity:.92;transform:translateY(48px)}to{opacity:1;transform:translateY(0)}}
@keyframes modalSlideDown{from{opacity:1;transform:translateY(0)}to{opacity:.92;transform:translateY(56px)}}
@keyframes modalCenterIn{from{opacity:.92;transform:translate(-50%,-46%)}to{opacity:1;transform:translate(-50%,-50%)}}
@keyframes modalCenterOut{from{opacity:1;transform:translate(-50%,-50%)}to{opacity:.92;transform:translate(-50%,-46%)}}
@media(prefers-reduced-motion:reduce){
  .experience-track{transition:none}
}
