
: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;
  font-weight:900;
  line-height:1;
}
.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);
}
.form-status.is-error{
  color:#c63b2d;
}
.form-status.is-success{
  color:#20803a;
}
.form-honeypot{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.recaptcha-wrap{
  margin:8px 0 18px;
}
.recaptcha-slot{
  min-height:78px;
}
.recaptcha-note{
  margin:10px 0 0;
  font-size:.9rem;
  color:var(--muted);
}

.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}
}


/* === Mobile/tablet fixes April 2026 === */
@media (max-width: 1024px){
  .topbar{
    display:none !important;
  }

  .site-header{
    position:sticky;
    top:0;
    z-index:9999;
    background:rgba(10,11,12,.94);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
  }

  .header-shell{
    min-height:72px;
    padding:10px 0;
    gap:12px;
  }

  .brand{
    min-width:0;
    gap:10px;
    flex:1 1 auto;
  }

  .brand img{
    width:50px;
  }

  .brand-text{
    min-width:0;
  }

  .brand-text strong{
    font-size:.94rem;
    line-height:1.12;
  }

  .brand-text span{
    display:none;
  }

  .menu-toggle{
    width:44px;
    height:44px;
    flex:0 0 44px;
    border-radius:14px;
  }

  .main-nav{
    top:calc(100% + 8px);
    left:.85rem;
    right:.85rem;
    padding:12px;
    border:1px solid rgba(255,255,255,.09);
    border-radius:22px;
    background:linear-gradient(180deg, rgba(15,16,18,.98), rgba(10,11,12,.98));
    box-shadow:0 22px 44px rgba(0,0,0,.36);
    z-index:10000;
  }

  .nav-link,
  .nav-cta{
    width:100%;
    min-height:46px;
    padding:0 14px;
    border-radius:14px;
  }

  .nav-link{
    display:flex;
    align-items:center;
  }

  .nav-link::after{
    display:none;
  }

  .nav-link.is-active,
  .nav-link:hover{
    background:rgba(255,255,255,.045);
  }

  .nav-cta{
    margin-left:0;
    margin-top:4px;
    min-width:0;
  }

  .hero-home,
  .hero-slider,
  .hero-slide,
  .hero-subpage{
    min-height:auto;
  }

  .hero-home .hero-content{
    padding-top:16px;
    padding-bottom:78px;
  }

  .hero-home-layout{
    grid-template-columns:1fr;
    width:min(680px,100%);
    gap:16px;
    align-items:start;
  }

  .hero-copy{
    max-width:620px;
    align-self:start;
  }

  .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;
  }

  .hero-media-row{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }

  .hero-media-row .hero-media-card,
  .hero-media-card-large{
    height:auto;
  }

  .subhero-grid,
  .split-layout,
  .faq-layout,
  .cta-grid,
  .map-grid,
  .contact-page-grid,
  .footer-grid{
    grid-template-columns:1fr;
    gap:18px;
  }

  .reverse-on-mobile > .content-card,
  .reverse-on-mobile > .cta-copy,
  .reverse-on-mobile > .hero-panel{
    order:1;
  }

  .reverse-on-mobile > .media-card,
  .reverse-on-mobile > .hero-visual,
  .reverse-on-mobile > .lead-form,
  .reverse-on-mobile > .map-card{
    order:2;
  }

  .hero-subpage .hero-content{
    padding-top:18px;
    padding-bottom:28px;
  }

  .hero-visual,
  .media-card{
    min-height:0;
    height:auto;
    border-radius:24px;
    overflow:hidden;
  }

  .hero-visual img,
  .media-card img{
    width:100%;
    height:auto;
    min-height:0;
    aspect-ratio:4 / 3;
    object-fit:cover;
    object-position:center center;
    display:block;
  }

  .floating-actions{
    right:10px;
    bottom:10px;
    gap:8px;
  }

  .floating-btn{
    min-width:82px;
    min-height:40px;
    padding:0 12px;
    font-size:.87rem;
    border-radius:16px;
    box-shadow:0 12px 26px rgba(0,0,0,.24);
  }
}

@media (max-width: 640px){
  .container{
    width:min(var(--container), calc(100% - 1.2rem));
  }

  .header-shell{
    min-height:68px;
    padding:8px 0;
  }

  .brand img{
    width:46px;
  }

  .brand-text strong{
    font-size:.88rem;
  }

  .main-nav{
    left:.6rem;
    right:.6rem;
    border-radius:18px;
  }

  .hero-home .hero-content{
    padding-top:12px;
    padding-bottom:76px;
  }

  .hero-home-layout{
    gap:14px;
  }

  .hero-copy h1,
  .hero-copy h2{
    font-size:clamp(1.95rem, 9vw, 2.8rem);
    line-height:.98;
  }

  .hero-copy p{
    font-size:.95rem;
    line-height:1.55;
    max-width:none;
  }

  .hero-actions{
    flex-direction:column;
    align-items:stretch;
    gap:10px;
  }

  .hero-actions .btn,
  .btn{
    width:100%;
  }

  .hero-mini-proof{
    grid-template-columns:1fr;
    gap:8px;
  }

  .hero-media-card,
  .hero-visual,
  .media-card{
    border-radius:20px;
  }

  .hero-media-row{
    grid-template-columns:1fr 1fr;
  }

  .hero-media-row .hero-media-card,
  .hero-media-card-large,
  .hero-visual img,
  .media-card img{
    aspect-ratio:4 / 3;
  }

  .hero-panel,
  .content-card,
  .contact-box,
  .lead-form{
    padding:20px 16px;
  }

  .floating-actions{
    right:8px;
    bottom:8px;
    gap:6px;
  }

  .floating-btn{
    min-width:72px;
    min-height:36px;
    padding:0 10px;
    font-size:.8rem;
    border-radius:14px;
  }
}

@media (max-width: 420px){
  .brand img{
    width:42px;
  }

  .menu-toggle{
    width:40px;
    height:40px;
    flex-basis:40px;
  }

  .hero-media-row{
    grid-template-columns:1fr;
  }

  .floating-btn{
    min-width:68px;
    min-height:34px;
    padding:0 9px;
    font-size:.76rem;
  }
}

/* === Brand refresh April 2026 === */
:root{
  --bg:#f7f6f0;
  --bg-soft:#eef5e6;
  --surface:#ffffff;
  --surface-2:#f4f7ee;
  --surface-3:#fff6eb;
  --text:#173621;
  --text-dark:#173621;
  --muted:#617064;
  --accent:#2f9b34;
  --accent-strong:#227a29;
  --accent-2:#ef8b1d;
  --accent-2-soft:#fff0de;
  --line:rgba(25,63,32,.12);
  --line-strong:rgba(25,63,32,.18);
  --shadow:0 22px 56px rgba(26,60,31,.12);
  --shadow-soft:0 12px 32px rgba(26,60,31,.08);
}

html{
  background:#eef1e8;
}

body{
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(47,155,52,.12), transparent 26%),
    radial-gradient(circle at 92% 0, rgba(239,139,29,.10), transparent 20%),
    linear-gradient(180deg, #faf9f4 0%, #f5f4ed 48%, #f7f6f0 100%);
}

::selection{
  background:rgba(47,155,52,.18);
  color:var(--text);
}

a{
  transition:color .2s ease, background-color .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

p{
  color:var(--muted);
}

.section{
  padding:92px 0;
}

.section-muted{
  background:rgba(255,255,255,.65);
}

.section-dark{
  background:
    radial-gradient(circle at 15% 0, rgba(47,155,52,.10), transparent 26%),
    linear-gradient(180deg, #eef5e7 0%, #f6f5ef 100%);
  border-block:1px solid var(--line);
}

.section-cta{
  background:
    radial-gradient(circle at top right, rgba(239,139,29,.14), transparent 18%),
    radial-gradient(circle at left center, rgba(47,155,52,.12), transparent 24%),
    linear-gradient(180deg, #fdfcf8 0%, #f3f5ec 100%);
}

.section-stats{
  padding-top:0;
}

.section-head{
  max-width:820px;
  padding-left:26px;
  margin-bottom:34px;
}

.section-head::before{
  width:4px;
  top:4px;
  bottom:6px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--accent-2), var(--accent));
}

.section-kicker{
  color:var(--accent-2);
  font-weight:800;
}

h1,h2,h3,h4{
  color:var(--text);
}

h1,h2{
  font-family:"Playfair Display", Georgia, serif;
}

.topbar{
  background:linear-gradient(90deg, #1d6723 0%, #2d9133 100%);
  border-bottom:none;
}

.topbar-inner{
  min-height:46px;
  font-size:.94rem;
}

.topbar-copy,
.contact-link{
  color:rgba(255,255,255,.92);
}

.contact-link:hover{
  color:#fff7e8;
}

.site-header{
  background:rgba(250,249,244,.92);
  border-bottom:1px solid var(--line);
  box-shadow:0 8px 26px rgba(26,60,31,.07);
  backdrop-filter:blur(18px);
}

.header-shell{
  min-height:96px;
  gap:18px;
}

.brand{
  min-width:0;
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}

.brand img{
  width:clamp(220px, 24vw, 360px);
  height:auto;
  filter:none;
}

.brand-text{
  display:none;
}

.main-nav{
  gap:8px;
}

.nav-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:0 16px;
  border-radius:999px;
  color:#21532a;
  font-size:.94rem;
  font-weight:800;
}

.nav-link::after{
  display:none;
}

.nav-link:hover,
.nav-link.is-active{
  color:var(--accent-strong);
  background:rgba(47,155,52,.10);
}

.nav-cta{
  margin-left:8px;
}

.menu-toggle{
  border-color:rgba(25,63,32,.10);
  background:#fff;
  color:var(--accent-strong);
  box-shadow:var(--shadow-soft);
}

.menu-toggle span{
  background:var(--accent-strong);
}

.btn{
  min-height:54px;
  padding:0 24px;
  border-radius:999px;
  font-weight:800;
  box-shadow:none;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn-primary{
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-strong) 100%);
  color:#fff;
  box-shadow:0 16px 34px rgba(47,155,52,.24);
}

.btn-primary:hover{
  box-shadow:0 20px 40px rgba(47,155,52,.28);
}

.btn-secondary{
  background:#fff;
  color:var(--accent-strong);
  border-color:rgba(47,155,52,.22);
  box-shadow:var(--shadow-soft);
}

.btn-secondary:hover{
  border-color:rgba(47,155,52,.34);
  background:#f8fbf5;
}

.hero{
  position:relative;
  overflow:hidden;
}

.hero-home{
  min-height:clamp(660px, 86vh, 820px);
}

.hero-slider,
.hero-slide{
  min-height:clamp(660px, 86vh, 820px);
  touch-action:pan-y;
}

.hero-slide{
  background:
    linear-gradient(90deg, rgba(248,247,241,.95) 0%, rgba(248,247,241,.86) 48%, rgba(248,247,241,.70) 100%),
    var(--hero-image) center / cover no-repeat;
}

.hero-subpage{
  min-height:560px;
  background:
    linear-gradient(90deg, rgba(248,247,241,.96) 0%, rgba(248,247,241,.88) 52%, rgba(248,247,241,.74) 100%),
    var(--page-hero) center / cover no-repeat;
}

.hero-overlay{
  background:
    radial-gradient(circle at 15% 15%, rgba(47,155,52,.16), transparent 24%),
    radial-gradient(circle at 82% 0, rgba(239,139,29,.14), transparent 18%);
}

.hero-content{
  padding:38px 0 92px;
}

.hero-home-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(320px, 430px);
  gap:clamp(24px, 4vw, 48px);
  align-items:center;
  width:min(1160px, 100%);
  margin:0 auto;
}

.hero-copy,
.hero-panel{
  position:relative;
  width:min(720px, 100%);
  padding:38px;
  border-radius:34px;
  border:1px solid rgba(25,63,32,.10);
  background:rgba(255,255,255,.76);
  backdrop-filter:blur(18px);
  box-shadow:var(--shadow);
}

.hero-copy h1,
.hero-copy h2{
  margin:14px 0 0;
  max-width:11ch;
  font-size:clamp(2.75rem, 5vw, 4.85rem);
  line-height:.94;
  letter-spacing:-.05em;
  text-shadow:none;
}

.hero-copy p{
  margin:16px 0 0;
  max-width:58ch;
  color:#53645b;
  font-size:1.04rem;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}

.hero-badge,
.hero-chip{
  line-height:1;
  border:1px solid rgba(239,139,29,.18);
  background:rgba(255,246,235,.92);
  color:#9a5511;
  box-shadow:none;
}

.hero-badge{
  font-weight:800;
}

.hero-chip{
  color:#6d5a32;
  border-color:rgba(25,63,32,.10);
  background:rgba(255,255,255,.72);
}

.hero-mini-proof{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}

.hero-mini-proof span{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(25,63,32,.08);
  color:#385543;
  font-size:.92rem;
  font-weight:700;
  box-shadow:var(--shadow-soft);
}

.hero-media-stack{
  display:grid;
  gap:14px;
  width:min(100%, 430px);
  margin-left:auto;
}

.hero-media-row{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.hero-media-card{
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(25,63,32,.08);
  background:#fff;
  box-shadow:var(--shadow);
}

.hero-media-card:hover{
  transform:translateY(-4px);
  border-color:rgba(47,155,52,.22);
  box-shadow:0 26px 50px rgba(26,60,31,.16);
}

.hero-media-card::after{
  background:linear-gradient(180deg, rgba(255,255,255,0) 30%, rgba(17,48,21,.78) 100%);
}

.hero-media-card-copy{
  left:18px;
  right:18px;
  bottom:18px;
}

.hero-media-card-copy small{
  color:#f4c78d;
}

.hero-media-card-copy strong{
  color:#fff;
}

.hero-controls{
  position:absolute;
  left:50%;
  right:auto;
  bottom:26px;
  z-index:3;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  width:fit-content;
  max-width:calc(100% - 1rem);
  padding:10px 14px;
  border-radius:999px;
  background:rgba(248,247,241,.78);
  backdrop-filter:blur(18px);
  box-shadow:var(--shadow-soft);
  transform:translateX(-50%);
}

.slider-arrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:54px;
  height:54px;
  padding:0;
  border:none;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  color:var(--accent-strong);
  font-size:1.35rem;
  line-height:1;
  box-shadow:var(--shadow-soft);
  cursor:pointer;
  flex:none;
}

.slider-arrow:hover{
  background:#fff;
}

.slider-dots{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}

.slider-dots button{
  width:12px;
  height:12px;
  padding:0;
  border:none;
  border-radius:999px;
  background:rgba(34,122,41,.22);
  cursor:pointer;
  transition:transform .2s ease, background-color .2s ease;
}

.slider-dots button.is-active{
  background:var(--accent-2);
  transform:scale(1.15);
}

.hero-subpage .hero-content{
  padding:72px 0;
}

.subhero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.08fr) minmax(320px, .92fr);
  gap:30px;
  align-items:center;
  width:100%;
}

.hero-topline{
  gap:12px;
  margin-bottom:18px;
}

.hero-subpage .hero-panel .section-kicker{
  display:none;
}

.hero-visual,
.media-card{
  overflow:hidden;
  border-radius:32px;
  border:1px solid rgba(25,63,32,.08);
  background:#fff;
  box-shadow:var(--shadow);
}

.hero-visual img,
.media-card img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
}

.stats-grid{
  gap:20px;
  margin-top:-48px;
  position:relative;
  z-index:2;
}

.stat-card,
.mini-card,
.offer-card,
.showcase-card,
.process-card,
.contact-box,
.contact-card,
.media-card,
.content-card{
  border:1px solid rgba(25,63,32,.08);
  background:rgba(255,255,255,.94);
  box-shadow:var(--shadow);
}

.stat-card{
  padding:28px 24px;
  border-top:4px solid rgba(47,155,52,.18);
}

.stat-card .card-kicker,
.mini-card .card-kicker{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:0 12px;
  margin-bottom:16px;
  border-radius:999px;
  border:1px solid rgba(239,139,29,.16);
  background:rgba(255,246,235,.92);
  color:#9a5511;
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.stat-card strong{
  position:relative;
  z-index:1;
  display:block;
  margin:0 0 12px;
  color:var(--text-dark);
  font-size:1.32rem;
  line-height:1.2;
}

.stat-card p{
  position:relative;
  z-index:1;
  margin:0;
  color:#53645b;
  line-height:1.7;
}

.card-grid{
  display:grid;
  gap:24px;
}

.card-grid-3{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.card-grid-4{
  grid-template-columns:repeat(4, minmax(0, 1fr));
}

.offer-card{
  display:flex;
  flex-direction:column;
  overflow:hidden;
  background:#fff;
}

.offer-card img{
  width:100%;
  aspect-ratio:16/11;
  object-fit:cover;
}

.offer-card-body{
  margin:-32px 18px 18px;
  padding:24px;
  border-radius:26px;
  border:1px solid rgba(25,63,32,.08);
  background:rgba(255,255,255,.96);
  box-shadow:0 16px 40px rgba(26,60,31,.10);
}

.offer-card-body::before{
  left:24px;
  right:24px;
  background:linear-gradient(90deg, var(--accent-2), rgba(47,155,52,.2));
}

.offer-card-body span{
  color:var(--accent-strong);
}

.offer-card:hover .offer-card-body{
  transform:translateY(-4px);
}

.mini-card-grid{
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:20px;
}

.mini-card{
  padding:26px 24px;
  text-align:left;
}

.mini-card strong{
  position:relative;
  z-index:1;
  display:block;
  margin:0 0 10px;
  color:var(--text-dark);
}

.mini-card p{
  position:relative;
  z-index:1;
  margin:0;
  color:#53645b;
  line-height:1.65;
}

.mini-card .card-kicker{
  box-shadow:none;
}

.split-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:30px;
  align-items:stretch;
}

.content-card,
.contact-box{
  padding:36px;
}

.content-card p:last-child,
.contact-box p:last-child{
  margin-bottom:0;
}

.bullet-grid{
  margin-top:28px;
  gap:14px;
}

.bullet-item{
  background:var(--surface-2);
  border:1px solid rgba(25,63,32,.08);
  color:var(--text);
}

.bullet-item::before{
  background:linear-gradient(135deg, var(--accent-2), var(--accent));
  box-shadow:0 0 0 6px rgba(239,139,29,.12);
}

.showcase-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}

.showcase-card{
  display:flex;
  flex-direction:column;
  overflow:hidden;
  background:#fff;
}

.showcase-card img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}

.showcase-card-body{
  padding:20px 22px 22px;
}

.showcase-card-body strong{
  color:var(--text);
}

.showcase-card-body span{
  color:var(--accent-strong);
}

.process-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:20px;
}

.process-card{
  padding:28px 24px;
  background:#fff;
}

.process-card::before{
  background:radial-gradient(circle at 100% 0, rgba(47,155,52,.10), transparent 32%);
}

.process-number{
  background:linear-gradient(135deg, var(--accent-2), #f6b158);
  color:#fff;
  box-shadow:0 14px 28px rgba(239,139,29,.22);
}

.faq-layout{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:24px;
}

.faq-item{
  border:1px solid rgba(25,63,32,.08);
  background:#fff;
}

.faq-item summary{
  color:var(--text);
}

.faq-item[open],
.faq-item:hover{
  border-color:rgba(47,155,52,.24);
}

.cta-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:start;
}

.contact-cards{
  gap:14px;
}

.contact-card{
  gap:8px;
  padding:22px;
  background:#fff;
}

.contact-card:hover{
  transform:translateY(-3px);
  border-color:rgba(47,155,52,.22);
}

.contact-card::after{
  background:radial-gradient(circle, rgba(47,155,52,.14), transparent 70%);
}

.contact-card-label{
  line-height:1;
  color:var(--accent-2);
}

.pill{
  background:rgba(255,255,255,.84);
  border:1px solid rgba(25,63,32,.08);
  color:#355141;
}

.lead-form{
  position:relative;
  overflow:hidden;
  padding:34px;
  border-radius:32px;
  border:1px solid rgba(25,63,32,.08);
  background:rgba(255,255,255,.95);
  box-shadow:var(--shadow);
}

.lead-form::before{
  background:radial-gradient(circle at 100% 0, rgba(47,155,52,.10), transparent 26%);
}

label span{
  color:var(--text);
}

input,
select,
textarea{
  border:1px solid rgba(25,63,32,.14);
  background:#fff;
  color:var(--text);
}

input::placeholder,
textarea::placeholder{
  color:#849188;
}

input:focus,
select:focus,
textarea:focus{
  border-color:rgba(47,155,52,.45);
  background:#fcfefb;
  box-shadow:0 0 0 4px rgba(47,155,52,.08);
}

.checkbox span{
  color:var(--muted);
}

.checkbox span a,
.cookie-banner-copy a,
.footer-legal-links a,
.footer-list a{
  color:#ffe0b7;
}

.checkbox span a{
  color:var(--accent-strong);
}

.form-status{
  color:var(--accent-strong);
}

.mini-card strong,
.contact-list li,
.modern-list li{
  color:var(--text);
}

.contact-list strong{
  color:var(--accent-strong);
}

.modern-list li{
  background:rgba(47,155,52,.06);
  border:1px solid rgba(25,63,32,.08);
}

.modern-list li::before{
  color:var(--accent-2);
}

.filter-bar{
  gap:12px;
}

.filter-chip{
  border:1px solid rgba(25,63,32,.12);
  background:#fff;
  color:#31503c;
  box-shadow:var(--shadow-soft);
}

.filter-chip:hover,
.filter-chip.is-active{
  background:rgba(47,155,52,.10);
  border-color:rgba(47,155,52,.24);
  color:var(--accent-strong);
}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:18px;
}

.gallery-link{
  display:flex;
  flex-direction:column;
  gap:0;
  padding:14px;
  border-radius:26px;
  border:1px solid rgba(25,63,32,.08);
  background:#fff;
  box-shadow:var(--shadow-soft);
}

.gallery-link img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:contain;
  object-position:center;
  background:linear-gradient(180deg, #fbfbf7 0%, #eff3e7 100%);
  border-radius:18px;
  padding:10px;
  transition:transform .32s ease;
}

.gallery-link:hover img{
  transform:scale(1.03);
}

.gallery-overlay{
  position:static;
  padding:16px 4px 2px;
  gap:5px;
  background:none;
}

.gallery-overlay strong{
  color:var(--text);
}

.gallery-overlay em{
  color:var(--accent-strong);
}

.contact-page-grid,
.map-grid{
  display:grid;
  gap:24px;
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.map-card{
  border-radius:32px;
  border:1px solid rgba(25,63,32,.08);
  box-shadow:var(--shadow);
}

.map-card iframe{
  min-height:460px;
}

.site-footer{
  border-top:none;
  background:
    radial-gradient(circle at top right, rgba(239,139,29,.18), transparent 22%),
    linear-gradient(135deg, #194f1f 0%, #216d29 58%, #2c7e2f 100%);
  color:rgba(255,255,255,.92);
  padding-top:52px;
}

.site-footer h3,
.site-footer h4{
  color:#fff;
}

.site-footer p,
.site-footer li{
  color:rgba(255,255,255,.78);
}

.footer-grid{
  grid-template-columns:1.2fr .9fr .9fr .85fr;
  gap:24px;
}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
}

.footer-bottom p{
  color:rgba(255,255,255,.76);
}

.footer-bottom-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

.footer-legal-links{
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}

.cookie-inline-link{
  appearance:none;
  border:none;
  background:none;
  color:#ffe0b7;
  font:inherit;
  font-weight:700;
  padding:0;
  cursor:pointer;
}

.cookie-inline-link:hover{
  color:#fff3dd;
}

.floating-actions{
  right:18px;
  bottom:18px;
  z-index:28;
  gap:10px;
}

.floating-btn{
  min-width:128px;
  min-height:48px;
  line-height:1;
  background:linear-gradient(135deg, var(--accent), var(--accent-strong));
  color:#fff;
  box-shadow:0 18px 36px rgba(26,60,31,.18);
}

.floating-btn.secondary{
  background:linear-gradient(135deg, var(--accent-2), #f3a340);
  border:none;
  color:#fff;
}

body.has-cookie-banner .floating-actions{
  bottom:132px;
}

.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));
  z-index:30;
  grid-template-columns:minmax(0,1fr) auto;
  gap:18px;
  padding:20px 22px;
  border-radius:28px;
  border:1px solid rgba(25,63,32,.10);
  background:rgba(255,255,255,.97);
  box-shadow:0 28px 60px rgba(26,60,31,.18);
}

.cookie-banner-copy strong{
  color:var(--text);
}

.cookie-banner-copy p{
  color:var(--muted);
  max-width:72ch;
}

.cookie-link{
  border-color:rgba(25,63,32,.12);
}

.lightbox{
  background:rgba(12,19,13,.92);
}

.lightbox-figure img{
  background:#fff;
  border:1px solid rgba(255,255,255,.14);
}

.lightbox-close,
.lightbox-nav{
  background:rgba(255,255,255,.12);
}

.reveal{
  transition:opacity .6s ease, transform .6s ease;
}

@media (max-width: 1180px){
  .header-shell{
    gap:14px;
  }

  .brand{
    padding:0;
  }

  .brand img{
    width:clamp(190px, 25vw, 300px);
  }

  .nav-link{
    padding:0 13px;
    font-size:.9rem;
  }

  .card-grid-4,
  .mini-card-grid,
  .gallery-grid,
  .process-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1024px){
  .topbar{
    display:none !important;
  }

  .site-header{
    background:rgba(250,249,244,.96);
  }

  .header-shell{
    min-height:84px;
    padding:10px 0;
  }

  .menu-toggle{
    display:inline-flex;
  }

  .main-nav{
    position:absolute;
    top:calc(100% + 8px);
    left:1rem;
    right:1rem;
    display:none;
    flex-direction:column;
    align-items:stretch;
    padding:14px;
    border-radius:24px;
    border:1px solid rgba(25,63,32,.10);
    background:rgba(255,255,255,.98);
    box-shadow:var(--shadow);
  }

  .main-nav.is-open{
    display:flex;
  }

  .nav-link,
  .nav-cta{
    width:100%;
  }

  .nav-cta{
    margin-left:0;
    margin-top:4px;
  }

  .hero-home,
  .hero-slider,
  .hero-slide,
  .hero-subpage{
    min-height:auto;
  }

  .hero-content,
  .hero-subpage .hero-content{
    padding:32px 0 84px;
  }

  .hero-home-layout,
  .subhero-grid,
  .split-layout,
  .faq-layout,
  .cta-grid,
  .contact-page-grid,
  .map-grid,
  .footer-grid{
    grid-template-columns:1fr;
  }

  .hero-home-layout{
    gap:18px;
  }

  .hero-copy,
  .hero-panel{
    width:100%;
  }

  .hero-media-stack{
    width:min(100%, 620px);
    margin-left:0;
  }

  .showcase-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .card-grid-3{
    grid-template-columns:1fr;
  }
}

@media (max-width: 768px){
  .section{
    padding:76px 0;
  }

  .section-head{
    padding-left:22px;
  }

  .hero-copy,
  .hero-panel,
  .content-card,
  .contact-box,
  .lead-form{
    padding:26px 22px;
  }

  .hero-copy h1,
  .hero-copy h2{
    font-size:clamp(2.3rem, 8vw, 3.3rem);
  }

  .hero-controls{
    bottom:18px;
    gap:10px;
    padding:8px 10px;
  }

  .slider-arrow{
    width:46px;
    height:46px;
    font-size:1.15rem;
  }

  .slider-dots{
    gap:8px;
  }

  .stats-grid{
    margin-top:0;
  }

  .showcase-grid,
  .card-grid-4{
    grid-template-columns:1fr;
  }

  .cookie-banner{
    grid-template-columns:1fr;
  }

  .footer-bottom-inner{
    align-items:flex-start;
  }
}

@media (max-width: 640px){
  .container{
    width:min(var(--container), calc(100% - 1.2rem));
  }

  .header-shell{
    min-height:76px;
    gap:10px;
  }

  .brand{
    padding:0;
    border-radius:0;
  }

  .brand img{
    width:190px;
  }

  .hero-content,
  .hero-subpage .hero-content{
    padding:18px 0 92px;
  }

  .hero-controls{
    left:12px;
    right:12px;
    bottom:14px;
    width:auto;
    max-width:none;
    justify-content:space-between;
    gap:12px;
    padding:0;
    background:transparent;
    backdrop-filter:none;
    box-shadow:none;
    transform:none;
  }

  .slider-arrow{
    width:44px;
    height:44px;
    font-size:1.05rem;
    background:rgba(255,255,255,.92);
  }

  .slider-dots{
    gap:8px;
    padding:9px 12px;
    border-radius:999px;
    background:rgba(248,247,241,.84);
    backdrop-filter:blur(18px);
    box-shadow:var(--shadow-soft);
  }

  .hero-copy,
  .hero-panel,
  .content-card,
  .contact-box,
  .lead-form{
    padding:22px 18px;
    border-radius:26px;
  }

  .hero-actions,
  .form-actions,
  .cookie-banner-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .btn{
    width:100%;
  }

  .mini-card-grid,
  .process-grid,
  .gallery-grid,
  .bullet-grid,
  .form-row.two{
    grid-template-columns:1fr;
  }

  .hero-mini-proof{
    display:grid;
    grid-template-columns:1fr;
  }

  .hero-media-row{
    grid-template-columns:1fr;
  }

  .gallery-link{
    padding:12px;
  }

  .gallery-link img{
    aspect-ratio:1/1;
  }

  .floating-actions{
    left:12px;
    right:12px;
    bottom:12px;
    display:grid;
    grid-template-columns:1fr 1fr;
  }

  .floating-btn{
    min-width:0;
    width:100%;
  }

  body.has-cookie-banner .floating-actions{
    bottom:168px;
  }

  .cookie-banner{
    left:12px;
    right:12px;
    bottom:12px;
    padding:18px;
  }
}

@media (max-width: 420px){
  .hero-controls{
    left:10px;
    right:10px;
    bottom:12px;
    gap:10px;
  }

  .slider-arrow{
    width:40px;
    height:40px;
    font-size:1rem;
  }

  .slider-dots{
    gap:7px;
    padding:8px 10px;
  }

  .brand img{
    width:168px;
  }

  .menu-toggle{
    width:42px;
    height:42px;
  }

  .floating-actions{
    grid-template-columns:1fr;
  }

  body.has-cookie-banner .floating-actions{
    bottom:216px;
  }
}

@media (prefers-reduced-motion: reduce){
  html{
    scroll-behavior:auto;
  }

  *,
  *::before,
  *::after{
    animation:none !important;
    transition:none !important;
  }
}
