/* ═══════════════════════════════════════════════════════════════
   VARIABLES & RESET
═══════════════════════════════════════════════════════════════ */
:root {
  --navy:        #080f1c;
  --navy-2:      #0e1a2e;
  --navy-3:      #172540;
  --accent:      #c8a96e;
  --accent-lt:   #e4c99a;
  --cream:       #f5f0e8;
  --cream-2:     #ede8de;
  --white:       #ffffff;
  --text:        #1a2840;
  --muted:       #7a8da0;
  --border-d:    rgba(200,169,110,0.18);
  --border-l:    rgba(0,0,0,0.09);
  --glass-d:     rgba(200,169,110,0.06);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'DM Sans',sans-serif;
  background:var(--cream);
  color:var(--text);
  overflow-x:hidden;
  cursor:none;
}
[id] { scroll-margin-top:80px; }

/* ═══════════════════════════════════════════════════════════════
   CUSTOM CURSOR
═══════════════════════════════════════════════════════════════ */
.cursor-dot {
  width:8px; height:8px; background:var(--accent);
  border-radius:50%; position:fixed; pointer-events:none;
  z-index:9999; transform:translate(-50%,-50%);
  transition:transform .1s ease, opacity .2s ease;
}
.cursor-ring {
  width:36px; height:36px;
  border:1.5px solid rgba(200,169,110,0.5);
  border-radius:50%; position:fixed; pointer-events:none;
  z-index:9998; transform:translate(-50%,-50%);
  transition:transform .18s ease, width .2s ease, height .2s ease, opacity .2s ease;
}
body:has(a:hover) .cursor-ring,
body:has(button:hover) .cursor-ring { width:52px; height:52px; border-color:var(--accent); }

/* ═══════════════════════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════════════════════ */
nav {
  position:fixed; top:0; width:100%; z-index:500;
  background:rgba(8,15,28,0); backdrop-filter:blur(0px);
  border-bottom:1px solid transparent;
  transition:background .4s ease, border-color .4s ease, backdrop-filter .4s ease;
}
nav.scrolled {
  background:rgba(8,15,28,0.94);
  backdrop-filter:blur(20px);
  border-color:var(--border-d);
}
.nav-inner {
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 64px;
}
.logo {
  font-family:'Cormorant Garamond',serif;
  font-size:1.55rem; font-weight:700;
  color:var(--white); letter-spacing:1px;
  cursor:none;
}
.logo span { color:var(--accent); }
.nav-links {
  display:flex; gap:36px; list-style:none;
}
.nav-links a {
  color:rgba(245,242,237,0.65);
  text-decoration:none; font-size:0.82rem;
  letter-spacing:1.8px; text-transform:uppercase;
  font-weight:500; transition:color .25s;
  cursor:none;
}
.nav-links a:hover { color:var(--accent); }
.nav-cta {
  background:var(--accent); color:var(--navy) !important;
  padding:10px 26px; border-radius:2px;
  font-size:0.82rem; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  text-decoration:none; transition:background .25s, transform .2s;
  cursor:none;
}
.nav-cta:hover { background:var(--accent-lt); transform:translateY(-1px); }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:none; padding:4px;
}
.hamburger span {
  display:block; width:24px; height:2px;
  background:var(--white); border-radius:2px;
  transition:all .3s ease;
}
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile nav */
.mobile-nav {
  display:none; flex-direction:column;
  background:rgba(8,15,28,0.97); padding:20px 32px 28px;
  border-top:1px solid var(--border-d);
  gap:0;
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  color:rgba(245,242,237,0.7); text-decoration:none;
  padding:14px 0; font-size:1rem; letter-spacing:1px;
  border-bottom:1px solid var(--border-d);
  transition:color .2s; cursor:none;
}
.mobile-nav a:hover { color:var(--accent); }
.mobile-cta {
  background:var(--accent) !important; color:var(--navy) !important;
  margin-top:16px; border-radius:2px; text-align:center;
  padding:14px !important; font-weight:700 !important;
  border:none !important; letter-spacing:1.5px;
}

/* ═══════════════════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════════════════ */
.hero {
  min-height:100vh; background:var(--navy);
  display:flex; flex-direction:column;
  position:relative; overflow:hidden;
}
.hero-grid-bg {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(200,169,110,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,169,110,0.035) 1px, transparent 1px);
  background-size:64px 64px;
  animation:gridDrift 24s linear infinite;
  pointer-events:none;
}
@keyframes gridDrift { 0%{transform:translateY(0)} 100%{transform:translateY(64px)} }

.hero-body {
  flex:1; display:grid; grid-template-columns:1fr 1fr;
  align-items:center; padding:140px 80px 80px 80px;
  position:relative; z-index:2; gap:40px;
}

/* Hero Left */
.hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--glass-d); border:1px solid var(--border-d);
  padding:9px 18px; border-radius:40px;
  color:var(--accent); font-size:0.77rem;
  letter-spacing:2px; text-transform:uppercase;
  margin-bottom:36px; width:fit-content;
  animation:fadeUp .8s ease both;
}
.badge-dot {
  width:7px; height:7px; background:var(--accent);
  border-radius:50%; flex-shrink:0;
  animation:pulse 2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.5)} }

.hero-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3.4rem,5.5vw,6.2rem);
  color:var(--white); line-height:1.0;
  font-weight:300; margin-bottom:32px;
  animation:fadeUp .8s ease .15s both;
}
.hero-title .ht-line { display:block; }
.hero-title em {
  font-style:italic; color:rgba(245,242,237,0.45);
  font-weight:300; display:block;
}
.hero-title .accent-word {
  font-style:italic; color:var(--accent);
  display:block; font-weight:300;
}

.hero-sub {
  color:rgba(245,242,237,0.55); font-size:1.05rem;
  line-height:1.75; max-width:440px;
  margin-bottom:48px;
  animation:fadeUp .8s ease .3s both;
}
.hero-actions {
  display:flex; gap:16px; flex-wrap:wrap;
  animation:fadeUp .8s ease .45s both;
}
.btn-primary {
  padding:15px 36px; background:var(--accent);
  color:var(--navy); border:none; border-radius:2px;
  font-size:0.88rem; font-weight:700;
  letter-spacing:1.2px; text-transform:uppercase;
  text-decoration:none; display:inline-block;
  transition:background .25s, transform .2s, box-shadow .25s;
  font-family:'DM Sans',sans-serif; cursor:none;
}
.btn-primary:hover {
  background:var(--accent-lt); transform:translateY(-2px);
  box-shadow:0 14px 40px rgba(200,169,110,0.35);
}
.btn-ghost {
  padding:15px 28px; background:transparent;
  color:rgba(245,242,237,0.7); border:1px solid var(--border-d);
  border-radius:2px; font-size:0.88rem; font-weight:400;
  letter-spacing:0.5px; text-decoration:none; display:inline-block;
  transition:color .25s, border-color .25s; cursor:none;
}
.btn-ghost span { transition:transform .25s; display:inline-block; }
.btn-ghost:hover { color:var(--accent); border-color:var(--accent); }
.btn-ghost:hover span { transform:translateX(4px); }
.btn-outline {
  padding:12px 24px; background:transparent;
  color:var(--white); border:1px solid var(--border-d);
  border-radius:2px; font-size:0.85rem;
  text-decoration:none; display:inline-block;
  transition:all .25s; font-family:'DM Sans',sans-serif; cursor:none;
}
.btn-outline:hover { border-color:var(--accent); color:var(--accent); }

/* Hero Visual — Window Art */
.hero-visual {
  display:flex; align-items:center; justify-content:center;
  position:relative;
  animation:fadeIn 1.2s ease .3s both;
}
.window-art {
  position:relative; width:340px; height:430px;
}
.wa-glow {
  position:absolute; inset:-60px;
  background:radial-gradient(ellipse at center, rgba(200,169,110,0.12) 0%, transparent 65%);
  animation:glowPulse 4s ease-in-out infinite;
}
@keyframes glowPulse { 0%,100%{opacity:.5} 50%{opacity:1} }
.wa-outer {
  position:absolute; inset:-24px;
  border:12px solid rgba(200,169,110,0.1);
  border-radius:6px;
}
.wa-frame {
  position:absolute; inset:0;
  border:3px solid var(--accent); border-radius:3px;
  background:linear-gradient(135deg, rgba(200,169,110,0.04) 0%, rgba(200,169,110,0.1) 50%, rgba(200,169,110,0.04) 100%);
  overflow:hidden;
}
.wa-cross-h {
  position:absolute; top:50%; left:0; right:0;
  height:3px; background:var(--accent); transform:translateY(-50%);
}
.wa-cross-v {
  position:absolute; top:0; bottom:0; left:50%;
  width:3px; background:var(--accent); transform:translateX(-50%);
}
.wa-pane {
  position:absolute; border-radius:1px;
  transition:opacity 1s ease;
}
.wa-pane.p1 { top:6%; left:5%; width:42%; height:42%; background:rgba(200,169,110,0.07); }
.wa-pane.p2 { top:6%; right:5%; width:42%; height:42%; background:rgba(200,169,110,0.05); }
.wa-pane.p3 { bottom:6%; left:5%; width:42%; height:42%; background:rgba(200,169,110,0.05); }
.wa-pane.p4 { bottom:6%; right:5%; width:42%; height:42%; background:rgba(200,169,110,0.09); }
.wa-shine {
  position:absolute; top:8%; left:8%; bottom:8%; right:8%;
  background:linear-gradient(118deg, transparent 0%, rgba(200,169,110,0.06) 35%, rgba(200,169,110,0.18) 50%, transparent 70%);
  animation:waShimmer 5s ease-in-out infinite;
}
@keyframes waShimmer { 0%,100%{opacity:.4;transform:translateX(-20px)} 50%{opacity:1;transform:translateX(20px)} }
.wa-tag {
  position:absolute; background:rgba(8,15,28,0.95);
  border:1px solid var(--border-d); padding:13px 18px;
  border-radius:4px; color:var(--white); font-size:0.82rem;
  backdrop-filter:blur(8px); line-height:1.4;
}
.wa-tag strong { color:var(--accent); display:block; font-size:0.92rem; margin-bottom:2px; }
.wa-tag span { color:rgba(245,242,237,0.55); font-size:0.78rem; }
.tag-top { top:50px; right:-70px; animation:floatTag 5s ease-in-out infinite; }
.tag-bot { bottom:80px; left:-52px; animation:floatTag 5s ease-in-out infinite .8s; }
@keyframes floatTag { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

/* Hero Stats */
.hero-stats-bar {
  display:flex; align-items:center; justify-content:center;
  gap:0; padding:32px 80px; border-top:1px solid var(--border-d);
  background:rgba(255,255,255,0.02);
  position:relative; z-index:2;
  animation:fadeUp .8s ease .7s both;
}
.hstat {
  display:flex; flex-direction:column; align-items:center;
  gap:4px; padding:0 52px;
  text-align:center;
}
.hstat-sep {
  width:1px; height:52px;
  background:var(--border-d); flex-shrink:0;
}
.hstat-n {
  font-family:'Cormorant Garamond',serif;
  font-size:2.6rem; color:var(--accent);
  font-weight:600; line-height:1;
}
.hstat-l {
  color:rgba(245,242,237,0.45); font-size:0.76rem;
  letter-spacing:1.5px; text-transform:uppercase;
  line-height:1.4;
}

/* Scroll hint */
.scroll-hint {
  position:absolute; bottom:100px; left:80px;
  display:flex; align-items:center; gap:16px;
  color:rgba(245,242,237,0.35); font-size:0.75rem;
  letter-spacing:2px; text-transform:uppercase;
  animation:fadeUp .8s ease .9s both;
  z-index:3;
}
.scroll-hint-line {
  width:40px; height:1px; background:rgba(200,169,110,0.4);
  position:relative; overflow:hidden;
}
.scroll-hint-line::after {
  content:''; position:absolute; top:0; left:-100%;
  width:100%; height:100%; background:var(--accent);
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine { 0%{left:-100%} 100%{left:100%} }

@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn  { from{opacity:0} to{opacity:1} }

/* ═══════════════════════════════════════════════════════════════
   MARQUEE
═══════════════════════════════════════════════════════════════ */
.marquee-wrap {
  background:var(--accent); overflow:hidden;
  padding:14px 0; white-space:nowrap;
  border-top:1px solid rgba(200,169,110,0.3);
}
.marquee-track {
  display:inline-flex; gap:28px; align-items:center;
  animation:marqueeScroll 28s linear infinite;
  will-change:transform;
}
.marquee-track span {
  font-size:0.82rem; font-weight:600;
  letter-spacing:1.5px; text-transform:uppercase;
  color:var(--navy);
  white-space:nowrap;
}
.marquee-track .mdot {
  color:rgba(8,15,28,0.3); font-size:0.6rem; flex-shrink:0;
}
@keyframes marqueeScroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.marquee-wrap:hover .marquee-track { animation-play-state:paused; }

/* ═══════════════════════════════════════════════════════════════
   SECTION SHARED
═══════════════════════════════════════════════════════════════ */
.section-label {
  color:var(--accent); font-size:0.76rem;
  letter-spacing:3px; text-transform:uppercase;
  margin-bottom:16px; font-weight:500;
  display:block;
}
.section-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,3.8vw,3.6rem);
  line-height:1.08; font-weight:600;
  margin-bottom:20px;
}
.section-sub {
  font-size:1.02rem; line-height:1.75;
  color:var(--muted); max-width:520px;
  margin-bottom:56px;
}

/* ═══════════════════════════════════════════════════════════════
   PRODUCTS
═══════════════════════════════════════════════════════════════ */
.products { background:var(--cream); padding:100px 0 0; }
.products-header {
  text-align:center; padding:0 80px;
  margin-bottom:72px;
}
.products-header .section-title { color:var(--navy); }
.products-header .section-sub { margin:0 auto 0; }

/* Product Panel */
.product-panel {
  display:grid; grid-template-columns:1fr 1fr;
  min-height:520px; border-top:1px solid var(--border-l);
}
.product-panel.reverse { direction:rtl; }
.product-panel.reverse > * { direction:ltr; }

/* Visual side */
.product-visual {
  position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  min-height:480px;
}
.pv-light { background:var(--cream-2); }
.pv-dark  { background:var(--navy-2); }

.pv-scene {
  position:relative; display:flex;
  flex-direction:column; align-items:center;
  gap:20px;
}
.pv-dim-label {
  font-family:'Cormorant Garamond',serif;
  font-size:1rem; letter-spacing:2px;
  color:rgba(0,0,0,0.3); text-align:center;
  text-transform:uppercase;
}

/* Window drawing */
.pv-window-draw {
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.pvw-frame {
  position:relative; width:220px; height:280px;
  border:3px solid rgba(23,37,64,0.5); border-radius:2px;
  background:rgba(200,169,110,0.04); overflow:hidden;
}
.pvw-h { position:absolute; top:50%; left:0; right:0; height:3px; background:rgba(23,37,64,0.4); transform:translateY(-50%); }
.pvw-v { position:absolute; top:0; bottom:0; left:50%; width:3px; background:rgba(23,37,64,0.4); transform:translateX(-50%); }
.pvw-pane {
  position:absolute; transition:background .3s;
}
.pvw-pane.a { top:5%; left:5%; width:41%; height:41%; background:rgba(200,169,110,0.08); }
.pvw-pane.b { top:5%; right:5%; width:41%; height:41%; background:rgba(200,169,110,0.12); }
.pvw-pane.c { bottom:5%; left:5%; width:41%; height:41%; background:rgba(200,169,110,0.06); }
.pvw-pane.d { bottom:5%; right:5%; width:41%; height:41%; background:rgba(200,169,110,0.1); }
.pvw-handle {
  position:absolute; right:25%; top:50%;
  width:6px; height:20px; background:var(--accent);
  border-radius:3px; transform:translate(50%,-50%);
}
.pvw-shine {
  position:absolute; top:5%; left:5%; width:90%; height:90%;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.08) 40%, rgba(255,255,255,0.14) 50%, transparent 60%);
  animation:pvShimmer 5s ease-in-out infinite;
}
@keyframes pvShimmer { 0%,100%{opacity:.5;transform:translateX(-10%)} 50%{opacity:1;transform:translateX(10%)} }
.pvw-sill {
  width:260px; height:16px;
  background:rgba(23,37,64,0.15); border-radius:2px;
  margin-top:0;
}
.product-panel:hover .pvw-pane { background:rgba(200,169,110,0.18); }

/* Door drawing */
.pv-door-draw {
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.pvd-frame {
  position:relative; width:170px; height:290px;
  border:3px solid var(--accent); border-radius:2px;
  background:rgba(200,169,110,0.06); overflow:hidden;
}
.pvd-top-glass {
  position:absolute; top:6%; left:10%; right:10%; height:25%;
  background:rgba(200,169,110,0.12); border:1px solid rgba(200,169,110,0.3);
  border-radius:1px;
}
.pvd-body {
  position:absolute; top:35%; left:10%; right:10%; bottom:6%;
  background:rgba(200,169,110,0.06); border:1px solid rgba(200,169,110,0.2);
}
.pvd-handle {
  position:absolute; right:18%; top:58%;
  width:6px; height:28px; background:var(--accent);
  border-radius:3px;
}
.pvd-hinges {
  position:absolute; left:12%; top:38%;
  display:flex; flex-direction:column; gap:24px;
}
.pvd-hinge {
  width:10px; height:14px;
  background:rgba(200,169,110,0.5); border-radius:1px;
}
.pvd-shine {
  position:absolute; inset:0;
  background:linear-gradient(130deg, transparent 0%, rgba(200,169,110,0.08) 40%, rgba(200,169,110,0.18) 50%, transparent 60%);
  animation:pvShimmer 6s ease-in-out infinite .5s;
}
.pvd-threshold {
  width:200px; height:12px;
  background:rgba(200,169,110,0.25); border-radius:1px;
}

/* Balcony drawing */
.pv-balcony-draw {
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.pvb-frame {
  position:relative; width:280px; height:260px;
  display:flex; border:3px solid rgba(23,37,64,0.45);
  border-radius:2px; background:rgba(200,169,110,0.04);
  overflow:hidden;
}
.pvb-win-left, .pvb-win-right {
  flex:1; display:flex; flex-direction:column;
  border-right:3px solid rgba(23,37,64,0.3);
}
.pvb-win-right { border-right:none; border-left:3px solid rgba(23,37,64,0.3); }
.pvb-pane {
  flex:1; background:rgba(200,169,110,0.06);
  border-bottom:2px solid rgba(23,37,64,0.2);
}
.pvb-pane:last-child { border-bottom:none; }
.pvb-h { position:absolute; /* handled by flex */ }
.pvb-door {
  flex:1.2; position:relative;
  background:rgba(200,169,110,0.08);
  border-left:2px solid rgba(23,37,64,0.3);
  border-right:2px solid rgba(23,37,64,0.3);
}
.pvb-door-glass {
  position:absolute; top:6%; left:12%; right:12%; height:45%;
  background:rgba(200,169,110,0.12); border:1px solid rgba(200,169,110,0.3);
}
.pvb-door-handle {
  position:absolute; right:18%; top:56%;
  width:5px; height:24px; background:var(--accent);
  border-radius:3px;
}
.pvb-door-shine {
  position:absolute; inset:0;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.06) 50%, transparent 65%);
  animation:pvShimmer 5s ease-in-out infinite 1s;
}
.pvb-sill {
  width:320px; height:14px;
  background:rgba(23,37,64,0.15); border-radius:1px;
}

/* Product content side */
.product-content {
  display:flex; flex-direction:column;
  justify-content:center; padding:72px 80px;
  background:var(--cream);
}
.product-num {
  font-family:'Cormorant Garamond',serif;
  font-size:5rem; color:rgba(200,169,110,0.15);
  line-height:1; font-weight:700;
  margin-bottom:-8px;
}
.product-content h3 {
  font-family:'Cormorant Garamond',serif;
  font-size:2.4rem; color:var(--navy);
  font-weight:600; margin-bottom:16px;
  line-height:1.1;
}
.product-content p {
  color:var(--muted); line-height:1.75;
  font-size:0.95rem; margin-bottom:28px; max-width:420px;
}
.product-features {
  list-style:none; margin-bottom:32px;
}
.product-features li {
  padding:8px 0; color:var(--text);
  font-size:0.9rem; display:flex;
  align-items:center; gap:12px;
  border-bottom:1px solid var(--border-l);
}
.product-features li::before {
  content:'—'; color:var(--accent);
  font-size:0.8rem; flex-shrink:0;
}
.product-price-block {
  display:flex; align-items:baseline; gap:6px;
  margin-top:4px;
}
.price-from {
  color:var(--muted); font-size:0.82rem;
  text-transform:uppercase; letter-spacing:1px;
}
.price-val {
  font-family:'Cormorant Garamond',serif;
  font-size:2.6rem; color:var(--navy);
  font-weight:600; line-height:1;
}
.price-cur {
  color:var(--muted); font-size:0.88rem;
  text-transform:uppercase; letter-spacing:1px;
}

/* ═══════════════════════════════════════════════════════════════
   GALLERY / PROJECTS — PHOTO
═══════════════════════════════════════════════════════════════ */
.gallery-section {
  background:var(--navy); padding:100px 80px;
}
.gallery-header { margin-bottom:48px; }
.gallery-header .section-title { color:var(--white); }
.gallery-header .section-sub { color:rgba(245,242,237,0.5); }

/* Filter buttons */
.gallery-filters {
  display:flex; gap:8px; flex-wrap:wrap;
  margin-bottom:40px;
}
.gf-btn {
  background:transparent; border:1px solid var(--border-d);
  color:rgba(245,242,237,0.6); padding:10px 22px;
  border-radius:2px; cursor:none; font-family:'DM Sans',sans-serif;
  font-size:0.84rem; font-weight:500; letter-spacing:.5px;
  transition:all .25s; display:flex; align-items:center; gap:8px;
}
.gf-btn em {
  font-style:normal; background:rgba(200,169,110,0.12);
  color:var(--accent); font-size:0.72rem; padding:2px 7px;
  border-radius:10px; font-weight:600;
}
.gf-btn:hover { border-color:var(--accent); color:var(--white); }
.gf-btn.active {
  background:var(--accent); border-color:var(--accent);
  color:var(--navy);
}
.gf-btn.active em { background:rgba(8,15,28,0.2); color:var(--navy); }

/* Photo grid */
.gallery-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:6px;
}
.gp {
  position:relative; overflow:hidden;
  aspect-ratio:4/3; cursor:none;
  background:var(--navy-3);
}
.gp-wide { grid-column:span 2; aspect-ratio:16/7; }

.gp img {
  width:100%; height:100%; object-fit:cover;
  display:block; transition:transform .55s ease;
}
.gp:hover img { transform:scale(1.06); }

.gp-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(8,15,28,0.75) 0%, rgba(8,15,28,0) 50%);
  opacity:0; transition:opacity .35s ease;
  display:flex; align-items:flex-end; justify-content:space-between;
  padding:20px 22px;
}
.gp:hover .gp-overlay { opacity:1; }
.gp-cat {
  color:var(--white); font-size:0.9rem;
  font-weight:600; letter-spacing:.5px;
}
.gp-zoom {
  width:36px; height:36px; border:1.5px solid rgba(255,255,255,0.5);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:var(--white); font-size:1rem;
  transition:background .25s, border-color .25s;
}
.gp:hover .gp-zoom { background:var(--accent); border-color:var(--accent); color:var(--navy); }

/* Hidden when filtered */
.gp.gp-hidden {
  display:none;
}

/* ═══════════════════════════════════════════════════════════════
   LIGHTBOX
═══════════════════════════════════════════════════════════════ */
.lightbox {
  position:fixed; inset:0; z-index:2000;
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none;
  transition:opacity .3s ease;
}
.lightbox.open { opacity:1; pointer-events:all; }

.lb-backdrop {
  position:absolute; inset:0;
  background:rgba(4,10,20,0.94);
  backdrop-filter:blur(8px);
}
.lb-stage {
  position:relative; z-index:2;
  max-width:90vw; max-height:85vh;
  display:flex; align-items:center; justify-content:center;
}
.lb-img {
  max-width:100%; max-height:85vh;
  border-radius:2px;
  box-shadow:0 30px 80px rgba(0,0,0,0.5);
  object-fit:contain;
  transition:opacity .25s ease;
}
.lb-close {
  position:absolute; top:20px; right:24px; z-index:3;
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.15);
  color:var(--white); width:44px; height:44px; border-radius:50%;
  font-size:1.4rem; cursor:none; transition:all .2s;
  display:flex; align-items:center; justify-content:center;
  font-family:'DM Sans',sans-serif;
}
.lb-close:hover { background:var(--accent); border-color:var(--accent); color:var(--navy); }

.lb-prev, .lb-next {
  position:absolute; top:50%; transform:translateY(-50%); z-index:3;
  background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.12);
  color:var(--white); width:52px; height:52px; border-radius:50%;
  font-size:1.2rem; cursor:none; transition:all .2s;
  display:flex; align-items:center; justify-content:center;
  font-family:'DM Sans',sans-serif;
}
.lb-prev { left:20px; }
.lb-next { right:20px; }
.lb-prev:hover, .lb-next:hover { background:var(--accent); border-color:var(--accent); color:var(--navy); }

.lb-bar {
  position:absolute; bottom:20px; left:50%;
  transform:translateX(-50%); z-index:3;
  display:flex; gap:16px; align-items:center;
  background:rgba(8,15,28,0.7); backdrop-filter:blur(8px);
  padding:8px 20px; border-radius:20px;
  border:1px solid var(--border-d);
}
.lb-cat {
  color:var(--accent); font-size:0.8rem;
  font-weight:600; letter-spacing:1.5px; text-transform:uppercase;
}
.lb-counter {
  color:rgba(245,242,237,0.5); font-size:0.8rem;
}

/* ═══════════════════════════════════════════════════════════════
   FEATURED TESTIMONIAL
═══════════════════════════════════════════════════════════════ */
.ft-section {
  background:var(--navy-2); padding:100px 80px;
  border-top:1px solid var(--border-d);
}
.ft-wrap { max-width:860px; margin:0 auto; }

.ft-track {
  position:relative; overflow:hidden;
  min-height:200px;
}
.ft-item {
  display:none; flex-direction:column; gap:28px;
  animation:ftFade .5s ease;
}
.ft-item.active { display:flex; }
@keyframes ftFade { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }

.ft-stars {
  color:var(--accent); letter-spacing:3px;
  font-size:1.1rem;
}
.ft-text {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.6rem,2.8vw,2.4rem);
  color:var(--white); line-height:1.45;
  font-weight:300; font-style:italic;
}
.ft-author {
  display:flex; align-items:center; gap:16px;
}
.ft-avatar {
  width:44px; height:44px; border-radius:50%;
  background:var(--accent); display:flex;
  align-items:center; justify-content:center;
  color:var(--navy); font-weight:700; font-size:0.88rem;
  flex-shrink:0;
}
.ft-name { color:var(--white); font-weight:500; font-size:0.95rem; }
.ft-role { color:rgba(245,242,237,0.4); font-size:0.8rem; margin-top:2px; }

.ft-controls {
  display:flex; align-items:center; gap:20px;
  margin-top:48px;
}
.ft-btn {
  width:48px; height:48px;
  border:1px solid var(--border-d); background:none;
  color:var(--white); font-size:1.1rem;
  border-radius:50%; cursor:none;
  transition:all .25s; display:flex;
  align-items:center; justify-content:center;
  font-family:'DM Sans',sans-serif;
}
.ft-btn:hover { border-color:var(--accent); color:var(--accent); }
.ft-dots {
  display:flex; gap:8px; align-items:center;
}
.ft-dot {
  width:6px; height:6px; border-radius:50%;
  background:var(--border-d); transition:all .25s;
  cursor:none;
}
.ft-dot.active {
  background:var(--accent); width:20px; border-radius:3px;
}
.ft-google-links {
  margin-top:32px; padding-top:24px;
  border-top:1px solid var(--border-d);
  display:flex; align-items:center; gap:16px;
  flex-wrap:wrap;
  color:rgba(245,242,237,0.4); font-size:0.85rem;
}
.ft-gl-link {
  color:var(--accent); text-decoration:none;
  font-size:0.85rem; border:1px solid var(--border-d);
  padding:8px 16px; border-radius:2px;
  transition:border-color .25s; cursor:none;
}
.ft-gl-link:hover { border-color:var(--accent); }

/* ═══════════════════════════════════════════════════════════════
   WHY US
═══════════════════════════════════════════════════════════════ */
.why-us { background:var(--cream-2); padding:100px 80px; }
.why-inner { max-width:1200px; margin:0 auto; }
.why-head { margin-bottom:60px; }
.why-head .section-title { color:var(--navy); }
.why-cards {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:2px; background:var(--border-l);
  border:1px solid var(--border-l);
}
.why-card {
  background:var(--cream-2); padding:44px 36px;
  border-right:1px solid var(--border-l);
  transition:background .3s; position:relative;
  overflow:hidden;
}
.why-card:last-child { border-right:none; }
.why-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px; background:var(--accent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s ease;
}
.why-card:hover::before { transform:scaleX(1); }
.why-card:hover { background:rgba(200,169,110,0.05); }
.why-num {
  font-family:'Cormorant Garamond',serif;
  font-size:3.5rem; color:rgba(200,169,110,0.2);
  line-height:1; font-weight:700; margin-bottom:12px;
}
.why-card h4 {
  color:var(--navy); font-size:1rem;
  margin-bottom:10px; font-weight:600;
}
.why-card p {
  color:var(--muted); font-size:0.86rem; line-height:1.65;
}

/* ═══════════════════════════════════════════════════════════════
   PROCESS
═══════════════════════════════════════════════════════════════ */
.process { background:var(--navy); padding:100px 80px; }
.process-head { margin-bottom:64px; }
.process-head .section-title { color:var(--white); }
.process-head .section-sub { color:rgba(245,242,237,0.5); }

.process-steps {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; border:1px solid var(--border-d);
}
.step {
  padding:48px 36px; border-right:1px solid var(--border-d);
  position:relative; transition:background .3s;
}
.step:last-child { border-right:none; }
.step:hover { background:rgba(200,169,110,0.06); }
.step-line {
  position:absolute; top:0; left:0; right:0;
  height:3px; background:var(--accent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .5s ease;
}
.step:hover .step-line { transform:scaleX(1); }
.step-num {
  font-family:'Cormorant Garamond',serif;
  font-size:4.5rem; color:rgba(200,169,110,0.15);
  line-height:1; font-weight:700; margin-bottom:24px;
}
.step h4 {
  color:var(--white); font-size:1.02rem;
  margin-bottom:12px; font-weight:600;
}
.step p { color:rgba(245,242,237,0.45); font-size:0.86rem; line-height:1.65; }

/* ═══════════════════════════════════════════════════════════════
   CALCULATOR
═══════════════════════════════════════════════════════════════ */
.calculator-section { background:var(--cream-2); padding:100px 80px; }
.calculator-section .section-title { color:var(--navy); }
.calculator-section .section-sub { color:var(--muted); }
.calc-wrapper {
  display:grid; grid-template-columns:1fr 400px;
  gap:48px; max-width:1080px; margin:0 auto;
}
.calc-inputs { display:flex; flex-direction:column; gap:30px; }
.calc-group { display:flex; flex-direction:column; gap:12px; }
.calc-label {
  color:var(--navy); font-size:0.82rem;
  font-weight:600; letter-spacing:1.5px; text-transform:uppercase;
}
.calc-tabs { display:flex; gap:8px; flex-wrap:wrap; }
.calc-tab {
  background:white; border:1.5px solid var(--border-l);
  color:var(--text); padding:10px 20px; border-radius:2px;
  cursor:none; font-family:'DM Sans',sans-serif;
  font-size:0.86rem; font-weight:500; transition:all .2s;
}
.calc-tab:hover { border-color:var(--accent); color:var(--navy); }
.calc-tab.active { background:var(--navy); border-color:var(--navy); color:white; }

.calc-dims { display:flex; align-items:center; gap:16px; }
.dim-field { flex:1; display:flex; flex-direction:column; gap:8px; }
.dim-label { color:var(--muted); font-size:0.76rem; letter-spacing:1px; text-transform:uppercase; }
.dim-control {
  display:flex; align-items:center;
  border:1.5px solid var(--border-l); border-radius:2px;
  overflow:hidden; background:white;
}
.dim-control button {
  background:none; border:none; width:40px; height:44px;
  font-size:1.2rem; cursor:none; color:var(--navy);
  transition:background .2s; font-weight:300;
}
.dim-control button:hover { background:rgba(200,169,110,0.12); }
.dim-control input {
  flex:1; border:none; text-align:center;
  font-size:1rem; font-family:'DM Sans',sans-serif;
  color:var(--navy); font-weight:500; background:white;
  width:60px; padding:0;
}
.dim-control input:focus { outline:none; }
.dim-x { color:var(--muted); font-size:1.2rem; padding-top:24px; }

.calc-slider {
  -webkit-appearance:none; width:100%; height:4px;
  background:rgba(0,0,0,0.1); border-radius:2px;
  outline:none; cursor:none;
}
.calc-slider::-webkit-slider-thumb {
  -webkit-appearance:none; width:20px; height:20px;
  border-radius:50%; background:var(--navy);
  border:3px solid var(--accent); cursor:none;
}
.slider-labels {
  display:flex; justify-content:space-between;
  color:var(--muted); font-size:0.76rem; margin-top:4px;
}
.calc-options { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.calc-option {
  display:flex; align-items:center; gap:10px;
  cursor:none; padding:11px 14px;
  border:1.5px solid var(--border-l); border-radius:2px;
  background:white; font-size:0.86rem; color:var(--text);
  transition:all .2s; user-select:none;
}
.calc-option:hover { border-color:var(--accent); }
.calc-option input { display:none; }
.opt-check {
  width:18px; height:18px; flex-shrink:0;
  border:2px solid rgba(0,0,0,0.18); border-radius:2px;
  background:white; transition:all .2s;
  display:flex; align-items:center; justify-content:center;
}
.calc-option input:checked ~ .opt-check { background:var(--navy); border-color:var(--navy); }
.calc-option input:checked ~ .opt-check::after { content:'✓'; color:var(--accent); font-size:0.75rem; font-weight:700; }

/* Result card */
.calc-result { position:sticky; top:100px; height:fit-content; }
.result-card {
  background:var(--navy); border:1px solid var(--border-d);
  padding:40px 36px; border-radius:4px;
}
.result-label {
  color:rgba(245,242,237,0.45); font-size:0.76rem;
  letter-spacing:2px; text-transform:uppercase; margin-bottom:10px;
}
.result-price {
  font-family:'Cormorant Garamond',serif;
  font-size:3.6rem; color:var(--accent);
  line-height:1; font-weight:600; margin-bottom:4px;
  transition:all .3s;
}
.result-per { color:rgba(245,242,237,0.35); font-size:0.82rem; margin-bottom:28px; }
.result-breakdown {
  border-top:1px solid var(--border-d); padding-top:20px;
  margin-bottom:20px; display:flex; flex-direction:column; gap:10px;
}
.breakdown-row {
  display:flex; justify-content:space-between;
  color:rgba(245,242,237,0.5); font-size:0.86rem;
}
.breakdown-row span:last-child { color:var(--white); font-weight:500; }
.total-row {
  border-top:1px solid var(--border-d);
  padding-top:10px; margin-top:4px;
}
.total-row span { color:var(--white) !important; font-size:1rem; }
.total-row span:last-child { color:var(--accent) !important; font-size:1.1rem; }
.result-note {
  background:rgba(200,169,110,0.08); border:1px solid var(--border-d);
  padding:10px 14px; border-radius:2px;
  color:rgba(245,242,237,0.55); font-size:0.8rem; margin-bottom:4px;
}

/* ═══════════════════════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════════════════════ */
.contact {
  background:var(--navy); display:grid;
  grid-template-columns:1fr 1fr; gap:0; padding:0;
}
.contact-left {
  padding:100px 80px;
  border-right:1px solid var(--border-d);
}
.contact-left .section-title { color:var(--white); }
.contact-info { display:flex; flex-direction:column; gap:24px; margin-top:48px; }
.contact-item {
  display:flex; flex-direction:column; gap:16px;
  padding:24px; background:var(--glass-d);
  border:1px solid var(--border-d); border-radius:4px;
}
.contact-item-header { display:flex; align-items:center; gap:12px; }
.contact-item-icon {
  width:42px; height:42px; flex-shrink:0;
  border:1px solid var(--border-d); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--accent); font-size:1.1rem;
}
.contact-item-label {
  color:var(--accent); font-size:0.9rem;
  font-weight:600; text-transform:uppercase; letter-spacing:1px;
}
.contact-item-value { color:var(--white); font-size:0.95rem; margin-bottom:8px; }
.contact-map-iframe {
  width:100%; height:230px; border-radius:4px;
  border:none; margin:12px 0 16px;
}
.call-btn {
  display:inline-flex; align-items:center; gap:10px;
  background:rgba(76,175,80,0.1); border:1.5px solid rgba(76,175,80,0.3);
  color:#81c784; padding:12px 18px; border-radius:4px;
  text-decoration:none; font-weight:600; font-size:1rem;
  transition:all .25s; margin:4px 0 16px; cursor:none;
}
.call-btn:hover { background:rgba(76,175,80,0.2); color:#a5d6a7; transform:translateY(-1px); }
.store-hours {
  background:rgba(200,169,110,0.05);
  border:1px solid var(--border-d); border-radius:4px;
  padding:14px 18px; margin-bottom:16px;
}
.hours-title {
  color:var(--accent); font-size:0.7rem;
  letter-spacing:2px; text-transform:uppercase;
  font-weight:600; margin-bottom:10px;
}
.hours-row {
  display:flex; justify-content:space-between;
  padding:5px 0; border-bottom:1px solid rgba(200,169,110,0.07);
  font-size:0.86rem; color:rgba(245,242,237,0.65);
}
.hours-row:last-child { border-bottom:none; }
.hours-closed { color:rgba(245,242,237,0.3); font-style:italic; }

.contact-right { padding:100px 80px; }
.form-group { margin-bottom:20px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
label {
  display:block; color:rgba(245,242,237,0.45);
  font-size:0.76rem; letter-spacing:1.5px;
  text-transform:uppercase; margin-bottom:8px;
}
input, textarea, select {
  width:100%; background:var(--glass-d);
  border:1px solid var(--border-d); color:var(--white);
  padding:13px 16px; border-radius:2px;
  font-family:'DM Sans',sans-serif; font-size:0.94rem;
  outline:none; transition:all .3s; cursor:none;
}
input::placeholder, textarea::placeholder { color:rgba(245,242,237,0.22); }
input:focus, textarea:focus, select:focus { border-color:var(--accent); background:rgba(200,169,110,0.08); }
select option { background:var(--navy-2); }
textarea { resize:vertical; min-height:100px; }
.form-submit {
  width:100%; background:var(--accent); color:var(--navy);
  border:none; padding:16px; border-radius:2px;
  font-size:0.88rem; font-weight:700; letter-spacing:1.5px;
  cursor:none; font-family:'DM Sans',sans-serif;
  text-transform:uppercase; transition:all .3s; margin-top:8px;
}
.form-submit:hover { background:var(--accent-lt); transform:translateY(-2px); box-shadow:0 10px 30px rgba(200,169,110,0.25); }

/* ═══════════════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════════════ */
footer { background:#040c18; border-top:1px solid var(--border-d); }
.footer-main {
  display:flex; gap:48px; padding:52px 80px 36px;
  align-items:flex-start; flex-wrap:wrap;
}
.footer-brand { flex:1.5; display:flex; flex-direction:column; gap:14px; }
.footer-contacts-col { flex:1; display:flex; flex-direction:column; gap:4px; }
.footer-social-col { flex:1; display:flex; flex-direction:column; gap:0; }
.footer-logo {
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem; color:var(--white); font-weight:700;
}
.footer-logo span { color:var(--accent); }
.footer-tagline { color:rgba(245,242,237,0.35); font-size:0.84rem; line-height:1.6; }
.footer-col-title {
  color:var(--accent); font-size:0.7rem;
  letter-spacing:2.5px; text-transform:uppercase;
  font-weight:600; margin-bottom:14px;
}
.footer-phone-link {
  display:flex; align-items:center; gap:8px;
  color:rgba(245,242,237,0.55) !important;
  text-decoration:none !important; font-size:0.86rem;
  padding:5px 0; transition:color .2s; cursor:none;
}
.footer-phone-link:hover { color:var(--white) !important; }
.footer-fb-btn {
  background:#1877f2; color:#fff !important;
  padding:10px 18px; border-radius:4px;
  text-decoration:none !important; font-weight:600;
  display:inline-flex; align-items:center; gap:8px;
  transition:opacity .25s; font-size:0.88rem;
  width:fit-content; cursor:none;
}
.footer-fb-btn:hover { opacity:.85; }
.footer-bottom {
  border-top:1px solid rgba(200,169,110,0.08);
  padding:20px 80px; text-align:center;
}
.footer-copy { color:rgba(245,242,237,0.2); font-size:0.78rem; }

/* ═══════════════════════════════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════════════════════════════ */
.reveal {
  opacity:0; transform:translateY(40px);
  transition:opacity .9s ease, transform .9s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════════ */
@media (max-width:1100px) {
  .why-cards { grid-template-columns:repeat(2,1fr); }
  .process-steps { grid-template-columns:repeat(2,1fr); }
  .step:nth-child(2) { border-right:none; }
  .step { border-bottom:1px solid var(--border-d); }
  .step:nth-child(3), .step:nth-child(4) { border-bottom:none; }
}

@media (max-width:900px) {
  .hero-body { grid-template-columns:1fr; padding:120px 32px 60px; }
  .hero-visual { display:none; }
  .hero-stats-bar { flex-wrap:wrap; padding:24px 32px; gap:0; }
  .hstat { padding:12px 28px; width:50%; }
  .hstat-sep { display:none; }
  .scroll-hint { left:32px; bottom:220px; }
  .product-panel { grid-template-columns:1fr; }
  .product-panel.reverse { direction:ltr; }
  .product-visual { min-height:300px; }
  .product-content { padding:48px 32px; }
  .gallery-grid { grid-template-columns:1fr 1fr; }
  .gp-wide { grid-column:span 2; aspect-ratio:16/7; }
  .lb-prev { left:8px; }
  .lb-next { right:8px; }
  .why-us { padding:80px 32px; }
  .why-cards { grid-template-columns:1fr; }
  .why-card { border-right:none; border-bottom:1px solid var(--border-l); }
  .gallery-section { padding:80px 32px; }
  .ft-section { padding:80px 32px; }
  .process { padding:80px 32px; }
  .process-steps { grid-template-columns:1fr; }
  .step { border-right:none; border-bottom:1px solid var(--border-d); }
  .step:last-child { border-bottom:none; }
  .calculator-section { padding:80px 32px; }
  .calc-wrapper { grid-template-columns:1fr; }
  .calc-result { position:static; }
  .calc-options { grid-template-columns:1fr 1fr; }
  .calc-dims { flex-direction:row; }
  .dim-x { display:block; }
  .contact { grid-template-columns:1fr; }
  .contact-left { padding:80px 32px; border-right:none; border-bottom:1px solid var(--border-d); }
  .contact-right { padding:80px 32px; }
  .form-row { grid-template-columns:1fr; }
  .footer-main { flex-direction:column; gap:32px; padding:40px 32px 28px; }
  .footer-bottom { padding:16px 32px; }
}

@media (max-width:768px) {
  .nav-inner { padding:18px 24px; }
  .nav-links { display:none; }
  .nav-cta { display:none; }
  .hamburger { display:flex; }
  .products-header { padding:0 24px; }
  .products { padding:60px 0 0; }
  .gallery-grid { grid-template-columns:1fr 1fr; }
  .gp-wide { grid-column:span 2; aspect-ratio:16/6; }
  .hero-title { font-size:clamp(2.8rem,10vw,4.5rem); }
  .hero-badge { font-size:0.68rem; letter-spacing:1.2px; }
  .hero-sub { font-size:0.95rem; }
  .hero-actions { flex-direction:column; gap:12px; }
  .hero-actions .btn-primary,
  .hero-actions .btn-ghost { width:100%; text-align:center; }
  .scroll-hint { display:none; }
  .gallery-filters { flex-wrap:wrap; gap:8px; }
  .gf-btn { flex:1 1 calc(50% - 8px); text-align:center; justify-content:center; }
  .calc-tabs { flex-wrap:wrap; gap:6px; }
  .calc-tab { flex:1 1 calc(50% - 6px); text-align:center; min-width:0; }
  .calc-options { grid-template-columns:1fr; }
  .calc-dims { flex-direction:column; gap:12px; }
  .dim-x { display:none; }
  body { cursor:auto; }
  .cursor-dot, .cursor-ring { display:none; }
  a, button, .calc-tab, .gf-btn, .ft-btn, .call-btn,
  .form-submit, .btn-primary, .btn-ghost, .btn-outline,
  .calc-option, .calc-slider, input, select, textarea,
  .hamburger, .lb-close, .lb-prev, .lb-next,
  .footer-phone-link, .footer-fb-btn, .mobile-nav a { cursor:pointer !important; }
}

@media (max-width:480px) {
  .nav-inner { padding:14px 18px; }
  .hero-body { padding:100px 20px 40px; }
  .hero-badge { font-size:0.62rem; padding:7px 14px; max-width:100%; }
  .hero-title { font-size:clamp(2.2rem,11vw,3rem); }
  .hero-sub { font-size:0.88rem; }
  .hero-stats-bar { padding:16px 12px; }
  .hstat { width:50%; padding:10px 8px; }
  .hstat-n { font-size:1.9rem; }
  .hstat-l { font-size:0.65rem; letter-spacing:1px; }
  .section-title { font-size:clamp(1.9rem,8vw,2.5rem); }
  .products-header { padding:0 20px; }
  .products { padding:50px 0 0; }
  .product-content { padding:32px 20px; }
  .product-content h3 { font-size:1.5rem; }
  .gallery-section { padding:56px 20px; }
  .gf-btn { font-size:0.76rem; padding:8px 10px; }
  .gallery-grid { grid-template-columns:1fr; }
  .gp-wide { grid-column:auto; aspect-ratio:4/3; }
  .ft-text { font-size:1.3rem; }
  .ft-section { padding:60px 20px; }
  .why-us { padding:60px 20px; }
  .process { padding:60px 20px; }
  .calculator-section { padding:60px 20px; }
  .calc-tab { font-size:0.8rem; padding:9px 10px; }
  .result-card { padding:28px 20px; }
  .result-price { font-size:2.6rem; }
  .contact-left { padding:56px 20px; }
  .contact-right { padding:48px 20px; }
  .contact-map-iframe { height:190px; }
  .call-btn { font-size:0.92rem; padding:10px 14px; }
  .footer-main { padding:36px 20px 20px; }
  .footer-bottom { padding:14px 20px; }
  .ft-controls { gap:12px; }
  .ft-btn { width:40px; height:40px; font-size:1.1rem; }
  .lb-close { top:12px; right:12px; width:38px; height:38px; font-size:1.4rem; }
  .lb-prev, .lb-next { width:38px; height:38px; font-size:1.1rem; }
  .mobile-nav a { font-size:1.05rem; padding:16px 0; }
}

@media (max-width:375px) {
  .hero-title { font-size:2.1rem; }
  .hero-badge { font-size:0.58rem; padding:6px 12px; }
  .gf-btn { flex:1 1 100%; }
  .calc-tab { flex:1 1 100%; }
  .hstat { padding:8px 6px; }
  .hstat-n { font-size:1.6rem; }
}
