body { overflow-x:hidden; }

/* NAV */
header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:20px max(60px, env(safe-area-inset-right, 0px)) 20px max(60px, env(safe-area-inset-left, 0px));
  padding-top:max(20px, env(safe-area-inset-top, 0px));
  display:flex; align-items:center; justify-content:space-between;
  transition:all .4s ease;
}
header.scrolled {
  background:rgba(26,26,24,.97);
  backdrop-filter:blur(20px);
  padding:14px max(60px, env(safe-area-inset-right, 0px)) 14px max(60px, env(safe-area-inset-left, 0px));
  padding-top:max(14px, env(safe-area-inset-top, 0px));
  box-shadow:0 2px 40px rgba(0,0,0,.3);
}
.logo { font-family:'Playfair Display',serif; font-size:28px; font-weight:700; color:var(--white); letter-spacing:6px; text-decoration:none; }
.logo span { color:var(--gold); }
nav { display:flex; gap:36px; align-items:center; }
nav a { color:rgba(255,255,255,.8); text-decoration:none; font-size:11px; letter-spacing:2px; text-transform:uppercase; transition:color .3s; position:relative; }
nav a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:1px; background:var(--gold); transition:width .3s; }
nav a:hover { color:var(--gold); }
nav a:hover::after { width:100%; }
.btn-nav { border:1px solid var(--gold) !important; color:var(--gold) !important; padding:9px 22px; }
.btn-nav:hover { background:var(--gold) !important; color:var(--dark) !important; }
.btn-nav::after { display:none !important; }
.burger { display:none; flex-direction:column; gap:5px; cursor:pointer; touch-action:manipulation; -webkit-tap-highlight-color:transparent; }
.burger span { display:block; width:26px; height:1.5px; background:var(--white); }

/* MOBILE MENU */
.mobile-menu {
  display:none;
  position:fixed;
  inset:0;
  background:var(--dark);
  z-index:3000;
  flex-direction:column;
  align-items:stretch;
  justify-content:flex-start;
  padding:18px max(24px, env(safe-area-inset-right, 0px)) max(34px, env(safe-area-inset-bottom, 0px)) max(24px, env(safe-area-inset-left, 0px));
  padding-top:max(18px, env(safe-area-inset-top, 0px));
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.mobile-menu.open { display:flex; }
.mobile-menu-head { display:flex; align-items:center; justify-content:space-between; gap:12px; min-height:48px; }
.mobile-menu-logo { font-family:'Playfair Display',serif; font-size:46px; font-weight:700; color:var(--white); letter-spacing:4px; text-decoration:none; line-height:1; }
.mobile-menu-logo span { color:var(--gold); }
.mobile-menu-actions { display:flex; align-items:center; gap:6px; }
.mobile-back,
.mobile-close {
  width:42px;
  height:42px;
  border:none;
  background:transparent;
  color:rgba(255,255,255,.75);
  font-size:30px;
  line-height:1;
  cursor:pointer;
}
.mobile-menu-links {
  margin-top:34px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:18px;
}
.mobile-menu-links a {
  font-family:'Playfair Display',serif;
  font-size:48px;
  color:var(--white);
  text-decoration:none;
  transition:color .3s;
  line-height:1.05;
}
.mobile-menu-links a:hover { color:var(--gold); }

/* HERO */
#hero { min-height:100vh; position:relative; display:flex; align-items:center; overflow:hidden; background:radial-gradient(circle at top left,rgba(201,168,76,.12),transparent 32%),var(--dark); }
.hero-pattern { position:absolute; inset:0; opacity:.06;
  background-image:linear-gradient(45deg,var(--gold) 25%,transparent 25%),linear-gradient(-45deg,var(--gold) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--gold) 75%),linear-gradient(-45deg,transparent 75%,var(--gold) 75%);
  background-size:60px 60px; animation:patternShift 20s linear infinite; }
@keyframes patternShift { to { background-position:60px 60px,60px 90px,90px 30px,30px 60px; } }
.hero-img {
  position:absolute; right:0; top:0; width:57%; height:100%; object-fit:cover;
  opacity:.44; filter:saturate(.82) contrast(.92) brightness(.82);
  transform:scale(1.03); transform-origin:center;
}
.hero-overlay {
  position:absolute; inset:0;
  background:
    linear-gradient(90deg,var(--dark) 38%,rgba(26,26,24,.72) 58%,rgba(26,26,24,.08) 100%),
    linear-gradient(180deg,rgba(0,0,0,.18) 0%,rgba(0,0,0,.4) 100%);
}
.hero-content { position:relative; z-index:2; padding:0 max(60px, env(safe-area-inset-right, 0px)) 0 max(60px, env(safe-area-inset-left, 0px)); max-width:760px; }
.hero-tag { display:inline-block; font-size:11px; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:24px; opacity:0; animation:fadeUp .8s .3s forwards; }
.hero-tag::before { content:''; display:inline-block; width:30px; height:1px; background:var(--gold); vertical-align:middle; margin-right:12px; }
.hero-title { font-family:'Playfair Display',serif; font-size:clamp(44px,7vw,92px); font-weight:700; color:var(--white); line-height:1.02; margin-bottom:24px; opacity:0; animation:fadeUp .8s .5s forwards; text-wrap:balance; }
.hero-title em { font-style:italic; color:var(--gold-light); }
.hero-sub { font-family:'Cormorant Garamond',serif; font-size:21px; color:rgba(255,255,255,.72); font-weight:300; line-height:1.7; margin-bottom:44px; opacity:0; animation:fadeUp .8s .7s forwards; max-width:620px; }
.hero-btns { display:flex; gap:18px; flex-wrap:wrap; opacity:0; animation:fadeUp .8s .9s forwards; }
.btn-primary { background:var(--gold); color:var(--dark); padding:15px 38px; font-size:11px; letter-spacing:2px; text-transform:uppercase; font-weight:500; border:none; cursor:pointer; transition:all .3s; text-decoration:none; display:inline-block; }
.btn-primary:hover { background:var(--gold-light); transform:translateY(-2px); box-shadow:0 8px 30px rgba(201,168,76,.4); }
.btn-outline { background:transparent; color:var(--white); padding:15px 38px; font-size:11px; letter-spacing:2px; text-transform:uppercase; border:1px solid rgba(255,255,255,.3); cursor:pointer; transition:all .3s; text-decoration:none; display:inline-block; }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.hero-stats {
  position:absolute; bottom:40px; right:60px; display:flex; gap:18px; z-index:2;
  opacity:0; animation:fadeUp .8s 1.1s forwards;
}
.stat {
  min-width:130px; padding:18px 20px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  backdrop-filter:blur(14px);
}
.stat-num { font-family:'Playfair Display',serif; font-size:34px; color:var(--gold); font-weight:700; display:block; }
.stat-label { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.5); margin-top:4px; }
@keyframes fadeUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }

/* SECTIONS */
section { padding:100px max(60px, env(safe-area-inset-right, 0px)) 100px max(60px, env(safe-area-inset-left, 0px)); }
.section-tag { font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:16px; }
.section-tag::before { content:''; display:inline-block; width:20px; height:1px; background:var(--gold); vertical-align:middle; margin-right:10px; }
.section-title { font-family:'Playfair Display',serif; font-size:clamp(30px,4vw,52px); font-weight:700; line-height:1.15; margin-bottom:18px; }
.section-subtitle { font-family:'Cormorant Garamond',serif; font-size:18px; color:var(--muted); font-weight:300; line-height:1.7; max-width:540px; }
.reveal { opacity:0; transform:translateY(40px); transition:all .8s cubic-bezier(.16,1,.3,1); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* TRENDS */
#trends { background:var(--dark); }
.trends-header { margin-bottom:50px; }
.trends-header .section-title { color:var(--white); }
.trends-header .section-subtitle { color:rgba(255,255,255,.5); }
.live-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(201,168,76,.15); border:1px solid rgba(201,168,76,.3); padding:6px 16px; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:30px; }
.live-dot { width:8px; height:8px; background:var(--gold); border-radius:50%; animation:pulse 2s ease infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.8)} }
.trends-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.trend-card { position:relative; background:var(--charcoal); padding:40px 32px; border-top:2px solid transparent; transition:all .4s; overflow:hidden; cursor:pointer; }
.trend-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--gold); transform:scaleX(0); transition:transform .4s; }
.trend-card:hover::before { transform:scaleX(1); }
.trend-card:hover { background:#242422; }
.trend-num { font-family:'Playfair Display',serif; font-size:64px; font-weight:700; color:rgba(201,168,76,.12); line-height:1; margin-bottom:16px; }
.trend-title { font-family:'Playfair Display',serif; font-size:20px; color:var(--white); margin-bottom:12px; }
.trend-desc { font-size:14px; color:rgba(255,255,255,.5); line-height:1.7; }
.trend-arrow { position:absolute; bottom:30px; right:30px; color:var(--gold); opacity:0; transform:translateX(-10px); transition:all .3s; }
.trend-card:hover .trend-arrow { opacity:1; transform:translateX(0); }

/* CATALOG */
#catalog { background:var(--cream); }
.catalog-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:50px; flex-wrap:wrap; gap:20px; }
.catalog-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.catalog-card {
  position:relative; overflow:hidden; aspect-ratio:3/4; cursor:pointer;
  background:linear-gradient(160deg,#302f2b 0%,#171715 100%);
}
.catalog-card:first-child { grid-row:span 2; aspect-ratio:auto; }
.catalog-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.06) 0%,rgba(255,255,255,0) 25%,rgba(0,0,0,.38) 100%);
  z-index:1; pointer-events:none;
}
.catalog-card::after {
  content:''; position:absolute; inset:16px;
  border:1px solid rgba(255,255,255,.18);
  opacity:0; transform:scale(.97); transition:all .45s cubic-bezier(.16,1,.3,1); z-index:2; pointer-events:none;
}
.catalog-card img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .9s cubic-bezier(.16,1,.3,1), filter .4s ease;
  filter:brightness(.76) saturate(.86) contrast(.95);
}
.catalog-card:hover img { transform:scale(1.08); filter:brightness(.56) saturate(1) contrast(1); }
.catalog-card-info { position:absolute; bottom:0; left:0; right:0; padding:32px 24px 24px; background:linear-gradient(to top,rgba(0,0,0,.9),rgba(0,0,0,.1)); transform:translateY(20px); transition:transform .4s; z-index:3; }
.catalog-card:hover .catalog-card-info { transform:translateY(0); }
.catalog-card:hover::after { opacity:1; transform:scale(1); }
.card-category { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:5px; }
.card-name { font-family:'Playfair Display',serif; font-size:22px; color:var(--white); font-weight:700; }
.card-count { font-size:12px; color:rgba(255,255,255,.6); margin-top:4px; }
.card-arrow {
  position:absolute; top:22px; right:22px; width:42px; height:42px; border:1px solid rgba(201,168,76,.7);
  display:flex; align-items:center; justify-content:center; color:var(--gold);
  opacity:0; transform:translateY(-10px); transition:all .3s; font-size:13px; z-index:3;
  background:rgba(15,15,13,.28); backdrop-filter:blur(10px);
}
.catalog-card:hover .card-arrow { opacity:1; transform:translateY(0); }

/* CALCULATOR */
#calculator { background:var(--white); }
.calc-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; margin-top:50px; align-items:start; }
.calc-box { background:var(--cream); padding:48px; border-top:3px solid var(--gold); }
.calc-box h3 { font-family:'Playfair Display',serif; font-size:22px; margin-bottom:28px; }
.form-row { margin-bottom:20px; }
.form-row label { display:block; font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:7px; font-weight:500; }
.form-row input, .form-row select { width:100%; padding:13px 15px; border:1px solid #ddd; background:var(--white); font-family:'Jost',sans-serif; font-size:15px; color:var(--dark); outline:none; transition:border-color .3s; }
.form-row input:focus, .form-row select:focus { border-color:var(--gold); }
.form-2col { display:grid; grid-template-columns:1fr 1fr; gap:15px; }
.calc-history { margin-top:24px; }
.calc-history h4 { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
.history-item { display:flex; justify-content:space-between; align-items:center; padding:12px 16px; background:var(--white); margin-bottom:6px; font-size:13px; }
.history-item span:last-child { font-family:'Playfair Display',serif; color:var(--gold); font-weight:700; }
.calc-result-box { background:var(--dark); padding:48px; display:none; }
.calc-result-box.show { display:block; }
.result-main { font-family:'Playfair Display',serif; font-size:72px; font-weight:700; color:var(--gold); line-height:1; }
.result-label { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.4); margin-top:6px; }
.result-details { margin-top:28px; padding-top:28px; border-top:1px solid rgba(255,255,255,.1); }
.result-row { display:flex; justify-content:space-between; margin-bottom:10px; }
.result-row span:first-child { font-size:13px; color:rgba(255,255,255,.5); }
.result-row span:last-child { font-size:13px; color:var(--white); font-weight:500; }
.calc-features { display:flex; flex-direction:column; gap:24px; }
.calc-feat { display:flex; gap:18px; }
.calc-feat-icon { width:48px; height:48px; background:var(--gold); display:flex; align-items:center; justify-content:center; color:var(--dark); flex-shrink:0; font-size:18px; }
.calc-feat h4 { font-family:'Playfair Display',serif; font-size:17px; margin-bottom:5px; }
.calc-feat p { font-size:13px; color:var(--muted); line-height:1.6; }
.calc-cta-box { margin-top:30px; background:linear-gradient(135deg,var(--dark),#262622); padding:34px; color:var(--white); }
.calc-cta-box h3 { font-family:'Playfair Display',serif; font-size:28px; margin-bottom:10px; }
.calc-cta-box p { color:rgba(255,255,255,.65); font-size:15px; line-height:1.8; max-width:520px; }
.calc-cta-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:22px; }

/* MAP SECTION */
#showroom { background:var(--cream); }
.showroom-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; margin-top:50px; align-items:start; }
.map-container { height:420px; position:relative; overflow:hidden; }
.map-container iframe { width:100%; height:100%; border:0; }
.showroom-info h3 { font-family:'Playfair Display',serif; font-size:28px; margin-bottom:24px; }
.info-row { display:flex; gap:16px; align-items:flex-start; margin-bottom:20px; }
.info-icon { width:42px; height:42px; border:1px solid var(--gold); display:flex; align-items:center; justify-content:center; color:var(--gold); flex-shrink:0; font-size:15px; }
.info-label { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:3px; }
.info-value { font-size:16px; color:var(--dark); font-family:'Cormorant Garamond',serif; font-size:17px; }
.store-cards { display:flex; flex-direction:column; gap:12px; margin-top:28px; }
.store-card { background:var(--white); padding:18px 20px; border-left:3px solid var(--gold); }
.store-card h4 { font-size:14px; font-weight:600; margin-bottom:4px; }
.store-card p { font-size:13px; color:var(--muted); }
.store-rating { display:flex; align-items:center; gap:6px; margin-top:6px; font-size:12px; color:var(--gold); }

/* CONSULTATION */
#consultation { background:var(--white); }
.consult-grid { margin-top:50px; display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:24px; }
.consult-card { background:var(--cream); padding:34px 30px; min-height:100%; }
.consult-card h3 { font-family:'Playfair Display',serif; font-size:26px; margin-bottom:14px; }
.consult-card p { font-size:15px; color:var(--muted); line-height:1.8; }
.consult-kicker { display:block; font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.consult-intro { background:var(--dark); }
.consult-intro h3 { color:var(--white); }
.consult-intro p { color:rgba(255,255,255,.6); }
.consult-points { display:flex; flex-direction:column; gap:14px; margin-top:28px; }
.consult-point { display:flex; align-items:flex-start; gap:12px; color:var(--white); font-size:14px; }
.consult-point i { color:var(--gold); margin-top:3px; }
.consult-topics { display:grid; gap:10px; margin:20px 0 26px; }
.consult-topic { display:block; padding:14px 16px; background:var(--white); border:1px solid rgba(0,0,0,.08); color:var(--text); text-decoration:none; transition:all .3s; }
.consult-topic:hover { border-color:var(--gold); color:var(--gold); transform:translateX(4px); }
.consult-actions { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:18px; }
.consult-outline { color:var(--dark); border-color:rgba(0,0,0,.18); }
.consult-outline:hover { border-color:var(--gold); color:var(--gold); }
.consult-note { padding-top:18px; border-top:1px solid rgba(0,0,0,.08); font-size:14px; color:var(--muted); line-height:1.7; }
.consult-highlight { background:linear-gradient(180deg,var(--warm),var(--cream)); }
.consult-benefits { display:grid; gap:16px; }
.consult-benefit { padding:18px 0; border-bottom:1px solid rgba(0,0,0,.08); }
.consult-benefit:last-child { border-bottom:none; padding-bottom:0; }
.consult-benefit h4 { font-family:'Playfair Display',serif; font-size:19px; margin-bottom:8px; }
.consult-benefit p { font-size:14px; }

/* CONTACT */
#contact { background:var(--charcoal); padding:100px max(60px, env(safe-area-inset-right, 0px)) 100px max(60px, env(safe-area-inset-left, 0px)); display:grid; grid-template-columns:1fr 1fr; gap:80px; }
.contact-info .section-title { color:var(--white); }
.contact-details { margin-top:40px; display:flex; flex-direction:column; gap:24px; }
.contact-item { display:flex; gap:18px; align-items:flex-start; }
.contact-icon { width:42px; height:42px; border:1px solid var(--gold); display:flex; align-items:center; justify-content:center; color:var(--gold); flex-shrink:0; }
.contact-item span { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.4); display:block; margin-bottom:3px; }
.contact-item p { color:var(--white); font-family:'Cormorant Garamond',serif; font-size:17px; }
.contact-item a { color:inherit; text-decoration:none; border-bottom:1px solid transparent; transition:all .3s; }
.contact-item a:hover { color:var(--gold); border-color:var(--gold); }
.contact-form-wrap { background:var(--white); padding:48px; }
.contact-form-wrap h3 { font-family:'Playfair Display',serif; font-size:24px; margin-bottom:26px; }
.form-success { display:none; text-align:center; padding:30px; }
.form-success.show { display:block; }
.form-success i { font-size:48px; color:var(--gold); margin-bottom:14px; }
.form-success h4 { font-family:'Playfair Display',serif; font-size:20px; margin-bottom:6px; }
.form-success p { color:var(--muted); font-size:14px; }
.form-success-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:20px; }

/* FLOATING CONTACT */
.floating-contact { position:fixed; right:max(24px, env(safe-area-inset-right, 0px)); bottom:max(24px, env(safe-area-inset-bottom, 0px)); z-index:1600; display:flex; flex-direction:column; gap:10px; }
.floating-contact-link { width:54px; height:54px; border-radius:50%; display:flex; align-items:center; justify-content:center; text-decoration:none; background:var(--dark); color:var(--white); box-shadow:0 14px 32px rgba(0,0,0,.18); transition:all .3s; }
.floating-contact-link:hover { transform:translateY(-3px); background:var(--gold); color:var(--dark); }

/* FOOTER */
footer { background:#0f0f0d; padding:50px max(60px, env(safe-area-inset-right, 0px)) max(50px, env(safe-area-inset-bottom, 0px)) max(60px, env(safe-area-inset-left, 0px)); display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:24px; }
.footer-logo { font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:var(--white); letter-spacing:6px; text-decoration:none; }
.footer-logo span { color:var(--gold); }
.footer-links { display:flex; gap:30px; }
.footer-links a { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.4); text-decoration:none; transition:color .3s; }
.footer-links a:hover { color:var(--gold); }
.footer-socials { display:flex; gap:12px; }
.footer-socials a { width:38px; height:38px; border:1px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.4); text-decoration:none; transition:all .3s; font-size:13px; }
.footer-socials a:hover { border-color:var(--gold); color:var(--gold); }
.footer-copy { font-size:11px; color:rgba(255,255,255,.25); letter-spacing:1px; }

/* LIGHTBOX */
.lightbox { display:none; position:fixed; inset:0; background:rgba(0,0,0,.95); z-index:2000; align-items:center; justify-content:center; cursor:pointer; }
.lightbox.open { display:flex; }
.lightbox img { max-width:90vw; max-height:90vh; object-fit:contain; }
.lightbox-close { position:absolute; top:max(24px, env(safe-area-inset-top, 0px)); right:max(24px, env(safe-area-inset-right, 0px)); font-size:32px; color:rgba(255,255,255,.5); cursor:pointer; background:none; border:none; transition:color .3s; }
.lightbox-close:hover { color:var(--gold); }

/* GALLERY */
#gallery { background:var(--white); }
.gallery-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:44px; flex-wrap:wrap; gap:20px; }
.gallery-grid { display:grid; grid-template-columns:repeat(12,1fr); grid-template-rows:repeat(2,260px); gap:4px; }
.g-item { overflow:hidden; position:relative; cursor:pointer; background:linear-gradient(160deg,#e8e0d5,#f7f2ea); }
.g-item:nth-child(1) { grid-column:1/6; grid-row:1; }
.g-item:nth-child(2) { grid-column:6/9; grid-row:1; }
.g-item:nth-child(3) { grid-column:9/13; grid-row:1/3; }
.g-item:nth-child(4) { grid-column:1/4; grid-row:2; }
.g-item:nth-child(5) { grid-column:4/9; grid-row:2; }
.g-item::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,0) 30%,rgba(0,0,0,.28) 100%);
  z-index:1; pointer-events:none;
}
.g-item img { width:100%; height:100%; object-fit:cover; transition:transform .85s cubic-bezier(.16,1,.3,1), filter .35s ease; filter:saturate(.9) contrast(.96); }
.g-item:hover img { transform:scale(1.07); filter:saturate(1.02) contrast(1.02); }
.g-overlay { position:absolute; inset:0; background:rgba(26,26,24,0); transition:background .3s; display:flex; align-items:center; justify-content:center; z-index:2; }
.g-item:hover .g-overlay { background:rgba(26,26,24,.34); }
.g-icon { color:var(--white); font-size:22px; opacity:0; transform:scale(.5); transition:all .3s; }
.g-item:hover .g-icon { opacity:1; transform:scale(1); }

/* ABOUT */
#about {
  background:
    radial-gradient(circle at top right,rgba(201,168,76,.1),transparent 26%),
    var(--dark);
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; padding:120px max(60px, env(safe-area-inset-right, 0px)) 120px max(60px, env(safe-area-inset-left, 0px));
}
.about-img-wrap img { width:100%; height:560px; object-fit:cover; filter:saturate(.92) contrast(.95); }
.about-img-wrap { position:relative; }
.about-img-wrap::before {
  content:''; position:absolute; inset:18px;
  border:1px solid rgba(255,255,255,.18);
  z-index:1; pointer-events:none;
}
.about-img-wrap::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,rgba(0,0,0,.15) 100%);
  pointer-events:none;
}
.about-badge { position:absolute; bottom:-24px; right:-24px; width:150px; height:150px; background:var(--gold); display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; }
.badge-num { font-family:'Playfair Display',serif; font-size:48px; font-weight:700; color:var(--dark); line-height:1; }
.badge-text { font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--dark); margin-top:4px; font-weight:500; }
.about-content .section-title { color:var(--white); }
.about-content p { color:rgba(255,255,255,.55); font-family:'Cormorant Garamond',serif; font-size:18px; line-height:1.8; margin:22px 0; }
.features-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:36px; }
.feature { border-left:2px solid var(--gold); padding-left:14px; }
.feature-title { font-size:12px; font-weight:500; color:var(--white); letter-spacing:1px; text-transform:uppercase; margin-bottom:5px; }
.feature-desc { font-size:13px; color:rgba(255,255,255,.45); line-height:1.6; }

/* RESPONSIVE */
@media(max-width:1100px) {
  .trends-grid { grid-template-columns:1fr 1fr; }
  .catalog-grid { grid-template-columns:1fr 1fr; }
  .catalog-card:first-child { grid-row:span 1; aspect-ratio:3/4; }
  .consult-grid { grid-template-columns:1fr; }
  #about { grid-template-columns:1fr; gap:50px; padding:80px max(40px, env(safe-area-inset-right, 0px)) 80px max(40px, env(safe-area-inset-left, 0px)); }
  .showroom-grid { grid-template-columns:1fr; }
  #contact { grid-template-columns:1fr; gap:50px; }
  .gallery-grid { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .g-item { grid-column:auto !important; grid-row:auto !important; height:200px; }
  .calc-grid { grid-template-columns:1fr; }
}
@media(max-width:768px) {
  header { padding:18px max(24px, env(safe-area-inset-right, 0px)) 18px max(24px, env(safe-area-inset-left, 0px)); padding-top:max(18px, env(safe-area-inset-top, 0px)); }
  header.scrolled { padding:14px max(24px, env(safe-area-inset-right, 0px)) 14px max(24px, env(safe-area-inset-left, 0px)); padding-top:max(14px, env(safe-area-inset-top, 0px)); }
  nav { display:none; }
  .burger { display:flex; }
  section { padding:70px max(24px, env(safe-area-inset-right, 0px)) 70px max(24px, env(safe-area-inset-left, 0px)); }
  #hero { min-height:auto; padding:max(118px, calc(90px + env(safe-area-inset-top, 0px))) 0 max(34px, env(safe-area-inset-bottom, 0px)); }
  .hero-content { padding:0 max(24px, env(safe-area-inset-right, 0px)) 0 max(24px, env(safe-area-inset-left, 0px)); }
  .hero-pattern { display:none; }
  .hero-img { width:100%; opacity:.2; }
  .hero-overlay { background:linear-gradient(180deg,rgba(26,26,24,.84) 0%,rgba(26,26,24,.92) 100%); }
  .hero-stats { position:relative; right:auto; bottom:auto; margin-top:30px; opacity:1; animation:none; flex-wrap:wrap; display:flex; gap:10px; width:100%; }
  .hero-sub { font-size:18px; line-height:1.55; margin-bottom:28px; max-width:none; }
  .stat { min-width:0; flex:1; padding:14px 10px; }
  .stat-num { font-size:clamp(22px, 7vw, 34px); }
  .stat-label { font-size:9px; letter-spacing:1.2px; }
  .section-subtitle { font-size:15px; line-height:1.55; }
  .live-badge { margin-bottom:20px; font-size:9px; border:none; padding:0; background:transparent; }
  .trend-card { padding:30px 22px; }
  .trend-num { font-size:50px; margin-bottom:12px; }
  .trend-desc { font-size:14px; line-height:1.6; }
  .catalog-header .section-subtitle { display:block; margin-top:10px; }
  .consult-card { padding:26px 22px; }
  .consult-card p { font-size:14px; line-height:1.65; }
  .consult-note { padding-top:12px; font-size:13px; }
  .calc-header .section-subtitle { display:block; margin-top:10px; }
  .calc-cta-box p { font-size:14px; line-height:1.65; }
  #about { padding:56px max(24px, env(safe-area-inset-right, 0px)) 56px max(24px, env(safe-area-inset-left, 0px)); }
  .about-badge { width:90px; height:90px; bottom:-10px; right:-10px; }
  .badge-num { font-size: 30px; }
  .about-content p { font-size:16px; line-height:1.65; margin:16px 0; }
  .gallery-header .btn-primary { width:100%; text-align:center; padding:14px; margin-top:12px; }
  .map-container { height:280px; }
  .store-rating { font-size: 11px; margin-top:8px; }
  footer { padding:36px max(24px, env(safe-area-inset-right, 0px)) max(36px, env(safe-area-inset-bottom, 0px)) max(24px, env(safe-area-inset-left, 0px)); flex-direction:column; text-align:left; align-items:flex-start; }
  .footer-links { flex-direction:column; align-items:flex-start; gap:12px; }
  .footer-socials { margin-top:4px; }
  #contact { padding:70px max(24px, env(safe-area-inset-right, 0px)) max(100px, calc(70px + env(safe-area-inset-bottom, 0px))) max(24px, env(safe-area-inset-left, 0px)); }
  .contact-details { gap:18px; margin-top:28px; }
  .contact-form-wrap { padding:28px 22px; }
  .calc-box { padding:28px 22px; }
  .trends-grid { grid-template-columns:1fr; }
  .features-grid { grid-template-columns:1fr; }
  .catalog-grid { grid-template-columns:1fr; }
  .hero-btns { flex-direction:column; align-items:stretch; gap:14px; }
  .floating-contact { right:max(16px, env(safe-area-inset-right, 0px)); bottom:max(16px, env(safe-area-inset-bottom, 0px)); }
  .floating-contact-link { width:50px; height:50px; }
  .mobile-menu-links { margin-top:18px; gap:12px; }
  .mobile-menu-links a { font-size:36px; }
  .mobile-menu-logo { font-size:36px; }
  .mobile-back,
  .mobile-close { font-size:24px; min-width: 44px; min-height: 44px; display:flex; align-items:center; justify-content:center; }
  .result-main { font-size:clamp(36px, 11vw, 56px); line-height:1.05; word-break:break-word; }
  .result-row { flex-wrap:wrap; gap:4px 12px; }
  .form-2col { grid-template-columns:1fr; }
  .calc-result-box { padding:28px 22px; }
}
@media(max-width:480px) {
  .mobile-menu-links a { font-size:clamp(26px, 9vw, 34px); line-height:1.1; }
  .mobile-menu-logo { font-size:clamp(28px, 8vw, 36px); }
  .hero-title { font-size:clamp(36px, 10vw, 52px); }
}
