/* ================== RESET ================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  line-height:1.55;
  min-height:100svh;
  touch-action:pan-y;
  overscroll-behavior-y:none;
}
body.is-locked{overflow:hidden;touch-action:none}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
::selection{background:var(--gold);color:#0b0b0d}

.skip-link{
  position:absolute;left:-9999px;top:0;
  background:var(--gold);color:#0b0b0d;
  padding:10px 16px;font-size:13px;font-weight:600;z-index:99999;letter-spacing:.06em;
}
.skip-link:focus{left:8px;top:8px}

/* ================== TOKENS ================== */
:root{
  --bg:#0a0807;
  --bg-2:#120e0b;
  --bg-3:#1a1410;
  --ink:#f0e6d6;
  --ink-dim:rgba(240,230,214,.62);
  --ink-faint:rgba(240,230,214,.18);
  --gold:#d4a36a;
  --gold-2:#a8743f;
  --gold-soft:#ecc890;
  --steel:#9aa3ab;
  --line:rgba(240,230,214,.1);
  --line-strong:rgba(240,230,214,.18);
  --serif:'Cormorant Garamond',Georgia,serif;
  --display:'Cinzel',Georgia,serif;
  --shadow-1:0 30px 80px -30px rgba(0,0,0,.6);
  --shadow-gold:0 24px 70px -20px rgba(201,166,97,.18);
}

.container{max-width:1280px;margin:0 auto;padding:0 32px}
@media (max-width:720px){.container{padding:0 20px}}

/* ================== ATMOSPHERIC SECTION BACKDROP ================== */
/* Тонкий «парящий» фон-снимок Patrimony, общий для главных секций.
   background-attachment:fixed создаёт паралакс-эффект: один и тот же кадр
   проступает в каждой секции при скролле, объединяя страницу. */
.manifesto,.collections,.pieces,.atelier,
.concierge,.reviews,.boutique,.contact{
  position:relative;isolation:isolate;
}
.manifesto::after,.collections::after,.pieces::after,.atelier::after,
.concierge::after,.reviews::after,.boutique::after,.contact::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url("assets/watches/patrimony-hero.webp");
  background-size:cover;background-position:center;
  background-attachment:fixed;
  opacity:.07;
  filter:saturate(.55) brightness(.85);
  mix-blend-mode:screen;
}
.manifesto > *,.collections > *,.pieces > *,.atelier > *,
.concierge > *,.reviews > *,.boutique > *,.contact > *{
  position:relative;z-index:1;
}
@media (max-width:980px){
  .manifesto::after,.collections::after,.pieces::after,.atelier::after,
  .concierge::after,.reviews::after,.boutique::after,.contact::after{
    background-attachment:scroll;
    opacity:.05;
  }
}
@media (prefers-reduced-motion: reduce){
  .manifesto::after,.collections::after,.pieces::after,.atelier::after,
  .concierge::after,.reviews::after,.boutique::after,.contact::after{
    background-attachment:scroll;
  }
}

/* ================== TYPE HELPERS ================== */
.eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink-dim);font-weight:500;
  margin-bottom:24px;
}
.eyebrow span{
  width:36px;height:1px;background:var(--gold);display:inline-block;
}

.section-title{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(36px,5.2vw,68px);
  line-height:1.05;
  letter-spacing:-.005em;
  color:var(--ink);
}
.section-title em{
  font-family:var(--serif);font-style:italic;font-weight:300;
  color:var(--gold-soft);
}
.section-sub{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(17px,1.6vw,21px);
  color:var(--ink-dim);
  max-width:560px;
  margin-top:24px;
  line-height:1.55;
}
.section-head{margin-bottom:80px}
.section-head--row{
  display:flex;justify-content:space-between;align-items:flex-end;gap:48px;
}
.section-sub--right{margin:0;text-align:right;max-width:380px}
@media (max-width:860px){
  .section-head{margin-bottom:48px}
  .section-head--row{flex-direction:column;align-items:flex-start}
  .section-sub--right{text-align:left;max-width:none}
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Inter',sans-serif;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  padding:16px 30px;border-radius:999px;
  transition:all .35s cubic-bezier(.22,.8,.25,1);
  cursor:pointer;border:1px solid transparent;
  font-weight:500;
}
.btn--gold{
  background:var(--gold);color:#0b0b0d;border-color:var(--gold);
}
.btn--gold:hover{
  background:var(--gold-soft);border-color:var(--gold-soft);
  transform:translateY(-2px);box-shadow:var(--shadow-gold);
}
.btn--ghost{
  background:transparent;color:var(--ink);border-color:var(--line-strong);
}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold);}
.btn--full{width:100%;padding:18px 30px;margin-top:6px}
.btn--sm{padding:12px 22px;font-size:11px}

.link{
  font-family:'Inter',sans-serif;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  border-bottom:1px solid var(--line-strong);padding-bottom:6px;
  transition:color .25s ease,border-color .25s ease;
}
.link--gold{color:var(--gold)}
.link--gold:hover{color:var(--gold-soft);border-color:var(--gold)}

/* ================== LOADER ================== */
.loader{
  position:fixed;inset:0;z-index:9999;background:#0b0b0d;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s ease,visibility .8s ease;
}
.loader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader__inner{text-align:center;width:min(320px,80vw)}
.loader__brand{
  font-family:var(--display);font-size:36px;letter-spacing:.4em;
  color:var(--gold);margin-bottom:32px;font-weight:500;
}
.loader__dial{margin:0 auto;display:block}
.loader__sweep{
  animation:loaderSweep 1.6s linear infinite;
}
@keyframes loaderSweep{
  0%{stroke-dashoffset:276}
  100%{stroke-dashoffset:0}
}
.loader__hint{
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--ink-dim);margin-top:24px;
}

/* ================== NAV ================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:26px 48px;
  transition:background .4s ease,backdrop-filter .4s ease,padding .4s ease,border-color .4s ease;
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{
  background:rgba(11,11,13,.92);
  backdrop-filter:blur(6px) saturate(140%);
  -webkit-backdrop-filter:blur(6px) saturate(140%);
  padding:16px 48px;
  border-bottom:1px solid var(--line);
}
.nav__logo{
  font-family:var(--display);font-size:22px;letter-spacing:.32em;
  color:var(--gold);font-weight:500;
}
.nav__links{display:flex;gap:36px}
.nav__links a{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-dim);transition:color .25s ease;font-weight:500;
}
.nav__links a:hover{color:var(--ink)}
.nav__cta{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  padding:11px 22px;border:1px solid var(--line-strong);border-radius:999px;
  transition:all .3s ease;font-weight:500;
}
.nav__cta:hover{background:var(--gold);color:#0b0b0d;border-color:var(--gold)}

.nav__burger{
  display:none;width:42px;height:42px;position:relative;
  border:1px solid var(--line-strong);border-radius:10px;background:transparent;
}
.nav__burger span{
  position:absolute;left:11px;right:11px;height:1px;background:var(--ink);
  transition:transform .35s ease,opacity .25s ease,top .35s ease;
}
.nav__burger span:nth-child(1){top:14px}
.nav__burger span:nth-child(2){top:20px}
.nav__burger span:nth-child(3){top:26px}
.nav__burger.is-open span:nth-child(1){top:20px;transform:rotate(45deg);background:var(--gold)}
.nav__burger.is-open span:nth-child(2){opacity:0}
.nav__burger.is-open span:nth-child(3){top:20px;transform:rotate(-45deg);background:var(--gold)}

@media (max-width:920px){
  .nav{padding:16px 20px}
  .nav.is-scrolled{padding:12px 20px}
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:block}
  .nav__logo{font-size:18px;letter-spacing:.3em}
}

/* ================== DRAWER ================== */
.drawer{
  position:fixed;inset:0;z-index:99;pointer-events:none;
  background:rgba(11,11,13,.4);backdrop-filter:blur(2px);
  opacity:0;transition:opacity .4s ease;
}
.drawer.is-open{opacity:1;pointer-events:auto}
.drawer__panel{
  position:absolute;top:0;right:0;height:100%;
  width:min(360px,90vw);background:var(--bg-2);
  border-left:1px solid var(--line);
  padding:96px 32px 32px;
  display:flex;flex-direction:column;gap:6px;
  transform:translateX(100%);transition:transform .45s cubic-bezier(.22,.8,.25,1);
  overflow-y:auto;
}
.drawer.is-open .drawer__panel{transform:translateX(0)}
.drawer__link{
  font-family:var(--display);font-size:24px;letter-spacing:.04em;
  color:var(--ink);padding:14px 0;border-bottom:1px solid var(--line);
  transition:color .25s ease;
}
.drawer__link:hover{color:var(--gold)}
.drawer__cta{
  margin-top:24px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  padding:16px;border-radius:999px;background:var(--gold);color:#0b0b0d;font-weight:500;
}
.drawer__meta{
  margin-top:auto;padding-top:32px;
  font-size:13px;color:var(--ink-dim);line-height:1.9;
}
.drawer__meta div+div{margin-top:0}

/* ================== HERO ================== */
.hero{
  position:relative;min-height:100svh;height:100svh;
  padding:148px 0 80px;
  background:#050403;
  overflow:hidden;
  isolation:isolate;
}
.hero__video{
  position:absolute;top:0;bottom:0;right:0;left:50%;
  width:50%;height:100%;
  object-fit:cover;object-position:center center;
  z-index:0;pointer-events:none;
}
.hero__overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(10,8,7,.55) 0%, transparent 22%, transparent 72%, rgba(10,8,7,.78) 100%),
    linear-gradient(90deg, rgba(5,4,3,1) 0%, rgba(5,4,3,1) 46%, rgba(5,4,3,.55) 52%, transparent 62%),
    radial-gradient(900px 700px at 80% 50%, rgba(212,163,106,.1), transparent 65%);
}
.hero__grain{
  position:absolute;inset:0;pointer-events:none;opacity:.35;mix-blend-mode:overlay;z-index:2;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .25 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
}
/* ----- vertical seam: thin gold rule + rotated brand label ----- */
.hero__seam{
  position:absolute;z-index:3;pointer-events:none;
  left:50%;top:8%;bottom:8%;width:1px;
  background:linear-gradient(to bottom,
    transparent 0%,
    rgba(212,163,106,.0) 4%,
    rgba(212,163,106,.45) 22%,
    rgba(212,163,106,.55) 50%,
    rgba(212,163,106,.45) 78%,
    rgba(212,163,106,.0) 96%,
    transparent 100%);
}
.hero__seam::before,
.hero__seam::after{
  content:"";position:absolute;left:50%;
  width:6px;height:6px;border:1px solid var(--gold);
  background:#050403;border-radius:50%;
  transform:translate(-50%,-50%) rotate(45deg);
}
.hero__seam::before{top:0}
.hero__seam::after{bottom:-6px;top:auto}
.hero__seam-label{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) rotate(-90deg);
  transform-origin:center center;
  white-space:nowrap;
  font-family:var(--display);
  font-size:10px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);
  padding:6px 18px;
  background:#050403;
}

.hero__inner{
  position:relative;z-index:3;
  max-width:none;margin:0;padding:0 48px;
  display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center;
  min-height:calc(100svh - 230px);
}
.hero__copy{max-width:500px;justify-self:center}
.hero__title{
  font-family:var(--display);font-weight:500;
  font-size:clamp(36px,4.8vw,68px);line-height:1.02;letter-spacing:-.01em;
  margin:18px 0 28px;
  word-break:normal;overflow-wrap:break-word;hyphens:manual;
}
.hero__title em{
  font-family:var(--serif);font-style:italic;font-weight:300;color:var(--gold-soft);
}
.hero__lead{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(17px,1.45vw,21px);line-height:1.55;
  color:rgba(240,230,214,.78);
  max-width:460px;margin-bottom:28px;
}

/* ----- atelier quote, between lead and actions ----- */
.hero__quote{
  position:relative;
  margin:0 0 32px;padding:0 0 0 22px;
  max-width:460px;
  border-left:1px solid rgba(212,163,106,.45);
}
.hero__quote-mark{
  position:absolute;top:-8px;left:8px;
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:48px;line-height:1;color:var(--gold);opacity:.7;
}
.hero__quote blockquote{
  margin:0;
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(15px,1.18vw,18px);line-height:1.5;
  color:rgba(240,230,214,.88);
  letter-spacing:.005em;
}
.hero__quote blockquote em{
  color:var(--gold-soft);font-style:italic;
}
.hero__quote figcaption{
  margin-top:8px;
  font-family:var(--display);
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(240,230,214,.42);
}

.hero__actions{display:flex;gap:14px;margin-bottom:40px;flex-wrap:wrap}

/* ----- pièce du moment: featured-watch mini card ----- */
.hero__piece{
  display:block;max-width:480px;
  padding-top:24px;border-top:1px solid rgba(212,163,106,.22);
}
.hero__piece-label{
  display:block;
  font-family:var(--display);font-size:10px;
  letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;
}
.hero__piece-card{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;
  width:100%;text-align:left;
  padding:14px 16px 14px 14px;font:inherit;
  appearance:none;-webkit-appearance:none;border-radius:0;
  background:linear-gradient(135deg, rgba(20,16,12,.7), rgba(10,8,7,.55));
  border:1px solid rgba(212,163,106,.22);
  text-decoration:none;color:inherit;cursor:pointer;
  transition:border-color .35s ease, transform .45s cubic-bezier(.22,.61,.36,1), background .35s ease, box-shadow .35s ease;
}
.hero__piece-card:hover,
.hero__piece-card:focus-visible{
  border-color:var(--gold);
  background:linear-gradient(135deg, rgba(40,28,18,.78), rgba(15,11,8,.7));
  transform:translateY(-2px);
  box-shadow:0 18px 38px -20px rgba(212,163,106,.45);
  outline:none;
}
.hero__piece-thumb{
  width:64px;height:64px;
  border-radius:50%;overflow:hidden;flex:none;
  border:1px solid rgba(212,163,106,.35);
  box-shadow:inset 0 0 0 2px rgba(5,4,3,.6);
}
.hero__piece-thumb img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s cubic-bezier(.22,.61,.36,1);
}
.hero__piece-card:hover .hero__piece-thumb img{transform:scale(1.08)}
.hero__piece-body{display:flex;flex-direction:column;gap:3px;min-width:0}
.hero__piece-brand{
  font-family:var(--display);font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--gold);
}
.hero__piece-model{
  font-family:var(--serif);font-weight:400;
  font-size:17px;line-height:1.2;color:var(--ink);
}
.hero__piece-meta{
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(240,230,214,.55);
}
.hero__piece-arrow{
  font-family:var(--display);font-size:18px;color:var(--gold);
  transition:transform .35s ease;flex:none;padding-right:4px;
}
.hero__piece-card:hover .hero__piece-arrow{transform:translateX(4px)}

.hero__stage{
  position:relative;display:flex;align-items:flex-end;justify-content:flex-end;
  min-height:560px;
}
.hero__halo{display:none}
.watch--hero{display:none}
@keyframes floatY{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}

.hand--sec{animation:tickSec 60s steps(60) infinite}
.hand--min{animation:tickMin 3600s linear infinite;transform:rotate(58deg)}
.hand--hour{animation:tickHour 43200s linear infinite;transform:rotate(85deg)}
.subhand{animation:tickSec 60s linear infinite}
@keyframes tickSec{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes tickMin{from{transform:rotate(58deg)}to{transform:rotate(418deg)}}
@keyframes tickHour{from{transform:rotate(85deg)}to{transform:rotate(445deg)}}

.hero__caption{
  position:absolute;bottom:18px;right:0;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-dim);line-height:1.7;text-align:right;
  padding:14px 18px;
  background:linear-gradient(135deg, rgba(10,8,7,.55), rgba(10,8,7,.25));
  backdrop-filter:blur(8px) saturate(140%);
  -webkit-backdrop-filter:blur(8px) saturate(140%);
  border:1px solid rgba(212,163,106,.18);
  border-radius:8px;
}
.hero__caption-title{color:var(--gold);font-weight:500}

/* ====== Scroll-driven hero: intro fade, cinematic overlays ====== */
.hero--scroll .hero__inner{
  position:absolute;inset:0;
  min-height:0;
  padding:148px 48px 110px;
  max-width:none;
  display:grid;grid-template-columns:minmax(0, 500px) 1fr;gap:64px;align-items:center;
  z-index:3;
  transition:opacity .35s ease, transform .45s ease;
  will-change:opacity, transform;
}
.hero--scroll .hero__inner > *{max-width:1280px}
.hero--scroll .hero__inner .hero__copy{max-width:520px;margin-left:0}
.hero--scroll .hero__ticker{
  position:absolute;bottom:0;left:0;right:0;
  margin-top:0;z-index:4;
  background:linear-gradient(to top, rgba(5,4,3,.85), rgba(5,4,3,.4) 70%, transparent);
  border-bottom:none;
}
.hero--scroll .hero__overlay{
  background:
    linear-gradient(180deg, rgba(5,4,3,.55) 0%, transparent 22%, transparent 70%, rgba(5,4,3,.85) 100%),
    linear-gradient(90deg, rgba(5,4,3,.65) 0%, transparent 30%, transparent 70%, rgba(5,4,3,.45) 100%);
}

@media (prefers-reduced-motion: reduce){
  .hero--scroll{height:auto;min-height:100svh}
  .hero--scroll .hero__sticky{position:relative;height:100svh}
}

@media (max-width:1180px) and (min-width:981px){
  .hero__inner{gap:28px}
  .hero__copy{max-width:440px}
  .hero__title{font-size:clamp(32px,4.4vw,54px)}
}

@media (max-width:980px){
  .hero{padding:110px 0 56px}
  .hero--scroll{height:280svh}
  .hero--scroll .hero__inner{
    position:absolute;inset:0;
    grid-template-columns:1fr;gap:18px;padding:104px 20px 92px;
    align-items:start;align-content:start;
    min-height:0;
  }
  .hero--scroll .hero__inner .hero__copy{margin-left:0;max-width:540px}
  .hero__inner{
    grid-template-columns:1fr;gap:20px;padding:0 20px;
    min-height:auto;
  }
  .hero__copy{order:2;max-width:540px}
  .hero__title{
    font-size:clamp(32px,7vw,48px);
    hyphens:none;-webkit-hyphens:none;
    margin:14px 0 20px;
  }
  .hero__stage{order:1;min-height:240px}
  .hero__video{
    left:0;width:100%;
    -webkit-mask-image:linear-gradient(to bottom, #000 30%, transparent 100%);
            mask-image:linear-gradient(to bottom, #000 30%, transparent 100%);
  }
  .hero__overlay{
    background:
      linear-gradient(180deg, rgba(10,8,7,.4) 0%, rgba(10,8,7,.55) 30%, rgba(10,8,7,.92) 60%, rgba(10,8,7,.98) 100%),
      radial-gradient(800px 600px at 50% 25%, rgba(212,163,106,.08), transparent 70%);
  }
  .hero__lead{
    color:rgba(240,230,214,.88);
    font-size:16px;line-height:1.6;
    margin-bottom:28px;
  }
  .hero__actions{margin-bottom:28px;gap:10px}
  .hero__actions .btn{flex:1 1 auto;min-width:0;padding:14px 18px;font-size:11px}
  .hero__quote{margin:0 0 24px;padding-left:16px;max-width:none}
  .hero__quote-mark{font-size:38px;top:-6px}
  .hero__quote blockquote{font-size:15px}
  .hero__piece{max-width:none;padding-top:18px}
  .hero__piece-card{padding:10px 12px;gap:14px}
  .hero__piece-thumb{width:56px;height:56px}
  .hero__piece-model{font-size:15px}
  .hero__piece-meta{font-size:10px;letter-spacing:.14em}
  .hero__caption{
    position:static;text-align:center;margin:16px auto 0;
    display:inline-block;
  }
  .hero__seam{display:none}
}
@media (max-width:420px){
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn{width:100%}
  .hero__piece-meta{display:none}
}

/* ================== TICKER ================== */
.hero__ticker{
  position:relative;z-index:2;margin-top:60px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:22px 0;overflow:hidden;
  mask-image:linear-gradient(to right, transparent, black 8%, black 92%, transparent);
}
.ticker__row{
  display:flex;gap:48px;white-space:nowrap;
  animation:tickerScroll 50s linear infinite;
  font-family:var(--display);font-size:18px;letter-spacing:.18em;
  color:var(--ink-dim);
}
.ticker__row span+span{flex-shrink:0}
.ticker__row span:nth-child(odd){color:var(--gold-soft)}
@keyframes tickerScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ================== MANIFESTO ================== */
.manifesto{
  padding:120px 0;background:var(--bg);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.manifesto__grid{
  display:grid;grid-template-columns:1fr 2fr;gap:64px;
  align-items:start;
}
.manifesto__grid .eyebrow{margin-bottom:0;padding-top:14px}
.manifesto__h{
  grid-column:2;
  font-family:var(--display);font-weight:500;
  font-size:clamp(28px,3.5vw,46px);line-height:1.2;
  letter-spacing:-.005em;
  margin-bottom:28px;
}
.manifesto__h em{
  font-family:var(--serif);font-style:italic;font-weight:300;
  color:var(--gold-soft);
}
.manifesto__p{
  grid-column:2;
  font-family:var(--serif);font-weight:300;
  font-size:clamp(17px,1.5vw,21px);
  color:var(--ink-dim);line-height:1.6;max-width:680px;
}
@media (max-width:860px){
  .manifesto{padding:80px 0}
  .manifesto__grid{grid-template-columns:1fr;gap:24px}
  .manifesto__h,.manifesto__p{grid-column:1}
}

/* ================== COLLECTIONS ================== */
.collections{padding:140px 0;background:var(--bg)}
.collections__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.collection{
  background:linear-gradient(180deg, var(--bg-2), var(--bg));
  border:1px solid var(--line);border-radius:6px;
  padding:32px 28px;
  position:relative;
  display:flex;flex-direction:column;
  transition:transform .5s cubic-bezier(.22,.8,.25,1),border-color .5s ease,box-shadow .5s ease;
  cursor:pointer;overflow:hidden;
}
.collection__link{
  position:absolute;inset:0;z-index:4;
  text-indent:-9999px;font-size:0;line-height:0;
  border-radius:inherit;
}
.collection__link:focus-visible{
  outline:1px solid var(--gold);outline-offset:-2px;
}
.collection::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(closest-side at 50% 0%, rgba(201,166,97,.08), transparent 70%);
  opacity:0;transition:opacity .5s ease;pointer-events:none;
}
.collection:hover{
  border-color:rgba(201,166,97,.3);
  transform:translateY(-6px);
  box-shadow:var(--shadow-gold);
}
.collection:hover::after{opacity:1}
.collection__art{
  width:100%;aspect-ratio:1/1;margin:0 0 28px;
  position:relative;overflow:hidden;
  border-radius:10px;
  border:1px solid rgba(201,166,97,.18);
  background:#0a0807;
  box-shadow:0 14px 32px -10px rgba(0,0,0,.55), inset 0 0 0 1px rgba(0,0,0,.4);
  transition:transform .5s cubic-bezier(.22,.8,.25,1),border-color .5s ease,box-shadow .5s ease;
}
.collection__art::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.35) 100%);
}
.collection__art img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;
  transition:transform .8s cubic-bezier(.22,.8,.25,1);
}
.collection:hover .collection__art{
  border-color:rgba(201,166,97,.42);
  box-shadow:0 22px 48px -12px rgba(0,0,0,.7), 0 0 0 1px rgba(201,166,97,.12);
}
.collection:hover .collection__art img{transform:scale(1.06)}
.collection__num{
  font-family:var(--display);font-size:11px;letter-spacing:.4em;
  color:var(--gold);margin-bottom:10px;font-weight:500;
}
.collection__title{
  font-family:var(--display);font-size:24px;font-weight:500;
  letter-spacing:.02em;margin-bottom:14px;
}
.collection__desc{
  font-family:var(--serif);font-weight:300;
  font-size:16px;line-height:1.5;color:var(--ink-dim);
  margin-bottom:24px;
  flex:1 1 auto;
}
.collection__count{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);font-weight:500;
  padding-top:18px;border-top:1px solid var(--line);
  margin-top:auto;
}
.collection--feature{
  grid-column:span 4;
  display:grid;
  grid-template-columns:auto 1fr;
  grid-template-rows:auto auto auto auto;
  column-gap:44px;row-gap:0;
  align-items:start;
  padding:36px 44px;
  background:
    linear-gradient(120deg, rgba(201,166,97,.06), transparent 50%),
    linear-gradient(180deg, var(--bg-2), var(--bg));
  border-color:rgba(201,166,97,.2);
}
.collection--feature .collection__art{
  margin:0;width:240px;aspect-ratio:1/1;flex-shrink:0;
  grid-column:1;grid-row:1 / span 4;align-self:center;
}
.collection--feature .collection__num{margin:0;grid-column:2;align-self:end;padding-bottom:4px}
.collection--feature .collection__title{font-size:34px;margin:6px 0 14px;grid-column:2}
.collection--feature .collection__desc{font-size:17px;max-width:560px;margin:0 0 22px;grid-column:2}
.collection--feature .collection__count{
  border-top:1px solid rgba(201,166,97,.3);padding-top:16px;
  border-left:none;padding-left:0;margin-top:0;
  grid-column:2;align-self:end;justify-self:start;
  white-space:nowrap;
}

@media (max-width:1100px){
  .collections__grid{grid-template-columns:repeat(2,1fr)}
  .collection--feature{grid-column:span 2}
}
@media (max-width:720px){
  .collections{padding:80px 0}
  .collections__grid{grid-template-columns:1fr;gap:16px}
  .collection--feature{
    grid-column:span 1;grid-template-columns:1fr;grid-template-rows:none;
    text-align:center;padding:32px 24px;row-gap:14px;
  }
  .collection--feature .collection__art{margin:0 auto;width:100%;max-width:340px;grid-column:1;grid-row:auto}
  .collection--feature .collection__num,
  .collection--feature .collection__title,
  .collection--feature .collection__desc,
  .collection--feature .collection__count{grid-column:1;justify-self:center}
  .collection--feature .collection__desc{margin:0}
  .collection--feature .collection__count{
    border-top:1px solid rgba(201,166,97,.3);padding-top:18px;margin-top:4px;
  }
}

/* ================== PIECES ================== */
.pieces{
  padding:140px 0;background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.pieces__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
.piece{
  background:var(--bg);
  border:1px solid var(--line);border-radius:6px;
  overflow:hidden;
  transition:transform .5s cubic-bezier(.22,.8,.25,1),border-color .5s ease,box-shadow .5s ease;
  display:flex;flex-direction:column;
}
.piece:hover{
  transform:translateY(-6px);
  border-color:rgba(201,166,97,.3);
  box-shadow:var(--shadow-gold);
}
.piece__media{
  position:relative;aspect-ratio:1/1;
  background:
    radial-gradient(circle at 50% 40%, #1a1612, #0a0908);
  display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.piece__media svg{width:78%;height:78%;transition:transform .8s ease}
.piece:hover .piece__media svg{transform:scale(1.04) rotate(2deg)}
.piece__photo{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;
  transition:transform .8s ease, filter .8s ease;
  filter:saturate(1.02) contrast(1.02);
}
.piece:hover .piece__photo{transform:scale(1.05)}

.piece__badge{
  position:absolute;top:18px;left:18px;z-index:3;
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  padding:7px 12px;background:rgba(11,11,13,.7);
  backdrop-filter:blur(8px);
  border:1px solid rgba(201,166,97,.3);color:var(--gold);
  border-radius:999px;font-weight:500;
}
.piece__badge--rare{background:rgba(201,166,97,.92);color:#0b0b0d;border-color:transparent}

.piece__body{padding:28px;flex:1;display:flex;flex-direction:column}
.piece__brand{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:12px;
}
.piece__title{
  font-family:var(--display);font-size:22px;font-weight:500;
  line-height:1.2;letter-spacing:0;margin-bottom:10px;
}
.piece__meta{
  font-family:var(--serif);font-weight:300;font-size:15px;
  color:var(--ink-dim);margin-bottom:24px;
}
.piece__row{
  margin-top:auto;
  display:flex;justify-content:space-between;align-items:center;
  padding-top:18px;border-top:1px solid var(--line);
  gap:14px;
}
.piece__price{
  font-family:var(--display);font-size:18px;color:var(--ink);font-weight:500;
}
.piece__cta{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:500;
  border:1px solid rgba(201,166,97,.3);
  padding:10px 16px;border-radius:999px;
  transition:all .3s ease;
}
.piece__cta:hover{background:var(--gold);color:#0b0b0d;border-color:var(--gold)}

.pieces__foot{
  margin-top:48px;padding-top:32px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);
}

@media (max-width:1100px){.pieces__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){
  .pieces{padding:80px 0}
  .pieces__grid{grid-template-columns:1fr;gap:20px}
  .pieces__foot{flex-direction:column;align-items:flex-start;text-align:left}
}

/* ================== ATELIER ================== */
.atelier{padding:140px 0;background:var(--bg)}
.atelier__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.atelier__art{position:relative}
.atelier__frame{
  position:relative;
  background:#050403;
  border:1px solid var(--line);border-radius:8px;
  aspect-ratio:1/1;overflow:hidden;
  box-shadow:var(--shadow-1);
  isolation:isolate;
}
.atelier__frame::before{
  content:"";position:absolute;inset:18px;border:1px solid rgba(201,166,97,.22);
  border-radius:4px;pointer-events:none;z-index:3;
}
.atelier__video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  z-index:1;
}
.atelier__frame-vignette{
  position:absolute;inset:0;pointer-events:none;z-index:2;
  background:
    radial-gradient(ellipse at center, transparent 35%, rgba(5,4,3,.55) 80%, rgba(5,4,3,.85) 100%),
    linear-gradient(180deg, rgba(5,4,3,.15) 0%, transparent 30%, transparent 70%, rgba(5,4,3,.45) 100%);
}
.atelier__frame-engraving{
  position:absolute;left:0;right:0;bottom:34px;z-index:3;
  text-align:center;
  font-family:'Cinzel',Georgia,serif;
  font-size:11px;letter-spacing:.32em;
  color:rgba(212,163,106,.62);
}
.atelier__caption{
  margin-top:18px;font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-dim);line-height:1.9;text-align:center;
}

.atelier__copy p{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(17px,1.5vw,20px);line-height:1.65;
  color:var(--ink-dim);margin:24px 0 28px;max-width:520px;
}
.atelier__list{
  list-style:none;margin:0 0 36px;padding:0;
  border-top:1px solid var(--line);
}
.atelier__list li{
  padding:18px 0;border-bottom:1px solid var(--line);
  font-size:15px;color:var(--ink-dim);
  display:flex;align-items:baseline;gap:14px;
}
.atelier__list li::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);
  flex-shrink:0;margin-top:8px;
}
.atelier__list b{color:var(--ink);font-weight:500;margin-right:6px}

@media (max-width:980px){
  .atelier{padding:80px 0}
  .atelier__grid{grid-template-columns:1fr;gap:40px}
  .atelier__art{order:2}
  .atelier__frame{padding:24px}
  .atelier__list li{padding:14px 0;font-size:14px;gap:10px;line-height:1.5}
  .atelier__list li::before{margin-top:7px;width:5px;height:5px}
  .atelier__copy p{font-size:16px;line-height:1.6;margin:18px 0 22px}
}

/* ================== CONCIERGE ================== */
.concierge{
  padding:140px 0;background:var(--bg-2);
  border-top:1px solid var(--line);
}
.concierge__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.service{
  background:var(--bg);border:1px solid var(--line);border-radius:6px;
  padding:36px 32px;
  cursor:pointer;
  display:flex;flex-direction:column;
  transition:transform .5s ease,border-color .5s ease,background .5s ease,box-shadow .5s ease;
}
.service:hover{
  background:linear-gradient(180deg, rgba(201,166,97,.04), transparent 60%), var(--bg);
  border-color:rgba(201,166,97,.3);transform:translateY(-4px);
  box-shadow:0 24px 60px rgba(0,0,0,.35);
}
.service:focus-visible{outline:1px solid var(--gold);outline-offset:4px}
.service__price{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.service__more{
  font-size:11px;letter-spacing:.18em;color:var(--ink-dim);
  opacity:.7;
  transition:opacity .2s ease, color .2s ease;
}
.service:hover .service__more,
.service:focus-visible .service__more{opacity:1;color:var(--gold)}
.service__icon{
  width:56px;height:56px;border:1px solid rgba(201,166,97,.3);
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:24px;
  transition:background .35s ease, border-color .35s ease;
}
.service:hover .service__icon{background:rgba(201,166,97,.08);border-color:var(--gold)}
.service__icon svg{width:32px;height:32px}
.service h3{
  font-family:var(--display);font-size:22px;font-weight:500;
  margin-bottom:14px;
}
.service p{
  font-family:var(--serif);font-weight:300;
  font-size:16px;line-height:1.55;color:var(--ink-dim);
  margin-bottom:24px;
}
.service__price{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold);font-weight:500;
  padding-top:18px;border-top:1px solid var(--line);
  margin-top:auto;
}

@media (max-width:1100px){.concierge__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){
  .concierge{padding:80px 0}
  .concierge__grid{grid-template-columns:1fr;gap:16px}
}

/* ================== REVIEWS ================== */
.reviews{padding:140px 0;background:var(--bg)}
.reviews__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
.quote{
  background:var(--bg-2);border:1px solid var(--line);border-radius:6px;
  padding:40px 36px;position:relative;
  display:flex;flex-direction:column;
  transition:border-color .4s ease,transform .4s ease;
}
.quote:hover{border-color:rgba(201,166,97,.25);transform:translateY(-4px)}
.quote::before{
  content:"\201C";position:absolute;top:16px;right:28px;
  font-family:var(--serif);font-size:80px;font-style:italic;
  color:var(--gold);opacity:.25;line-height:1;
}
.quote blockquote{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:18px;line-height:1.55;color:var(--ink);
  margin:0 0 28px;
  flex:1 1 auto;
}
.quote figcaption{
  padding-top:20px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:4px;
  margin-top:auto;
}
.quote figcaption span{
  font-family:var(--display);font-size:14px;letter-spacing:.06em;
  color:var(--gold);font-weight:500;
}
.quote figcaption em{
  font-style:normal;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim);
}

@media (max-width:1100px){.reviews__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){
  .reviews{padding:80px 0}
  .reviews__grid{grid-template-columns:1fr;gap:16px}
}

/* ================== BOUTIQUE ================== */
.boutique{
  padding:140px 0;background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.boutique__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.boutique__copy p{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(17px,1.5vw,20px);line-height:1.65;
  color:var(--ink-dim);margin:24px 0 40px;max-width:520px;
}
.boutique__meta{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px;
  padding-top:32px;border-top:1px solid var(--line);
}
.boutique__meta h4{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:10px;
}
.boutique__meta p{
  font-family:'Inter',sans-serif;font-weight:400;
  font-size:15px;color:var(--ink);margin:0;line-height:1.6;
}

.boutique__map{
  position:relative;aspect-ratio:1/1;
  background:var(--bg);border:1px solid var(--line);border-radius:8px;
  overflow:hidden;box-shadow:var(--shadow-1);
  isolation:isolate;
}
.map{width:100%;height:100%}
.pin__pulse{animation:pulse 2.4s ease-out infinite}
@keyframes pulse{
  0%{transform:scale(.7);opacity:.6}
  100%{transform:scale(2.6);opacity:0}
}
.boutique__map-fallback{
  position:absolute;inset:0;z-index:1;
  border-radius:inherit;overflow:hidden;
}
.boutique__map-frame{
  position:absolute;inset:0;
  border-radius:inherit;overflow:hidden;
  z-index:2;
}
.boutique__map-iframe{
  position:absolute;top:0;left:0;
  width:100%;height:100%;border:0;display:block;
  filter:saturate(.85) contrast(1.05) brightness(.92);
  opacity:0;transition:opacity .5s ease;
}
.boutique__map[data-map-state="ready"] .boutique__map-iframe{opacity:1}
.boutique__map[data-map-state="failed"] .boutique__map-iframe,
.boutique__map[data-map-state="failed"] .boutique__map-frame{display:none}
.boutique__map-card{
  position:absolute;top:16px;left:16px;z-index:4;
  display:inline-flex;align-items:center;gap:12px;
  padding:10px 16px 10px 12px;
  background:rgba(11,11,13,.85);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  border:1px solid rgba(201,166,97,.22);border-radius:999px;
  color:var(--ink);
  box-shadow:0 10px 30px rgba(0,0,0,.45);
  pointer-events:none;
}
.boutique__map-card b{
  display:block;font-family:var(--display);font-size:13px;
  letter-spacing:.08em;color:var(--gold);line-height:1.2;font-weight:500;
}
.boutique__map-card small{
  display:block;font-size:11px;
  color:rgba(236,230,221,.7);letter-spacing:.02em;
}
.boutique__map-card-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 4px rgba(201,166,97,.22);
  animation:mapCardPulse 2s infinite;flex-shrink:0;
}
@keyframes mapCardPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(201,166,97,.45)}
  50%    {box-shadow:0 0 0 10px rgba(201,166,97,0)}
}
.boutique__map-open{
  position:absolute;right:16px;bottom:16px;z-index:5;
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;
  background:rgba(11,11,13,.9);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  border:1px solid rgba(201,166,97,.28);border-radius:999px;
  color:var(--ink);font-size:11px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;text-decoration:none;
  box-shadow:0 10px 30px rgba(0,0,0,.45);
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
}
.boutique__map-open:hover{
  transform:translateY(-2px);
  background:rgba(201,166,97,.18);
  border-color:rgba(201,166,97,.5);
  color:var(--gold);
}
.boutique__map-open span{transition:transform .2s ease}
.boutique__map-open:hover span{transform:translateX(3px)}

@media (max-width:980px){
  .boutique{padding:80px 0}
  .boutique__grid{grid-template-columns:1fr;gap:48px}
  .boutique__map{order:2;max-width:520px;margin:0 auto;width:100%}
  .boutique__meta{grid-template-columns:1fr 1fr;gap:24px}
}

/* ================== CONTACT ================== */
.contact{padding:140px 0;background:var(--bg)}
.contact__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;
}
.contact__copy p{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(17px,1.5vw,20px);line-height:1.65;
  color:var(--ink-dim);margin:24px 0 40px;
}
/* Direct contact channels: phone / telegram / whatsapp */
.contact__channels{
  display:grid;grid-template-columns:1fr;gap:10px;
  margin:0 0 36px;
}
.channel{
  display:flex;align-items:center;gap:16px;
  padding:14px 18px;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:6px;
  text-decoration:none;color:var(--ink);
  transition:border-color .25s ease, transform .35s cubic-bezier(.2,.7,.2,1), background .25s ease;
}
.channel:hover{
  border-color:rgba(201,166,97,.55);
  transform:translateY(-1px);
  background:rgba(201,166,97,.04);
}
.channel__icon{
  flex:0 0 auto;width:42px;height:42px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:rgba(201,166,97,.08);
  color:var(--gold);
  transition:background .25s ease;
}
.channel:hover .channel__icon{background:rgba(201,166,97,.16)}
.channel__icon svg{width:20px;height:20px}
.channel__icon--tg svg,
.channel__icon--wa svg{width:22px;height:22px}
.channel__body{display:flex;flex-direction:column;gap:2px;min-width:0}
.channel__label{
  font-family:var(--display);font-size:10.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);font-weight:500;
}
.channel__value{
  font-family:var(--serif);font-weight:400;font-size:18px;letter-spacing:.01em;
  color:var(--ink);
}

.field__hint-link{
  color:var(--gold);text-decoration:none;
  border-bottom:1px solid rgba(201,166,97,.4);
  transition:border-color .2s ease;
}
.field__hint-link:hover{border-bottom-color:var(--gold)}

.contact__assured{
  display:grid;grid-template-columns:1fr;gap:18px;
  padding-top:32px;border-top:1px solid var(--line);
}
.contact__assured>div{display:flex;flex-direction:column;gap:6px}
.contact__assured b{
  font-family:var(--display);font-size:14px;letter-spacing:.06em;
  color:var(--gold);font-weight:500;
}
.contact__assured span{
  font-family:var(--serif);font-weight:300;font-size:16px;color:var(--ink-dim);
}

.contact__form{
  background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  padding:40px;
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  box-shadow:var(--shadow-1);
}
.field{display:flex;flex-direction:column}
.field--full{grid-column:span 2}
.field label{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim);margin-bottom:10px;font-weight:500;
}
.field input,.field select,.field textarea{
  background:var(--bg);
  border:1px solid var(--line-strong);
  border-radius:4px;
  padding:14px 16px;
  font-size:15px;
  color:var(--ink);
  transition:border-color .25s ease,background .25s ease;
  font-family:'Inter',sans-serif;
  resize:vertical;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--gold);background:rgba(201,166,97,.04);
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-dim)}
.field select{appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1L6 6L11 1' stroke='%23c9a661' stroke-width='1.4' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 16px center;
  padding-right:42px;
}
.field__hint{
  grid-column:span 2;font-size:12px;color:var(--ink-dim);
  line-height:1.5;text-align:center;margin-top:4px;
}
.contact__success{
  grid-column:span 2;
  background:rgba(201,166,97,.1);
  border:1px solid var(--gold);
  border-radius:4px;
  padding:18px 20px;
  font-size:14px;color:var(--gold);text-align:center;letter-spacing:.04em;
}

@media (max-width:980px){
  .contact{padding:80px 0}
  .contact__grid{grid-template-columns:1fr;gap:32px}
  .contact__form{padding:24px 20px;grid-template-columns:1fr;margin:0 -4px}
  .field--full,.field__hint,.contact__success{grid-column:span 1}
  .field input,.field select,.field textarea{font-size:16px;padding:13px 14px}
  .contact__copy p{font-size:16px;line-height:1.6;margin:18px 0 28px}
  .contact__assured{padding-top:24px;gap:14px}
  .contact__assured span{font-size:15px}
}
@media (max-width:560px){
  .contact{padding:64px 0}
  .contact__form{padding:20px 16px}
}

/* ================== FOOTER ================== */
.footer{
  background:#06060a;border-top:1px solid var(--line);
  padding:80px 0 36px;
}
.footer__grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
  padding-bottom:60px;border-bottom:1px solid var(--line);
}
.footer__col h5{
  font-family:'Inter',sans-serif;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:20px;
}
.footer__col a{
  display:block;font-size:14px;color:var(--ink-dim);
  padding:6px 0;transition:color .25s ease;
}
.footer__col a:hover{color:var(--ink)}
.footer__logo{
  font-family:var(--display);font-size:32px;letter-spacing:.32em;
  color:var(--gold);font-weight:500;margin-bottom:18px;
}
.footer__col--brand p{
  font-family:var(--serif);font-weight:300;font-size:15px;
  color:var(--ink-dim);line-height:1.7;
}
.footer__bottom{
  margin-top:36px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;letter-spacing:.12em;color:var(--ink-dim);gap:24px;
}

@media (max-width:860px){
  .footer{padding:48px 0 24px}
  .footer__grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:520px){
  .footer__grid{grid-template-columns:1fr;gap:32px}
  .footer__bottom{flex-direction:column;gap:8px;text-align:center}
}

/* ================== REVEAL ================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s cubic-bezier(.22,.8,.25,1)}
.reveal.is-visible{opacity:1;transform:translateY(0)}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
  }
  .hand--sec,.hand--min,.hand--hour,.subhand{display:none}
}


/* ================================================================
   PIECE INTERACTIVE (clickable card → detail modal)
   ================================================================ */
.piece--interactive,
.piece--interactive *{cursor:pointer}
.piece--interactive .piece__cta,
.piece--interactive .piece__cta *{cursor:pointer}
.piece--interactive:focus-visible{outline:1px solid var(--gold);outline-offset:2px}

/* full-image hover scrim — даёт явный визуальный отклик о кликабельности */
.piece__media::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:
    radial-gradient(ellipse at 50% 60%, rgba(5,4,3,.35), rgba(5,4,3,.62) 70%),
    linear-gradient(180deg, transparent 0%, transparent 40%, rgba(5,4,3,.45) 100%);
  opacity:0;
  transition:opacity .35s ease;
}
.piece--interactive:hover .piece__media::after,
.piece--interactive:focus-visible .piece__media::after{opacity:1}

.piece__explore{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px 14px 18px;
  background:rgba(11,11,13,.92);
  border:1px solid rgba(201,166,97,.55);
  border-radius:999px;
  color:var(--gold);
  font-size:12px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;
  transition:opacity .18s ease;
  white-space:nowrap;
  z-index:2;
  box-shadow:0 18px 38px -16px rgba(0,0,0,.55);
}
.piece__explore svg{width:16px;height:16px;flex-shrink:0}
.piece--interactive:hover .piece__explore,
.piece--interactive:focus-visible .piece__explore,
.piece--interactive:hover .piece__media::after,
.piece__media:hover .piece__explore{
  opacity:1;
}

/* ================================================================
   WATCH DETAIL MODAL
   ================================================================ */
.watch-detail{
  position:fixed;inset:0;z-index:120;
  display:flex;align-items:center;justify-content:center;
  padding:32px;
  pointer-events:none;opacity:0;
  transition:opacity .4s cubic-bezier(.22,.8,.25,1);
}
.watch-detail.is-open{opacity:1;pointer-events:auto}

.watch-detail__backdrop{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 40%, rgba(28,18,8,.55), rgba(0,0,0,.94) 70%);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}

.watch-detail__panel{
  position:relative;
  width:min(1280px, 100%);
  height:calc(100vh - 64px);
  max-height:calc(100vh - 64px);
  overflow:hidden;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg, #0d0a08 0%, #060504 100%);
  border:1px solid rgba(201,166,97,.18);
  border-radius:8px;
  box-shadow:0 60px 160px rgba(0,0,0,.7), 0 0 0 1px rgba(201,166,97,.05);
  padding:28px 48px 24px;
  transform:translateY(24px) scale(.985);
  transition:transform .55s cubic-bezier(.22,.8,.25,1);
}
.watch-detail.is-open .watch-detail__panel{transform:none}

.watch-detail__close{
  position:absolute;top:18px;right:18px;
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:50%;color:var(--ink);
  cursor:pointer;
  transition:background .3s ease, border-color .3s ease, color .3s ease, transform .3s ease;
  z-index:3;
}
.watch-detail__close:hover{
  background:rgba(201,166,97,.14);border-color:rgba(201,166,97,.4);color:var(--gold);
  transform:rotate(90deg);
}
.watch-detail__close svg{width:18px;height:18px}

.watch-detail__head{
  flex:0 0 auto;
  text-align:center;
  margin-bottom:18px;
  padding:0 60px;
}
.watch-detail__head .eyebrow{justify-content:center;margin-bottom:10px}
.watch-detail__title{
  font-family:var(--display);font-size:clamp(24px, 2.6vw, 38px);font-weight:300;
  line-height:1.05;letter-spacing:-.01em;margin-bottom:8px;
}
.watch-detail__title em{font-style:italic;color:var(--gold);font-weight:400}
.watch-detail__sub{
  font-family:var(--serif);font-weight:300;font-size:14px;
  color:var(--ink-dim);letter-spacing:.04em;
}
.watch-detail__layout{
  flex:1 1 auto;min-height:0;
  display:grid;
  grid-template-columns:minmax(280px, 1fr) minmax(0, 1.35fr);
  gap:32px;
  align-items:stretch;
}

.watch-detail__side{
  display:flex;flex-direction:column;min-height:0;gap:14px;
}
.watch-detail__side .watch-detail__price-row{
  flex:0 0 auto;
  display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  padding:14px 18px;
  border:1px solid rgba(201,166,97,.28);
  border-radius:14px;
  background:rgba(201,166,97,.06);
}
.watch-detail__side .watch-detail__price-label{margin-bottom:0}
.watch-detail__side .watch-detail__price{font-size:22px;line-height:1}

/* --- feature pills (left column) --- */
.watch-detail__features{
  display:flex;flex-direction:column;gap:8px;
  min-height:0;overflow-y:auto;
  padding-right:6px;
  scrollbar-width:thin;
  scrollbar-color:rgba(201,166,97,.28) transparent;
}
.watch-detail__features::-webkit-scrollbar{width:4px}
.watch-detail__features::-webkit-scrollbar-thumb{background:rgba(201,166,97,.28);border-radius:2px}
.feat-pill{
  display:flex;align-items:flex-start;gap:12px;
  padding:10px 16px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.06);
  border-radius:12px;
  color:var(--ink);
  text-align:left;
  cursor:pointer;
  transition:background .35s cubic-bezier(.22,.8,.25,1),
             border-color .35s cubic-bezier(.22,.8,.25,1),
             padding .35s cubic-bezier(.22,.8,.25,1),
             transform .35s cubic-bezier(.22,.8,.25,1);
  position:relative;
  overflow:hidden;
}
.feat-pill:hover{
  background:rgba(255,255,255,.045);
  border-color:rgba(201,166,97,.18);
}
.feat-pill__chip{
  flex-shrink:0;
  width:30px;height:30px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.14);
  border-radius:50%;
  color:rgba(255,255,255,.65);
  transition:border-color .35s ease, color .35s ease, background .35s ease;
}
.feat-pill__chip svg{width:14px;height:14px;stroke-linecap:round;stroke-linejoin:round}
.feat-pill__content{
  display:flex;flex-direction:column;gap:4px;flex:1;min-width:0;
}
.feat-pill__label{
  font-family:var(--display);font-size:15px;font-weight:500;
  letter-spacing:.005em;line-height:1.2;
  color:var(--ink);
  transition:color .35s ease;
}
.feat-pill__desc{
  font-family:var(--serif);font-weight:300;font-size:13.5px;
  color:var(--ink-dim);line-height:1.5;
  letter-spacing:.01em;
  max-height:0;opacity:0;
  overflow:hidden;
  transition:max-height .45s cubic-bezier(.22,.8,.25,1), opacity .35s ease;
  margin-top:0;
}
.feat-pill.is-active{
  background:rgba(201,166,97,.08);
  border-color:rgba(201,166,97,.34);
  padding:12px 16px 14px;
}
.feat-pill.is-active .feat-pill__chip{
  border-color:var(--gold);color:var(--gold);
  background:rgba(201,166,97,.12);
}
.feat-pill.is-active .feat-pill__label{color:var(--gold)}
.feat-pill.is-active .feat-pill__desc{
  max-height:160px;opacity:1;margin-top:6px;
}

/* --- 3D viewer (right column) --- */
.watch-detail__viewer{
  display:flex;flex-direction:column;gap:16px;
  min-width:0;min-height:0;
}
.watch-360{
  position:relative;
  flex:1 1 auto;min-height:0;
  width:100%;
  max-width:620px;
  margin:0 auto;
  background:
    radial-gradient(ellipse at 50% 35%, rgba(201,166,97,.10), transparent 60%),
    radial-gradient(circle at 50% 55%, #1a1410 0%, #060403 80%);
  border:1px solid rgba(201,166,97,.12);
  border-radius:10px;
  overflow:hidden;
  cursor:grab;
  touch-action:none;
  user-select:none;-webkit-user-select:none;
  perspective:1600px;
  perspective-origin:50% 45%;
}
.watch-360{cursor:default}
.watch-360.is-canvas-mode{cursor:grab}
.watch-360.is-canvas-mode.is-dragging{cursor:grabbing}
.watch-360__video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  opacity:1;
  transition:opacity .25s ease;
  background:transparent;
  pointer-events:none;
  z-index:1;
}
.watch-360.is-canvas-mode .watch-360__video{opacity:0;pointer-events:none}
.watch-360__canvas{
  position:absolute;inset:0;
  width:100%;height:100%;
  display:block;
  opacity:0;
  transition:opacity .25s ease;
  pointer-events:none;
  z-index:2;
}
.watch-360.is-canvas-mode .watch-360__canvas,
.watch-360.is-feature .watch-360__canvas{opacity:1;pointer-events:auto}
.watch-360__mode{
  position:absolute;right:14px;bottom:14px;
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px 9px 12px;
  background:rgba(11,11,13,.72);
  border:1px solid rgba(201,166,97,.28);
  border-radius:999px;
  color:rgba(255,255,255,.85);
  font:600 10px/1 'Inter','Helvetica Neue',sans-serif;
  letter-spacing:.22em;text-transform:uppercase;
  cursor:pointer;
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  z-index:4;
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
}
.watch-360__mode:hover{background:rgba(20,16,12,.85);border-color:rgba(201,166,97,.5);transform:translateY(-1px)}
.watch-360__mode svg{width:16px;height:16px;color:var(--gold)}
.watch-360__mode-icon-play{display:none}
.watch-360.is-canvas-mode .watch-360__mode-icon-3d{display:none}
.watch-360.is-canvas-mode .watch-360__mode-icon-play{display:block}
.watch-360.is-feature .watch-360__mode{opacity:0;pointer-events:none}
.watch-360__loader{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  background:rgba(6,4,3,.7);
  color:rgba(255,255,255,.55);
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  pointer-events:none;
  opacity:0;
  transition:opacity .35s ease;
  z-index:3;
}
.watch-360.is-canvas-mode:not(.is-loaded) .watch-360__loader{opacity:1}
.watch-360__loader-spin{
  width:28px;height:28px;
  border:1px solid rgba(201,166,97,.2);
  border-top-color:var(--gold);
  border-radius:50%;
  animation:loaderSpin 1s linear infinite;
}
@keyframes loaderSpin{to{transform:rotate(360deg)}}

.watch-360__hint{
  position:absolute;left:14px;bottom:14px;
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;
  background:rgba(11,11,13,.65);
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  color:rgba(255,255,255,.6);
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  backdrop-filter:blur(6px);
  pointer-events:none;
  z-index:3;
  opacity:0;
  transition:opacity .35s ease;
}
.watch-360__hint svg{width:18px;height:auto;color:var(--gold)}
.watch-360.is-canvas-mode:not(.has-interacted) .watch-360__hint{opacity:.9}

.watch-360__progress{
  position:absolute;left:24px;right:24px;bottom:18px;
  height:1px;
  background:rgba(255,255,255,.08);
  z-index:3;
  pointer-events:none;
  opacity:0;
  transition:opacity .25s ease;
}
.watch-360.is-canvas-mode:not(.is-loaded) .watch-360__progress{opacity:1}
.watch-360__progress-bar{
  position:absolute;left:0;top:-1px;
  height:3px;width:18px;
  background:var(--gold);
  border-radius:2px;
  transform:translateX(0);
  transition:transform .25s cubic-bezier(.22,.8,.25,1), width .25s ease;
}

@media (prefers-reduced-motion: reduce){
  .watch-360__progress-bar{transition:none}
}

.watch-3d__hint{
  position:absolute;left:50%;bottom:16px;
  transform:translateX(-50%);
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;
  background:rgba(11,11,13,.6);
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  color:rgba(255,255,255,.55);
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  backdrop-filter:blur(6px);
  opacity:.85;
  transition:opacity .4s ease;
  pointer-events:none;
}
.watch-3d__hint svg{width:24px;height:auto;color:var(--gold)}
.watch-3d.has-interacted .watch-3d__hint{opacity:0}

.watch-detail__foot{
  flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  gap:18px;flex-wrap:wrap;
  padding:0;
  border:none;background:none;
}
.watch-detail__price-label{
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-dim);margin-bottom:4px;
}
.watch-detail__price{
  font-family:var(--display);font-size:24px;color:var(--ink);font-weight:500;
}
.watch-detail__cta{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:#0b0b0d;font-weight:500;
  background:var(--gold);
  padding:14px 22px;border-radius:999px;
  transition:background .3s ease, transform .3s ease;
}
.watch-detail__cta:hover{background:#d9b673;transform:translateY(-2px)}

/* body lock when modal open */
body.watch-detail-open{overflow:hidden}

/* responsive */
@media (max-width:980px){
  .watch-detail{padding:14px}
  .watch-detail__panel{
    padding:18px 14px 14px;
    height:calc(100svh - 28px);max-height:calc(100svh - 28px);
    overflow:hidden;
  }
  .watch-detail__close{top:12px;right:12px;width:38px;height:38px}
  .watch-detail__head{padding:0 56px 0 14px;margin-bottom:12px;text-align:left}
  .watch-detail__head .eyebrow{justify-content:flex-start;margin-bottom:6px}
  .watch-detail__title{font-size:22px;margin-bottom:4px}
  .watch-detail__sub{font-size:12.5px}
  .watch-detail__layout{
    display:flex;flex-direction:column;
    grid-template-columns:none;grid-template-rows:none;
    gap:12px;
    flex:1 1 auto;min-height:0;
    overflow:hidden;
  }
  .watch-detail__viewer{order:1;flex:0 0 auto;min-width:0;gap:10px}
  .watch-360{max-width:none;height:34vh;flex:0 0 auto;aspect-ratio:auto}
  .watch-detail__foot{padding-top:2px;flex:0 0 auto}
  .watch-detail__side{
    order:2;
    flex:1 1 auto;min-width:0;min-height:0;
    overflow-y:auto;overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    gap:12px;
    padding-right:6px;
    scrollbar-width:thin;
    scrollbar-color:rgba(201,166,97,.34) transparent;
  }
  .watch-detail__side::-webkit-scrollbar{width:4px}
  .watch-detail__side::-webkit-scrollbar-thumb{background:rgba(201,166,97,.34);border-radius:2px}
  .watch-detail__features{
    flex:0 0 auto;
    flex-direction:column;gap:0;
    max-height:none;overflow:visible;
    padding-right:0;
  }
  .feat-pill{
    position:relative;
    display:flex;align-items:flex-start;gap:12px;
    padding:13px 38px 13px 12px;
    background:rgba(255,255,255,.035);
    border:1px solid rgba(255,255,255,.09);
    border-radius:12px;
    overflow:visible;
    cursor:pointer;
    transition:background .25s ease, border-color .25s ease, transform .15s ease;
    min-width:0;
    margin-bottom:8px;
    -webkit-tap-highlight-color:transparent;
  }
  .feat-pill:hover{background:rgba(255,255,255,.05);border-color:rgba(201,166,97,.22)}
  .feat-pill:active{transform:scale(.985)}
  .feat-pill:last-child{margin-bottom:0;border-bottom:1px solid rgba(255,255,255,.09)}
  .feat-pill::after{
    content:"";
    position:absolute;top:50%;right:14px;
    width:8px;height:8px;
    border-right:1.5px solid rgba(201,166,97,.6);
    border-bottom:1.5px solid rgba(201,166,97,.6);
    transform:translateY(-65%) rotate(45deg);
    transition:transform .3s ease, border-color .25s ease;
  }
  .feat-pill__chip{
    width:30px;height:30px;
    border-color:rgba(201,166,97,.5);
    color:var(--gold);
    background:rgba(201,166,97,.06);
    margin-top:1px;
  }
  .feat-pill__chip svg{width:14px;height:14px}
  .feat-pill__content{gap:6px;min-width:0;flex:1 1 auto}
  .feat-pill__label{font-size:16.5px;color:var(--ink)}
  .feat-pill__desc{
    max-height:none;opacity:1;margin-top:0;
    font-size:14px;line-height:1.6;color:var(--ink-dim);
    overflow:visible;
    overflow-wrap:anywhere;word-break:break-word;
    transition:none;
  }
  .feat-pill.is-active{
    padding:14px 38px 16px 12px;
    background:rgba(201,166,97,.07);
    border-color:rgba(201,166,97,.32);
    align-items:flex-start;
  }
  .feat-pill.is-active::after{
    transform:translateY(-35%) rotate(-135deg);
    border-color:var(--gold);
  }
  .feat-pill.is-active .feat-pill__chip{
    border-color:var(--gold);color:var(--gold);
    background:rgba(201,166,97,.14);
    margin-top:1px;
  }
  .feat-pill.is-active .feat-pill__label{color:var(--gold)}
  .feat-pill.is-active .feat-pill__desc{
    max-height:none;opacity:1;margin-top:0;
  }
  .watch-detail__side .watch-detail__price-row{padding:10px 14px}
  .watch-detail__side .watch-detail__price-label{font-size:9px}
  .watch-detail__side .watch-detail__price{font-size:18px}
  .watch-detail__cta{padding:12px 18px;font-size:11px}
}
@media (max-width:560px){
  .watch-detail{padding:0}
  .watch-detail__panel{
    border-radius:0;
    border-left:none;border-right:none;
    height:100svh;max-height:100svh;
    padding:14px 12px 12px;
  }
  .watch-detail__close{top:10px;right:10px;width:36px;height:36px}
  .watch-detail__close svg{width:16px;height:16px}
  .watch-detail__head{padding:0 50px 0 4px;margin-bottom:10px}
  .watch-detail__title{font-size:19px;letter-spacing:-.005em}
  .watch-detail__sub{font-size:11.5px}
  .watch-360{height:32vh}
  .feat-pill__label{font-size:16px}
  .feat-pill__desc{font-size:13.5px}
}

@media (prefers-reduced-motion: reduce){
  .watch-detail, .watch-detail__panel{transition:none}
  .watch-3d__scene{transition:none}
  .watch-3d__hotspot::before{animation:none}
}

/* ================================================================
   SERVICE DETAIL MODAL — concierge service deep-dive
   ================================================================ */
.service-detail{
  position:fixed;inset:0;z-index:120;
  display:flex;align-items:center;justify-content:center;
  padding:32px;
  pointer-events:none;opacity:0;
  transition:opacity .4s cubic-bezier(.22,.8,.25,1);
}
.service-detail.is-open{opacity:1;pointer-events:auto}

.service-detail__backdrop{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 40%, rgba(28,18,8,.55), rgba(0,0,0,.94) 70%);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}

.service-detail__panel{
  position:relative;
  width:min(1120px, 100%);
  max-height:calc(100vh - 64px);
  overflow:hidden;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg, #0d0a08 0%, #060504 100%);
  border:1px solid rgba(201,166,97,.18);
  border-radius:8px;
  box-shadow:0 60px 160px rgba(0,0,0,.7), 0 0 0 1px rgba(201,166,97,.05);
  padding:28px 48px 28px;
  transform:translateY(24px) scale(.985);
  transition:transform .55s cubic-bezier(.22,.8,.25,1);
}
.service-detail.is-open .service-detail__panel{transform:none}

.service-detail__close{
  position:absolute;top:18px;right:18px;
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:50%;color:var(--ink);
  cursor:pointer;
  transition:background .3s ease, border-color .3s ease, color .3s ease, transform .3s ease;
  z-index:3;
}
.service-detail__close:hover{
  background:rgba(201,166,97,.14);border-color:rgba(201,166,97,.4);color:var(--gold);
  transform:rotate(90deg);
}
.service-detail__close svg{width:18px;height:18px}

.service-detail__head{
  flex:0 0 auto;
  text-align:center;
  margin-bottom:22px;
  padding:0 60px;
}
.service-detail__head .eyebrow{justify-content:center;margin-bottom:10px}
.service-detail__title{
  font-family:var(--display);font-size:clamp(24px, 2.4vw, 36px);font-weight:300;
  line-height:1.05;letter-spacing:-.01em;margin-bottom:8px;
}
.service-detail__title em{font-style:italic;color:var(--gold);font-weight:400}
.service-detail__eyebrow-txt{font-style:normal;white-space:nowrap}
.service-detail__sub{
  font-family:var(--serif);font-weight:300;font-size:14px;
  color:var(--ink-dim);letter-spacing:.04em;
}

.service-detail__layout{
  flex:1 1 auto;min-height:0;
  display:grid;
  grid-template-columns:minmax(280px, 360px) minmax(0, 1fr);
  gap:36px;
  overflow:hidden;
}

/* --- left column --- */
.service-detail__side{
  display:flex;flex-direction:column;gap:16px;
  min-height:0;
  overflow-y:auto;
  padding-right:8px;
  scrollbar-width:thin;
  scrollbar-color:rgba(201,166,97,.28) transparent;
}
.service-detail__side::-webkit-scrollbar{width:4px}
.service-detail__side::-webkit-scrollbar-thumb{background:rgba(201,166,97,.28);border-radius:2px}

.service-detail__media{
  position:relative;
  width:100%;
  aspect-ratio:1 / 1;
  border:1px solid rgba(201,166,97,.28);
  border-radius:14px;
  overflow:hidden;
  background:#070504;
  box-shadow:0 24px 60px rgba(0,0,0,.45);
}
.service-detail__video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  pointer-events:none;
}
/* Android Chrome иногда показывает inline-overlay controls на video-теге.
   Прячем все стандартные WebKit/Chrome controls через pseudo-элементы. */
.service-detail__video::-webkit-media-controls,
.service-detail__video::-webkit-media-controls-enclosure,
.service-detail__video::-webkit-media-controls-panel,
.service-detail__video::-webkit-media-controls-overlay-play-button,
.watch-360__video::-webkit-media-controls,
.watch-360__video::-webkit-media-controls-enclosure,
.watch-360__video::-webkit-media-controls-panel,
.watch-360__video::-webkit-media-controls-overlay-play-button,
.hero__video::-webkit-media-controls,
.hero__video::-webkit-media-controls-enclosure,
.hero__video::-webkit-media-controls-panel,
.hero__video::-webkit-media-controls-overlay-play-button{
  display:none !important;
  -webkit-appearance:none !important;
  opacity:0 !important;
  pointer-events:none !important;
}
.service-detail__media-vignette{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(0,0,0,.45), transparent 55%),
    linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,.35) 100%);
}

.service-detail__lede{
  font-family:var(--serif);font-weight:300;
  font-size:18px;line-height:1.7;
  color:var(--ink);
  letter-spacing:.005em;
}

.service-detail__meta{
  display:flex;flex-direction:column;gap:1px;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.service-detail__meta-row{
  display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  padding:12px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.service-detail__meta-row:last-child{border-bottom:none}
.service-detail__meta-label{
  font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);
}
.service-detail__meta-value{
  font-family:var(--serif);font-size:16px;color:var(--ink);text-align:right;line-height:1.45;
}

.service-detail__price-row{
  display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  padding:16px 20px;
  border:1px solid rgba(201,166,97,.28);
  border-radius:14px;
  background:rgba(201,166,97,.06);
}
.service-detail__price-label{
  font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim);
}
.service-detail__price{
  font-family:var(--display);font-size:26px;color:var(--ink);font-weight:500;line-height:1;
}

.service-detail__cta{
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;
  color:#0b0b0d;font-weight:500;
  background:var(--gold);
  padding:16px 24px;border-radius:999px;
  text-align:center;
  transition:background .3s ease, transform .3s ease;
}
.service-detail__cta:hover{background:#d9b673;transform:translateY(-2px)}

/* --- right column --- */
.service-detail__body{
  min-height:0;
  overflow-y:auto;
  padding-right:10px;
  display:flex;flex-direction:column;gap:28px;
  scrollbar-width:thin;
  scrollbar-color:rgba(201,166,97,.28) transparent;
}
.service-detail__body::-webkit-scrollbar{width:4px}
.service-detail__body::-webkit-scrollbar-thumb{background:rgba(201,166,97,.28);border-radius:2px}

.service-detail__block{}

/* ---- Strap gallery (straps service modal): expanding-accordion of 3 vertical cards ---- */
.strap-gallery{
  display:flex;gap:14px;
  align-items:stretch;
}
.strap-card{
  margin:0;position:relative;
  flex:1 1 0;min-width:0;
  height:540px;
  cursor:pointer;
  border-radius:2px;
  overflow:hidden;
  border:1px solid rgba(201,166,97,.18);
  background:#0d0a08;
  box-shadow:0 14px 30px rgba(0,0,0,.45);
  transition:flex-grow .8s cubic-bezier(.22,.7,.2,1),
             border-color .45s ease,
             box-shadow .45s ease;
  will-change:flex-grow;
}
/* default — first card expanded, others collapsed */
.strap-gallery .strap-card{flex-grow:.7}
/* `.is-active` only applies when no other card is being hovered/focused */
.strap-gallery:not(:hover):not(:focus-within) .strap-card.is-active{flex-grow:2.8}
/* on hover/focus, the targeted card expands instead */
.strap-gallery:hover .strap-card:hover,
.strap-gallery:focus-within .strap-card:focus-visible{flex-grow:2.8}

.strap-card__media{
  position:absolute;inset:0;overflow:hidden;
}
.strap-card__img{
  display:block;width:100%;height:100%;object-fit:cover;object-position:center center;
  filter:saturate(.85) brightness(.78);
  transform:scale(1.02);
  transition:transform 1.1s cubic-bezier(.2,.7,.2,1),
             filter .6s ease;
  will-change:transform,filter;
}
.strap-gallery:not(:hover):not(:focus-within) .strap-card.is-active .strap-card__img,
.strap-card:hover .strap-card__img,
.strap-card:focus-visible .strap-card__img{
  transform:scale(1.06);
  filter:saturate(1.02) brightness(.96);
}
/* bottom gradient overlay only on expanded card */
.strap-card__media::after{
  content:"";position:absolute;inset:auto 0 0 0;height:62%;
  background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.35) 45%, rgba(0,0,0,.86) 100%);
  pointer-events:none;
  opacity:0;transition:opacity .6s ease;
}
.strap-gallery:not(:hover):not(:focus-within) .strap-card.is-active .strap-card__media::after,
.strap-card:hover .strap-card__media::after,
.strap-card:focus-visible .strap-card__media::after{opacity:1}

.strap-card__num{
  position:absolute;top:14px;left:16px;z-index:2;
  font-family:var(--display);font-size:11px;letter-spacing:.32em;
  color:var(--gold);opacity:.9;
  text-shadow:0 1px 4px rgba(0,0,0,.6);
}

/* vertical rotated label for collapsed cards */
.strap-card__label{
  position:absolute;left:50%;bottom:24px;z-index:2;
  writing-mode:vertical-rl;transform:translateX(-50%) rotate(180deg);
  font-family:var(--display);font-size:13px;letter-spacing:.38em;
  text-transform:uppercase;color:var(--gold);
  opacity:.9;
  text-shadow:0 1px 6px rgba(0,0,0,.7);
  transition:opacity .35s ease;
  pointer-events:none;
}
.strap-gallery:not(:hover):not(:focus-within) .strap-card.is-active .strap-card__label,
.strap-card:hover .strap-card__label,
.strap-card:focus-visible .strap-card__label{opacity:0}

/* full caption — visible only on expanded card */
.strap-card__cap{
  position:absolute;left:24px;right:24px;bottom:22px;z-index:2;
  display:flex;flex-direction:column;gap:4px;
  opacity:0;transform:translateY(10px);
  transition:opacity .5s ease .15s,
             transform .65s cubic-bezier(.2,.7,.2,1) .1s;
}
.strap-gallery:not(:hover):not(:focus-within) .strap-card.is-active .strap-card__cap,
.strap-card:hover .strap-card__cap,
.strap-card:focus-visible .strap-card__cap{
  opacity:1;transform:none;
}
.strap-card__cap strong{
  font-family:var(--serif);font-weight:500;
  font-size:24px;letter-spacing:.01em;color:#fff;
  text-shadow:0 2px 10px rgba(0,0,0,.55);
}
.strap-card__cap em{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:15px;color:rgba(255,255,255,.78);
}
.strap-card__meta{
  font-family:var(--display);font-size:10.5px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold);opacity:.92;
  margin-top:6px;
}

.strap-gallery:not(:hover):not(:focus-within) .strap-card.is-active,
.strap-card:hover,
.strap-card:focus-visible{
  border-color:rgba(201,166,97,.55);
  box-shadow:0 22px 50px rgba(0,0,0,.65);
}

@media (max-width:760px){
  .strap-gallery{
    flex-direction:column;gap:16px;
    align-items:stretch;
  }
  .strap-card{
    width:100%;
    height:auto;aspect-ratio:3/4;
    flex:0 0 auto;
  }
  /* neutralise desktop accordion-grow rules so each card sits at its own size */
  .strap-gallery .strap-card,
  .strap-gallery .strap-card.is-active,
  .strap-gallery:hover .strap-card,
  .strap-gallery:hover .strap-card:hover,
  .strap-gallery:focus-within .strap-card,
  .strap-gallery .strap-card:focus-visible{flex-grow:0}
  /* always show caption and bottom gradient, hide rotated label */
  .strap-card__label{display:none}
  .strap-card__cap{
    opacity:1;transform:none;
    left:20px;right:20px;bottom:18px;
  }
  .strap-card__cap strong{font-size:22px}
  .strap-card__cap em{font-size:14px}
  .strap-card__media::after{opacity:1;height:55%}
  .strap-card__img{
    filter:saturate(1) brightness(.92);
    transform:scale(1.02);
    object-position:center center;
  }
  .strap-card__num{top:12px;left:14px;font-size:10.5px}
}

.service-detail__h3{
  font-family:var(--display);font-size:14.5px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:20px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(201,166,97,.18);
}

.service-detail__includes{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr 1fr;gap:20px 28px;
}
.service-detail__includes li{
  position:relative;padding-left:26px;
  font-family:var(--serif);font-weight:300;
  font-size:17px;line-height:1.6;color:var(--ink-dim);
}
.service-detail__includes li::before{
  content:"";position:absolute;left:0;top:.55em;
  width:9px;height:9px;border-radius:50%;
  background:rgba(201,166,97,.6);
  box-shadow:0 0 0 3px rgba(201,166,97,.1);
}
.service-detail__includes li strong{
  display:block;color:var(--ink);font-weight:500;font-size:17px;
  margin-bottom:4px;letter-spacing:.01em;
}

.service-detail__steps{
  list-style:none;padding:0;margin:0;counter-reset:step;
  display:flex;flex-direction:column;gap:14px;
}
.service-detail__steps li{
  counter-increment:step;
  position:relative;padding:18px 22px 18px 70px;
  border:1px solid rgba(255,255,255,.06);
  border-radius:12px;
  background:rgba(255,255,255,.02);
  font-family:var(--serif);font-weight:300;
  font-size:16.5px;line-height:1.6;color:var(--ink-dim);
}
.service-detail__steps li::before{
  content:counter(step,decimal-leading-zero);
  position:absolute;left:22px;top:18px;
  font-family:var(--display);font-size:16px;font-weight:500;
  color:var(--gold);letter-spacing:.06em;
}
.service-detail__steps li strong{
  display:block;color:var(--ink);font-weight:500;font-size:17.5px;
  margin-bottom:4px;
}

/* body lock when service modal open */
body.service-detail-open{overflow:hidden}

/* responsive */
@media (max-width:980px){
  .service-detail{padding:14px}
  .service-detail__panel{
    padding:18px 16px 16px;
    height:calc(100svh - 28px);max-height:calc(100svh - 28px);
    overflow:hidden;
  }
  .service-detail__close{top:12px;right:12px;width:38px;height:38px}
  .service-detail__head{padding:0 50px 0 4px;margin-bottom:14px;text-align:left}
  .service-detail__head .eyebrow{justify-content:flex-start;margin-bottom:6px}
  .service-detail__title{font-size:24px;margin-bottom:6px}
  .service-detail__sub{font-size:13.5px}
  .service-detail__layout{
    display:block;
    grid-template-columns:none;
    gap:0;
    overflow-y:auto;overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
    flex:1 1 auto;min-height:0;
  }
  .service-detail__side{
    display:block;
    overflow:visible;padding-right:0;
    min-height:0;
    margin-bottom:24px;
  }
  .service-detail__side > * + *{margin-top:16px}
  .service-detail__media{aspect-ratio:16 / 10;border-radius:12px;margin-top:0}
  .service-detail__body{
    display:block;
    overflow:visible;padding-right:0;
    min-height:0;
  }
  .service-detail__body > * + *{margin-top:28px}
  .service-detail__lede{font-size:16.5px;line-height:1.65}
  .service-detail__includes{grid-template-columns:1fr;gap:14px}
  .service-detail__includes li{font-size:15.5px}
  .service-detail__includes li strong{font-size:16px}
  .service-detail__steps li{font-size:15.5px;padding:16px 18px 16px 60px}
  .service-detail__steps li strong{font-size:16.5px}
  .service-detail__meta-value{font-size:15px}
  .service-detail__price{font-size:22px}
}

@media (max-width:520px){
  .service-detail__panel{padding:14px 12px 12px}
  .service-detail__head{padding:0 50px 0 2px}
  .service-detail__title{font-size:22px}
  .service-detail__sub{font-size:12.5px}
  .service-detail__price{font-size:20px}
  .service-detail__lede{font-size:16px}
}

@media (prefers-reduced-motion: reduce){
  .service-detail, .service-detail__panel{transition:none}
}

/* ================== РКН: CONSENT CHECKBOX + COOKIE BAR + LEGAL PAGES ================== */

/* Согласие на форме */
.field--consent{margin:6px 0 14px}
.consent{
  display:flex;gap:12px;align-items:flex-start;cursor:pointer;
  user-select:none;
}
.consent input[type="checkbox"]{
  position:absolute;opacity:0;width:0;height:0;
  pointer-events:none;
}
.consent__box{
  flex:0 0 18px;width:18px;height:18px;margin-top:3px;
  border:1px solid rgba(201,166,97,.5);background:transparent;
  border-radius:2px;position:relative;
  transition:background .2s ease, border-color .2s ease;
}
.consent input[type="checkbox"]:checked + .consent__box{
  background:var(--gold,#c9a661);border-color:var(--gold,#c9a661);
}
.consent input[type="checkbox"]:checked + .consent__box::after{
  content:"";position:absolute;left:5px;top:1px;
  width:5px;height:10px;
  border:solid #0b0b0d;border-width:0 1.5px 1.5px 0;
  transform:rotate(45deg);
}
.consent input[type="checkbox"]:focus-visible + .consent__box{
  outline:2px solid var(--gold,#c9a661);outline-offset:2px;
}
.consent__text{
  font-family:var(--serif);font-weight:300;font-size:13.5px;line-height:1.5;
  color:var(--ink-dim,#a89b85);
}
.consent__text a{color:var(--gold,#c9a661);text-decoration:underline;text-underline-offset:2px}
.consent__text a:hover{color:#e3c180}

/* Cookie бар */
.cookie-bar{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:9000;
  background:rgba(11,11,13,.98);backdrop-filter:blur(6px);
  border:1px solid rgba(201,166,97,.25);
  box-shadow:0 18px 48px rgba(0,0,0,.55);
  border-radius:4px;
  padding:18px 22px;
  animation:cookieRise .45s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes cookieRise{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-bar__inner{
  display:flex;align-items:center;gap:24px;
  max-width:1180px;margin:0 auto;flex-wrap:wrap;
}
.cookie-bar__text{
  flex:1 1 380px;margin:0;
  font-family:var(--serif);font-weight:300;font-size:14px;line-height:1.55;
  color:var(--ink,#f0e6d6);
}
.cookie-bar__text a{color:var(--gold,#c9a661);text-decoration:underline;text-underline-offset:2px}
.cookie-bar__actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.cookie-bar__more{
  font-family:var(--display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim,#a89b85);text-decoration:none;padding:6px 4px;
}
.cookie-bar__more:hover{color:var(--gold,#c9a661)}
.cookie-bar__btn{
  font-family:var(--display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  background:var(--gold,#c9a661);color:#0b0b0d;border:none;
  padding:12px 22px;cursor:pointer;border-radius:1px;
  transition:transform .25s ease, background .25s ease;
}
.cookie-bar__btn:hover{background:#e3c180;transform:translateY(-1px)}
@media (max-width:600px){
  .cookie-bar{left:8px;right:8px;bottom:8px;padding:14px 16px}
  .cookie-bar__inner{gap:14px}
  .cookie-bar__text{font-size:13px;flex-basis:100%}
  .cookie-bar__actions{width:100%;justify-content:space-between}
}

/* Юридические страницы (privacy / terms) */
.legal-page{background:#0a0a0b;color:var(--ink,#f0e6d6);min-height:100vh;display:flex;flex-direction:column}
.legal-page .nav{position:sticky;top:0;background:rgba(11,11,13,.96);backdrop-filter:blur(6px);border-bottom:1px solid rgba(201,166,97,.12)}
.legal-page main{flex:1}
.nav--solid{background:rgba(11,11,13,.92)!important}

.legal{padding:120px 0 80px}
.legal__wrap{max-width:820px;margin:0 auto;padding:0 24px}
.legal__crumbs{
  font-family:var(--display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim,#a89b85);margin-bottom:32px;
}
.legal__crumbs a{color:var(--gold,#c9a661);text-decoration:none}
.legal__crumbs a:hover{text-decoration:underline}
.legal__title{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(34px,5vw,52px);line-height:1.15;margin:0 0 14px;
  color:var(--ink,#f0e6d6);
}
.legal__meta{
  font-family:var(--display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold,#c9a661);opacity:.7;margin-bottom:48px;
}
.legal__section{margin-bottom:40px}
.legal__section h2{
  font-family:var(--display);font-size:14.5px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold,#c9a661);
  margin:0 0 18px;padding-bottom:12px;
  border-bottom:1px solid rgba(201,166,97,.16);
}
.legal__section p,.legal__section li{
  font-family:var(--serif);font-weight:300;
  font-size:17px;line-height:1.7;color:rgba(240,230,214,.86);
}
.legal__section p{margin:0 0 14px}
.legal__section ul{padding-left:22px;margin:0 0 14px}
.legal__section li{margin-bottom:6px}
.legal__section a{color:var(--gold,#c9a661);text-decoration:underline;text-underline-offset:2px}
.legal__section a:hover{color:#e3c180}
.legal__section strong{color:var(--ink,#f0e6d6);font-weight:400}
.legal__back{margin-top:32px}
.legal__back a{
  font-family:var(--display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold,#c9a661);text-decoration:none;
}
.legal__back a:hover{text-decoration:underline}

.footer--slim{padding:32px 0;border-top:1px solid rgba(201,166,97,.12)}
.footer--slim .footer__bottom{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-family:var(--display);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-dim,#a89b85);
}
.footer--slim a{color:var(--gold,#c9a661);text-decoration:none}
.footer--slim a:hover{text-decoration:underline}

@media (max-width:600px){
  .legal{padding:96px 0 56px}
  .legal__section p,.legal__section li{font-size:15.5px}
}
