:root{
  --bg:        #DDDDEA;
  --bg-soft:   #C8CADE;
  --bg-deep:   #B5B7CE;
  --ink:       #08092A;
  --ink-soft:  #121333;
  --muted:     rgba(8,9,42,.55);
  --line:      rgba(8,9,42,.16);
  --line-soft: rgba(8,9,42,.08);
  --accent:    #1A1A86;
  --accent-2:  #2D2DA6;
  --accent-3:  #5C61C2;
  --accent-glow:#9098C8;
  --accent-deep:#0E0E5C;

  --mono:    'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  --display: 'Bricolage Grotesque', 'Bricolage Grotesque Placeholder', system-ui, sans-serif;

  --gut: clamp(1.25rem, 4vw, 3.25rem);
  --maxw: 1440px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--mono);
  font-weight:400;
  font-size:14px;
  line-height:1.55;
  letter-spacing:.01em;
  text-transform:uppercase;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
body::before{
  content:''; position:fixed; inset:-15vh -10vw;
  z-index:-2;
  background:
    radial-gradient(circle 55vmin at 8% 12%, rgba(26,26,134,.4), transparent 60%),
    radial-gradient(circle 45vmin at 88% 18%, rgba(144,152,200,.35), transparent 60%),
    radial-gradient(circle 60vmin at 18% 78%, rgba(45,45,166,.4), transparent 60%),
    radial-gradient(circle 50vmin at 92% 88%, rgba(14,14,92,.35), transparent 60%);
  filter:blur(45px);
  animation: drift 60s ease-in-out infinite alternate;
  pointer-events:none;
  opacity: .85;
}
body::after{
  content:''; position:fixed; inset:0;
  z-index:-1;
  background: linear-gradient(180deg, rgba(221,221,234,.55), rgba(221,221,234,.85) 30%, rgba(221,221,234,.6) 70%, rgba(221,221,234,.85));
  pointer-events:none;
}
@keyframes drift{
  0%   { transform: translate3d(0,0,0) scale(1); }
  100% { transform: translate3d(-1.5vw,1.5vh,0) scale(1.04); }
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;text-transform:inherit;letter-spacing:inherit}

::selection{background:var(--accent);color:#fff}

.reveal{
  opacity:0;
  transform:translateY(20px);
  filter: blur(8px);
  transition: opacity 1.1s ease, transform 1.1s cubic-bezier(.22,.8,.36,1), filter 1.1s ease;
}
.reveal.is-in{ opacity:1; transform:none; filter: blur(0) }
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
}

.nav{
  position:fixed;
  inset:0 0 auto 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1.45rem var(--gut);
  z-index:50;
  font-size:12.5px;
  letter-spacing:.18em;
  background:linear-gradient(to bottom, rgba(220,208,236,.78), rgba(220,208,236,0));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.nav__brand{
  position:relative;
  display:inline-block;
  font-family: var(--display);
  font-weight:700;
  letter-spacing:-.01em;
  font-size:20px;
  line-height:1;
  text-transform:none;
  color: var(--accent);
  isolation:isolate;
}
.nav__brand-blur,
.nav__brand-sharp{
  display:block;
  white-space:nowrap;
}
.nav__brand-blur{
  filter: blur(6.5px);
  opacity: .65;
  transform: scale(1.04);
}
.nav__brand-sharp{
  position:absolute; inset:0;
  filter: blur(1.4px);
  opacity: .95;
}
.nav__links{display:flex; gap:2.2rem; align-items:center}
.nav__links a{position:relative; padding:.35rem 0;}
.nav__links a:not(.nav__ig){
  transition: color .35s ease, letter-spacing .45s ease;
}
.nav__links a:not(.nav__ig){
  position:relative;
  isolation:isolate;
  transition: color .4s ease;
}
.nav__links a:not(.nav__ig) > span{ position:relative; z-index:1 }
.nav__links a:not(.nav__ig)::before{
  content:''; position:absolute; inset: -22px -42px;
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 280 100'%3E%3Cdefs%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='2.6' numOctaves='3' seed='9'/%3E%3CfeColorMatrix values='0 0 0 0 0.10 0 0 0 0 0.10 0 0 0 0 0.52 0 0 0 1.7 -0.85'/%3E%3C/filter%3E%3C/defs%3E%3Crect width='280' height='100' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size: 100% 100%;
  background-repeat:no-repeat;
  -webkit-mask-image: radial-gradient(ellipse 70% 55% at center, #000 25%, transparent 75%);
          mask-image: radial-gradient(ellipse 70% 55% at center, #000 25%, transparent 75%);
  opacity:0;
  transition: opacity .55s ease;
  z-index:-2;
  pointer-events:none;
}
.nav-fx{
  position:absolute;
  left:50%; top:50%;
  width: calc(100% + 90px);
  height: calc(100% + 38px);
  transform: translate(-50%, -50%);
  pointer-events:none;
  z-index:-1;
  overflow:visible;
}
.nav-fx path{
  fill:none;
  stroke: var(--accent);
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: url(#sloppy);
  stroke-dasharray: 620;
  stroke-dashoffset: 620;
  transition: stroke-dashoffset .55s cubic-bezier(.45,.05,.5,1);
}
.nav__links a:not(.nav__ig):hover{ color: var(--accent) }
.nav__links a:not(.nav__ig):hover::before{ opacity: .55 }
.nav__links a:not(.nav__ig):hover .nav-fx path{ stroke-dashoffset: 0 }
.nav__ig{
  display:inline-flex; align-items:center; justify-content:center;
  width: 32px; height: 32px;
  margin-left: .8rem;
  color: var(--ink);
  transition: color .3s ease, transform .35s ease;
}
.nav__ig svg{ width: 20px; height: 20px }
.nav__ig span{ display:none }
.nav__ig:hover{ color: var(--accent); transform: scale(1.1) }

.lang-switch{
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin-left: 1rem;
  padding-left: 1rem;
  border-left: 1px solid var(--line);
  font-size: 11px; letter-spacing: .22em;
  color: var(--muted);
}
.lang-switch a{
  position: relative;
  padding: .15rem .1rem;
  transition: color .35s ease;
}
.lang-switch a.is-active{ color: var(--accent); font-weight: 500 }
.lang-switch a:not(.is-active):hover{ color: var(--ink) }
.lang-switch span{ opacity:.4 }

.nav__burger{
  display:none;
  width:32px; height:24px; position:relative;
}
.nav__burger span{position:absolute; left:4px; right:4px; height:1.5px; background:var(--ink); transition:transform .3s, top .3s, opacity .2s}
.nav__burger span:nth-child(1){top:7px}
.nav__burger span:nth-child(2){top:15px}
.nav__burger[aria-expanded="true"] span:nth-child(1){top:11px;transform:rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){top:11px;transform:rotate(-45deg)}

@media (max-width: 780px){
  .nav{ padding: 1.2rem 1.2rem 1.2rem var(--gut); }
  .nav__burger{ display:block; z-index: 60; margin-right: -.4rem; }
  .nav__links{
    position: fixed; inset: 0;
    width: 100vw; height: 100vh; height: 100svh;
    background: var(--bg);
    padding: 5.5rem 2rem 6rem;
    flex-direction: column;
    align-items: center; justify-content: center;
    gap: 1.6rem;
    font-size: 14px;
    transform: translateY(-30px);
    opacity: 0;
    visibility: hidden;
    transition: transform .55s cubic-bezier(.22,.8,.36,1), opacity .4s ease, visibility 0s linear .5s;
    border-left: 0;
    isolation: isolate;
    overflow: hidden;
  }
  .nav__links.is-open{
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    transition: transform .55s cubic-bezier(.22,.8,.36,1), opacity .4s ease, visibility 0s linear 0s;
  }
  .nav__links::before{
    content: ''; position: absolute; inset: -10vh -10vw; z-index: -1;
    background:
      radial-gradient(circle 55vmin at 18% 22%, rgba(26,26,134,.45), transparent 60%),
      radial-gradient(circle 50vmin at 85% 78%, rgba(14,14,92,.4), transparent 60%),
      radial-gradient(circle 40vmin at 60% 50%, rgba(144,152,200,.35), transparent 60%);
    filter: blur(45px);
    pointer-events: none;
  }
  .nav__links a:not(.nav__ig){
    font-family: var(--display);
    font-weight: 600;
    font-size: clamp(2.4rem, 11vw, 3.6rem);
    letter-spacing: -.015em;
    text-transform: none;
    color: var(--accent);
    line-height: 1;
    padding: .35rem 0;
    opacity: 0;
    transform: translateY(14px);
    transition: opacity .5s ease, transform .55s cubic-bezier(.22,.8,.36,1), color .3s ease;
  }
  .nav__links a:not(.nav__ig) > span{ font-family: var(--display) }
  .nav__links a:not(.nav__ig)::before{ display:none }
  .nav__links .nav-fx{ display: none }
  .nav__links.is-open a:not(.nav__ig){
    opacity: 1; transform: translateY(0);
  }
  .nav__links.is-open a:not(.nav__ig):nth-of-type(1){ transition-delay: .12s }
  .nav__links.is-open a:not(.nav__ig):nth-of-type(2){ transition-delay: .18s }
  .nav__links.is-open a:not(.nav__ig):nth-of-type(3){ transition-delay: .24s }
  .nav__links a.nav__ig{
    position: absolute;
    bottom: 5rem; left: 50%;
    transform: translateX(-50%);
    width: 44px; height: 44px;
    margin: 0; padding: 0;
    opacity: 0;
    font-size: 0;
    transition: opacity .5s ease .35s;
  }
  .nav__links a.nav__ig svg{ width: 22px; height: 22px }
  .nav__links.is-open a.nav__ig{ opacity: 1 }
  .nav__links .lang-switch{
    position: absolute;
    bottom: 2.2rem; left: 50%;
    transform: translateX(-50%);
    margin: 0; padding: 0; border: 0;
    font-size: 11.5px; letter-spacing: .28em;
    opacity: 0;
    transition: opacity .5s ease .42s;
  }
  .nav__links.is-open .lang-switch{ opacity: 1 }
}

.hero{
  position:relative;
  min-height:100vh;
  padding:5.5rem var(--gut) 7rem;
  display:grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto 1fr auto;
  overflow:hidden;
  isolation:isolate;
  margin-bottom: -4rem;
}
.hero::after{
  content:''; position:absolute; left:0; right:0; bottom:0;
  height: 18vh;
  background: linear-gradient(to bottom, transparent 0%, var(--bg) 85%);
  pointer-events:none; z-index:0;
}
.hero__bg{
  position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(ellipse 60% 50% at 18% 25%, rgba(26,26,134,.45), transparent 65%),
    radial-gradient(ellipse 50% 45% at 82% 70%, rgba(26,26,134,.4), transparent 65%),
    radial-gradient(ellipse 60% 55% at 50% 100%, rgba(14,14,92,.35), transparent 65%),
    var(--bg);
}
.blob{
  position:absolute; border-radius:50%; filter:blur(85px); opacity:.7;
  mix-blend-mode:multiply;
}
.blob--1{
  left:-10%; top:5%; width:55vw; height:55vw;
  background:radial-gradient(circle, var(--accent) 0%, transparent 60%);
  animation:float-a 24s ease-in-out infinite alternate;
}
.blob--2{
  right:-8%; top:30%; width:42vw; height:42vw;
  background:radial-gradient(circle, var(--accent-deep) 0%, transparent 60%);
  animation:float-b 28s ease-in-out infinite alternate;
}
.blob--3{
  left:30%; bottom:-20%; width:55vw; height:55vw;
  background:radial-gradient(circle, var(--accent-2) 0%, transparent 60%);
  animation:float-a 32s ease-in-out infinite alternate-reverse;
  filter:blur(110px);
  opacity:.55;
}
.blob--4{
  right:15%; top:8%; width:32vw; height:32vw;
  background:radial-gradient(circle, var(--accent-3) 0%, transparent 60%);
  animation:float-b 30s ease-in-out infinite alternate;
  filter:blur(75px);
  opacity:.55;
}
.blob--5{
  left:8%; bottom:8%; width:38vw; height:38vw;
  background:radial-gradient(circle, var(--accent-2) 0%, transparent 60%);
  animation:float-a 26s ease-in-out infinite alternate;
  filter:blur(90px);
  opacity:.5;
}
@keyframes float-a{
  0%{transform:translate(0,0) scale(1)}
  100%{transform:translate(8%,4%) scale(1.08)}
}
@keyframes float-b{
  0%{transform:translate(0,0) scale(1)}
  100%{transform:translate(-6%,6%) scale(1.05)}
}
.hero__shard{ display:none }

.hero__title{
  grid-column:1 / -1;
  grid-row:2 / span 2;
  align-self:center;
  justify-self:center;
  text-align:center;
  position:relative;
  margin:0;
  font-family: var(--display);
  font-weight:700;
  font-size: clamp(3.8rem, 14.5vw, 13rem);
  font-variation-settings: "opsz" 96;
  line-height:.88;
  letter-spacing:-.025em;
  color:var(--accent);
  user-select:none;
  text-transform:none;
  transform: scale(var(--hero-scale, .96));
  transform-origin: 50% 55%;
  transition: transform .18s linear;
  animation: heroPulse 5s ease-in-out infinite;
}
@keyframes heroPulse{
  0%, 100% { opacity: 1; }
  50%      { opacity: .82; }
}
.hero__title-blur,
.hero__title-sharp{
  display:block;
  position:relative;
  white-space:nowrap;
}
.hero__title-blur{
  filter:blur(var(--hero-blur-strong, 38px));
  opacity: var(--hero-opacity, .7);
  transform:translateY(3px) scale(1.04);
  transition:filter .12s linear, opacity .15s linear;
}
.hero__title-sharp{
  position:absolute; inset:0;
  filter:blur(var(--hero-blur-soft, 8px));
  opacity:.92;
  transition:filter .12s linear;
}
@keyframes heroPulse{
  0%   { filter: hue-rotate(0deg); }
  100% { filter: hue-rotate(-10deg); }
}

.hero__address{
  position:absolute;
  right:var(--gut);
  top:50%;
  transform: translateY(-50%) rotate(180deg);
  writing-mode: vertical-rl;
  display:flex; gap:1.5rem;
  font-size:11.5px; letter-spacing:.32em;
  color:var(--ink-soft);
}
.hero__address span{display:inline-block}

.hero__tag{
  grid-column:1; grid-row:4;
  align-self:end;
  position:absolute;
  left: var(--gut);
  bottom: 4.5rem;
  font-size:11.5px; letter-spacing:.28em;
  margin-top:0;
}
.hero__tag p{margin:0;line-height:1.5}
.hero__tag-dot{
  display:block; width:6px; height:6px; border-radius:50%;
  background:var(--accent); margin-top:.85rem;
}

.hero__scroll{
  position:absolute;
  bottom:2rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap: 1rem;
  font-size:11px; letter-spacing:.36em; font-weight:500;
  color:var(--accent);
  z-index: 4;
  text-shadow: 0 0 12px rgba(221,221,234,.7);
}
.ink{
  position: relative;
  display:block;
  width: 18px;
  height: 110px;
}
.ink__line{
  position: absolute; left: 50%; top:0; bottom:0;
  width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(26,26,134,.4) 25%, rgba(26,26,134,.4) 75%, transparent);
  transform: translateX(-50%);
}
.ink__trail{
  position:absolute; left:50%; top:0;
  border-radius: 50%;
  background: linear-gradient(to top, var(--accent) 0%, rgba(26,26,134,.55) 50%, transparent 100%);
  transform-origin: 50% 100%;
  pointer-events:none;
  animation: inkDrip 3.6s cubic-bezier(.5,0,.6,1) infinite;
}
.ink__trail.t0{
  width: 4px; height: 38px;
  filter: blur(2.4px);
  transform: translate(-50%, -38px);
  animation-delay: 0s;
}
.ink__trail.t1{
  width: 2.2px; height: 22px;
  filter: blur(3px);
  opacity: .55;
  transform: translate(-50%, -22px);
  animation-delay: .12s;
}
.ink__drop{
  position:absolute; left:50%; top:0;
  background: var(--accent);
  border-radius: 50%;
  transform: translateX(-50%);
  animation: inkDrip 3.6s cubic-bezier(.5,0,.6,1) infinite;
  pointer-events:none;
}
.ink__drop.d0{ width: 11px; height: 11px; filter: blur(.7px); animation-delay: 0s }
.ink__drop.d1{ width: 5px;  height: 5px;  filter: blur(2px);   opacity:.55; animation-delay: .25s }
.ink__drop.d2{ width: 3px;  height: 3px;  filter: blur(2.5px); opacity:.4;  animation-delay: .42s }
.ink__drop.d3{ width: 2px;  height: 2px;  filter: blur(3px);   opacity:.28; animation-delay: .6s }
@keyframes inkDrip{
  0%   { top: -12%; opacity: 0 }
  8%   { opacity: 1 }
  90%  { opacity: 1 }
  100% { top: 105%; opacity: 0 }
}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

@media (max-width:780px){
  .hero{
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto auto;
    padding: 5.5rem var(--gut) 4.5rem;
    min-height: 100svh;
    margin-bottom: 0;
    text-align:center;
  }
  .hero::after{ height: 14vh }
  .hero__address{
    position:static; transform:none; writing-mode:horizontal-tb;
    grid-column:1; grid-row:1;
    justify-content:center;
    gap: 1.4rem;
    margin: 0 0 1rem;
    font-size: 10px; letter-spacing:.28em;
    color: var(--muted);
  }
  .hero__title{
    font-size: clamp(2.6rem, 16vw, 6rem);
    letter-spacing: -.018em;
    grid-row: 2 / span 1;
  }
  .hero__title-blur{ filter: blur(var(--hero-blur-strong, 22px)) }
  .hero__title-sharp{ filter: blur(var(--hero-blur-soft, 4px)) }
  .hero__tag{
    position: static;
    grid-column: 1; grid-row: 3;
    align-self: center; justify-self: center;
    text-align: center;
    margin-top: 1.4rem;
    font-size: 10.5px;
  }
  .hero__tag-dot{ margin: .85rem auto 0 }
  .hero__scroll{ display: none }
}

.rule{border:0;height:1px;background:var(--line); margin:0 var(--gut)}
section{padding: clamp(4rem, 8vw, 7rem) var(--gut)}
.section-head{margin-bottom: clamp(2rem, 4vw, 3rem)}
.section-tag{
  display:inline-block;
  font-size:11px; letter-spacing:.32em; color:var(--ink);
  position:relative; padding-left:0;
}
.big{
  font-family:var(--mono); font-weight:500;
  font-size: clamp(1.75rem, 3.6vw, 3rem);
  line-height:1.05;
  letter-spacing:-.005em;
  margin:0 0 1.4rem;
  text-transform:uppercase;
}

.link-arrow{
  display:inline-flex; align-items:center; gap:.85rem;
  font-size:12px; letter-spacing:.22em;
  border-top:1px solid var(--line);
  padding-top:.85rem;
  width: 18ch;
  max-width:100%;
  transition:color .3s ease, gap .3s ease;
  color:var(--ink-soft);
}
.link-arrow svg{width:24px;height:8px}
.link-arrow:hover{ color:var(--accent); gap:1.4rem }
.link-arrow--small{ width:auto; min-width:13ch }

.stock{
  position:relative;
  overflow:hidden;
  background: var(--accent-deep);
  isolation:isolate;
  border-radius: 22px;
}
.stock img{
  width:100%; height:100%; object-fit:cover;
  display:block;
  filter: saturate(.35) contrast(.95) brightness(1.08) blur(3px);
  transform: scale(1.05);
  transition: filter 1s ease, transform 1.2s cubic-bezier(.22,.8,.36,1);
}
.stock::before{
  content:''; position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(135deg, rgba(232,234,245,.55), rgba(180,184,210,.45) 50%, rgba(144,152,200,.6));
  mix-blend-mode: screen;
  pointer-events:none;
  transition: opacity .8s ease;
}
.stock::after{
  content:''; position:absolute; inset:0; z-index:2;
  background:
    radial-gradient(ellipse 75% 65% at 25% 30%, rgba(144,152,200,.5), transparent 55%),
    radial-gradient(ellipse 65% 55% at 80% 80%, rgba(26,26,134,.4), transparent 55%),
    linear-gradient(180deg, transparent 60%, rgba(14,14,92,.3));
  mix-blend-mode: overlay;
  pointer-events:none;
  transition: opacity .8s ease;
}
.stock:hover img{
  filter: saturate(1) contrast(1) brightness(1) blur(0);
  transform: scale(1.02);
}
.stock:hover::before,
.stock:hover::after{ opacity: 0 }

.studio__grid{
  display:grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1.2fr);
  gap: clamp(2rem, 6vw, 5rem);
  align-items:center;
}
.studio__copy p{ margin: 0 0 1rem; max-width: 38ch; color:var(--ink-soft); letter-spacing:.04em }
.studio__copy p:last-of-type{ margin-bottom: 2.2rem }
.studio__ctas{ display:flex; gap: 2.5rem; flex-wrap:wrap }

.studio__media{
  display:grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: clamp(.5rem, 1vw, .85rem);
  margin:0;
  max-width: 700px;
  margin-left: auto;
  height: clamp(380px, 34vw, 500px);
}
.studio__pic{ margin:0; height:100% }
.studio__pic--main{ grid-column: 1; grid-row: 1 / 3 }
.studio__pic--a{ grid-column: 2 / 4; grid-row: 1 }
.studio__pic--b{ grid-column: 2; grid-row: 2 }
.studio__pic--c{ grid-column: 3; grid-row: 2 }
.studio__pic--d{ display: none }
@media (max-width:780px){
  .studio__media{ height: clamp(380px, 90vw, 520px); max-width: 100%; margin: 0; grid-template-columns: 1.4fr 1fr; grid-template-rows: 1fr 1fr 1fr; }
  .studio__pic--main{ grid-row: 1 / 3 }
  .studio__pic--a{ grid-column: 2; grid-row: 1 }
  .studio__pic--b{ grid-column: 2; grid-row: 2 }
  .studio__pic--c{ grid-column: 1; grid-row: 3 }
  .studio__pic--d{ display:block; grid-column: 2; grid-row: 3 }
}

@media (max-width:780px){
  .studio__grid{grid-template-columns:1fr; gap:2rem}
  .studio__media{
    order:-1; margin: 0 auto; max-width: 100%;
    height: clamp(280px, 80vw, 420px);
    grid-template-columns: 1.4fr 1fr; grid-template-rows: 1fr 1fr 1fr;
    gap: .5rem;
  }
  .studio__pic--main{ grid-row: 1 / 3 }
  .studio__pic--a{ grid-column: 2; grid-row: 1 }
  .studio__pic--b{ grid-column: 2; grid-row: 2 }
  .studio__pic--c{ grid-column: 1; grid-row: 3 }
  .studio__pic--d{ display:block; grid-column: 2; grid-row: 3 }
}

.artists__intro{
  display:flex; justify-content:space-between; align-items:flex-end; gap:2rem;
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
.artists__intro .big{margin-bottom:0; max-width:18ch}

.artists__grid{
  list-style:none; padding:0; margin:0;
  max-width: 1080px;
  margin-inline: auto;
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.2rem, 2.4vw, 2rem);
}
.artists__intro{ max-width: 1080px; margin-inline: auto }
.artists .section-head{ max-width: 1080px; margin-inline: auto }
.artist{
  display:flex; flex-direction:column; gap:0;
}
.artist__btn{
  display:block; width:100%;
  text-align:left;
  background: transparent;
  padding: 0;
  border:0; border-radius:0;
  cursor:pointer;
  transition:transform .5s cubic-bezier(.22,.8,.36,1);
  font:inherit; color:inherit; text-transform:inherit; letter-spacing:inherit;
}
.artist__btn:hover{ transform:translateY(-6px) }
.artist__btn:focus-visible{ outline:2px solid var(--accent); outline-offset:6px; border-radius:22px }
.artist__portrait{
  position:relative;
  aspect-ratio: 4/5;
  overflow:hidden;
  margin-bottom: 1rem;
  border-radius: 22px;
  box-shadow: 0 24px 50px -20px rgba(31,31,140,.4);
  transition: box-shadow .6s ease;
}
.artist__btn:hover .artist__portrait{ box-shadow: 0 30px 70px -15px rgba(31,31,140,.55) }

.artist__meta{ display:flex; flex-direction:column; gap:.35rem; padding:.25rem .15rem; min-height: 5.5rem }
.artist__meta strong{
  font-weight:500; letter-spacing:.05em; font-size:14px;
}
.artist__meta span{
  font-size:10.5px; letter-spacing:.2em; color:var(--muted);
}
.artist__meta .link-arrow{ margin-top:.85rem; padding-top:.7rem; font-size:10.5px; letter-spacing:.2em; width:auto }
.artist__meta .link-arrow svg{width:18px;height:8px}

@media (max-width: 980px){ .artists__grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width: 560px){
  .artists__grid{grid-template-columns:repeat(2,1fr); gap: 1.2rem .8rem; padding: 0 .25rem}
  .artists__grid > .artist:last-child:nth-child(odd){
    grid-column: 1 / -1;
    max-width: calc(50% - .4rem);
    justify-self: center;
  }
  .artist__btn{ padding: 0 }
  .artist__portrait{ border-radius: 12px; margin-bottom: .65rem; box-shadow: 0 12px 28px -14px rgba(26,26,134,.35) }
  .artist__meta{ min-height: 4.4rem; gap:.25rem; padding: 0 .1rem }
  .artist__meta strong{ font-size: 11px; letter-spacing: .08em }
  .artist__meta > span:not(.link-arrow){
    font-size: 8.5px; letter-spacing: .12em;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .artist__meta .link-arrow{ font-size: 8.5px; letter-spacing:.14em; padding-top:.45rem; gap:.5rem }
  .artist__meta .link-arrow svg{ width:16px; height:6px }
}
@media (max-width: 560px){
  .artists__intro{ flex-direction: column; align-items: flex-start; gap: 1rem }
  .artists__intro .link-arrow{ width: auto; min-width: 14ch }
}

.booking{
  position:relative;
  isolation:isolate;
  padding-top: clamp(5rem, 9vw, 8rem);
  padding-bottom: clamp(5rem, 9vw, 8rem);
}
.booking__bg{
  position:absolute; inset:-10% -5%; z-index:-1;
  background:
    radial-gradient(circle 45vmin at 8% 50%, rgba(31,31,140,.55), transparent 55%),
    radial-gradient(circle 40vmin at 95% 30%, rgba(168,174,232,.6), transparent 55%),
    radial-gradient(circle 50vmin at 50% 110%, rgba(56,56,181,.45), transparent 55%);
  filter: blur(50px);
  pointer-events:none;
}

.booking__head{
  max-width: 720px;
  margin: 0 auto clamp(3rem, 6vw, 5rem);
  text-align:center;
  position:relative; z-index:1;
}
.booking__head .section-tag{ display:block; margin-bottom: 1.4rem }
.booking__head .big{ margin: 0 auto .9rem; max-width: 14ch }
.booking__intro{
  margin: 0 auto;
  max-width: 42ch;
  font-size: 13px;
  letter-spacing: .04em;
  color: var(--ink-soft);
  text-transform: none;
  line-height: 1.7;
}

.booking__form{
  position:relative; z-index:1;
  max-width: 760px;
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.8rem 2.4rem;
  padding: clamp(2.5rem, 5vw, 3.5rem) clamp(1.8rem, 4vw, 3rem);
  background:
    radial-gradient(ellipse 80% 100% at 50% 0%, rgba(168,174,232,.4), transparent 60%),
    linear-gradient(160deg, rgba(255,255,255,.85) 0%, rgba(239,236,247,.75) 100%);
  backdrop-filter: blur(20px) saturate(1.05);
  -webkit-backdrop-filter: blur(20px) saturate(1.05);
  border: 1px solid rgba(255,255,255,.5);
  border-radius: 28px;
  box-shadow:
    0 40px 80px -30px rgba(31,31,140,.35),
    0 0 0 1px rgba(31,31,140,.06),
    inset 0 1px 0 rgba(255,255,255,.8);
}
.field{ display:flex; flex-direction:column; gap:.6rem; min-width:0; position:relative }
.field--wide{ grid-column: 1 / -1 }
.field--submit{ grid-column: 1 / -1; align-items:center; gap:1rem; padding-top:.5rem }
.field--privacy{
  grid-column: 1 / -1;
  display:flex !important;
  flex-direction:row; align-items:center; gap:.85rem;
  font-size:11.5px; letter-spacing:.04em; color:var(--muted);
  text-transform:none;
  margin-top:.2rem;
  width:100%;
}
.field--privacy input[type="checkbox"]{
  appearance:none; -webkit-appearance:none;
  box-sizing: border-box;
  margin:0;
  width:18px; min-width:18px; max-width:18px;
  height:18px; min-height:18px;
  flex: 0 0 18px;
  aspect-ratio: 1 / 1;
  cursor:pointer;
  border: 1.5px solid var(--accent);
  border-radius: 3px;
  background: rgba(255,255,255,.7);
  display:inline-block;
  position: relative;
  align-self: center;
  transition: background .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.field--privacy input[type="checkbox"]:hover{ box-shadow: 0 0 0 4px rgba(26,26,134,.08) }
.field--privacy input[type="checkbox"]:checked{ background: var(--accent); border-color: var(--accent) }
.field--privacy input[type="checkbox"]:checked::after{
  content:''; position:absolute;
  left: 50%; top: 50%;
  width: 4px; height: 8px;
  border: solid #fff;
  border-width: 0 1.6px 1.6px 0;
  transform: translate(-50%, -60%) rotate(45deg);
}
.field--privacy input[type="checkbox"]:focus-visible{ outline:none; box-shadow: 0 0 0 5px rgba(26,26,134,.22) }
.field--privacy label{
  flex: 1 1 auto;
  min-width:0;
  cursor:pointer;
  line-height:1.55;
  font-size:11.5px;
  letter-spacing:.04em;
  color:var(--muted);
  text-transform:none;
}
.field--privacy a{ color:var(--accent); border-bottom:1px solid var(--line) }
.field--privacy a:hover{ border-color:var(--accent) }

.field label{
  font-size:11px; letter-spacing:.24em; color:var(--accent);
  font-weight:500;
  text-transform:uppercase;
}
.field__opt{ color:var(--muted); font-weight:400; letter-spacing:.18em }

.field input:not([type="checkbox"]),
.field textarea{
  width:100%;
  font:inherit; color:var(--ink);
  background:transparent;
  border:0; border-bottom:1px solid var(--line);
  padding:.65rem 0;
  font-size:14px; letter-spacing:.02em;
  text-transform:none;
  resize:none;
  transition: border-color .3s ease;
}
.field input::placeholder,
.field textarea::placeholder{ color: rgba(10,10,46,.35); font-style:italic; letter-spacing:.02em }
.field input:focus,
.field textarea:focus{ outline:none; border-bottom-color:var(--accent) }
.field textarea{ line-height: 1.6 }

.btn-primary{
  display:inline-flex; align-items:center; gap:.9rem;
  border:0;
  padding: 1.05rem 2rem;
  font-size:11.5px; letter-spacing:.28em;
  background:var(--accent);
  color:#fff;
  border-radius: 999px;
  text-transform:uppercase;
  cursor:pointer;
  transition: background .3s ease, gap .3s ease, transform .3s ease, box-shadow .3s ease;
  box-shadow: 0 14px 30px -10px rgba(31,31,140,.4);
}
.btn-primary svg{ width:24px; height:8px }
.btn-primary:hover{ background:var(--accent-deep); gap:1.4rem; transform: translateY(-1px); box-shadow: 0 20px 40px -10px rgba(31,31,140,.55) }

.form-status{
  margin:0;
  font-size:11.5px; letter-spacing:.04em; color:var(--ink-soft);
  min-height: 1.2em;
  text-transform:none;
}

.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden }

@media (max-width:560px){
  .booking__form{ grid-template-columns:1fr; gap:1.5rem; padding: 1.6rem 1.2rem; border-radius: 18px }
  .booking__head{ margin-bottom: 2rem }
  .booking__intro{ font-size: 12.5px }
  .field input:not([type="checkbox"]),
  .field textarea{ font-size: 16px }
  .btn-primary{ padding: 1rem 1.6rem; font-size: 11px; letter-spacing:.22em }
  .field--privacy{ font-size: 11px }
}

body.modal-open{ overflow:hidden }
body.menu-open{ overflow:hidden }

.modal{
  border:0; padding:0;
  background:#F5F5FA;
  color:var(--ink);
  width: min(1180px, 94vw);
  height: min(88vh, 720px);
  max-height: 88vh;
  margin:auto;
  border-radius: 4px;
  position:fixed; inset:0;
  overflow:hidden;
  box-shadow: 0 40px 100px rgba(8,9,42,.4);
  isolation:isolate;
  opacity:0;
  transform: translateY(40px) scale(.94);
  filter: blur(20px);
  transition: opacity .55s ease, transform .85s cubic-bezier(.16,1,.3,1), filter .7s ease;
}
.modal[open]{ display: block }
.modal.is-open{
  opacity:1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}
.modal::backdrop{
  background: rgba(8,9,42,.55);
  backdrop-filter: blur(0);
  -webkit-backdrop-filter: blur(0);
  opacity: 0;
  transition: opacity .55s ease, backdrop-filter .55s ease, -webkit-backdrop-filter .55s ease;
}
.modal[open]::backdrop{ opacity: 1; backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); }

.modal__close{
  position:absolute; top:1.25rem; right:1.25rem; z-index:10;
  width:42px; height:42px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(8,9,42,.35);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: background .3s ease, color .3s ease, border-color .3s ease, transform .35s ease;
}
.modal__close svg{ width:16px; height:16px }
.modal__close:hover{ background:#fff; color:var(--accent); border-color:#fff; transform:rotate(90deg) }

.modal__inner{
  height: 100%;
  display:grid;
  grid-template-columns: minmax(0, .85fr) minmax(0, 1.15fr);
  grid-template-rows: 1fr;
}

.modal__hero{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background: var(--accent-deep);
  min-height: 0;
  height: 100%;
}
.modal__hero img{
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%; object-fit:cover; object-position: center;
  filter: grayscale(.6) contrast(.95) brightness(.95);
}
.modal__hero::before{
  content:''; position:absolute; inset:0; z-index:1;
  background: linear-gradient(135deg, rgba(26,26,134,.55), rgba(14,14,92,.5) 50%, rgba(8,9,42,.6));
  mix-blend-mode: multiply;
  pointer-events:none;
}
.modal__hero::after{
  content:''; position:absolute; inset:0; z-index:2;
  background:
    radial-gradient(ellipse 65% 50% at 30% 25%, rgba(144,152,200,.4), transparent 55%),
    radial-gradient(ellipse 50% 50% at 80% 85%, rgba(26,26,134,.35), transparent 55%);
  mix-blend-mode: screen;
  pointer-events:none;
}
.modal__hero-meta{
  position:absolute; left:0; right:0; bottom:0;
  padding: clamp(1.6rem, 3vw, 2.5rem);
  z-index:3;
  color: #FAFAFE;
  background: linear-gradient(to top, rgba(8,9,42,.6), transparent);
  display:flex; flex-direction:column; gap:.45rem;
}
.modal__hero .section-tag{
  color: rgba(255,255,255,.65);
  letter-spacing:.32em;
  margin-bottom: .25rem;
}
.modal__hero h3{
  font-family: var(--display);
  font-weight:600;
  letter-spacing:-.02em;
  font-size: clamp(1.8rem, 3.4vw, 3rem);
  line-height: .95;
  margin: 0;
  text-transform:none;
  color: #fff;
  font-variation-settings: "opsz" 96;
}
.modal__style{
  margin: .35rem 0 0;
  font-size: 11px; letter-spacing: .28em;
  color: var(--accent-glow);
  text-transform:uppercase;
}

.modal__body{
  padding: clamp(1.1rem, 1.8vw, 1.6rem);
  display:flex; flex-direction:column;
  gap: clamp(.55rem, 1vw, .85rem);
  overflow: hidden;
}
.modal__intro{ display:flex; flex-direction:column; gap:.3rem; margin-bottom:.2rem }
.modal__intro .section-tag{ display:block; margin-bottom:.1rem }
.modal__intro h3{
  font-family: var(--display);
  font-weight:600;
  letter-spacing:-.015em;
  font-size: clamp(1.7rem, 3.2vw, 2.4rem);
  line-height: .95;
  margin: 0;
  text-transform:none;
  color: var(--ink);
  font-variation-settings: "opsz" 96;
}
.modal__style{ font-size:11px; letter-spacing:.24em; color:var(--accent); margin: .2rem 0 0 }
.modal__body::-webkit-scrollbar{ width:5px }
.modal__body::-webkit-scrollbar-thumb{ background:rgba(26,26,134,.35); border-radius:3px }

.modal__tags{ display:flex; flex-direction:column; gap:.7rem }
.modal__tags .section-tag{ display:block }
.modal__tags ul{
  list-style:none; padding:0; margin:0;
  display:flex; flex-wrap:wrap; gap:.45rem;
}
.modal__tags li{
  display:inline-block;
  padding: .4rem .85rem;
  border:1px solid var(--accent);
  border-radius: 999px;
  font-size: 10.5px;
  letter-spacing:.18em;
  color: var(--accent);
  text-transform:uppercase;
}

.modal__bio{
  margin: 0;
  font-size: 12.5px; letter-spacing:.015em;
  line-height: 1.6;
  color: var(--ink-soft);
  text-transform:none;
  max-width: 52ch;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.modal__links{
  display:flex; gap: clamp(.8rem, 1.6vw, 1.4rem); flex-wrap:wrap;
  margin: 0;
}
.modal__links .link-arrow{
  width: auto;
  min-width: 0;
  white-space: nowrap;
  flex: 0 0 auto;
}
.modal__links .link-arrow:hover{ gap: 1.05rem }

.modal__work{ display:flex; flex-direction:column; min-height:0; margin-top:.2rem }
.modal__work .section-tag{ display:block; margin-bottom: .55rem }
.modal__grid{
  list-style:none; padding:0; margin:0;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .45rem;
}
.modal__grid li{
  position:relative;
  aspect-ratio: 4 / 5;
  overflow:hidden;
  border-radius: 6px;
  cursor: pointer;
}

@media (max-width: 880px){
  .modal{
    width: 100vw; max-width: 100vw;
    height: 100vh; height: 100svh;
    max-height: 100vh; max-height: 100svh;
    border-radius: 0;
  }
  .modal__inner{
    grid-template-columns: 1fr;
    grid-template-rows: 38vh 1fr;
    max-height: 100svh; height: 100svh;
    overflow-y: auto;
  }
  .modal__hero{ aspect-ratio: auto; min-height: 0; height: 100% }
  .modal__hero-meta{ display: none }
  .modal__body{ overflow-y: visible; padding: 1.2rem var(--gut) 2rem }
  .modal__intro h3{ font-size: clamp(1.6rem, 8vw, 2.2rem) }
  .modal__bio{ font-size: 13px; -webkit-line-clamp: 4 }
  .modal__grid{ grid-template-columns: repeat(2, 1fr); gap: .35rem }
  .modal__close{ top: .8rem; right: .8rem }
}

.foot{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items:start;
  padding: 2rem var(--gut) 1.6rem;
  border-top:1px solid var(--line);
  font-size: 11px; letter-spacing:.22em;
}
.foot__credit{
  grid-column: 1 / -1;
  margin: 1.4rem 0 0;
  padding-top: 1.4rem;
  border-top: 1px solid var(--line-soft);
  text-align: center;
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 400;
}
.foot__credit a{
  color: var(--ink-soft);
  position: relative;
  transition: color .35s ease, letter-spacing .45s ease;
}
.foot__credit a:hover{ color: var(--accent); letter-spacing: .35em }
.foot__brand{
  font-family: var(--display);
  font-weight:600;
  letter-spacing:-.005em;
  margin:0 0 1rem;
  font-size:18px;
  text-transform:none;
}
.foot address{ font-style:normal; line-height:2; color:var(--ink-soft) }
.foot address a{
  display:inline-block;
  padding: .35rem 0;
  min-height: 32px;
}
.foot address a{
  display: inline-block;
  transition: color .3s ease, letter-spacing .45s ease;
}
.foot address a:hover{ color: var(--accent); letter-spacing: .25em; text-shadow: 0 0 10px rgba(26,26,134,.3) }
.foot__col--mid{
  position:relative;
  align-self:center;
  text-align:center;
  font-size:11px; letter-spacing:.22em;
  text-transform:none;
  color:var(--ink-soft);
}
.foot__blur{
  display:block;
  margin:0 auto .55rem;
  width:160px; height:60px;
  background:
    radial-gradient(ellipse 60% 70% at 35% 50%, rgba(31,31,140,.9), transparent 65%),
    radial-gradient(ellipse 60% 70% at 65% 50%, rgba(17,17,110,.85), transparent 65%);
  filter:blur(18px);
  border-radius:50%;
}
.foot__col--right{
  display:flex; gap: 2rem; justify-content:flex-end; align-items:center;
}
.foot__col--right a{ padding: .55rem 0; min-height: 32px; display:inline-flex; align-items:center }
.foot__col--right a{
  position:relative;
  transition: color .35s ease, letter-spacing .5s cubic-bezier(.22,.8,.36,1);
}
.foot__col--right a:hover{ color: var(--accent); letter-spacing: .26em; text-shadow: 0 0 12px rgba(26,26,134,.3) }

@media (max-width:780px){
  .foot{ grid-template-columns: 1fr; text-align:left}
  .foot__col--mid{ text-align:left}
  .foot__col--mid .foot__blur{margin:0 0 .5rem}
  .foot__col--right{ justify-content:flex-start}
}
