/* ════════════════════════════════════════════════
   YOURS GALLERY — editorial luxe · single artist
═══════════════════════════════════════════════════ */
:root{
  --aub-950:#07020F;
  --aub-900:#0E031B;
  --aub-800:#140422;
  --aub-700:#1E0831;
  --aub-600:#2C1148;
  --aub-500:#3F1C63;
  --gold:#D4AF58;
  --gold-hi:#F0D58A;
  --gold-lo:#8E6A2A;
  --cream:#F6EFE1;
  --cream-dim:#B9AE94;
  --line:rgba(246,239,225,.12);
  --line-strong:rgba(246,239,225,.22);

  --serif:'Cormorant Garamond', serif;
  --accent:'Italiana', serif;
  --sans:'Jost', system-ui, sans-serif;

  --max:1440px;
  --pad:clamp(20px,4.2vw,72px);

  --ease:cubic-bezier(.77,0,.18,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--aub-900);color:var(--cream);font-family:var(--sans);font-weight:300;-webkit-font-smoothing:antialiased}
body{
  overflow-x:hidden;min-height:100vh;
  background:
    radial-gradient(1200px 700px at 85% -10%, rgba(212,175,88,.10), transparent 60%),
    radial-gradient(900px 600px at -10% 30%, rgba(63,28,99,.55), transparent 60%),
    var(--aub-900);
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .09 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;opacity:.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
.sr-defs{position:absolute;width:0;height:0;overflow:hidden}
::selection{background:var(--gold);color:var(--aub-900)}

/* ════════ CUSTOM CURSOR ════════ */
.cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:9998;mix-blend-mode:difference}
.cursor__dot,.cursor__ring{position:absolute;top:0;left:0;border-radius:50%;transform:translate(-50%,-50%)}
.cursor__dot{width:6px;height:6px;background:var(--cream);transition:width .25s, height .25s, background .25s}
.cursor__ring{width:36px;height:36px;border:1px solid var(--cream);transition:width .3s var(--ease), height .3s var(--ease), border-color .3s, opacity .3s}
.cursor.is-hover .cursor__dot{width:2px;height:2px}
.cursor.is-hover .cursor__ring{width:64px;height:64px;border-color:var(--gold)}
@media (max-width:900px){.cursor{display:none}*{cursor:auto!important}}
body{cursor:none}
a,button{cursor:none}

/* ════════ LOADER ════════
   Note: core loader CSS is also inlined in <head> so it renders before
   this stylesheet loads — this is the extended styling. */
.loader.is-done{opacity:0;visibility:hidden;transition:opacity .9s var(--ease), visibility 0s .9s}
.loader__ring{position:absolute;animation:spin 8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loader__arc{stroke-dasharray:100;stroke-dashoffset:100;animation:draw 2.2s var(--ease) .1s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes mark{to{opacity:1;transform:scale(1)}}
@keyframes ltr{to{opacity:1;transform:translateY(0)}}

/* ════════ NAV ════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:26px var(--pad);transition:padding .4s, background .4s, backdrop-filter .4s;
}
.nav.is-scrolled{
  padding:16px var(--pad);
  background:rgba(14,3,27,.72);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.nav__brand{display:flex;align-items:center;gap:14px}
.nav__brand img{width:42px;height:42px;border-radius:10px;box-shadow:0 0 0 1px rgba(212,175,88,.4)}
.nav__brand span{line-height:1}
.nav__brand em{font-family:var(--accent);font-style:normal;font-size:22px;color:var(--gold);letter-spacing:.08em;display:block}
.nav__brand small{font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--cream-dim)}
.nav__links{display:flex;gap:38px}
.nav__links a{position:relative;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-dim);padding:6px 0;transition:color .3s;display:flex;align-items:baseline;gap:6px}
.nav__links a i{font-style:normal;font-size:9px;color:var(--gold);opacity:.6}
.nav__links a:hover{color:var(--gold)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .4s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__cta{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border:1px solid var(--line-strong);border-radius:999px;transition:.35s;color:var(--cream)}
.nav__cta-txt{font-size:11px;letter-spacing:.26em;text-transform:uppercase}
.nav__cta-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;box-shadow:0 0 12px var(--gold);animation:blink 2s infinite}
@keyframes blink{50%{opacity:.3}}
.nav__cta:hover{border-color:var(--gold);background:var(--gold);color:var(--aub-900)}
.nav__cta:hover .nav__cta-dot{background:var(--aub-900);box-shadow:none}
@media (max-width:900px){.nav__links{display:none}}

/* ════════ BUTTONS ════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  padding:17px 30px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  border-radius:999px;transition:.5s var(--ease);position:relative;overflow:hidden;
}
.btn--gold{
  background:linear-gradient(180deg, var(--gold-hi), var(--gold) 45%, var(--gold-lo));
  color:var(--aub-900);font-weight:500;
  box-shadow:0 18px 50px -10px rgba(212,175,88,.5), inset 0 1px 0 rgba(255,255,255,.4);
}
.btn--gold::before{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg, #fff, var(--gold-hi));
  opacity:0;transition:opacity .5s;
}
.btn--gold>*{position:relative;z-index:1}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 26px 70px -10px rgba(212,175,88,.65)}
.btn--gold:hover::before{opacity:.3}
.btn--ghost{border:1px solid var(--line-strong);color:var(--cream)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn--lg{padding:22px 42px;font-size:12px}

/* ════════ REVEAL ════════ */
[data-reveal]{opacity:0;transform:translateY(40px);transition:opacity 1.1s var(--ease), transform 1.1s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}
[data-split]{display:inline-block;overflow:hidden;vertical-align:top}
[data-split] .char{
  display:inline-block;transform:translateY(110%);
  transition:transform 1.2s var(--ease);
  transition-delay:calc(var(--i,0)*.035s);
}
[data-split].is-in .char{transform:translateY(0)}

/* ════════ HERO ════════ */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;padding:0 var(--pad) 60px;
  overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  filter:saturate(.8) brightness(.55) contrast(1.05);
  transform:scale(1.08);
  animation:kenburns 18s var(--ease) forwards;
}
@keyframes kenburns{to{transform:scale(1)}}
.hero__bg-veil{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(14,3,27,.55) 0%, rgba(14,3,27,.2) 30%, rgba(14,3,27,.85) 100%),
    radial-gradient(1200px 700px at 50% 110%, rgba(212,175,88,.08), transparent 60%);
}
.hero__side{position:absolute;top:0;bottom:0;width:50px;display:grid;place-items:center;z-index:3}
.hero__side--l{left:var(--pad)}
.hero__side--r{right:var(--pad)}
.hero__side-rot{
  writing-mode:vertical-rl;transform:rotate(180deg);
  font-size:10px;letter-spacing:.45em;text-transform:uppercase;color:var(--cream-dim);
  opacity:0;animation:fadeIn 1s 1.8s forwards;
}
.hero__side--r .hero__side-rot{transform:rotate(0)}
@keyframes fadeIn{to{opacity:1}}
@media (max-width:820px){.hero__side{display:none}}

.hero__wrap{position:relative;z-index:2;max-width:var(--max);width:100%;margin:0 auto}

.hero__eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:10px;letter-spacing:.38em;text-transform:uppercase;color:var(--gold);
  margin-bottom:40px;
}
.hero__eyebrow svg{color:var(--gold)}

.hero__title{
  font-family:var(--serif);font-weight:300;
  line-height:.92;letter-spacing:-.025em;color:var(--cream);
  margin-bottom:70px;
}
.hero__row{display:block;overflow:hidden}
.hero__row--center{padding-left:10vw}
.hero__row--small{display:flex;align-items:center;gap:.4em;margin-top:.1em;padding-left:3vw}
.hero__word{
  display:inline-block;font-size:clamp(72px,13vw,220px);
  position:relative;
}
.hero__word--italic{font-style:italic;color:var(--gold);font-family:var(--serif);font-weight:300}
.hero__row--small .hero__word{font-size:clamp(48px,8vw,140px)}
.hero__sep{display:inline-block;color:var(--gold);margin:0 .25em;transform:translateY(-.15em);font-size:clamp(40px,6vw,100px);line-height:1;font-family:var(--serif);font-weight:300}

.hero__footer{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;
  padding-top:40px;border-top:1px solid var(--line);
  max-width:1100px;
}
.hero__lead{font-size:15px;line-height:1.7;color:var(--cream-dim);max-width:420px}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-end}
@media (max-width:820px){
  .hero__footer{grid-template-columns:1fr;gap:30px}
  .hero__actions{justify-content:flex-start}
  .hero__row--center{padding-left:0}
  .hero__row--small{padding-left:0}
}

.hero__scroll{
  position:absolute;right:calc(var(--pad) + 10px);bottom:40px;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--cream-dim);
  opacity:0;animation:fadeIn 1s 2s forwards;transition:color .3s;
}
.hero__scroll:hover{color:var(--gold)}
.hero__scroll span{writing-mode:vertical-rl;transform:rotate(180deg)}
.hero__scroll-line{width:1px;height:70px;background:var(--gold);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;inset:0;background:var(--aub-900);animation:slide 2s ease-in-out infinite}
@keyframes slide{0%{transform:translateY(-100%)}50%{transform:translateY(0)}100%{transform:translateY(100%)}}
@media (max-width:820px){.hero__scroll{display:none}}

/* ════════ MARQUEE ════════ */
.marquee{
  position:relative;padding:40px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;background:linear-gradient(180deg, rgba(14,3,27,.5), rgba(20,4,34,.9));
}
.marquee__track{display:flex;gap:40px;white-space:nowrap;animation:marquee 40s linear infinite;will-change:transform}
.marquee__track span{
  font-family:var(--serif);font-style:italic;font-size:clamp(52px,8vw,120px);
  color:transparent;-webkit-text-stroke:1px var(--gold);font-weight:300;
}
.marquee__track i{font-style:normal;font-size:clamp(36px,6vw,80px);color:var(--gold);display:grid;place-items:center}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ════════ STUDIO ════════ */
.studio{max-width:var(--max);margin:0 auto;padding:140px var(--pad) 100px}
.studio__num,.works__num,.process__num,.commission__num{
  font-family:var(--accent);font-size:11px;letter-spacing:.4em;color:var(--gold);text-transform:uppercase;margin-bottom:40px;display:block;
}
.studio__grid{display:grid;grid-template-columns:1.15fr 1fr;gap:90px;align-items:center}
.studio h2{font-family:var(--serif);font-weight:300;font-size:clamp(44px,6.2vw,100px);line-height:.95;letter-spacing:-.02em;margin-bottom:36px}
.studio h2 em{font-style:italic;color:var(--gold)}
.studio h2 i{font-family:var(--serif);font-style:italic;color:var(--cream-dim)}
.studio__text p{font-size:16px;line-height:1.85;color:var(--cream-dim);margin-bottom:22px;max-width:500px}
.studio__facts{display:flex;gap:50px;margin-top:40px;padding-top:30px;border-top:1px solid var(--line);flex-wrap:wrap}
.studio__facts div{display:flex;flex-direction:column}
.studio__facts b{font-family:var(--serif);font-weight:400;font-size:34px;color:var(--gold);line-height:1}
.studio__facts span{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim);margin-top:8px}

/* ════════ SHOWCASE (Nuestro trabajo) ════════ */
.showcase{position:relative;padding:120px 0 140px;overflow:hidden}
.showcase__head{max-width:var(--max);margin:0 auto 70px;padding:0 var(--pad);max-width:820px}
.showcase__head h2{font-family:var(--serif);font-weight:300;font-size:clamp(48px,6.5vw,110px);line-height:.92;letter-spacing:-.02em;margin:0 0 30px}
.showcase__head h2 em{font-style:italic;color:var(--gold)}
.showcase__head p{color:var(--cream-dim);font-size:16px;line-height:1.75;max-width:560px;margin-bottom:30px}
.showcase__hint{display:inline-flex;align-items:center;gap:14px;font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--gold)}
.showcase__track{
  display:flex;gap:24px;overflow-x:auto;overflow-y:hidden;
  padding:20px var(--pad) 50px;scroll-snap-type:x proximity;
  scroll-behavior:auto;
  scrollbar-width:thin;scrollbar-color:var(--gold) transparent;
  -webkit-overflow-scrolling:touch;cursor:grab;
  user-select:none;-webkit-user-select:none;
}
.showcase__track img,
.showcase__track .slide{
  -webkit-user-drag:none;user-drag:none;
}
.showcase__track img{pointer-events:none}
.showcase__track.is-dragging{cursor:grabbing;scroll-snap-type:none}
.showcase__track::-webkit-scrollbar{height:4px}
.showcase__track::-webkit-scrollbar-track{background:var(--line)}
.showcase__track::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}
.slide{
  position:relative;flex:0 0 auto;
  width:clamp(300px, 42vw, 640px);height:72vh;max-height:820px;min-height:520px;
  overflow:hidden;scroll-snap-align:start;
  box-shadow:0 50px 120px -20px rgba(0,0,0,.7);
}
.slide:first-child{margin-left:0}
.slide img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.85) brightness(.88);
  transition:transform 1.4s var(--ease), filter .8s;
}
.slide:hover img{transform:scale(1.05);filter:saturate(1.05) brightness(1)}
.slide::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, transparent 50%, rgba(7,2,15,.85));
}
.slide__num{
  position:absolute;top:20px;right:24px;z-index:2;
  font-family:var(--accent);font-size:13px;letter-spacing:.3em;color:var(--cream);
}
.slide figcaption{
  position:absolute;left:0;right:0;bottom:0;z-index:2;padding:26px 28px;
}
.slide__tag{
  display:inline-block;padding:6px 12px;margin-bottom:12px;
  font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
  border:1px solid rgba(212,175,88,.45);background:rgba(7,2,15,.5);backdrop-filter:blur(6px);
}
.slide figcaption h3{font-family:var(--serif);font-size:clamp(24px,2.6vw,38px);font-weight:400;line-height:1.1;letter-spacing:-.01em}

@media (max-width:820px){
  .slide{width:78vw;height:62vh;min-height:420px}
  .showcase{padding:80px 0 100px}
}
.studio__img{position:relative;aspect-ratio:4/5;overflow:hidden;box-shadow:0 50px 120px -20px rgba(0,0,0,.7)}
.studio__img img{width:100%;height:100%;object-fit:cover;transition:transform 8s var(--ease)}
.studio__img:hover img{transform:scale(1.08)}
.studio__img figcaption{
  position:absolute;left:0;bottom:0;right:0;padding:18px 20px;
  background:linear-gradient(0deg, rgba(14,3,27,.9), transparent);
  font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--cream-dim);
}
.studio__img figcaption span{color:var(--gold);margin-right:8px}
@media (max-width:900px){.studio__grid{grid-template-columns:1fr;gap:50px}}

/* ════════ WORKS ════════ */
.works{max-width:var(--max);margin:0 auto;padding:80px var(--pad) 140px}
.works__head{max-width:760px;margin-bottom:60px}
.works__head h2{font-family:var(--serif);font-size:clamp(48px,6.8vw,120px);font-weight:300;line-height:.92;letter-spacing:-.02em;margin-bottom:30px}
.works__head h2 em{font-style:italic;color:var(--gold)}
.works__head p{color:var(--cream-dim);font-size:16px;line-height:1.75;max-width:520px}
.works__filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:60px}
.chip{
  padding:14px 24px;border:1px solid var(--line-strong);border-radius:999px;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--cream-dim);
  transition:.4s var(--ease);display:inline-flex;align-items:center;gap:8px;
}
.chip em{color:var(--gold);font-style:normal}
.chip:hover{border-color:var(--gold);color:var(--gold)}
.chip.is-active{background:var(--gold);color:var(--aub-900);border-color:var(--gold)}
.chip.is-active em{color:var(--aub-900)}

.works__grid{display:grid;grid-template-columns:repeat(12,1fr);gap:40px 30px}
.card{
  grid-column:span 4;display:flex;flex-direction:column;gap:22px;
  opacity:0;transform:translateY(60px);transition:opacity 1s var(--ease), transform 1s var(--ease);
  transition-delay:calc(var(--i,0)*.08s);position:relative;
}
.card.is-in{opacity:1;transform:none}
.card:nth-child(6n+1){grid-column:span 5;margin-top:0}
.card:nth-child(6n+2){grid-column:span 4;margin-top:80px}
.card:nth-child(6n+3){grid-column:span 3;margin-top:-30px}
.card:nth-child(6n+4){grid-column:span 4}
.card:nth-child(6n+5){grid-column:span 3;margin-top:60px}
.card:nth-child(6n+6){grid-column:span 5;margin-top:-20px}
@media (max-width:900px){.card,.card:nth-child(n){grid-column:span 6;margin-top:0}}
@media (max-width:600px){.card,.card:nth-child(n){grid-column:span 12}}

.card__frame{
  position:relative;overflow:hidden;aspect-ratio:4/5;background:var(--aub-700);
}
.card__frame img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s var(--ease), filter .8s;
  filter:saturate(.85) brightness(.9);
  clip-path:inset(0 0 0 0);
}
.card:hover .card__frame img{transform:scale(1.08);filter:saturate(1.05) brightness(1)}
.card__frame::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg, transparent 55%, rgba(14,3,27,.85));
  opacity:0;transition:opacity .6s;
}
.card:hover .card__frame::before{opacity:1}
.card__frame::after{
  content:"Ver obra →";position:absolute;left:24px;bottom:24px;z-index:3;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
  opacity:0;transform:translateY(10px);transition:.5s var(--ease);
}
.card:hover .card__frame::after{opacity:1;transform:translateY(0)}
.card__tag{
  position:absolute;top:16px;left:16px;z-index:3;padding:7px 12px;
  background:rgba(14,3,27,.6);backdrop-filter:blur(8px);
  font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
  border:1px solid rgba(212,175,88,.35);
}
.card__num{
  position:absolute;top:16px;right:16px;z-index:3;
  font-family:var(--accent);font-size:12px;color:var(--cream);letter-spacing:.2em;
}
.card__meta h3{font-family:var(--serif);font-size:30px;font-weight:400;letter-spacing:-.01em;margin-bottom:10px;line-height:1.05}
.card__row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;color:var(--cream-dim);font-size:12px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.card__row b{color:var(--gold);font-weight:500;font-family:var(--serif);font-size:16px}
.card__row span{letter-spacing:.08em}

/* ════════ PROCESS ════════ */
.process{max-width:var(--max);margin:0 auto;padding:120px var(--pad)}
.process__title{font-family:var(--serif);font-size:clamp(48px,6.5vw,110px);font-weight:300;line-height:.95;letter-spacing:-.02em;margin-bottom:80px}
.process__title em{font-style:italic;color:var(--gold)}
.process__list{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:0;counter-reset:p}
.process__list li{padding:44px 36px;border-top:1px solid var(--line);position:relative}
.process__list li:not(:last-child){border-right:1px solid var(--line)}
.process__list li:first-child{padding-left:0}
.process__list li:last-child{padding-right:0}
.process__list li::before{
  content:"";position:absolute;top:-1px;left:0;height:1px;width:0;background:var(--gold);transition:width 1.2s var(--ease);
}
.process__list li.is-in::before{width:100%}
.process__list b{font-family:var(--accent);font-size:14px;color:var(--gold);letter-spacing:.2em;display:block;margin-bottom:20px}
.process__list h3{font-family:var(--serif);font-size:32px;font-weight:400;margin-bottom:14px;letter-spacing:-.01em}
.process__list p{font-size:14px;line-height:1.7;color:var(--cream-dim)}
@media (max-width:900px){
  .process__list{grid-template-columns:1fr}
  .process__list li:not(:last-child){border-right:0;padding-right:0}
}

/* ════════ COMMISSION ════════ */
.commission{max-width:var(--max);margin:0 auto;padding:80px var(--pad) 140px;display:grid;grid-template-columns:1fr 1.25fr;gap:90px;align-items:start}
.commission__num{grid-column:1/-1}
.commission__head h2{font-family:var(--serif);font-size:clamp(44px,5.8vw,96px);font-weight:300;line-height:.95;letter-spacing:-.02em;margin-bottom:28px}
.commission__head h2 em{font-style:italic;color:var(--gold)}
.commission__head p{color:var(--cream-dim);line-height:1.8;max-width:420px;font-size:15px}

.commission__card{
  position:relative;min-height:560px;padding:56px;overflow:hidden;
  background:
    linear-gradient(180deg, rgba(63,28,99,.35), rgba(20,4,34,.7));
  border:1px solid var(--line);
  border-radius:2px;
}
.commission__glow{
  position:absolute;inset:-2px;pointer-events:none;
  background:conic-gradient(from 0deg, transparent, rgba(212,175,88,.15), transparent 30%);
  animation:spin 10s linear infinite;opacity:.6;
}
.commission__card::after{
  content:"";position:absolute;inset:1px;background:
    radial-gradient(600px 400px at 100% 0%, rgba(212,175,88,.08), transparent 60%),
    linear-gradient(180deg, rgba(63,28,99,.35), rgba(20,4,34,.85));
  pointer-events:none;
}
.step{
  position:relative;z-index:2;opacity:0;pointer-events:none;
  transform:translateX(30px);transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.step.is-active{opacity:1;pointer-events:auto;transform:none}
.step:not(.is-active){position:absolute;inset:56px}
.step__label{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:30px;display:flex;align-items:baseline;gap:10px}
.step__label b{color:var(--gold);font-weight:400}
.step__label i{color:var(--gold);font-style:italic;font-family:var(--serif);font-size:15px;letter-spacing:0;text-transform:none;margin-left:8px}
.step__opts{display:flex;flex-direction:column;gap:14px}
.opt{
  display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:4px 22px;
  align-items:center;padding:26px 30px;text-align:left;
  border:1px solid var(--line);background:rgba(14,3,27,.35);transition:.5s var(--ease);
  position:relative;overflow:hidden;
}
.opt::before{
  content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(212,175,88,.12), transparent);
  transform:translateX(-100%);transition:transform .6s var(--ease);
}
.opt:hover::before{transform:translateX(0)}
.opt:hover{border-color:var(--gold);transform:translateX(6px)}
.opt>*{position:relative;z-index:1}
.opt__num{grid-row:1/3;font-family:var(--accent);font-size:34px;color:var(--gold);min-width:30px}
.opt__name{font-family:var(--serif);font-size:28px;letter-spacing:-.01em;line-height:1}
.opt__desc{grid-column:2;font-size:13px;color:var(--cream-dim);line-height:1.5}
.opt__arrow{grid-row:1/3;color:var(--gold);transition:transform .4s var(--ease)}
.opt:hover .opt__arrow{transform:translateX(8px)}

.step__back{
  display:inline-flex;align-items:center;gap:10px;
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim);
  margin-bottom:24px;transition:.3s;
}
.step__back:hover{color:var(--gold)}

.form__fields{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form__fields .full{grid-column:1/-1}
.form label{display:flex;flex-direction:column;gap:10px}
.form label span{font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim)}
.form input,.form select,.form textarea{
  background:transparent;border:0;border-bottom:1px solid var(--line-strong);
  color:var(--cream);padding:12px 0;font-family:var(--sans);font-size:15px;
  transition:.3s;border-radius:0;font-weight:300;
}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-bottom-color:var(--gold)}
.form input::placeholder,.form textarea::placeholder{color:rgba(246,239,225,.3)}
.form select{color:var(--cream-dim)}
.form textarea{resize:vertical;min-height:80px}
.form__hint{grid-column:1/-1;color:var(--cream-dim);font-size:10px;font-style:italic;text-align:center;opacity:.6;letter-spacing:.05em}
.form__done{text-align:center;padding:30px 0}
.form__check{
  width:70px;height:70px;border-radius:50%;margin:0 auto 24px;
  display:grid;place-items:center;color:var(--aub-900);
  background:linear-gradient(180deg, var(--gold-hi), var(--gold));
  box-shadow:0 0 0 10px rgba(212,175,88,.12), 0 20px 50px -10px rgba(212,175,88,.5);
  animation:pop .6s var(--ease);
}
@keyframes pop{from{transform:scale(.5);opacity:0}}
.form__done h3{font-family:var(--serif);font-size:36px;font-weight:400;margin-bottom:14px}
.form__done p{color:var(--cream-dim);margin-bottom:28px;max-width:340px;margin-left:auto;margin-right:auto}
.full{grid-column:1/-1}
@media (max-width:900px){
  .commission{grid-template-columns:1fr;gap:50px;padding:80px var(--pad)}
  .commission__card{padding:32px}
  .step:not(.is-active){inset:32px}
  .form__fields{grid-template-columns:1fr}
}

/* ════════ FINALE ════════ */
.finale{
  position:relative;text-align:center;padding:160px var(--pad);overflow:hidden;
}
.finale__bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(600px 400px at 50% 50%, rgba(212,175,88,.16), transparent 60%),
    linear-gradient(180deg, transparent, rgba(63,28,99,.5));
}
.finale__bg::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(circle at 50% 50%, black, transparent 70%);
  -webkit-mask-image:radial-gradient(circle at 50% 50%, black, transparent 70%);
  opacity:.5;
}
.finale h2{position:relative;font-family:var(--serif);font-size:clamp(48px,7vw,130px);font-weight:300;line-height:1;letter-spacing:-.02em;margin-bottom:60px}
.finale h2 em{font-style:italic;color:var(--gold)}
.finale .btn{position:relative}

/* ════════ FOOTER ════════ */
.foot{max-width:var(--max);margin:0 auto;padding:80px var(--pad) 30px;border-top:1px solid var(--line);position:relative}
.foot__top{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap;padding-bottom:60px}
.foot__brand{display:flex;align-items:center;gap:16px}
.foot__brand img{width:56px;height:56px;border-radius:12px;box-shadow:0 0 0 1px rgba(212,175,88,.4)}
.foot__brand em{font-family:var(--accent);font-style:normal;font-size:26px;color:var(--gold);letter-spacing:.06em;display:block}
.foot__brand small{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--cream-dim)}
.foot__links{display:flex;gap:30px;flex-wrap:wrap}
.foot__links a{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--cream-dim);transition:color .3s}
.foot__links a:hover{color:var(--gold)}
.foot__huge{
  font-family:var(--serif);font-weight:400;font-size:clamp(100px,18vw,300px);line-height:.85;
  color:rgba(212,175,88,.18);
  text-align:center;letter-spacing:-.02em;
  padding:20px 0 10px;pointer-events:none;
}
.foot__huge i{font-style:italic;color:rgba(212,175,88,.28)}
.foot__legal{display:flex;justify-content:space-between;padding-top:30px;border-top:1px solid var(--line);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim);flex-wrap:wrap;gap:14px}

/* ════════ FAB ════════ */
.fab{
  position:fixed;right:26px;bottom:26px;z-index:90;
  width:62px;height:62px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(180deg, var(--gold-hi), var(--gold));color:var(--aub-900);
  box-shadow:0 20px 50px rgba(212,175,88,.4), 0 0 0 1px rgba(212,175,88,.4);
  transition:.4s var(--ease);
}
.fab::before{
  content:"";position:absolute;inset:0;border-radius:50%;
  border:1px solid var(--gold);animation:ripple 2.4s ease-out infinite;
}
@keyframes ripple{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.8);opacity:0}}
.fab:hover{transform:scale(1.08) rotate(-6deg)}

/* ════════ PRODUCT PAGE ════════ */
.is-product{padding-top:110px}
.product{max-width:var(--max);margin:0 auto;padding:40px var(--pad) 120px}
.product__back{display:inline-flex;align-items:center;gap:8px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim);transition:color .3s}
.product__back:hover{color:var(--gold)}
.product__stage{display:grid;grid-template-columns:1.3fr 1fr;gap:80px;margin-top:50px;align-items:start}
.product__media{position:relative;overflow:hidden;box-shadow:0 50px 120px -20px rgba(0,0,0,.7)}
.product__media img{width:100%;height:auto;object-fit:cover;aspect-ratio:4/5}
.product__tag{
  position:absolute;top:20px;left:20px;padding:8px 14px;
  background:rgba(14,3,27,.7);backdrop-filter:blur(6px);
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
  border:1px solid rgba(212,175,88,.4);z-index:2;
}
.product__panel{position:sticky;top:130px;align-self:start}
.product__num{font-family:var(--accent);font-size:11px;letter-spacing:.4em;color:var(--gold);text-transform:uppercase;margin-bottom:22px}
.product__title{font-family:var(--serif);font-size:clamp(44px,5.8vw,96px);font-weight:300;line-height:.95;letter-spacing:-.02em;margin-bottom:24px}
.product__price{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--gold);margin-bottom:30px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.product__desc{color:var(--cream-dim);line-height:1.85;font-size:15px;margin-bottom:34px}
.product__facts{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:40px}
.product__facts dt{font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:6px}
.product__facts dd{font-family:var(--serif);font-size:18px;color:var(--cream)}
.product__buy{width:100%}
.product__hint{display:block;margin-top:16px;text-align:center;color:var(--cream-dim);font-size:10px;font-style:italic;letter-spacing:.05em}
.product__story{max-width:720px;margin:120px auto;text-align:center;padding:60px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.product__story p{font-family:var(--serif);font-size:26px;font-style:italic;line-height:1.55;color:var(--cream)}
.product__more h2{font-family:var(--serif);font-size:clamp(32px,4vw,60px);font-weight:300;text-align:center;margin-bottom:60px}
.product__more h2 em{font-style:italic;color:var(--gold)}
.product__more-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}
.product__more-list li{border-bottom:1px solid var(--line)}
.more-row{
  display:grid;
  grid-template-columns:54px 120px 1fr auto 60px;
  align-items:center;gap:28px;
  padding:26px 18px;
  color:var(--cream);text-decoration:none;
  position:relative;transition:background .5s ease,padding .5s ease;
}
.more-row::before{
  content:"";position:absolute;left:0;top:0;height:100%;width:0;
  background:linear-gradient(90deg,rgba(201,162,90,.10),transparent 70%);
  transition:width .6s cubic-bezier(.2,.7,.2,1);pointer-events:none;
}
.more-row:hover{padding-left:34px}
.more-row:hover::before{width:100%}
.more-row__idx{
  font-family:var(--accent);font-size:22px;color:var(--gold);
  letter-spacing:.08em;
}
.more-row__thumb{
  display:block;width:120px;height:88px;overflow:hidden;
  border:1px solid var(--line);background:var(--aub-900);
}
.more-row__thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s cubic-bezier(.2,.7,.2,1),filter .6s ease;
  filter:saturate(.9);
}
.more-row:hover .more-row__thumb img{transform:scale(1.08);filter:saturate(1.05)}
.more-row__body{display:flex;flex-direction:column;gap:6px;min-width:0}
.more-row__tag{
  font-size:9px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--cream-dim);
}
.more-row__name{
  font-family:var(--serif);font-size:clamp(22px,2.2vw,30px);
  font-weight:300;line-height:1.15;
}
.more-row:hover .more-row__name{font-style:italic;color:var(--gold-hi)}
.more-row__dim{font-size:12px;color:var(--cream-dim);letter-spacing:.04em}
.more-row__price{
  font-family:var(--serif);font-style:italic;font-size:20px;
  color:var(--gold);white-space:nowrap;
}
.more-row__arrow{
  display:flex;justify-content:flex-end;color:var(--cream-dim);
  transition:transform .5s cubic-bezier(.2,.7,.2,1),color .4s ease;
}
.more-row:hover .more-row__arrow{transform:translateX(8px);color:var(--gold)}
@media (max-width:900px){
  .product__stage{grid-template-columns:1fr;gap:40px}
  .product__panel{position:static}
  .more-row{
    grid-template-columns:40px 88px 1fr;
    grid-template-areas:
      "idx thumb body"
      ".   .     price";
    gap:18px;padding:22px 10px;
  }
  .more-row__idx{grid-area:idx;font-size:18px}
  .more-row__thumb{grid-area:thumb;width:88px;height:66px}
  .more-row__body{grid-area:body}
  .more-row__price{grid-area:price;justify-self:start;margin-top:4px;font-size:17px}
  .more-row__arrow{display:none}
  .more-row:hover{padding-left:16px}
}

/* ════════════════════════════════════════════
   RESPONSIVE HARDENING
   ════════════════════════════════════════════ */

/* always: prevent the huge footer wordmark from bleeding */
.foot{overflow:hidden}

/* ── tablet / small laptop ── */
@media (max-width:900px){
  .nav{padding:16px var(--pad)}
  .nav.is-scrolled{padding:12px var(--pad)}
  .nav__brand img{width:38px;height:38px}
  .nav__brand em{font-size:20px}
  .nav__cta{padding:11px 18px}
  .nav__cta-txt{font-size:10px;letter-spacing:.2em}

  .hero{padding:130px var(--pad) 50px;min-height:auto}
  .hero__eyebrow{margin-bottom:28px;padding:8px 16px}
  .hero__title{margin-bottom:50px}
  .hero__footer{padding-top:28px}
  .hero__side{display:none}

  .marquee{padding:26px 0}

  .studio{padding:80px var(--pad) 60px}
  .studio__num,.works__num,.process__num,.commission__num,.showcase__num{margin-bottom:28px}
  .studio__facts{gap:30px 40px;margin-top:32px;padding-top:26px}
  .studio__facts b{font-size:26px}

  .showcase{padding:70px 0 90px}
  .showcase__head{margin-bottom:44px}

  .works{padding:40px var(--pad) 80px}
  .works__head{margin-bottom:40px}
  .works__filters{margin-bottom:40px;gap:8px}
  .chip{padding:11px 18px;font-size:9px;letter-spacing:.22em}
  .works__grid{gap:28px 20px}

  .process{padding:80px var(--pad)}
  .process__title{margin-bottom:40px}
  .process__list li,
  .process__list li:first-child,
  .process__list li:last-child{padding:32px 0;border-right:0!important}
  .process__list li:first-child{padding-top:44px}

  .commission{padding:60px var(--pad) 80px}
  .commission__card{padding:30px;min-height:0}
  .commission__head h2{margin-bottom:22px}
  .opt{padding:20px 22px;gap:4px 16px}
  .opt__name{font-size:22px}
  .opt__desc{font-size:12px}
  .opt__num{font-size:26px}

  .finale{padding:100px var(--pad)}
  .finale h2{margin-bottom:44px}

  .foot{padding:60px var(--pad) 24px}
  .foot__top{padding-bottom:40px;gap:28px}
  .foot__links{gap:14px 22px}
  .foot__links a{font-size:10px;letter-spacing:.22em}
  .foot__huge{font-size:clamp(60px,18vw,200px);letter-spacing:-.03em}
  .foot__legal{font-size:9px;letter-spacing:.22em;padding-top:22px}

  .fab{right:18px;bottom:18px;width:54px;height:54px}
  .fab svg{width:22px;height:22px}

  .loader__name{font-size:11px;letter-spacing:.38em}
  .loader__mark{width:68px;height:68px}
  .loader__tag{bottom:calc(50% - 180px);font-size:8px;letter-spacing:.3em}
}

/* ── phones ── */
@media (max-width:560px){
  :root{--pad:18px}

  .nav__cta-txt{display:none}
  .nav__cta{padding:10px;width:40px;height:40px;justify-content:center}
  .nav__cta-dot{margin:0}

  .hero{padding:120px 18px 40px}
  .hero__eyebrow{font-size:9px;letter-spacing:.3em}
  .hero__row--center{padding-left:6%}
  .hero__row--small{padding-left:0;gap:.3em;flex-wrap:wrap}
  .hero__word{font-size:clamp(64px,18vw,120px)}
  .hero__row--small .hero__word{font-size:clamp(40px,11vw,80px)}
  .hero__sep{font-size:clamp(32px,9vw,64px);margin:0 .15em}
  .hero__lead{font-size:14px;line-height:1.65}
  .hero__actions{gap:10px}
  .hero__actions .btn{padding:14px 22px;font-size:10px;letter-spacing:.22em}
  .hero__scroll{right:14px;bottom:24px}

  .marquee{padding:20px 0}

  .studio h2,
  .works__head h2,
  .showcase__head h2,
  .process__title,
  .commission__head h2{font-size:clamp(36px,10.5vw,64px)!important;line-height:.98}
  .studio__text p,
  .works__head p,
  .showcase__head p,
  .commission__head p{font-size:15px;line-height:1.7}

  .studio__facts{gap:20px 36px}
  .studio__facts b{font-size:22px}

  .card__meta h3{font-size:24px;line-height:1.1}
  .card__row{font-size:11px}
  .card__row b{font-size:14px}

  .slide figcaption{padding:22px 20px}
  .slide__tag{margin-bottom:10px}

  .commission__card{padding:22px}
  .step:not(.is-active){inset:22px}
  .opt{padding:18px 18px;grid-template-columns:auto 1fr}
  .opt__arrow{display:none}
  .opt__name{font-size:20px}
  .opt__desc{font-size:11px;line-height:1.5}
  .opt__num{font-size:22px;min-width:22px}

  .form__fields{gap:18px}
  .form__done h3{font-size:26px}
  .form__done p{font-size:14px}

  .finale h2{font-size:clamp(38px,11vw,72px)!important;line-height:1.05}

  .foot__brand img{width:48px;height:48px}
  .foot__brand em{font-size:22px}
  .foot__top{flex-direction:column;align-items:flex-start}
  .foot__legal{flex-direction:column;gap:10px;align-items:flex-start;text-align:left}
  .foot__huge{font-size:clamp(48px,19vw,140px)}

  .loader__name{font-size:10px;letter-spacing:.3em}

  .product{padding:20px var(--pad) 60px}
  .is-product{padding-top:92px}
  .product__title{font-size:clamp(40px,11vw,64px)!important;line-height:.95}
  .product__price{font-size:24px}
  .product__facts{grid-template-columns:1fr 1fr;gap:18px}
  .product__story{margin:70px auto;padding:40px 0}
  .product__story p{font-size:20px;line-height:1.55}
}
