
:root{
  --bg:#0c0c0d;
  --bg-soft:#121315;
  --surface:#17191c;
  --surface-2:#1d2025;
  --muted:#a7adb8;
  --text:#f7f7f5;
  --text-dark:#141516;
  --accent:#c8a56a;
  --accent-2:#f3dfb5;
  --line:rgba(255,255,255,.08);
  --shadow:0 18px 60px rgba(0,0,0,.35);
  --radius:28px;
  --radius-sm:18px;
  --container:1200px;
  --header-offset:96px;
}

*,
*::before,
*::after{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:"Manrope",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:
    radial-gradient(circle at top left, rgba(200,165,106,.12), transparent 28%),
    radial-gradient(circle at 90% 15%, rgba(255,255,255,.05), transparent 20%),
    linear-gradient(180deg,#0b0c0d 0%, #121315 38%, #0d0e10 100%);
  color:var(--text);
  min-width:320px;
}

img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button,input,select,textarea{font:inherit}

.container{
  width:min(var(--container), calc(100% - 2rem));
  margin:0 auto;
}

.section{
  padding:96px 0;
  position:relative;
}

.section-tight{padding:36px 0 20px}
.section-muted{background:rgba(255,255,255,.02)}
.section-dark{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.015)); border-block:1px solid var(--line)}
.section-cta{
  padding:96px 0 110px;
  background:
    radial-gradient(circle at 20% 0%, rgba(200,165,106,.16), transparent 26%),
    linear-gradient(180deg, rgba(17,18,20,1), rgba(11,12,13,1));
}
.section-stats{padding:32px 0 0}

.section-head{
  max-width:760px;
  margin-bottom:36px;
}

.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:.85rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent-2);
  margin-bottom:12px;
}
.section-kicker::before{
  content:"";
  width:34px;
  height:1px;
  background:linear-gradient(90deg,var(--accent),transparent);
}

h1,h2,h3,h4{
  margin:0 0 18px;
  line-height:1.08;
  letter-spacing:-0.03em;
}
h1,h2{
  font-family:"Playfair Display", Georgia, serif;
}
h1{font-size:clamp(2.3rem, 5vw, 5.2rem)}
h2{font-size:clamp(2rem, 4vw, 3.3rem)}
h3{font-size:1.35rem}
p{
  margin:0 0 16px;
  color:var(--muted);
  line-height:1.75;
  font-size:1rem;
}

.topbar{
  background:rgba(0,0,0,.32);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar-inner{
  min-height:42px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  font-size:.92rem;
}
.topbar-copy{color:#d8d8d4}
.topbar-actions{display:flex; gap:18px; flex-wrap:wrap}
.contact-link{color:#f7ead2; transition:.25s ease}
.contact-link:hover{color:#fff}

.site-header{
  position:sticky;
  top:0;
  z-index:20;
  backdrop-filter:blur(14px);
  background:rgba(10,11,12,.66);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header-shell{
  min-height:84px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
}
.brand img{
  width:74px;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 6px 24px rgba(0,0,0,.35));
}
.brand-text{
  display:flex;
  flex-direction:column;
  gap:3px;
  min-width:0;
}
.brand-text strong{font-size:1rem}
.brand-text span{
  font-size:.86rem;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.main-nav{
  display:flex;
  align-items:center;
  gap:20px;
}
.nav-link{
  color:#ece7dc;
  font-weight:600;
  font-size:.95rem;
  position:relative;
  transition:.25s ease;
}
.nav-link::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-10px;
  width:100%;
  height:2px;
  transform:scaleX(0);
  transform-origin:left center;
  background:linear-gradient(90deg,var(--accent),transparent);
  transition:.25s ease;
}
.nav-link:hover,
.nav-link.is-active{color:#fff}
.nav-link:hover::after,
.nav-link.is-active::after{transform:scaleX(1)}
.nav-cta{margin-left:8px}

.menu-toggle{
  display:none;
  width:48px;
  height:48px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:#fff;
  justify-content:center;
  align-items:center;
  padding:0;
  cursor:pointer;
}
.menu-toggle span{
  display:block;
  width:20px;
  height:2px;
  margin:3px 0;
  background:#fff;
  border-radius:999px;
  transition:.25s ease;
}

.hero{
  position:relative;
  overflow:hidden;
}
.hero-home{
  min-height:clamp(640px, 84vh, 820px);
}
.hero-slider,
.hero-slide{
  position:relative;
  min-height:clamp(640px, 84vh, 820px);
}
.hero-slide{
  display:none;
  background:
    linear-gradient(90deg, rgba(7,8,10,.84) 0%, rgba(7,8,10,.58) 44%, rgba(7,8,10,.74) 100%),
    var(--hero-image) center / cover no-repeat;
}
.hero-slide.is-active{display:block}
.hero-subpage{
  min-height:520px;
  background:
    linear-gradient(90deg, rgba(7,8,10,.8) 0%, rgba(7,8,10,.45) 52%, rgba(7,8,10,.76) 100%),
    var(--page-hero) center / cover no-repeat;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 20%, rgba(200,165,106,.18), transparent 22%),
    radial-gradient(circle at 80% 0%, rgba(255,255,255,.08), transparent 18%);
  pointer-events:none;
}
.hero-content{
  position:relative;
  min-height:inherit;
  display:flex;
  align-items:center;
  padding:22px 0 72px;
}
.hero-content.narrow{padding-top:120px}
.hero-panel{
  position:relative;
  z-index:1;
  width:min(760px,100%);
  padding:34px;
  border-radius:32px;
  border:1px solid rgba(255,255,255,.09);
  background:linear-gradient(180deg, rgba(18,19,22,.76), rgba(12,13,15,.76));
  box-shadow:var(--shadow);
}
.hero-home .hero-panel{margin-top:40px}
.hero-panel p{
  font-size:1.08rem;
  max-width:62ch;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:28px;
}

.hero-controls{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  width:min(var(--container), calc(100% - 2rem));
  gap:16px;
}
.slider-arrow{
  width:52px;
  height:52px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(10,10,11,.48);
  color:#fff;
  font-size:1.1rem;
  cursor:pointer;
  transition:.25s ease;
}
.slider-arrow:hover{background:rgba(200,165,106,.16); transform:translateY(-1px)}
.slider-dots{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  flex:1;
}
.slider-dots button{
  width:12px;
  height:12px;
  border:none;
  border-radius:999px;
  background:rgba(255,255,255,.36);
  cursor:pointer;
  transition:.25s ease;
}
.slider-dots button.is-active{
  width:36px;
  background:linear-gradient(90deg,var(--accent),#f2d59e);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 22px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:800;
  letter-spacing:.01em;
  transition:.25s ease;
  cursor:pointer;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  background:linear-gradient(135deg,var(--accent),#efd4a0);
  color:#151515;
  box-shadow:0 14px 40px rgba(200,165,106,.24);
}
.btn-secondary{
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.16);
  color:#fff;
}
.btn-small{
  min-height:44px;
  padding:0 18px;
  font-size:.94rem;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}
.stat-card,
.mini-card,
.offer-card,
.showcase-card,
.process-card,
.contact-box,
.contact-card,
.media-card,
.content-card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  box-shadow:var(--shadow);
}
.stat-card{
  padding:28px 24px;
}
.stat-card strong{
  display:block;
  font-size:clamp(2rem,4vw,3rem);
  color:#fff;
  margin-bottom:8px;
}
.stat-card span{
  color:var(--muted);
  line-height:1.5;
}

.card-grid{
  display:grid;
  gap:24px;
}
.card-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.offer-card{
  overflow:hidden;
  position:relative;
  isolation:isolate;
  transition:.3s ease;
}
.offer-card:hover,
.showcase-card:hover{
  transform:translateY(-8px);
  border-color:rgba(200,165,106,.32);
}
.offer-card img{
  aspect-ratio:4/3;
  object-fit:cover;
}
.offer-card-body{
  padding:24px;
}
.offer-card-body span{
  display:inline-flex;
  margin-top:14px;
  color:var(--accent-2);
  font-weight:800;
}

.split-layout{
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:28px;
  align-items:center;
}
.media-card{
  overflow:hidden;
  min-height:100%;
}
.media-card img{
  width:100%;
  height:100%;
  min-height:420px;
  object-fit:cover;
}
.content-card{
  padding:34px;
}
.bullet-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:28px;
}
.bullet-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  color:#fff;
  font-weight:700;
}
.bullet-item::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--accent),#f2d59e);
  box-shadow:0 0 0 6px rgba(200,165,106,.12);
}

.showcase-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}
.showcase-card{
  overflow:hidden;
  transition:.3s ease;
}
.showcase-card img{
  aspect-ratio:4/3;
  object-fit:cover;
}
.showcase-card-body{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:18px 20px;
}
.showcase-card-body strong{font-size:1.05rem}
.showcase-card-body span{color:var(--accent-2); font-weight:800; white-space:nowrap}

.process-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:20px;
}
.process-card{
  padding:26px;
}
.process-number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  margin-bottom:16px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--accent),#efd4a0);
  color:#151515;
  font-weight:900;
}
.process-card p{margin-bottom:0}

.faq-layout{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:24px;
}
.faq-list{display:grid; gap:14px}
.faq-item{
  padding:0 22px;
  border-radius:24px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:22px 4px;
  font-weight:800;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item p{
  padding:0 4px 20px;
  margin:0;
}

.cta-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:start;
}
.contact-cards{
  display:grid;
  gap:14px;
  margin:28px 0 22px;
}
.contact-card{
  padding:22px;
  display:flex;
  flex-direction:column;
  gap:6px;
  transition:.25s ease;
}
.contact-card:hover{transform:translateY(-4px); border-color:rgba(200,165,106,.28)}
.contact-card-label{
  color:var(--accent-2);
  font-size:.84rem;
  text-transform:uppercase;
  letter-spacing:.16em;
}
.contact-card strong{font-size:1.1rem}
.contact-card.static{pointer-events:none}

.pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.pill{
  display:inline-flex;
  align-items:center;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
  font-size:.94rem;
}

.lead-form{
  padding:32px;
  border-radius:32px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow:var(--shadow);
}
.form-row{
  display:grid;
  gap:16px;
  margin-bottom:18px;
}
.form-row.two{grid-template-columns:repeat(2,minmax(0,1fr))}
label{display:grid; gap:10px}
label span{font-weight:700}
input, select, textarea{
  width:100%;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(12,13,15,.75);
  color:#fff;
  padding:16px 18px;
  outline:none;
  transition:border-color .2s ease, background .2s ease;
}
input:focus, select:focus, textarea:focus{
  border-color:rgba(200,165,106,.75);
  background:rgba(16,17,19,.92);
}
textarea{resize:vertical; min-height:130px}
.checkbox{
  grid-template-columns:auto 1fr;
  align-items:flex-start;
  gap:12px;
  margin-bottom:18px;
}
.checkbox input{
  width:18px;
  height:18px;
  margin-top:4px;
  padding:0;
}
.form-actions{
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.form-note{font-size:.92rem; margin:0}
.form-status{
  margin-top:16px;
  min-height:26px;
  font-weight:700;
  color:var(--accent-2);
}

.breadcrumbs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:22px;
  font-size:.95rem;
  color:#e7dcc7;
}
.breadcrumbs a{
  color:#e7dcc7;
}
.breadcrumbs span::before,
.breadcrumbs a + a::before{
  content:"";
}
.breadcrumbs a::after{
  content:"/";
  margin-left:10px;
  color:rgba(255,255,255,.35);
}
.breadcrumbs span{color:#fff}

.mini-card-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}
.mini-card{
  padding:24px;
}
.mini-card strong{
  display:block;
  font-size:1.12rem;
  margin-bottom:8px;
}
.mini-card span{
  display:inline-flex;
  margin-bottom:10px;
  color:var(--accent-2);
  font-weight:900;
  font-size:1.2rem;
}
.mini-card p{margin:0}

.filter-bar{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:28px;
}
.filter-chip{
  min-height:44px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.03);
  color:#fff;
  font-weight:700;
  cursor:pointer;
  transition:.25s ease;
}
.filter-chip:hover,
.filter-chip.is-active{
  border-color:rgba(200,165,106,.42);
  background:rgba(200,165,106,.16);
}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}
.gallery-item{
  transition:opacity .25s ease, transform .25s ease;
}
.gallery-item.is-hidden{
  display:none;
}
.gallery-link{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:24px;
  border:1px solid var(--line);
  background:#0c0d0e;
  box-shadow:var(--shadow);
}
.gallery-link img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  transition:transform .45s ease;
}
.gallery-overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:5px;
  background:linear-gradient(180deg, transparent, rgba(5,6,7,.92));
}
.gallery-overlay strong{
  font-size:.98rem;
  color:#fff;
}
.gallery-overlay em{
  font-style:normal;
  color:#d5c39e;
  font-size:.85rem;
}
.gallery-link:hover img{transform:scale(1.06)}

.modern-list{
  list-style:none;
  padding:0;
  margin:24px 0 0;
  display:grid;
  gap:12px;
}
.modern-list li{
  padding:16px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
}
.modern-list li::before{
  content:"✓";
  color:var(--accent-2);
  font-weight:900;
  margin-right:10px;
}

.contact-page-grid,
.map-grid{
  display:grid;
  gap:24px;
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.contact-box{
  padding:30px;
}
.contact-list{
  list-style:none;
  padding:0;
  margin:18px 0 0;
  display:grid;
  gap:14px;
}
.contact-list li{color:#fff}
.contact-list strong{color:var(--accent-2)}
.map-card{
  overflow:hidden;
  border-radius:32px;
  border:1px solid var(--line);
  min-height:460px;
  box-shadow:var(--shadow);
}
.map-card iframe{
  width:100%;
  height:100%;
  min-height:460px;
  border:0;
  display:block;
}

.site-footer{
  border-top:1px solid rgba(255,255,255,.08);
  background:#0b0c0d;
  padding:34px 0 0;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr .9fr;
  gap:24px;
  padding-bottom:24px;
}
.footer-grid h3,
.footer-grid h4{margin-bottom:14px}
.footer-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}
.footer-list.compact{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.footer-bottom{
  padding:18px 0 28px;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-bottom p{margin:0}

.floating-actions{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:17;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.floating-btn{
  min-width:112px;
  min-height:48px;
  padding:0 18px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--accent),#efd4a0);
  color:#151515;
  font-weight:900;
  box-shadow:0 16px 34px rgba(0,0,0,.32);
}
.floating-btn.secondary{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
}

.cookie-banner{
  position:fixed;
  left:18px;
  right:18px;
  bottom:18px;
  z-index:30;
  display:grid;
  grid-template-columns:1fr auto;
  gap:18px;
  align-items:center;
  padding:18px 20px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(9,10,12,.95);
  box-shadow:var(--shadow);
}
.cookie-banner p{margin:6px 0 0}
.cookie-banner-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.lightbox{
  position:fixed;
  inset:0;
  z-index:40;
  background:rgba(4,4,5,.94);
  display:grid;
  place-items:center;
  padding:40px;
}
.lightbox[hidden],
.cookie-banner[hidden]{display:none !important}
.lightbox-figure{
  width:min(1100px,100%);
  margin:0;
  text-align:center;
}
.lightbox-figure img{
  width:100%;
  max-height:80vh;
  object-fit:contain;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.1);
  box-shadow:var(--shadow);
}
.lightbox-figure figcaption{
  margin-top:14px;
  color:#efe6d7;
}
.lightbox-close,
.lightbox-nav{
  position:absolute;
  border:none;
  cursor:pointer;
}
.lightbox-close{
  top:18px;
  right:18px;
  width:54px;
  height:54px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:2rem;
}
.lightbox-nav{
  top:50%;
  transform:translateY(-50%);
  width:56px;
  height:56px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:1.5rem;
}
.lightbox-nav.prev{left:20px}
.lightbox-nav.next{right:20px}

.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.is-visible{
  opacity:1;
  transform:none;
}

@media (max-width: 1100px){
  .card-grid-4,
  .mini-card-grid,
  .stats-grid,
  .process-grid,
  .gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .showcase-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .split-layout,
  .faq-layout,
  .cta-grid,
  .map-grid,
  .contact-page-grid,
  .footer-grid{grid-template-columns:1fr}
}

@media (max-width: 900px){
  .site-header{position:sticky}
  .menu-toggle{display:inline-flex}
  .main-nav{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    display:none;
    flex-direction:column;
    align-items:flex-start;
    padding:18px 1rem 24px;
    background:rgba(11,12,13,.97);
    border-bottom:1px solid rgba(255,255,255,.08);
  }
  .main-nav.is-open{display:flex}
  .nav-cta{margin-left:0}
  .topbar-inner{flex-direction:column; align-items:flex-start; padding:10px 0}
  .hero-home,
  .hero-slider,
  .hero-slide{min-height:700px}
  .hero-subpage{min-height:560px}
  .hero-controls{bottom:22px}
  .hero-panel{padding:28px}
}

@media (max-width: 640px){
  :root{--radius:24px}
  .section{padding:74px 0}
  .hero-panel{padding:24px 20px}
  .hero-actions,
  .form-actions,
  .cookie-banner-actions{flex-direction:column; align-items:stretch}
  .btn,.floating-btn{width:100%}
  .form-row.two,
  .stats-grid,
  .card-grid-4,
  .showcase-grid,
  .process-grid,
  .mini-card-grid,
  .gallery-grid,
  .bullet-grid{grid-template-columns:1fr}
  .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
    grid-template-columns:1fr;
  }
  .floating-actions{
    left:12px;
    right:12px;
    bottom:12px;
  }
  .lightbox{
    padding:18px;
  }
  .lightbox-nav{display:none}
  .lightbox-close{
    top:10px;
    right:10px;
  }
  .brand img{width:60px}
  .brand-text span{white-space:normal}
}


/* Premium refresh */
.section-head{
  position:relative;
  padding:0 0 0 22px;
}
.section-head::before{
  content:"";
  position:absolute;
  left:0;
  top:6px;
  bottom:10px;
  width:2px;
  border-radius:999px;
  background:linear-gradient(180deg,var(--accent),transparent);
}

.hero-topline{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:14px;
  margin:0 0 18px;
  position:relative;
  z-index:1;
}
.hero-badge,
.hero-chip{
  display:inline-flex;
  align-items:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(14px);
  color:#fff;
  font-weight:700;
  box-shadow:0 14px 28px rgba(0,0,0,.22);
}
.hero-badge{
  background:linear-gradient(135deg, rgba(200,165,106,.26), rgba(255,255,255,.07));
  color:#fff4de;
}
.hero-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.hero-chip{
  font-size:.95rem;
  color:#ece6dc;
}
.breadcrumbs{display:none !important}

.stats-grid{
  gap:22px;
  margin-top:-44px;
  position:relative;
  z-index:2;
}
.stat-card{
  padding:30px 26px 26px;
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(10px);
  background:linear-gradient(180deg, rgba(23,25,28,.92), rgba(16,18,20,.94));
}
.stat-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 100% 0, rgba(200,165,106,.22), transparent 34%);
  pointer-events:none;
}
.stat-card strong{
  position:relative;
  margin-bottom:14px;
}
.stat-card span{
  position:relative;
  display:block;
  max-width:22ch;
}

.offer-card{
  display:flex;
  flex-direction:column;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
}
.offer-card img{
  aspect-ratio:16/11;
  width:100%;
}
.offer-card-body{
  position:relative;
  margin:-42px 18px 18px;
  padding:24px 24px 22px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg, rgba(17,18,20,.95), rgba(14,15,17,.96));
  box-shadow:0 24px 34px rgba(0,0,0,.3);
}
.offer-card-body::before{
  content:"";
  position:absolute;
  left:24px;
  right:24px;
  top:0;
  height:1px;
  background:linear-gradient(90deg, rgba(200,165,106,.9), transparent);
}
.offer-card h3,
.showcase-card strong,
.mini-card strong{
  letter-spacing:-.02em;
}
.offer-card-body p{
  min-height:84px;
}
.offer-card-body span{
  gap:8px;
  align-items:center;
}
.offer-card-body span::after{
  content:"→";
  font-size:1rem;
}
.offer-card:hover .offer-card-body{
  transform:translateY(-4px);
  transition:.3s ease;
}

.mini-card-grid{
  gap:22px;
}
.mini-card{
  padding:26px 24px;
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
}
.mini-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 100% 0, rgba(200,165,106,.18), transparent 36%);
  pointer-events:none;
}
.mini-card span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:58px;
  min-height:58px;
  margin-bottom:18px;
  border-radius:18px;
  color:#151515;
  background:linear-gradient(135deg,var(--accent),#f3dfb5);
  box-shadow:0 16px 30px rgba(200,165,106,.2);
}
.mini-card strong,
.mini-card p{position:relative}

.content-card,
.contact-box,
.contact-card,
.media-card,
.showcase-card,
.gallery-link{
  background:linear-gradient(180deg, rgba(23,25,28,.96), rgba(14,16,18,.98));
}
.content-card,
.contact-box{
  padding:38px;
}
.contact-card{
  position:relative;
  overflow:hidden;
}
.contact-card::after{
  content:"";
  position:absolute;
  right:-18px;
  top:-18px;
  width:72px;
  height:72px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(200,165,106,.28), transparent 70%);
}

.gallery-link{
  border-radius:28px;
}
.gallery-overlay{
  background:linear-gradient(180deg, transparent 0%, rgba(9,10,12,.24) 28%, rgba(9,10,12,.88) 100%);
}
.filter-chip{
  padding:0 18px;
  background:rgba(255,255,255,.045);
}

.lead-form{
  position:relative;
  overflow:hidden;
}
.lead-form::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 100% 0, rgba(200,165,106,.14), transparent 30%);
  pointer-events:none;
}
.lead-form .form-note{
  color:#d9d1c0;
}
.checkbox span a,
.cookie-banner-copy a,
.footer-legal-links a,
.footer-list a{
  color:#f2dfb8;
}

.site-footer{
  padding-top:46px;
}
.footer-grid{
  grid-template-columns:1.2fr .9fr .9fr .85fr;
}
.footer-bottom-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.footer-legal-links{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
}

.cookie-banner{
  left:max(18px, env(safe-area-inset-left));
  right:max(18px, env(safe-area-inset-right));
  bottom:max(18px, env(safe-area-inset-bottom));
  grid-template-columns:minmax(0,1fr) auto;
  gap:20px;
  padding:20px 22px;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(14,15,17,.96), rgba(10,11,12,.98));
  box-shadow:0 28px 60px rgba(0,0,0,.42);
}
.cookie-banner-copy strong{
  display:block;
  margin-bottom:6px;
  font-size:1.05rem;
}
.cookie-banner-copy p{
  max-width:72ch;
}
.cookie-link{
  border-color:rgba(255,255,255,.1);
}

@media (max-width: 1100px){
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .card-grid-4,
  .mini-card-grid,
  .gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 768px){
  .hero-topline{margin-bottom:14px}
  .stats-grid{margin-top:0}
  .offer-card-body{margin:-26px 14px 14px}
  .offer-card-body p{min-height:0}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom-inner{align-items:flex-start}
  .cookie-banner{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .hero-chip-row{gap:8px}
  .hero-chip,.hero-badge{min-height:38px; padding:0 14px; font-size:.86rem}
}

.process-card{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
}
.process-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 100% 0, rgba(200,165,106,.16), transparent 34%);
  pointer-events:none;
}
.process-number{
  box-shadow:0 16px 28px rgba(200,165,106,.18);
}
.faq-item{
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.018));
  transition:.25s ease;
}
.faq-item[open],
.faq-item:hover{
  border-color:rgba(200,165,106,.28);
  transform:translateY(-2px);
}



/* Final polish update */
.site-header{background:rgba(10,11,12,.78)}
.header-shell{min-height:78px; gap:14px}
.brand img{width:64px}
.brand-text strong{font-size:.98rem}
.main-nav{gap:12px; flex-wrap:nowrap; white-space:nowrap}
.nav-link{font-size:.88rem; letter-spacing:.01em}
.nav-cta{margin-left:4px; min-width:154px; text-align:center; white-space:nowrap}

.hero-home .hero-panel{width:min(700px,100%); padding:38px 36px}
.hero-home .hero-panel h1{max-width:14ch; margin-bottom:14px}
.hero-home .hero-panel p{max-width:58ch; color:#e6dfd1}
.hero-highlight-row{display:flex; flex-wrap:wrap; gap:12px; margin:18px 0 0}
.hero-highlight{display:inline-flex; align-items:center; gap:10px; padding:12px 16px; border-radius:18px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); color:#fff; font-weight:700}
.hero-highlight::before{content:""; width:10px; height:10px; border-radius:999px; background:linear-gradient(135deg,var(--accent),#f0ddb5); box-shadow:0 0 0 6px rgba(200,165,106,.12)}

.section-head{max-width:820px}
.mini-card{text-align:center}
.mini-card p{max-width:26ch; margin:0 auto}

.split-layout{grid-template-columns:1fr 1fr; gap:32px; align-items:stretch}
.media-card{height:100%; display:flex; align-items:center; justify-content:center}
.media-card img{width:100%; height:100%; min-height:100%; display:block; object-fit:cover; object-position:center center}
.content-card{display:flex; flex-direction:column; justify-content:center; min-height:100%}
.content-card p{max-width:60ch}
.content-card .section-kicker{margin-bottom:10px}

.hero-subpage{min-height:500px}
.hero-subpage .hero-content{padding-top:84px; padding-bottom:84px}
.subhero-grid{display:grid; grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr); gap:28px; align-items:center; width:100%}
.subhero-grid .hero-panel{width:100%; margin-top:0}
.hero-visual{position:relative; overflow:hidden; border-radius:32px; border:1px solid rgba(255,255,255,.1); background:linear-gradient(180deg, rgba(23,25,28,.96), rgba(14,16,18,.98)); box-shadow:var(--shadow); min-height:360px}
.hero-visual::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,9,11,.02), rgba(8,9,11,.18)); pointer-events:none}
.hero-visual img{width:100%; height:100%; min-height:360px; display:block; object-fit:cover; object-position:center}
.hero-panel .hero-topline{margin-bottom:18px}
.hero-panel .hero-topline .hero-chip{background:rgba(255,255,255,.05)}
.hero-subpage .hero-panel .section-kicker{display:none}
.hero-subpage.is-compact .hero-panel{max-width:820px}
.hero-subpage.is-compact .hero-content{padding-bottom:72px}

.cookie-banner{padding:18px 20px}
.cookie-banner-copy p{max-width:64ch}

@media (max-width: 1280px){
  .brand-text span{display:none}
  .main-nav{gap:10px}
  .nav-link{font-size:.84rem}
  .nav-cta{min-width:140px; padding:0 14px}
}
@media (max-width: 1100px){
  .subhero-grid{grid-template-columns:1fr}
  .hero-visual{min-height:280px}
  .hero-visual img{min-height:280px}
}
@media (max-width: 900px){
  .main-nav{white-space:normal}
}
@media (max-width: 640px){
  .hero-home .hero-panel{padding:26px 20px}
  .hero-highlight-row{display:grid; grid-template-columns:1fr}
  .subhero-grid{gap:18px}
}


/* Homepage hero refresh */
.hero-home{
  min-height:clamp(620px, 78vh, 760px);
}
.hero-slider,
.hero-slide{
  min-height:clamp(620px, 78vh, 760px);
}
.hero-home .hero-content{
  padding-top:26px;
  padding-bottom:86px;
}
.hero-home-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(330px, 430px);
  align-items:center;
  gap:clamp(26px, 4vw, 48px);
  width:min(1120px, 100%);
  margin:0 auto;
}
.hero-copy{
  position:relative;
  z-index:1;
  max-width:540px;
  align-self:center;
  padding:0;
  border:none;
  background:none;
  backdrop-filter:none;
  box-shadow:none;
}
.hero-copy h1,
.hero-copy h2{
  margin:14px 0 0;
  max-width:10ch;
  font-size:clamp(2.55rem, 4.1vw, 4.1rem);
  line-height:.94;
  letter-spacing:-.05em;
  text-shadow:0 8px 22px rgba(0,0,0,.34);
}
.hero-copy p{
  margin:14px 0 0;
  max-width:34ch;
  color:#efe7da;
  font-size:1rem;
  line-height:1.62;
  text-shadow:0 6px 18px rgba(0,0,0,.28);
}
.hero-copy .hero-badge{
  box-shadow:0 14px 28px rgba(0,0,0,.16);
}
.hero-mini-proof{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:16px;
}
.hero-mini-proof span{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:0 13px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(10px);
  color:#fff;
  font-size:.92rem;
  font-weight:700;
}
.hero-media-stack{
  position:relative;
  z-index:1;
  align-self:center;
  display:grid;
  gap:12px;
  width:min(100%, 430px);
  margin-left:auto;
}
.hero-media-row{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}
.hero-media-card{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 22px 56px rgba(0,0,0,.24);
  transform:translateY(0);
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}
.hero-media-card:hover{
  transform:translateY(-3px);
  border-color:rgba(200,165,106,.34);
  box-shadow:0 24px 60px rgba(0,0,0,.3);
}
.hero-media-card-large{aspect-ratio: 0.95 / 1}
.hero-media-row .hero-media-card{aspect-ratio: 1.18 / .78}
.hero-media-card img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
}
.hero-media-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(10,11,13,.04) 18%, rgba(10,11,13,.72) 100%);
}
.hero-media-card-copy{
  position:absolute;
  left:16px;
  right:16px;
  bottom:16px;
  z-index:1;
  display:grid;
  gap:4px;
}
.hero-media-card-copy small{
  color:#f0ddbb;
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.hero-media-card-copy strong{
  color:#fff;
  font-size:1rem;
  line-height:1.15;
}
.hero-home .hero-actions{margin-top:18px}

@media (max-width: 1180px){
  .hero-home-layout{
    grid-template-columns:minmax(0, 1fr) minmax(300px, 390px);
    width:min(980px, 100%);
    gap:28px;
  }
  .hero-copy{max-width:500px}
  .hero-copy h1,
  .hero-copy h2{font-size:clamp(2.45rem, 4vw, 3.85rem)}
  .hero-media-stack{width:min(100%, 390px)}
}
@media (max-width: 920px){
  .hero-home,
  .hero-slider,
  .hero-slide{min-height:auto}
  .hero-home .hero-content{padding-top:18px; padding-bottom:84px}
  .hero-home-layout{
    grid-template-columns:1fr;
    width:min(680px, 100%);
    gap:18px;
  }
  .hero-copy{max-width:620px}
  .hero-copy h1,
  .hero-copy h2{max-width:11ch}
  .hero-media-stack{width:min(100%, 620px); margin-left:0}
  .hero-media-card-large{aspect-ratio: 1.18 / .95}
}
@media (max-width: 640px){
  .hero-home .hero-content{padding-top:12px; padding-bottom:82px}
  .hero-home-layout{gap:16px}
  .hero-copy h1,
  .hero-copy h2{
    font-size:clamp(2rem, 9vw, 3rem);
    max-width:12ch;
  }
  .hero-copy p{font-size:.96rem; max-width:32ch; line-height:1.55}
  .hero-mini-proof{gap:7px}
  .hero-mini-proof span{font-size:.84rem; min-height:34px; padding:0 11px}
  .hero-media-row{grid-template-columns:1fr 1fr}
  .hero-media-card{border-radius:20px}
  .hero-media-card-copy strong{font-size:.92rem}
}
