
:root{
  --bg:#07090d;
  --bg-soft:#0d1118;
  --panel:#10161f;
  --panel-2:#141b25;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(214,170,96,.2);
  --text:#f6f2ea;
  --muted:#b7ab9b;
  --muted-2:#8f8578;
  --gold:#d8a45a;
  --gold-2:#f4d59f;
  --gold-3:#9d6b30;
  --shadow:0 26px 70px rgba(0,0,0,.45);
  --radius:28px;
  --radius-lg:38px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(216,164,90,.10), transparent 22%),
    radial-gradient(circle at 85% 18%, rgba(255,255,255,.06), transparent 14%),
    linear-gradient(180deg,#06080b 0%,#0a0d12 40%,#090c11 100%);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
.container{width:min(1200px,calc(100% - 32px));margin:0 auto}
.section{padding:104px 0;position:relative}
.section.compact{padding:82px 0}
.section.tight{padding:58px 0}
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:#e8cfaa;text-transform:uppercase;letter-spacing:.18em;
  font-size:.72rem;font-weight:700;
}
.kicker::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));
  box-shadow:0 0 18px rgba(216,164,90,.7);
}
.serif{font-family:'Cormorant Garamond',serif;line-height:.96;letter-spacing:-.03em}
h1,h2,h3,p{margin:0}
h1{font-size:clamp(3.5rem,7vw,7.2rem);font-weight:700}
h2{font-size:clamp(2.4rem,4.8vw,4.8rem);font-weight:700}
h3{font-size:1.45rem;font-weight:600}
p{color:var(--muted)}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);max-width:66ch}
.card{
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.028));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  backdrop-filter:blur(12px);
}
.btn,.btn-soft,.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:52px;padding:0 24px;border-radius:999px;font-weight:700;
  transition:.25s ease;cursor:pointer
}
.btn{
  color:#0d0c0a;
  background:linear-gradient(135deg,var(--gold-2),var(--gold));
  box-shadow:0 16px 34px rgba(216,164,90,.28), inset 0 1px 0 rgba(255,255,255,.4);
}
.btn:hover{transform:translateY(-2px);box-shadow:0 22px 42px rgba(216,164,90,.34), inset 0 1px 0 rgba(255,255,255,.4)}
.btn-soft{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:#f4ede3}
.btn-soft:hover,.btn-ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn-ghost{border:1px solid rgba(216,164,90,.25);background:rgba(216,164,90,.07);color:#e8cfaa}
.header{position:sticky;top:0;z-index:1100;padding:18px 0 0;transition:padding .28s ease}
.header-inner{
  display:grid;grid-template-columns:minmax(0,auto) 1fr auto;gap:22px;align-items:center;
  padding:16px 18px;background:rgba(8,10,14,.72);border:1px solid rgba(255,255,255,.07);
  border-radius:24px;backdrop-filter:blur(20px);box-shadow:0 10px 40px rgba(0,0,0,.18);
  transition:background .28s ease,border-color .28s ease,box-shadow .28s ease,padding .28s ease,transform .28s ease
}
.header.scrolled{padding:10px 0 0}
.header.scrolled .header-inner{
  padding:14px 18px;
  background:linear-gradient(180deg,rgba(12,15,20,.9),rgba(7,9,13,.78));
  border-color:rgba(216,164,90,.24);
  box-shadow:0 18px 44px rgba(0,0,0,.34), 0 1px 0 rgba(255,255,255,.04) inset, 0 -1px 0 rgba(216,164,90,.08) inset;
}
.header.scrolled .brand-logo{filter:drop-shadow(0 0 14px rgba(216,164,90,.24))}
.brand{display:flex;align-items:center;gap:0;min-width:0}
.brand-logo{display:block;height:64px;width:auto;object-fit:contain;filter:drop-shadow(0 0 10px rgba(216,164,90,.18));flex:0 0 auto}
.brand-copy{min-width:0}
.brand-copy strong{display:block;font-size:1rem;color:#fff;line-height:1.1}
.brand-copy span{display:block;font-size:.75rem;color:#b6aa98;text-transform:uppercase;letter-spacing:.18em}
.nav{display:flex;justify-content:center;gap:26px;flex-wrap:wrap}
.nav a{position:relative;color:#dfd5c7;font-weight:500}
.nav a::after{content:"";position:absolute;left:0;bottom:-8px;width:0;height:1px;background:linear-gradient(90deg,var(--gold),var(--gold-2));transition:.24s}
.nav a:hover::after,.nav a.active::after{width:100%}
.header-actions{display:flex;align-items:center;gap:12px;justify-self:end}
.mobile-toggle{display:none}
.hero{padding:42px 0 30px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(circle at 14% 28%, rgba(216,164,90,.12), transparent 24%),
  radial-gradient(circle at 84% 16%, rgba(255,255,255,.06), transparent 14%),
  radial-gradient(circle at 82% 82%, rgba(216,164,90,.08), transparent 20%)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(420px,540px);gap:48px;align-items:center;position:relative}
.hero-copy{padding:28px 0 18px}
.hero-copy h1{margin-top:20px;max-width:10ch;text-wrap:balance}
.hero-copy .lead{margin-top:24px;max-width:60ch}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:34px;max-width:780px}
.metric{padding:26px 24px;border-radius:24px;background:rgba(255,255,255,.03);border:1px solid var(--line)}
.metric strong{display:block;font-size:1.45rem;color:#fff;line-height:1}
.metric span{display:block;margin-top:8px;color:#c8baa6;font-size:.92rem;line-height:1.55}
.hero-visual{position:relative;min-height:720px}
.hero-stage{
  position:absolute;inset:0;border-radius:var(--radius-lg);overflow:hidden;
  background:#0b1016;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow)
}
.hero-stage img{width:100%;height:100%;object-fit:cover;object-position:center center;filter:brightness(.76) saturate(.96)}
.hero-stage::before{content:"";position:absolute;inset:0;background:
  linear-gradient(125deg, rgba(8,10,14,.24) 0%, rgba(8,10,14,.64) 40%, rgba(8,10,14,.22) 100%),
  radial-gradient(circle at 78% 18%, rgba(244,213,159,.16), transparent 20%),
  linear-gradient(180deg, rgba(8,10,14,0) 36%, rgba(8,10,14,.82) 100%);z-index:1}
.hero-stage::after{content:"";position:absolute;inset:auto -12% -26% auto;width:68%;height:58%;background:radial-gradient(circle, rgba(216,164,90,.18), transparent 62%);z-index:1;pointer-events:none}
.hero-overlay{
  position:absolute;left:22px;right:22px;bottom:22px;z-index:2;
  display:grid;grid-template-columns:1.1fr auto;gap:16px;align-items:end;
  padding:22px;border-radius:24px;background:rgba(8,10,14,.62);
  border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(18px)
}
.hero-overlay strong{display:block;font-size:1.42rem;color:#fff;max-width:14ch;line-height:1.05}
.hero-overlay p{margin-top:8px;max-width:34ch;font-size:.95rem}
.hero-phone{font-size:2rem;font-weight:800;color:#fff;letter-spacing:-.05em;white-space:nowrap}
.floating-note,.floating-proof{
  position:absolute;z-index:3;padding:18px 20px;border-radius:22px;
  background:rgba(9,11,15,.78);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(16px)
}
.floating-note{top:26px;right:-14px;max-width:250px}
.floating-proof{left:-14px;bottom:132px;max-width:220px}
.floating-note small,.floating-proof small,.spotlight small,.list-card small,.cta-card small,.contact-item small,.kpi small{display:block;color:var(--muted-2);text-transform:uppercase;letter-spacing:.16em;font-size:.7rem}
.floating-note strong,.floating-proof strong,.spotlight strong,.list-card strong,.cta-card strong,.contact-item strong,.kpi strong{display:block;margin-top:10px;color:#fff}
.spotlight{padding:24px}
.info-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.info-item{padding:22px}
.info-item strong{display:block;margin-top:10px;font-size:1.16rem;color:#fff}
.info-item span{display:block;margin-top:8px;font-size:.95rem;line-height:1.55}
.section-head{display:flex;justify-content:space-between;gap:24px;align-items:end;flex-wrap:wrap;margin-bottom:32px}
.section-head p{max-width:560px}
.grid-2,.grid-3,.grid-4,.gallery-grid,.timeline,.contact-grid,.cta-grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.feature-card{padding:30px;position:relative;overflow:hidden}
.feature-card::before{content:attr(data-num);position:absolute;right:18px;top:8px;font-size:4rem;line-height:1;font-weight:800;color:rgba(255,255,255,.045)}
.feature-card p{margin-top:10px}
.split{display:grid;grid-template-columns:minmax(0,.98fr) minmax(0,1.02fr);gap:28px;align-items:stretch}
.media-card{position:relative;overflow:hidden;min-height:660px;border-radius:34px}
.media-card img,.page-shot img,.gallery-card img{width:100%;height:100%;object-fit:cover}
.media-card img{filter:brightness(.82)}
.media-card .overlay,.gallery-card .overlay{position:absolute;left:0;right:0;bottom:0;padding:28px;background:linear-gradient(180deg,transparent 16%, rgba(0,0,0,.86) 100%)}

.media-card-show-full{display:flex;align-items:center;justify-content:center;padding:18px;background:linear-gradient(180deg,rgba(9,12,17,.96),rgba(6,8,12,.98));min-height:auto;}
.media-card-show-full img{display:block;width:100%;height:auto;max-height:640px;object-fit:contain;object-position:center center;filter:none;background:transparent;border-radius:22px;}
.media-card-show-full .overlay{display:none;}
.content-card{padding:34px}
.content-card p{margin-top:18px}
.tick-list{display:grid;gap:12px;margin-top:22px}
.tick-list span{position:relative;padding-left:28px;color:#d8ccbc;line-height:1.65}
.tick-list span::before{content:"";position:absolute;left:0;top:.67rem;width:10px;height:10px;border-radius:50%;background:linear-gradient(180deg,var(--gold-2),var(--gold));box-shadow:0 0 18px rgba(216,164,90,.5)}
.spotlight-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:22px}
.social-proof-grid{display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);gap:24px;align-items:stretch}
.proof-summary{padding:34px;position:relative;overflow:hidden}
.proof-summary::before{content:"";position:absolute;inset:auto -40px -40px auto;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(216,164,90,.16),transparent 72%);pointer-events:none}
.proof-summary p{margin-top:18px;max-width:52ch}
.proof-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:24px}
.proof-stat{padding:18px 18px 16px;border-radius:20px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07)}
.proof-stat strong{display:block;font-size:2rem;line-height:1;color:#fff}
.proof-stat span{display:block;margin-top:8px;color:#cdbfa9;font-size:.94rem;line-height:1.55}
.proof-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.proof-card{padding:24px;display:flex;flex-direction:column;justify-content:space-between;min-height:220px}
.proof-stars{display:flex;gap:5px;color:#f2c977;font-size:.95rem;letter-spacing:.04em}
.proof-card blockquote{margin:18px 0 0;font-size:1.02rem;line-height:1.7;color:#f5efe7}
.proof-person{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}
.proof-person strong{display:block;color:#fff}
.proof-person span{display:block;margin-top:6px;color:#bcae98;font-size:.92rem}
.list-card{padding:26px}
.list-card ul{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:12px}
.list-card li{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);color:#d9cebf}
.kpi{padding:24px}
.kpi span{display:block;margin-top:8px}
.gallery-grid{grid-template-columns:1.16fr .84fr .84fr;grid-auto-rows:300px}
.gallery-grid .tall{grid-row:span 2}
.gallery-grid .wide{grid-column:span 2}
.gallery-card{position:relative;overflow:hidden;border-radius:28px;border:1px solid var(--line);box-shadow:var(--shadow)}
.gallery-card img{filter:brightness(.82)}
.timeline{grid-template-columns:repeat(3,1fr)}
.timeline-card{padding:28px}
.timeline-card strong{display:block;color:#fff;font-size:1.2rem}
.timeline-card p{margin-top:8px}
.cta-wrap{padding:0}
.cta-grid{grid-template-columns:1.1fr .9fr;gap:0}
.cta-copy{padding:40px}
.cta-side{padding:40px;border-left:1px solid var(--line);background:linear-gradient(180deg,rgba(216,164,90,.07),rgba(255,255,255,.02))}
.page-hero{padding:56px 0 22px}
.page-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 500px;gap:30px;align-items:center}
.page-shot{overflow:hidden;border-radius:34px;min-height:560px}
.page-shot img{filter:brightness(.82)}
.gallery-page{grid-template-columns:repeat(12,1fr);grid-auto-rows:170px}
.gallery-page .item{grid-column:span 4;grid-row:span 2}
.gallery-page .wide{grid-column:span 8}
.gallery-page .tall{grid-row:span 4}
.contact-grid{grid-template-columns:.86fr 1.14fr}
.contact-list{display:grid;gap:16px}
.contact-item{padding:24px}
.contact-item p{margin-top:8px}
.form-wrap{padding:34px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:22px}
.form-grid .full{grid-column:1 / -1}
.input,.textarea{
  width:100%;padding:16px 18px;border-radius:16px;border:1px solid rgba(255,255,255,.09);
  background:rgba(255,255,255,.04);color:#fff;font:inherit
}
.textarea{min-height:150px;resize:vertical}
.notice{margin-top:16px;padding:14px 16px;border-radius:16px;background:rgba(216,164,90,.08);border:1px solid rgba(216,164,90,.18);color:#ecd9b6;font-size:.95rem}
.footer{padding:44px 0 100px;border-top:1px solid rgba(255,255,255,.06)}
.footer-row{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;align-items:center}
.footer-nav{display:flex;gap:18px;flex-wrap:wrap;color:#cfbea4}
.progress{position:fixed;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-2));z-index:1300}
.sticky-call{display:none;position:fixed;left:12px;right:12px;bottom:12px;z-index:1000;padding:12px 14px;border-radius:22px;background:rgba(8,10,14,.88);border:1px solid rgba(255,255,255,.08);box-shadow:0 24px 52px rgba(0,0,0,.42);backdrop-filter:blur(18px);align-items:center;justify-content:space-between;gap:16px}
.sticky-call small{display:block;color:#cdb998;text-transform:uppercase;letter-spacing:.18em;font-size:.68rem}
.sticky-call strong{display:block;margin-top:4px}
.back-to-top{
  position:fixed;
  right:14px;
  bottom:18px;
  width:62px;
  height:62px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.07);
  background:linear-gradient(180deg,rgba(22,26,33,.96),rgba(10,12,16,.96));
  color:#d8a45a;
  display:grid;
  place-items:center;
  z-index:1050;
  opacity:0;
  pointer-events:none;
  overflow:hidden;
  transform:translateY(20px) scale(.96);
  transition:opacity .32s ease, transform .32s ease, box-shadow .32s ease, border-color .28s ease, color .28s ease, background .28s ease;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 14px 34px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.04), inset 0 0 0 1px rgba(216,164,90,.05);
}
.back-to-top::before{
  content:"";
  position:absolute;
  top:-18px;
  left:50%;
  width:30px;
  height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,rgba(216,164,90,.6),transparent);
  pointer-events:none;
}
.back-to-top::after{
  content:"";
  position:absolute;
  inset:9px;
  border-radius:15px;
  border:1px solid rgba(216,164,90,.11);
  pointer-events:none;
}
.back-to-top.show{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
.back-to-top:hover{
  transform:translateY(-4px) scale(1.03);
  background:linear-gradient(180deg,rgba(26,31,39,.98),rgba(12,15,20,.98));
  border-color:rgba(216,164,90,.24);
  box-shadow:0 20px 44px rgba(0,0,0,.62),0 0 22px rgba(216,164,90,.16), inset 0 1px 0 rgba(255,255,255,.06), inset 0 0 0 1px rgba(216,164,90,.08);
  color:#f0c57d;
}
.back-to-top svg{position:absolute;inset:0;transform:rotate(-90deg);z-index:0}
.back-to-top circle{fill:none;stroke-width:2.5}
.back-to-top .track{stroke:rgba(255,255,255,.08)}
.back-to-top .progress-ring{stroke:url(#ringGradient);stroke-linecap:round;stroke-dasharray:157;stroke-dashoffset:157;transition:stroke-dashoffset .12s linear;filter:drop-shadow(0 0 6px rgba(216,164,90,.2))}
.back-to-top{font-size:22px;font-weight:700;line-height:1;text-indent:0;text-shadow:0 0 14px rgba(216,164,90,.16)}

.hero-refined{padding-top:44px}
.gold-text{background:linear-gradient(90deg,#f5d08a 0%,#d8a45a 55%,#f1ddb5 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent}
.hero-primary{padding-left:28px;padding-right:28px}
.compact-metrics .metric strong{font-size:1.32rem}
.refined-stage{min-height:720px}
.single-overlay{left:24px;right:auto;bottom:24px;display:block;max-width:320px;padding:18px 20px;background:rgba(7,9,13,.68)}
.single-overlay small{display:block;color:var(--muted-2);text-transform:uppercase;letter-spacing:.16em;font-size:.68rem}
.single-overlay strong{display:block;margin-top:10px;font-size:2.35rem;line-height:.95;max-width:none}
.single-overlay p{margin-top:8px;max-width:none;font-size:.92rem;color:#cbbda8}
.subtle-note{top:34px;right:-8px;max-width:236px}
.hero-scroll{display:flex;align-items:center;gap:12px;margin-top:28px;color:#bca98d;text-transform:uppercase;letter-spacing:.18em;font-size:.72rem}
.hero-scroll i{position:relative;width:20px;height:34px;border-radius:999px;border:1px solid rgba(255,255,255,.18);display:block}
.hero-scroll i::after{content:"";position:absolute;left:50%;top:7px;width:4px;height:8px;border-radius:999px;background:linear-gradient(180deg,var(--gold-2),var(--gold));transform:translateX(-50%);animation:scrollDot 1.7s ease-in-out infinite}
@keyframes scrollDot{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}

[data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .7s ease, transform .7s ease}
[data-reveal].visible{opacity:1;transform:none}
.mobile-open .nav{display:flex;position:absolute;left:16px;right:16px;top:82px;flex-direction:column;align-items:flex-start;padding:18px;border-radius:24px;background:rgba(8,10,14,.97);border:1px solid var(--line);box-shadow:var(--shadow)}


.music-player{
  position:fixed;
  left:18px;
  bottom:20px;
  z-index:1080;
  display:flex;
  align-items:center;
  gap:12px;
}
.music-toggle{
  position:relative;
  width:58px;
  height:58px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg,rgba(18,22,29,.96),rgba(8,10,14,.98));
  color:#f5dfba;
  display:grid;
  place-items:center;
  cursor:pointer;
  box-shadow:0 18px 42px rgba(0,0,0,.38), 0 0 0 1px rgba(216,164,90,.08) inset;
  backdrop-filter:blur(16px);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.music-toggle::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg,rgba(241,221,181,.55),rgba(216,164,90,.35),rgba(255,255,255,.08));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:.9;
  pointer-events:none;
}
.music-toggle:hover{
  transform:translateY(-2px) scale(1.04);
  box-shadow:0 24px 52px rgba(0,0,0,.46), 0 0 24px rgba(216,164,90,.18);
  border-color:rgba(216,164,90,.24);
}
.music-icon{font-size:1.1rem;line-height:1;transform:translateX(1px);}
.music-toggle.is-playing .music-icon{display:none;}
.music-eq{display:none;align-items:flex-end;gap:3px;height:16px;}
.music-eq i{display:block;width:3px;height:100%;border-radius:999px;background:linear-gradient(180deg,#f5d08a,#c9944a);animation:musicBars 1s ease-in-out infinite;transform-origin:bottom;}
.music-eq i:nth-child(2){animation-delay:.14s}
.music-eq i:nth-child(3){animation-delay:.28s}
.music-toggle.is-playing .music-eq{display:flex;}
.music-bubble{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(9,11,15,.86);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 16px 40px rgba(0,0,0,.28);
  color:#e7d6b7;
  font-size:.82rem;
  letter-spacing:.04em;
  white-space:nowrap;
  backdrop-filter:blur(14px);
  opacity:1;
  transform:translateX(0);
  transition:opacity .25s ease, transform .25s ease;
}
.music-bubble.is-hidden{opacity:0;transform:translateX(-8px);pointer-events:none;}
@keyframes musicBars{
  0%,100%{transform:scaleY(.45);opacity:.75}
  50%{transform:scaleY(1);opacity:1}
}

@media (max-width:1180px){
  .hero-grid,.split,.spotlight-grid,.page-hero-grid,.contact-grid,.cta-grid,.grid-2{grid-template-columns:1fr}
  .hero-visual{min-height:620px}
  .hero-stage{min-height:620px}
  .cta-side{border-left:none;border-top:1px solid var(--line)}
  .grid-3,.grid-4,.timeline{grid-template-columns:1fr 1fr}
  .info-strip{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:260px}
  .gallery-grid .tall,.gallery-grid .wide{grid-column:auto;grid-row:auto}
  .gallery-page .item,.gallery-page .wide,.gallery-page .tall{grid-column:span 6;grid-row:span 2}
  .page-shot,.media-card{min-height:460px}
}
@media (max-width:820px){
  .music-player{left:12px;bottom:86px;gap:8px}
  .music-toggle{width:52px;height:52px}
  .music-bubble{padding:9px 12px;font-size:.76rem}

  .section{padding:82px 0}.section.compact{padding:64px 0}.section.tight{padding:42px 0}
  .header-inner{grid-template-columns:minmax(0,1fr) auto}

  .brand-logo{height:48px}
  .brand-copy strong{font-size:.92rem}
  .brand-copy span{font-size:.64rem;letter-spacing:.14em}
  .nav{display:none}
  .header-actions .btn,.header-actions .btn-ghost{display:none}
  .mobile-toggle{display:inline-flex}
  .hero-grid{gap:26px}
  .hero-copy h1{max-width:8.5ch;font-size:clamp(3rem,12vw,4.2rem)}
  .hero-visual{min-height:470px}
  .hero-stage,.refined-stage{min-height:470px}
  .hero-overlay{grid-template-columns:1fr;padding:18px;gap:10px}
  .single-overlay{left:16px;bottom:16px;max-width:280px}
  .single-overlay strong{font-size:2rem}
  .floating-note,.floating-proof,.hero-scroll{display:none}
  .hero-metrics,.info-strip,.grid-3,.grid-4,.timeline,.form-grid{grid-template-columns:1fr}
  .gallery-grid,.gallery-page{grid-template-columns:1fr;grid-auto-rows:240px}
  .gallery-page .item,.gallery-page .wide,.gallery-page .tall{grid-column:auto;grid-row:auto}
  .page-shot,.media-card{min-height:380px}
  .footer{padding-bottom:112px}
  .sticky-call{display:none}
  .back-to-top{right:12px;bottom:18px;width:56px;height:56px;border-radius:18px;line-height:1}
}

@media (max-width:560px){
  .music-bubble{display:none}
}

.cta-grid-single{grid-template-columns:1fr}
.urgency-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border-radius:999px;
  background:rgba(216,164,90,.12);
  border:1px solid rgba(216,164,90,.34);
  color:var(--gold-2);
  font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  box-shadow:0 0 18px rgba(216,164,90,.14);
  margin-bottom:16px;
}

.signature-v2{padding-top:40px}
.signature-shell{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:28px;
  padding:34px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(216,164,90,.16), transparent 26%),
    radial-gradient(circle at 88% 80%, rgba(244,213,159,.10), transparent 22%),
    linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.028));
}
.signature-shell::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,rgba(255,255,255,.02),transparent 40%,rgba(216,164,90,.04) 100%);
  pointer-events:none;
}
.signature-copy{position:relative;z-index:1;padding:10px 4px 10px 6px}
.signature-copy p{max-width:58ch}
.signature-points{display:grid;gap:12px;margin-top:24px}
.signature-points span{
  position:relative;
  padding:14px 16px 14px 44px;
  border-radius:18px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.07);
  color:#e4d9ca;
}
.signature-points span::before{
  content:"";
  position:absolute;
  left:18px;
  top:50%;
  width:10px;
  height:10px;
  border-radius:50%;
  transform:translateY(-50%);
  background:linear-gradient(180deg,var(--gold-2),var(--gold));
  box-shadow:0 0 18px rgba(216,164,90,.45);
}
.signature-grid{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.signature-card{
  min-height:220px;
  padding:24px;
  border-radius:26px;
  background:linear-gradient(180deg,rgba(16,22,31,.92),rgba(12,16,23,.88));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 20px 44px rgba(0,0,0,.28);
  transition:transform .28s ease,border-color .28s ease, box-shadow .28s ease;
}
.signature-card:hover{
  transform:translateY(-6px);
  border-color:rgba(216,164,90,.32);
  box-shadow:0 28px 54px rgba(0,0,0,.34),0 0 30px rgba(216,164,90,.10);
}
.signature-card small{
  display:block;
  color:var(--gold-2);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.68rem;
}
.signature-card h3{margin-top:16px;font-size:1.6rem;line-height:1.1;color:#fff}
.signature-card p{margin-top:12px;color:#c8bcad}
.signature-card-lg{grid-row:span 2;min-height:100%}
.signature-card-lg h3{font-size:2rem;max-width:10ch}
.signature-accent{
  background:
    radial-gradient(circle at top right, rgba(216,164,90,.14), transparent 30%),
    linear-gradient(180deg,rgba(24,20,14,.96),rgba(12,16,23,.9));
  border-color:rgba(216,164,90,.22);
}
.cta-wrap-v2{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 84% 24%, rgba(216,164,90,.12), transparent 20%),
    linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.026));
}
.cta-wrap-v2::after{
  content:"";
  position:absolute;
  inset:auto -6% -34% auto;
  width:280px;
  height:280px;
  background:radial-gradient(circle, rgba(216,164,90,.18), transparent 62%);
  pointer-events:none;
}
@media (max-width:1180px){
  .signature-shell{grid-template-columns:1fr}
}
@media (max-width:820px){
  .signature-shell{padding:22px}
  .signature-grid{grid-template-columns:1fr}
  .signature-card-lg{grid-row:auto}
}


/* WOW V2.1 — cinematic hero polish */
.hero-refined{
  position:relative;
  overflow:hidden;
}
.hero-refined .hero-stage img{
  animation:heroCinematicZoom 18s ease-in-out infinite alternate;
  transform-origin:center center;
  will-change:transform;
}
.hero-refined .hero-stage::after{
  content:"";
  position:absolute;
  top:-18%;
  bottom:-18%;
  left:-32%;
  width:42%;
  z-index:2;
  pointer-events:none;
  background:linear-gradient(100deg, rgba(255,255,255,0) 0%, rgba(244,213,159,.08) 45%, rgba(255,255,255,0) 100%);
  filter:blur(8px);
  transform:translateX(0) rotate(8deg);
  animation:heroLightSweep 8.5s ease-in-out infinite;
}
.hero-refined .hero-copy h1{
  text-shadow:0 0 16px rgba(212,175,55,.18), 0 0 40px rgba(212,175,55,.10);
}
.hero-refined .gold-text{
  filter:drop-shadow(0 0 20px rgba(212,175,55,.18));
}

@keyframes heroCinematicZoom{
  0%{transform:scale(1)}
  100%{transform:scale(1.08)}
}

@keyframes heroLightSweep{
  0%, 18%{transform:translateX(-8%) rotate(8deg);opacity:0}
  28%{opacity:.55}
  52%{transform:translateX(285%) rotate(8deg);opacity:.08}
  100%{transform:translateX(285%) rotate(8deg);opacity:0}
}

@media (prefers-reduced-motion: reduce){
  .hero-refined .hero-stage img,
  .hero-refined .hero-stage::after,
  .hero-scroll i::after{
    animation:none !important;
  }
}


.footer p + p{max-width:620px}
.page-shot img,.gallery-card img{object-position:center center}


/* CITY HUB + CITY PAGES */
.city-hub-hero .lead{max-width:68ch}
.city-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:30px}
.city-card{padding:22px 20px;display:flex;flex-direction:column;gap:8px;transition:.25s ease;text-decoration:none}
.city-card strong{font-size:1.08rem;color:var(--text)}
.city-card span{color:#e8cfaa;font-size:.92rem}
.city-card small{color:var(--muted-2);font-size:.88rem}
.city-card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:0 24px 46px rgba(0,0,0,.42)}
.city-proof{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.city-quickbar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;padding:14px 16px;overflow:hidden}
.city-quickbar-item{padding:12px 14px;min-width:0}
.city-quickbar-item + .city-quickbar-item{border-left:1px solid rgba(255,255,255,.06)}
.city-quickbar-item small{display:block;color:var(--muted-2);text-transform:uppercase;letter-spacing:.16em;font-size:.68rem}
.city-quickbar-item strong{display:block;margin-top:10px;color:#fff;font-size:1rem;line-height:1.45}
.city-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.city-chip{display:inline-flex;align-items:center;border:1px solid rgba(212,175,55,.24);background:rgba(255,255,255,.03);padding:10px 14px;border-radius:999px;color:#f1dfc2;font-size:.92rem}
.city-copy-grid{align-items:stretch}
.city-benefits{padding:30px}
.city-benefits-intro{max-width:72ch}
.city-benefits-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:24px}
.city-benefit-item{position:relative;padding:22px 22px 20px;border-radius:24px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.07)}
.city-benefit-num{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;background:rgba(216,164,90,.12);border:1px solid rgba(216,164,90,.24);color:#f5dfb4;font-size:.82rem;font-weight:800;letter-spacing:.08em}
.city-benefit-item h3{margin-top:16px;font-size:1.12rem;color:#fff}
.city-benefit-item p{margin-top:10px;color:#d8ccbc;line-height:1.68}
.city-visual-section{padding-top:24px}
.city-visual-heading{margin-bottom:24px}
.city-photo-grid{display:grid;grid-template-columns:minmax(0,1.22fr) minmax(0,.92fr);grid-template-rows:repeat(2,minmax(250px,1fr));gap:20px;align-items:stretch}
.city-photo-card{position:relative;overflow:hidden;min-height:250px;padding:0;border-radius:30px;border:1px solid rgba(255,255,255,.08);background:#0d1118;box-shadow:0 22px 60px rgba(0,0,0,.28);isolation:isolate;cursor:pointer;text-decoration:none;transform:perspective(1200px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translate3d(0,var(--lift,0px),0);transform-style:preserve-3d;transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease}
.city-photo-card--large{grid-row:span 2;min-height:100%}
.city-photo-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.84) saturate(1);transform:scale(1) translate3d(var(--img-x,0px),var(--img-y,0px),0);transform-origin:center center;transition:transform .8s ease, filter .45s ease}
.city-photo-card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,14,.04) 0%,rgba(8,10,14,.02) 32%,rgba(8,10,14,.26) 100%);z-index:0}
.city-photo-card::after{content:"";position:absolute;inset:1px;border-radius:28px;border:1px solid rgba(255,255,255,.06);pointer-events:none;z-index:1}
.city-photo-card:hover{--lift:-5px;border-color:rgba(216,164,90,.24);box-shadow:0 28px 80px rgba(0,0,0,.38)}
.city-photo-card:hover img{transform:scale(1.06) translate3d(var(--img-x,0px),var(--img-y,0px),0);filter:brightness(.9) saturate(1.03)}
.city-photo-overlay{position:relative;z-index:2;display:flex;align-items:flex-start;justify-content:flex-end;min-height:100%;padding:18px;transform:translate3d(var(--ov-x,0px),var(--ov-y,0px),0);transition:transform .45s ease}
.city-photo-meta{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px}
.city-photo-index,.city-photo-expand{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:999px;background:rgba(8,10,14,.44);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(12px);color:#fff;font-size:.88rem;font-weight:800;letter-spacing:.08em}
.city-photo-expand{margin-left:auto;background:rgba(216,164,90,.14);border-color:rgba(216,164,90,.3);font-size:1rem;line-height:1;transform:translateY(0);transition:transform .35s ease, background .35s ease, border-color .35s ease}
.city-photo-card--large .city-photo-overlay{padding:22px}
.booking-flow{padding:32px}
.booking-flow-head{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);gap:24px;align-items:start}
.booking-flow-copy p{margin:0;color:#d8ccbc;line-height:1.72}
.booking-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:24px}
.booking-step{padding:22px;border-radius:24px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.07)}
.booking-step-num{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;background:rgba(216,164,90,.12);border:1px solid rgba(216,164,90,.24);color:#f5dfb4;font-size:.82rem;font-weight:800;letter-spacing:.08em}
.booking-step h3{margin-top:16px;font-size:1.08rem;color:#fff}
.booking-step p{margin-top:10px;color:#d8ccbc;line-height:1.66}
.booking-flow-footer{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:24px;align-items:center;margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.07)}
.booking-tags{margin-top:0}
.booking-flow-actions p{margin:0;color:#d8ccbc;line-height:1.72}
.faq-stack{padding:24px 24px 10px}
.faq-stack-head{max-width:68ch;margin-bottom:14px}
.faq-row{border-top:1px solid rgba(255,255,255,.08)}
.faq-row:last-child{border-bottom:1px solid rgba(255,255,255,.08)}
.faq-row summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 4px;color:#fff;font-weight:700;cursor:pointer}
.faq-row summary::-webkit-details-marker{display:none}
.faq-row summary span{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);font-size:1.15rem;line-height:1;transition:transform .25s ease}
.faq-row[open] summary span{transform:rotate(45deg)}
.faq-row p{padding:0 4px 18px;color:#d8ccbc;line-height:1.72;max-width:72ch}
.cta-band{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:30px 32px}
.cta-band .cta-actions{display:flex;gap:14px;flex-wrap:wrap}
@media (max-width: 1100px){.city-grid,.city-benefits-grid,.booking-steps{grid-template-columns:repeat(2,minmax(0,1fr))}.booking-flow-head,.booking-flow-footer{grid-template-columns:1fr}}
@media (max-width: 768px){.city-grid,.city-benefits-grid,.city-photo-grid,.booking-steps{grid-template-columns:1fr}.city-photo-grid{grid-template-rows:auto}.city-photo-card,.city-photo-card--large{min-height:270px}.city-photo-overlay,.city-photo-card--large .city-photo-overlay{padding:20px}.city-quickbar{grid-template-columns:1fr;padding:8px 14px}.city-quickbar-item{padding:14px 6px}.city-quickbar-item + .city-quickbar-item{border-left:0;border-top:1px solid rgba(255,255,255,.06)}.city-benefits,.booking-flow,.faq-stack,.cta-band{padding:22px}.booking-flow-footer{grid-template-columns:1fr}.cta-band{flex-direction:column;align-items:flex-start}}

@media (hover: hover) and (pointer: fine){.city-photo-card:hover .city-photo-index,.city-photo-card:hover .city-photo-expand{transform:translateY(-2px)}.city-photo-index,.city-photo-expand{transition:transform .35s ease, background .35s ease, border-color .35s ease}}

.lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(4,6,9,.88);backdrop-filter:blur(12px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease, visibility .28s ease;z-index:120}
.lightbox.is-open{opacity:1;visibility:visible;pointer-events:auto}
.lightbox img{max-width:min(92vw,1200px);max-height:88vh;border-radius:24px;border:1px solid rgba(255,255,255,.12);box-shadow:0 40px 90px rgba(0,0,0,.45);object-fit:contain;background:#090c10}
.lightbox-close{position:absolute;top:18px;right:18px;width:46px;height:46px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(8,10,14,.62);backdrop-filter:blur(12px);color:#fff;font-size:1.6rem;line-height:1;cursor:pointer}
.lightbox-close:hover{border-color:rgba(216,164,90,.4);background:rgba(216,164,90,.12)}
@media (max-width:768px){.lightbox{padding:16px}.lightbox img{max-width:100%;max-height:82vh;border-radius:18px}.lightbox-close{top:12px;right:12px;width:42px;height:42px}}


/* floating contact icons */
.floating-contact{
position:fixed;
right:14px;
bottom:92px;
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
gap:12px;
width:62px;
padding:10px 0;
box-sizing:content-box;
border-radius:30px;
background:linear-gradient(180deg,rgba(18,22,28,.72),rgba(10,12,16,.54));
border:1px solid rgba(255,255,255,.06);
backdrop-filter:blur(16px);
-webkit-backdrop-filter:blur(16px);
box-shadow:0 22px 55px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.04);
z-index:9999;
opacity:0;
transform:translateY(20px) scale(.96);
pointer-events:none;
transition:opacity .32s ease, transform .32s ease, box-shadow .32s ease;
}
.floating-contact.show{
opacity:1;
transform:translateY(0) scale(1);
pointer-events:auto;
}
.fc-btn{
width:62px;
height:62px;
margin:0 auto;
flex:0 0 62px;
border-radius:20px;
display:flex;
align-items:center;
justify-content:center;
position:relative;
overflow:hidden;
background:linear-gradient(180deg,rgba(22,26,33,.96),rgba(10,12,16,.96));
border:1px solid rgba(255,255,255,.07);
backdrop-filter:blur(14px);
-webkit-backdrop-filter:blur(14px);
box-shadow:0 14px 34px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.04), inset 0 0 0 1px rgba(216,164,90,.05);
color:#d8a45a;
transition:transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s cubic-bezier(.2,.8,.2,1), border-color .28s ease, color .28s ease, background .28s ease;
}
.fc-btn::after{
content:"";
position:absolute;
inset:9px;
border-radius:15px;
border:1px solid rgba(216,164,90,.11);
pointer-events:none;
}
.fc-btn i{
position:relative;
z-index:1;
display:flex;
align-items:center;
justify-content:center;
font-size:22px;
line-height:1;
color:currentColor;
text-shadow:0 0 14px rgba(216,164,90,.16);
transform:translateX(0);
}
.fc-btn.phone i{transform:translateX(1px);}
.fc-btn:hover{
transform:translateY(-4px) scale(1.03);
background:linear-gradient(180deg,rgba(26,31,39,.98),rgba(12,15,20,.98));
border-color:rgba(216,164,90,.24);
box-shadow:0 20px 44px rgba(0,0,0,.62),0 0 22px rgba(216,164,90,.16), inset 0 1px 0 rgba(255,255,255,.06), inset 0 0 0 1px rgba(216,164,90,.08);
color:#f0c57d;
}
.fc-btn:active{transform:translateY(-1px) scale(.99);}
@media (max-width: 767px){
  .sticky-call{display:none !important}
  .floating-contact{right:12px;bottom:88px;width:56px;padding:8px 0;gap:10px;border-radius:26px}
  .fc-btn{width:56px;height:56px;border-radius:18px;flex-basis:56px}
  .fc-btn::after{inset:8px;border-radius:13px}
  .fc-btn i{font-size:20px}
  .back-to-top::after{inset:8px;border-radius:13px}
  .back-to-top{right:12px;bottom:18px;width:56px;height:56px;border-radius:18px;font-size:20px;z-index:10001}
}


html,body{
  max-width:100%;
}

body.mobile-open{
  overflow:hidden;
}

h1,h2,h3,.serif{
  overflow-wrap:anywhere;
}

.metric,
.info-item,
.feature-card,
.proof-card,
.timeline-card,
.list-card,
.contact-item,
.signature-card,
.cta-copy,
.cta-side,
.content-card,
.form-wrap{
  min-width:0;
}

.nav a,
.footer-nav a,
.btn,
.btn-soft,
.btn-ghost{
  -webkit-tap-highlight-color:transparent;
}

.input,
.textarea,
.btn,
.btn-soft,
.btn-ghost,
.mobile-toggle{
  min-height:52px;
}

@media (max-width:1080px){
  .container{width:min(100% - 28px, 1180px)}
  .header-inner{gap:16px}
  .nav{gap:18px}
  .hero{padding:34px 0 22px}
  .hero-grid{gap:34px}
  .hero-copy{padding:14px 0 8px}
  .hero-copy .lead{max-width:62ch}
  .hero-metrics{max-width:none}
  .hero-visual{min-height:560px}
  .hero-stage,.refined-stage{min-height:560px}
  .proof-list{grid-template-columns:1fr 1fr}
  .signature-shell{grid-template-columns:1fr;gap:22px;padding:28px}
}

@media (max-width:900px){
  .section-head{margin-bottom:26px}
  .header{padding-top:12px}
  .header-inner{padding:14px 16px;border-radius:22px}
  .brand-logo{height:54px}
  .hero-copy h1{max-width:11ch}
  .hero-actions{gap:12px}
  .hero-actions .btn,
  .hero-actions .btn-soft,
  .hero-actions .btn-ghost{padding-left:20px;padding-right:20px}
  .hero-metrics{grid-template-columns:1fr;gap:12px;margin-top:26px}
  .metric{padding:22px 20px}
  .info-strip{gap:14px}
  .proof-list,
  .proof-stats,
  .signature-grid{grid-template-columns:1fr}
  .proof-card{min-height:unset}
  .gallery-grid{gap:16px}
  .page-hero{padding:42px 0 12px}
  .page-hero-grid{gap:22px}
  .page-shot{min-height:420px}
  .contact-grid{gap:18px}
  .cta-copy,.cta-side,.content-card,.form-wrap{padding:28px}
  .footer{padding-bottom:118px}
}

@media (max-width:820px){
  .container{width:min(100% - 24px, 1180px)}
  .mobile-open .nav{
    position:fixed;
    left:12px;
    right:12px;
    top:86px;
    z-index:1200;
    max-height:calc(100vh - 108px);
    overflow:auto;
    gap:0;
    padding:12px;
  }
  .mobile-open .nav a{
    width:100%;
    padding:14px 12px;
    border-radius:16px;
  }
  .mobile-open .nav a::after{display:none}
  .mobile-open .nav a:hover,
  .mobile-open .nav a.active{background:rgba(255,255,255,.05)}
  .hero{padding-top:22px}
  .hero-grid{gap:22px}
  .hero-copy .lead{margin-top:18px;font-size:1rem}
  .hero-actions{margin-top:22px}
  .hero-actions .btn,
  .hero-actions .btn-soft,
  .hero-actions .btn-ghost{
    width:auto;
    flex:0 0 auto;
  }
  .hero-visual{min-height:420px}
  .hero-stage,.refined-stage{min-height:420px}
  .hero-stage img,.page-shot img,.media-card img,.gallery-card img{object-position:center center}
  .hero-overlay{left:14px;right:14px;bottom:14px;border-radius:18px}
  .info-item,
  .feature-card,
  .timeline-card,
  .proof-summary,
  .proof-card,
  .spotlight,
  .list-card,
  .signature-card{padding:22px}
  .section-head p,
  .lead,
  .content-card p,
  .proof-summary p,
  .signature-copy p{max-width:none}
  .gallery-grid,.gallery-page{gap:14px}
  .gallery-card,.page-shot,.media-card{border-radius:24px}
  .page-shot,.media-card{min-height:340px}
  .contact-item{padding:20px}
  .form-grid{gap:12px}
  .sticky-call{
    left:10px;
    right:10px;
    bottom:10px;
    gap:12px;
    padding:12px;
    border-radius:20px;
  }
  .sticky-call .btn{padding-left:18px;padding-right:18px;min-width:146px}
}

@media (max-width:640px){
  .section{padding:68px 0}
  .section.compact{padding:54px 0}
  .section.tight{padding:34px 0}
  h2{font-size:clamp(2rem,9vw,3rem)}
  .kicker{padding:9px 12px;font-size:.68rem;letter-spacing:.14em}
  .header-inner{padding:12px 14px}
  .brand-logo{height:44px}
  .mobile-toggle{padding:0 18px}
  .hero-copy h1{font-size:clamp(2.5rem,12vw,3.5rem);max-width:9ch}
  .hero-visual{min-height:360px}
  .hero-stage,.refined-stage{min-height:360px}
  .single-overlay{max-width:calc(100% - 32px);padding:16px 16px 15px}
  .single-overlay strong{font-size:1.7rem}
  .metric strong,.proof-stat strong{font-size:1.7rem}
  .proof-person{margin-top:14px;padding-top:14px}
  .cta-copy,.cta-side,.content-card,.form-wrap,.signature-shell{padding:22px}
  .input,.textarea{padding:15px 16px;border-radius:14px}
  .sticky-call{display:none}
  .sticky-call .btn{width:auto;flex:0 0 auto}
  .back-to-top{right:10px;bottom:18px;width:54px;height:54px;border-radius:17px;z-index:10001}
}

@media (max-width:480px){
  .container{width:min(100% - 18px, 1180px)}
  .header{padding-top:10px}
  .header-inner{border-radius:18px}
  .hero{padding-top:16px}
  .hero-copy h1{font-size:clamp(2.15rem,11.6vw,3rem)}
  .hero-copy .lead{font-size:.96rem}
  .hero-visual{min-height:320px}
  .hero-stage,.refined-stage{min-height:320px}
  .hero-overlay{padding:14px}
  .single-overlay{left:12px;bottom:12px}
  .single-overlay strong{font-size:1.5rem}
  .proof-summary,.proof-card,.feature-card,.info-item,.timeline-card,.list-card,.spotlight,.signature-card{padding:18px}
  .gallery-grid,.gallery-page{grid-auto-rows:220px}
  .page-shot,.media-card{min-height:280px}
  .footer-row{gap:12px}
  .footer-nav{gap:12px;font-size:.95rem}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important}
}


/* Classic gallery refresh */
.classic-gallery-wrap{position:relative}
.classic-gallery{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  align-items:start;
}
.classic-gallery .gallery-card{
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(10,12,16,.9),rgba(14,17,23,.86));
  border:1px solid rgba(255,255,255,.07);
  box-shadow:0 18px 44px rgba(0,0,0,.22);
}
.classic-gallery .gallery-link{
  display:block;
  position:relative;
  overflow:hidden;
  background:#090b0f;
}
.classic-gallery .gallery-card img{
  display:block;
  width:100%;
  aspect-ratio:4/3;
  height:auto;
  object-fit:cover;
  object-position:center;
  filter:none;
  transition:transform .45s ease;
}
.classic-gallery .gallery-card:hover img{transform:scale(1.025)}
.classic-gallery .overlay{display:none}
.gallery-caption{padding:14px 16px 16px;background:rgba(15,19,25,.96);border-top:1px solid var(--line)}
.gallery-caption strong{display:block;font-size:1rem}
.gallery-caption p{margin:6px 0 0;color:var(--muted);font-size:.94rem;line-height:1.55}
.gallery-lightbox{position:fixed;inset:0;background:rgba(5,7,10,.88);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:28px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s ease, visibility .25s ease;z-index:1200}
.gallery-lightbox.is-open{opacity:1;visibility:visible;pointer-events:auto}
.gallery-lightbox img{max-width:min(1200px,92vw);max-height:86vh;border-radius:24px;box-shadow:0 24px 90px rgba(0,0,0,.45)}
.lightbox-close{position:absolute;top:22px;right:22px;width:52px;height:52px;border-radius:16px;font-size:2rem;line-height:1;background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.14)}
.footer a{color:inherit}
.footer a:hover{color:#fff}

@media (max-width:1024px){
  .classic-gallery{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
}

@media (max-width:640px){
  .classic-gallery{grid-template-columns:1fr;gap:16px}
  .gallery-caption{padding:12px 14px 14px}
}


/* Gallery stability fix */
.classic-gallery{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  align-items:start;
  grid-auto-flow:row;
}
.classic-gallery > *{min-width:0}
.classic-gallery .gallery-card{
  margin:0;
  position:relative;
  isolation:isolate;
  contain:layout paint;
}
.classic-gallery .gallery-link,
.classic-gallery .gallery-caption{position:relative;z-index:1}
.classic-gallery .gallery-link img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover}
.footer{clear:both;position:relative;z-index:0}

@media (max-width:1024px){
  .classic-gallery{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:640px){
  .classic-gallery{grid-template-columns:1fr;}
}


/* ===== V9 image polish: natural image display across the whole site ===== */
.hero-stage,
.page-shot,
.media-card,
.gallery-card,
.thumb,
.preview-box,
.preview-inline img{
  background:#0b1016;
}

.page-shot,
.media-card{
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

.page-shot{
  min-height:auto;
  padding:16px;
}

.page-shot img{
  display:block;
  width:100%;
  height:auto;
  max-height:640px;
  object-fit:contain;
  object-position:center center;
  border-radius:22px;
  filter:none;
}

.media-card{
  min-height:auto;
  padding:16px;
}

.media-card img{
  display:block;
  width:100%;
  height:auto;
  max-height:680px;
  object-fit:contain;
  object-position:center center;
  border-radius:22px;
  filter:none;
}

.media-card .overlay{
  display:none;
}

.gallery-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  grid-auto-rows:auto;
  align-items:start;
}

.gallery-grid .wide,
.gallery-grid .tall{
  grid-column:auto;
  grid-row:auto;
}

.gallery-grid .gallery-card{
  display:flex;
  flex-direction:column;
  padding:0;
  background:linear-gradient(180deg,rgba(12,16,23,.98),rgba(9,12,18,.98));
}

.gallery-grid .gallery-card img{
  display:block;
  width:100%;
  height:auto;
  max-height:none;
  object-fit:contain;
  object-position:center center;
  filter:none;
  background:#0b1016;
}

.classic-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;
  align-items:start;
}

.classic-gallery > *{
  min-width:0;
}

.classic-gallery .gallery-card{
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border-radius:26px;
  background:linear-gradient(180deg,rgba(12,16,23,.98),rgba(9,12,18,.98));
}

.classic-gallery .gallery-link{
  display:block;
  background:#0b1016;
}

.classic-gallery .gallery-link img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:auto;
  object-fit:contain;
  object-position:center center;
  filter:none;
  transform:none;
  background:#0b1016;
}

.classic-gallery .gallery-card:hover img{
  transform:none;
}

.gallery-caption{
  padding:14px 16px 16px;
  background:rgba(15,19,25,.98);
}

.gallery-caption:empty{
  display:none;
}

.gallery-card figcaption strong:empty,
.gallery-card figcaption p:empty{
  display:none;
}

.thumb img{
  width:100%;
  height:220px;
  object-fit:contain;
  border-radius:14px;
  background:#0b1016;
  padding:8px;
}

.preview-box img,
.preview-inline img{
  object-fit:contain;
  background:#0b1016;
  padding:6px;
}

@media (max-width: 980px){
  .gallery-grid{
    grid-template-columns:1fr;
    gap:18px;
  }

  .page-shot,
  .media-card{
    padding:14px;
  }

  .page-shot img,
  .media-card img{
    max-height:none;
  }
}


.gallery-grid .overlay{
  position:static;
  padding:14px 16px 16px;
  background:rgba(15,19,25,.98);
}
.gallery-grid .overlay strong:empty,
.gallery-grid .overlay p:empty,
.gallery-grid .overlay:has(strong:empty):has(p:empty){
  display:none;
}


/* ===== V10 final polish: stable 4:3 gallery + clearer hero ===== */
.hero-stage img{filter:brightness(.9) saturate(1.02) contrast(1.01);}
.hero-stage::before{background:linear-gradient(125deg, rgba(8,10,14,.12) 0%, rgba(8,10,14,.34) 42%, rgba(8,10,14,.14) 100%),radial-gradient(circle at 78% 18%, rgba(244,213,159,.1), transparent 22%),linear-gradient(180deg, rgba(8,10,14,0) 52%, rgba(8,10,14,.44) 100%);}
.hero-stage::after{opacity:.7;}
.single-overlay{background:rgba(7,9,13,.48);border-color:rgba(255,255,255,.12);box-shadow:0 18px 46px rgba(0,0,0,.22);}
.single-overlay p{color:#e0d4c3;}
.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;align-items:start;}
.gallery-grid .gallery-card,.gallery-grid .wide,.gallery-grid .tall{grid-column:auto !important;grid-row:auto !important;}
.gallery-grid .gallery-card{overflow:hidden;border-radius:26px;}
.gallery-grid .gallery-card img{width:100%;aspect-ratio:4/3;height:auto;object-fit:cover;object-position:center;display:block;}
.gallery-grid .overlay{position:static;padding:14px 16px 16px;background:rgba(15,19,25,.98);border-top:1px solid var(--line);}
.gallery-grid .overlay strong{display:block;}
.gallery-grid .overlay p{margin-top:6px;}
@media (max-width:860px){.gallery-grid{grid-template-columns:1fr;}}
.classic-gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;align-items:start;}
.classic-gallery .gallery-card{border-radius:24px;overflow:hidden;background:linear-gradient(180deg,rgba(12,16,23,.98),rgba(9,12,18,.98));border:1px solid rgba(255,255,255,.07);box-shadow:0 18px 44px rgba(0,0,0,.22);}
.classic-gallery .gallery-link{display:block;background:#0b1016;}
.classic-gallery .gallery-link img{width:100%;aspect-ratio:4 / 3;height:auto;object-fit:cover;object-position:center;display:block;background:#0b1016;transition:transform .35s ease;}
.classic-gallery .gallery-card:hover .gallery-link img{transform:scale(1.03);}
.gallery-caption{display:none !important;}
.gallery-lightbox{background:rgba(5,7,10,.92);backdrop-filter:blur(10px);}
.gallery-lightbox img{width:auto;height:auto;max-width:min(1280px,94vw);max-height:90vh;object-fit:contain;background:#0b1016;}
@media (max-width:1024px){.classic-gallery{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;}}
@media (max-width:640px){.classic-gallery{grid-template-columns:1fr;gap:16px;}}


/* === V3.1 polish overrides === */
.header{padding:10px 0 0}
.header-inner{
  min-height:78px;
  border-radius:26px;
  background:rgba(8,10,14,.64);
  border-color:rgba(255,255,255,.08);
  backdrop-filter:blur(22px);
}
.header .nav a{
  font-weight:600;
  color:#efe6d8;
}
.header .nav a::after{
  height:2px;
  bottom:-7px;
  box-shadow:0 0 12px rgba(216,164,90,.25);
}
.header-call{white-space:nowrap}
.hero-refined .hero-stage img{filter:brightness(.84) saturate(1)}
.hero-refined .hero-stage::before{
  background:
    linear-gradient(120deg, rgba(8,10,14,.18) 0%, rgba(8,10,14,.46) 42%, rgba(8,10,14,.14) 100%),
    radial-gradient(circle at 78% 18%, rgba(244,213,159,.14), transparent 20%),
    linear-gradient(180deg, rgba(8,10,14,0) 42%, rgba(8,10,14,.70) 100%);
}
.hero-trust{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:20px;
}
.hero-trust span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  color:#f0e2c9;
  font-size:.92rem;
  line-height:1.3;
  backdrop-filter:blur(12px);
}
.home-gallery-grid .gallery-card{
  border-radius:26px;
  overflow:hidden;
}
.home-gallery-grid .gallery-link{
  display:block;
  background:#0b1016;
}
.home-gallery-grid .gallery-link img{
  width:100%;
  aspect-ratio:4/3;
  height:auto;
  object-fit:cover;
  display:block;
  transition:transform .35s ease;
}
.home-gallery-grid .gallery-card:hover .gallery-link img{transform:scale(1.03)}
.home-gallery-grid .overlay{
  position:absolute;
  left:0; right:0; bottom:0;
  padding:24px;
}
.classic-gallery{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}
.classic-gallery .gallery-card{
  border-radius:24px;
  overflow:hidden;
  background:linear-gradient(180deg,rgba(12,16,23,.98),rgba(9,12,18,.98));
  border:1px solid rgba(255,255,255,.07);
  box-shadow:0 18px 44px rgba(0,0,0,.22);
}
.classic-gallery .gallery-link{display:block;background:#0b1016}
.classic-gallery .gallery-link img{
  width:100%;
  aspect-ratio:4 / 3;
  height:auto;
  object-fit:cover;
  object-position:center;
  display:block;
  background:#0b1016;
  transition:transform .35s ease;
}
.classic-gallery .gallery-card:hover .gallery-link img{transform:scale(1.03)}
.gallery-caption{
  padding:18px 18px 20px;
}
.gallery-caption strong{
  display:block;
  color:#fff;
  line-height:1.25;
}
.gallery-caption p{
  margin-top:6px;
  font-size:.95rem;
}
.gallery-lightbox{
  background:rgba(5,7,10,.92);
  backdrop-filter:blur(10px);
}
.gallery-lightbox img{
  width:auto;
  height:auto;
  max-width:min(1280px,94vw);
  max-height:90vh;
  object-fit:contain;
  background:#0b1016;
}
.contact-grid-v31{
  display:grid;
  grid-template-columns:.94fr 1.06fr;
  gap:22px;
}
.contact-quick{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:24px;
}
.contact-meta{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:22px;
}
.contact-meta > div,
.faq-item{
  padding:18px 20px;
  border-radius:22px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}
.contact-meta small{
  display:block;
  color:var(--muted-2);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.68rem;
}
.contact-meta strong{
  display:block;
  margin-top:10px;
  color:#fff;
}
.contact-form-v31{
  display:grid;
  gap:16px;
  margin-top:18px;
}
.form-grid-v31{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.contact-form-v31 label span{
  display:block;
  margin-bottom:8px;
  color:#efe3d0;
  font-size:.92rem;
}
.contact-form-v31 input,
.contact-form-v31 textarea,
.contact-form-v31 select{
  width:100%;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:#fff;
  padding:15px 16px;
  outline:none;
}
.contact-form-v31 textarea{
  min-height:150px;
  resize:vertical;
}
.contact-form-v31 input:focus,
.contact-form-v31 textarea:focus,
.contact-form-v31 select:focus{
  border-color:rgba(216,164,90,.4);
  box-shadow:0 0 0 4px rgba(216,164,90,.10);
}
.form-note{
  color:#a89e8e;
  font-size:.92rem;
}
.faq-v31 .faq-list{
  display:grid;
  gap:14px;
}
.faq-item summary{
  cursor:pointer;
  font-weight:700;
  color:#fff;
}
.faq-item p{
  margin-top:12px;
}
.form-toast{
  position:fixed;
  left:50%;
  bottom:24px;
  transform:translateX(-50%) translateY(18px);
  padding:14px 18px;
  border-radius:999px;
  background:#12151b;
  color:#fff;
  border:1px solid rgba(255,255,255,.09);
  box-shadow:0 18px 40px rgba(0,0,0,.28);
  opacity:0;
  pointer-events:none;
  transition:opacity .28s ease, transform .28s ease;
  z-index:1200;
}
.form-toast.show{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}
@media (max-width:1024px){
  .classic-gallery{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
  .contact-grid-v31{grid-template-columns:1fr}
}
@media (max-width:820px){
  .header-actions .mobile-toggle{display:inline-flex}
  .header-actions .header-call{display:none}
  .mobile-open .nav{
    display:flex;
    position:absolute;
    left:16px;
    right:16px;
    top:82px;
    flex-direction:column;
    align-items:flex-start;
    padding:18px;
    border-radius:24px;
    background:rgba(8,10,14,.97);
    border:1px solid var(--line);
    box-shadow:var(--shadow);
  }
}
@media (max-width:640px){
  .hero-trust span{width:100%;justify-content:flex-start}
  .form-grid-v31,
  .contact-meta{grid-template-columns:1fr}
  .classic-gallery{grid-template-columns:1fr;gap:16px}
}


/* === MOBILE OPTIMIZATION PATCH / TITLE MASTER === */
html,body{
  overflow-x:hidden;
}
img,video{
  max-width:100%;
  height:auto;
}
.hero-copy,
.hero-visual,
.page-hero-grid > *,
.split > *,
.social-proof-grid > *,
.spotlight-grid > *,
.contact-grid > *,
.contact-grid-v31 > *{
  min-width:0;
}
.hero-actions .btn,
.hero-actions .btn-soft,
.hero-actions .btn-ghost,
.header-actions .btn,
.header-actions .btn-soft,
.header-actions .btn-ghost{
  white-space:normal;
  text-align:center;
}
.hero-overlay,
.single-overlay,
.form-wrap,
.content-card,
.proof-card,
.proof-summary,
.signature-shell,
.contact-item,
.list-card,
.spotlight,
.feature-card,
.timeline-card,
.metric,
.info-item{
  overflow:hidden;
}
@media (max-width:1024px){
  .hero-copy h1{max-width:10.5ch;}
  .hero-phone{font-size:1.55rem;}
  .hero-overlay p{max-width:none;}
  .social-proof-grid,
  .spotlight-grid,
  .contact-grid,
  .contact-grid-v31,
  .page-hero-grid,
  .split,
  .cta-grid,
  .hero-grid{grid-template-columns:1fr;}
}
@media (max-width:820px){
  .header{padding-top:10px;}
  .header-inner{
    grid-template-columns:minmax(0,1fr) auto;
    gap:10px;
    padding:12px 14px;
  }
  .brand{min-width:0;gap:10px;}
  .brand-copy{min-width:0;}
  .brand-copy strong,
  .brand-copy span{
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .mobile-open{overflow:hidden;}
  .mobile-open .nav{
    display:flex;
    position:fixed;
    left:10px;
    right:10px;
    top:84px;
    bottom:10px;
    max-height:none;
    align-items:stretch;
    padding:12px;
    gap:6px;
    overflow:auto;
  }
  .mobile-open .nav a{
    width:100%;
    padding:14px 14px;
    line-height:1.35;
  }
  .hero{padding:18px 0 10px;}
  .hero-grid{gap:18px;}
  .hero-copy h1{
    font-size:clamp(2.35rem,11vw,3.6rem);
    max-width:9.5ch;
  }
  .hero-copy .lead,
  .page-hero .lead{font-size:1rem;line-height:1.65;}
  .hero-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
    width:100%;
  }
  .hero-actions .btn,
  .hero-actions .btn-soft,
  .hero-actions .btn-ghost,
  .sticky-call .btn{
    width:100%;
    justify-content:center;
  }
  .hero-visual,
  .hero-stage,
  .refined-stage{min-height:390px;}
  .hero-overlay,
  .single-overlay{
    left:12px;
    right:12px;
    bottom:12px;
    padding:16px;
    border-radius:18px;
  }
  .hero-overlay strong{font-size:1.18rem;max-width:none;}
  .hero-phone{font-size:1.2rem;white-space:normal;}
  .section-head{gap:16px;}
  .section-head p{font-size:.98rem;}
  .info-strip,
  .proof-stats,
  .proof-list,
  .grid-3,
  .grid-4,
  .timeline,
  .form-grid,
  .form-grid-v31,
  .contact-meta{grid-template-columns:1fr;}
  .gallery-grid,
  .gallery-page,
  .classic-gallery{grid-template-columns:1fr;}
  .gallery-grid,
  .gallery-page{grid-auto-rows:auto;}
  .gallery-card img,
  .classic-gallery .gallery-link img,
  .home-gallery-grid .gallery-link img{aspect-ratio:4/3;object-fit:cover;}
  .page-shot,
  .media-card{min-height:320px;}
  .cta-copy,
  .cta-side,
  .content-card,
  .form-wrap,
  .signature-shell{padding:22px;}
  .floating-contact{
    right:10px;
    bottom:82px;
  }
  .back-to-top{
    right:10px;
    bottom:14px;
  }
}
@media (max-width:640px){
  .container{width:min(100% - 18px, 1180px);}
  h1{letter-spacing:-.04em;}
  .brand-logo{height:42px;}
  .brand-copy strong{font-size:.86rem;}
  .brand-copy span{font-size:.6rem;}
  .mobile-toggle{min-width:50px;padding:0 14px;}
  .hero-copy h1{font-size:clamp(2.1rem,11.4vw,3rem);max-width:9ch;}
  .hero-copy .lead{margin-top:16px;font-size:.98rem;}
  .hero-visual,
  .hero-stage,
  .refined-stage{min-height:350px;}
  .hero-overlay,
  .single-overlay{padding:14px;}
  .single-overlay strong{font-size:1.45rem;}
  .hero-phone{font-size:1.05rem;}
  .proof-card blockquote,
  .content-card p,
  .proof-summary p,
  .spotlight p,
  .list-card li,
  .lead{font-size:.97rem;line-height:1.7;}
  .footer-row{align-items:flex-start;}
  .footer-nav{gap:12px 14px;}
}
@media (max-width:480px){
  .header-inner{padding:10px 12px;border-radius:18px;}
  .brand{gap:8px;}
  .brand-logo{height:38px;}
  .brand-copy span{display:none;}
  .hero{padding-top:12px;}
  .section{padding:60px 0;}
  .section.compact{padding:48px 0;}
  .section.tight{padding:30px 0;}
  .hero-copy h1{font-size:clamp(1.95rem,11vw,2.75rem);}
  .hero-actions{gap:9px;}
  .hero-actions .btn,
  .hero-actions .btn-soft,
  .hero-actions .btn-ghost,
  .btn,
  .btn-soft,
  .btn-ghost{padding:15px 18px;border-radius:16px;}
  .hero-visual,
  .hero-stage,
  .refined-stage,
  .page-shot,
  .media-card{min-height:300px;}
  .metric,
  .info-item,
  .feature-card,
  .proof-card,
  .proof-summary,
  .content-card,
  .contact-item,
  .form-wrap,
  .list-card,
  .spotlight,
  .signature-shell{padding:18px;}
  .floating-contact{
    right:8px;
    bottom:76px;
    width:52px;
    border-radius:22px;
    gap:8px;
    padding:7px 0;
  }
  .fc-btn{width:52px;height:52px;flex-basis:52px;border-radius:16px;}
  .fc-btn::after{inset:7px;border-radius:11px;}
  .fc-btn i{font-size:18px;}
  .back-to-top{width:50px;height:50px;border-radius:16px;font-size:18px;}
}


/* === NEXT LEVEL global polish === */
body::before,
body::after{
  content:"";
  position:fixed;
  inset:auto;
  pointer-events:none;
  z-index:-1;
}
body::before{
  top:-12vh;
  left:-10vw;
  width:42vw;
  height:42vw;
  border-radius:50%;
  background:radial-gradient(circle, rgba(216,164,90,.12), transparent 62%);
  filter:blur(12px);
  opacity:.9;
}
body::after{
  right:-12vw;
  top:26vh;
  width:34vw;
  height:34vw;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.07), transparent 58%);
  opacity:.55;
}
.container{width:min(1240px,calc(100% - 32px));}
.section:not(.hero)::before,
.page-hero::before{
  content:"";
  position:absolute;
  left:50%;
  top:0;
  width:min(1180px, calc(100% - 32px));
  height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg, transparent 0%, rgba(216,164,90,.18) 18%, rgba(255,255,255,.08) 50%, rgba(216,164,90,.18) 82%, transparent 100%);
}
.hero::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  width:min(1180px, calc(100% - 32px));
  height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg, transparent 0%, rgba(216,164,90,.16) 20%, rgba(255,255,255,.06) 50%, rgba(216,164,90,.16) 80%, transparent 100%);
}
.card,
.gallery-card,
.page-shot,
.media-card,
.hero-stage,
.classic-gallery .gallery-card,
.proof-stat,
.faq-item,
.contact-meta > div{
  position:relative;
}
.card::after,
.gallery-card::after,
.page-shot::after,
.media-card::after,
.hero-stage::after,
.classic-gallery .gallery-card::after,
.proof-stat::after,
.faq-item::after,
.contact-meta > div::after{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:inherit;
  border:1px solid rgba(255,255,255,.035);
  pointer-events:none;
}
.card:hover,
.feature-card:hover,
.info-item:hover,
.proof-card:hover,
.content-card:hover,
.list-card:hover,
.spotlight:hover,
.timeline-card:hover,
.gallery-card:hover,
.classic-gallery .gallery-card:hover,
.proof-stat:hover,
.contact-meta > div:hover{
  border-color:rgba(216,164,90,.16);
  box-shadow:0 34px 80px rgba(0,0,0,.34), 0 0 0 1px rgba(216,164,90,.06) inset;
  transform:translateY(-4px);
}
.card,
.feature-card,
.info-item,
.proof-card,
.content-card,
.list-card,
.spotlight,
.timeline-card,
.gallery-card,
.classic-gallery .gallery-card,
.proof-stat,
.contact-meta > div{
  transition:transform .32s ease, box-shadow .32s ease, border-color .32s ease, background .32s ease;
}
.btn,.btn-soft,.btn-ghost{
  position:relative;
  overflow:hidden;
}
.btn::before,.btn-soft::before,.btn-ghost::before{
  content:"";
  position:absolute;
  top:-120%;
  left:-40%;
  width:42%;
  height:300%;
  transform:rotate(22deg);
  background:linear-gradient(180deg, transparent 0%, rgba(255,255,255,.16) 50%, transparent 100%);
  opacity:0;
  transition:left .55s ease, opacity .28s ease;
}
.btn:hover::before,.btn-soft:hover::before,.btn-ghost:hover::before{
  left:118%;
  opacity:1;
}
.header-inner{
  background:linear-gradient(180deg, rgba(8,10,14,.78), rgba(8,10,14,.6));
  box-shadow:0 16px 60px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.03);
}
.header.scrolled .header-inner{
  box-shadow:0 24px 60px rgba(0,0,0,.34), 0 0 0 1px rgba(216,164,90,.08) inset;
}
.nav{
  padding:12px 18px;
  border-radius:999px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
}
.header-call{
  min-width:186px;
  padding:14px 18px;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  border-radius:20px;
}
.header-call-label{
  font-size:.74rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  opacity:.82;
}
.header-call strong{
  font-size:1rem;
  line-height:1.05;
  letter-spacing:.01em;
}
.hero-copy h1,
.page-hero h1,
.section h2.serif{
  text-shadow:0 8px 28px rgba(0,0,0,.22);
}
.hero-copy .lead,
.page-hero .lead{
  color:#d2c6b7;
}
.hero-stage,
.page-shot,
.media-card{
  transform:perspective(1500px) rotateX(var(--tilt-x,0deg)) rotateY(var(--tilt-y,0deg)) translate3d(0,var(--tilt-lift,0px),0);
  transform-style:preserve-3d;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.hero-stage:hover,
.page-shot:hover,
.media-card:hover{
  --tilt-lift:-4px;
  border-color:rgba(216,164,90,.18);
  box-shadow:0 34px 90px rgba(0,0,0,.38);
}
.hero-stage img,
.page-shot img,
.media-card img{
  transition:transform .7s ease, filter .35s ease;
}
.hero-stage:hover img,
.page-shot:hover img,
.media-card:hover img{
  transform:scale(1.035) translate3d(var(--img-shift-x,0px),var(--img-shift-y,0px),0);
}
.section-head{
  margin-bottom:38px;
}
.section-head > div{max-width:720px;}
.info-strip .info-item,
.hero-metrics .metric,
.proof-stat,
.list-card li,
.signature-points span,
.hero-trust span{
  backdrop-filter:blur(16px);
}
.footer{
  margin-top:36px;
  padding:52px 0 108px;
  border-top:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(8,10,14,.08), rgba(8,10,14,.28));
}
.footer-grid{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(220px,.72fr) minmax(280px,.9fr);
  gap:26px;
  align-items:start;
}
.footer-brand-title{
  display:block;
  font-size:1.22rem;
  color:#fff;
}
.footer-copy{
  margin-top:12px;
  max-width:60ch;
}
.footer-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.footer-badges span,
.footer-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#dbc9ad;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:.69rem;
}
.footer-badges span{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}
.footer-links-col{
  padding-top:4px;
}
.footer-nav{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px 18px;
  margin-top:14px;
}
.footer-nav a{
  color:#e8ddce;
}
.footer-cta{
  padding:24px;
  background:linear-gradient(180deg, rgba(216,164,90,.08), rgba(255,255,255,.03));
}
.footer-phone{
  display:block;
  margin-top:12px;
  font-size:clamp(1.35rem,2.2vw,1.9rem);
  line-height:1;
  color:#fff;
}
.footer-cta p{margin-top:12px;}
.footer-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;
}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-top:20px;
  padding-top:20px;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-bottom p{color:#bcae98;}
.gallery-grid .gallery-card,
.home-gallery-grid .gallery-card,
.classic-gallery .gallery-card{
  overflow:hidden;
}
.gallery-grid .gallery-link img,
.home-gallery-grid .gallery-link img,
.classic-gallery .gallery-link img{
  transition:transform .55s ease, filter .35s ease;
}
.gallery-grid .gallery-card:hover .gallery-link img,
.home-gallery-grid .gallery-card:hover .gallery-link img,
.classic-gallery .gallery-card:hover .gallery-link img{
  transform:scale(1.045);
  filter:brightness(.95) saturate(1.03);
}
.gallery-grid .overlay,
.home-gallery-grid .overlay{
  background:linear-gradient(180deg, transparent 0%, rgba(7,10,14,.16) 18%, rgba(7,10,14,.88) 100%);
}
.faq-item{
  overflow:hidden;
}
.faq-item summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{
  content:'+';
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.04);
  color:#fff;
  font-size:1.1rem;
  flex:0 0 auto;
}
.faq-item[open] summary::after{content:'−';}
.sticky-call{
  background:linear-gradient(180deg, rgba(8,10,14,.92), rgba(8,10,14,.82));
  border-color:rgba(216,164,90,.16);
  box-shadow:0 28px 60px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.03);
}
.floating-contact{
  background:rgba(8,10,14,.74);
  border-color:rgba(216,164,90,.18);
  box-shadow:0 20px 46px rgba(0,0,0,.3);
}
@media (max-width: 1024px){
  .footer-grid{grid-template-columns:1fr 1fr;}
  .footer-cta{grid-column:1/-1;}
}
@media (max-width: 820px){
  .nav{
    padding:0;
    background:transparent;
    border:none;
  }
  .footer-grid{grid-template-columns:1fr;gap:20px;}
  .footer-nav{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 640px){
  .container{width:min(100%,calc(100% - 24px));}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .footer-nav{grid-template-columns:1fr 1fr;}
  .footer-actions .btn,
  .footer-actions .btn-soft{min-width:0;flex:1 1 auto;}
}
