:root{
  --wa:#25d366;
  --wa-hover:#20bd5a;
  --bg0:#f7f0e6;
  --bg1:#fbf6ef;
  --surface:rgba(255,255,255,.72);
  --surface-2:rgba(255,255,255,.9);
  --text:#1f1b16;
  --muted:#6b5e52;
  --border:rgba(40,28,20,.14);
  --shadow:0 18px 50px rgba(26,18,12,.12);
  --shadow-soft:0 10px 24px rgba(26,18,12,.10);
  --brand:#a66a3a; /* warm wood */
  --brand-2:#d7a76a; /* honey */
  --brand-3:#2a5b4e; /* sage */
  --brand-purple:#6b4d9e; /* ikon / wordmark vurgusu */
  --radius:18px;
  --radius-lg:26px;
  --focus:rgba(166,106,58,.35);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 400px at 18% 4%, rgba(215,167,106,.22), transparent 60%),
    radial-gradient(700px 420px at 85% 10%, rgba(42,91,78,.14), transparent 60%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  min-height:100vh;
}

.skip-link{
  position:absolute;
  top:-48px;
  left:14px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  z-index:9999;
  transition:top .2s ease;
}
.skip-link:focus{top:12px; outline:3px solid var(--focus)}

.container{
  width:min(1060px, calc(100% - 56px));
  margin:0 auto;
}

button,
input,
textarea,
select{
  font-family:inherit;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:saturate(1.2) blur(10px);
  background:rgba(247,240,230,.62);
  border-bottom:1px solid rgba(40,28,20,.10);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 0;
}

.brand-link{
  display:inline-flex;
  align-items:center;
  gap:11px;
  text-decoration:none;
  color:inherit;
  min-width:0;
  border-radius:14px;
}
.brand-link:focus-visible,
.footer-brand-mark:focus-visible{
  outline:3px solid var(--focus);
  outline-offset:3px;
}
.brand-icon{
  width:64px;
  height:64px;
  flex-shrink:0;
  object-fit:contain;
  display:block;
  image-rendering:auto;
}
.brand-wordmark{
  font-family:"Noto Serif", serif;
  font-weight:600;
  font-size:clamp(1.38rem, 3.6vw, 1.78rem);
  letter-spacing:-0.02em;
  line-height:1.05;
  color:var(--text);
  white-space:nowrap;
}
.brand-wordmark--footer{
  font-size:clamp(1.34rem, 2.85vw, 1.62rem);
}
.brand-wordmark-accent{
  color:var(--brand-purple);
  font-weight:600;
}

.footer-brand-mark{
  display:inline-flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:inherit;
  border-radius:14px;
}
.footer-icon{
  width:48px;
  height:48px;
  flex-shrink:0;
  object-fit:contain;
  display:block;
}

.nav{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  position:relative;
  min-width:0;
}
.header-end{
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}
.nav-toggle{
  display:none;
  width:44px; height:44px;
  border-radius:12px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.75);
  cursor:pointer;
}
.nav-toggle:focus{outline:3px solid var(--focus)}
.nav-toggle-lines{
  width:18px; height:12px;
  display:block;
  margin:0 auto;
  background:
    linear-gradient(var(--text), var(--text)) 0 0/100% 2px no-repeat,
    linear-gradient(var(--text), var(--text)) 0 50%/100% 2px no-repeat,
    linear-gradient(var(--text), var(--text)) 0 100%/100% 2px no-repeat;
  opacity:.85;
}

.nav-list{
  list-style:none;
  display:flex;
  align-items:center;
  gap:26px;
  margin:0;
  padding:0;
}
.nav-link{
  color:var(--muted);
  text-decoration:none;
  font-weight:600;
  letter-spacing:.45px;
  padding:10px 0;
  position:relative;
  font-size:1.08rem;
}
.nav-link::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:6px;
  height:2px;
  background:linear-gradient(90deg, var(--brand), var(--brand-2));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .2s ease;
}
.nav-link:hover{color:var(--text)}
.nav-link:hover::after{transform:scaleX(1)}

.header-actions{
  display:flex;
  align-items:center;
  gap:14px;
}

.lang-switch{
  display:flex;
  padding:4px;
  border:1px solid var(--border);
  border-radius:14px;
  background:rgba(255,255,255,.65);
}
.lang-btn{
  border:0;
  cursor:pointer;
  background:transparent;
  color:var(--muted);
  font-weight:700;
  padding:8px 12px;
  border-radius:10px;
}
.lang-btn.is-active{
  background:rgba(166,106,58,.15);
  color:var(--text);
}
.lang-btn:focus{outline:3px solid var(--focus)}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  height:44px;
  padding:0 18px;
  border-radius:14px;
  border:1px solid transparent;
  font-weight:600;
  letter-spacing:.35px;
  text-decoration:none;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  user-select:none;
  white-space:nowrap;
}
.btn:focus{outline:3px solid var(--focus)}
.btn:active{transform:translateY(1px)}

.btn-primary{
  background:var(--brand);
  color:#fff;
  box-shadow:0 2px 6px rgba(26,18,12,.12);
}
.btn-primary:hover{
  background:#955a2e;
  box-shadow:0 4px 12px rgba(166,106,58,.22);
}
.btn-primary:focus{
  outline:3px solid rgba(166,106,58,.35);
}

/* WhatsApp — ürün sayfası ve kartlar */
.btn-wa{
  background:var(--wa);
  color:#fff;
  border:1px solid transparent;
  box-shadow:0 2px 8px rgba(37,211,102,.35);
}
.btn-wa:hover{
  background:var(--wa-hover);
  color:#fff;
  box-shadow:0 4px 14px rgba(37,211,102,.4);
}
.btn-wa:focus{
  outline:3px solid rgba(37,211,102,.4);
}

/* İkincil: düz çerçeveli buton (tekil “normal” görünüm) */
.btn-outline{
  background:#fff;
  color:var(--text);
  border:1px solid var(--border);
  box-shadow:0 1px 2px rgba(26,18,12,.06);
}
.btn-outline:hover{
  background:rgba(255,255,255,.95);
  border-color:rgba(40,28,20,.22);
}
.btn-outline:focus{
  outline:3px solid var(--focus);
}

.btn-ghost{
  background:rgba(255,255,255,.65);
  border-color:var(--border);
  color:var(--text);
}
.btn-ghost:hover{background:rgba(255,255,255,.85)}

.header-cta{display:none}

.hero-slider{
  position:relative;
  min-height:calc(100vh - 74px);
  overflow:hidden;
  border-bottom:1px solid rgba(40,28,20,.12);
}
.hero-slider-track{
  position:relative;
  min-height:inherit;
}
.hero-slide{
  position:absolute;
  inset:0;
  opacity:0;
  visibility:hidden;
  transition:opacity 1200ms ease-in-out, visibility 1200ms ease-in-out;
}
.hero-slide.is-active{
  opacity:1;
  visibility:visible;
}
.hero-slide-bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1);
  opacity:.9;
  transition:transform 1200ms ease-in-out, opacity 1200ms ease-in-out;
  will-change:transform, opacity;
}
.hero-slide.is-active .hero-slide-bg{
  transform:scale(1.08);
  opacity:1;
}
.hero-slide-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(12,12,12,.68) 12%, rgba(12,12,12,.42) 45%, rgba(12,12,12,.36) 100%);
}
.hero-slide-content{
  position:relative;
  z-index:2;
  min-height:inherit;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap:14px;
  color:#fff;
  padding:clamp(34px, 7vw, 72px) 0;
}
.hero-slide-badge{
  display:inline-flex;
  align-items:center;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.3);
  border-radius:999px;
  padding:8px 13px;
  font-weight:800;
  font-size:13px;
  letter-spacing:.2px;
}
.hero-slide-title{
  font-family:"Noto Serif", serif;
  font-weight:600;
  font-size:clamp(38px, 5.4vw, 72px);
  line-height:1.05;
  max-width:min(800px, 92%);
  margin:0;
}
.hero-slide-subtitle{
  margin:0;
  max-width:min(640px, 92%);
  line-height:1.7;
  font-size:clamp(14px, 1.8vw, 18px);
  color:rgba(255,255,255,.9);
}
.hero-slide-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:6px;
}
.hero-slide-actions .btn-ghost{
  color:#fff;
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.35);
}
.hero-slide-actions .btn-ghost:hover{
  background:rgba(255,255,255,.2);
}
.hero-slider-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:4;
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(0,0,0,.36);
  color:#fff;
  font-size:22px;
  cursor:pointer;
  display:grid;
  place-items:center;
}
.hero-slider-nav:hover{
  background:rgba(0,0,0,.54);
}
.hero-slider-prev{left:18px}
.hero-slider-next{right:18px}
.hero-slider-dots{
  position:absolute;
  z-index:4;
  left:50%;
  bottom:22px;
  transform:translateX(-50%);
  display:flex;
  gap:10px;
}
.hero-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.7);
  background:rgba(255,255,255,.32);
  cursor:pointer;
  padding:0;
}
.hero-dot.is-active{
  background:#fff;
}

.hero{
  padding:26px 0 0;
}
.section-divider{
  height:1px;
  margin-top:30px;
  background:linear-gradient(90deg, transparent, rgba(40,28,20,.18), transparent);
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:26px;
  align-items:center;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:rgba(166,106,58,.12);
  border:1px solid rgba(166,106,58,.18);
  color:var(--text);
  font-weight:800;
  padding:10px 14px;
  border-radius:999px;
  letter-spacing:.2px;
  margin-bottom:14px;
}

.hero-title{
  font-family:"Noto Serif", serif;
  font-weight:600;
  font-size: clamp(34px, 4.4vw, 54px);
  line-height:1.05;
  margin:0 0 12px;
  letter-spacing:-.2px;
}
.hero-subtitle{
  color:var(--muted);
  font-weight:500;
  line-height:1.7;
  margin:0 0 18px;
  font-size:16.5px;
}

.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:22px;
}

.hero-highlights{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
}
.highlight{
  display:flex;
  gap:12px;
  padding:14px 14px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(40,28,20,.11);
  border-radius:16px;
  box-shadow:0 10px 22px rgba(26,18,12,.06);
}
.highlight-icon{
  flex:0 0 auto;
  align-self:flex-start;
  width:38px;
  height:38px;
  min-width:38px;
  min-height:38px;
  aspect-ratio:1;
  border-radius:14px;
  background:
    radial-gradient(10px 10px at 30% 30%, rgba(215,167,106,.8), rgba(215,167,106,0) 70%),
    linear-gradient(135deg, rgba(166,106,58,.18), rgba(42,91,78,.12));
  border:1px solid rgba(166,106,58,.18);
}
.highlight-title{font-weight:800; margin-bottom:2px}
.highlight-text{color:var(--muted); font-weight:500; line-height:1.4; font-size:13.5px}

.hero-visual{
  position:relative;
}
.visual-card{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(40,28,20,.12);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  padding:18px;
  position:relative;
  overflow:hidden;
}
.visual-card::before{
  content:"";
  position:absolute;
  inset:-60px -80px auto -80px;
  height:180px;
  background:radial-gradient(circle at 30% 40%, rgba(215,167,106,.35), transparent 60%);
  transform:rotate(-8deg);
}
.visual-text{
  width:min(72%, 320px);
  max-width:100%;
  height:auto;
  display:block;
  object-fit:contain;
  margin:0 auto 10px;
  position:relative;
}
.visual-frame{
  height:220px;
  border-radius:20px;
  border:1px solid rgba(40,28,20,.12);
  background:
    linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.55));
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.hero-photo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  min-width:100%;
  min-height:100%;
  object-fit:cover;
  object-position:center;
  opacity:.45;
  filter:saturate(1.08) contrast(1.05);
  transform:scale(1.05);
  z-index:0;
}
.visual-glow{
  position:absolute;
  inset:-120px -120px auto -120px;
  height:260px;
  background:
    radial-gradient(circle at 50% 40%, rgba(166,106,58,.22), transparent 60%),
    radial-gradient(circle at 60% 55%, rgba(42,91,78,.14), transparent 55%);
  z-index:1;
}
.visual-logo{position:relative; z-index:2}
.visual-text{position:relative; z-index:3}

.visual-stats{
  display:flex;
  gap:12px;
  margin-top:12px;
}
.stat{
  flex:1;
  background:rgba(255,255,255,.65);
  border:1px solid rgba(40,28,20,.12);
  border-radius:18px;
  padding:14px;
  box-shadow:0 12px 22px rgba(26,18,12,.06);
}
.stat-value{
  font-weight:900;
  font-size:22px;
  letter-spacing:-.2px;
}
.stat-label{color:var(--muted); font-weight:600; margin-top:4px; font-size:13px}

.section{
  padding:82px 0;
}
.section-alt{
  background:linear-gradient(180deg, rgba(255,255,255,.28), rgba(255,255,255,.0));
  border-top:1px solid rgba(40,28,20,.06);
  border-bottom:1px solid rgba(40,28,20,.06);
}
.section-head{margin-bottom:22px}
.section-title{
  font-family:"Noto Serif", serif;
  font-weight:600;
  margin:0 0 10px;
  font-size: clamp(26px, 3vw, 38px);
}
.section-subtitle{
  margin:0;
  color:var(--muted);
  font-weight:500;
  line-height:1.9;
  font-size:1.22rem;
}

.cards-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:16px;
}
.cards-grid--categories{
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap:18px;
}
.card{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(40,28,20,.12);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow-soft);
  transition:transform .2s ease, box-shadow .2s ease;
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute;
  inset:-40px -60px auto -60px;
  height:140px;
  background:radial-gradient(circle at 30% 40%, rgba(215,167,106,.28), transparent 60%);
  transform:rotate(-7deg);
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(26,18,12,.14);
}
.card-media{
  height:170px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:10px;
  position:relative;
  border-radius:14px;
  overflow:hidden;
  background:#f3f3f3;
  border:1px solid rgba(17,17,17,.1);
}
.card-icon{
  width:100%;
  height:100%;
  border-radius:0;
  object-fit:cover;
  background:transparent;
  padding:0;
  display:block;
  border:0;
  transition:transform .25s ease;
}
.card:hover .card-icon{transform:scale(1.04)}
.card-title{
  margin:0 0 8px;
  font-size:1.55rem;
}
.card-text{
  margin:0 0 14px;
  color:var(--muted);
  line-height:1.8;
  font-weight:500;
  position:relative;
  font-size:1.08rem;
}
.card-link{
  color:var(--brand);
  font-weight:800;
  text-decoration:none;
  position:relative;
}
.card-link::after{
  content:"";
  display:block;
  height:2px;
  background:linear-gradient(90deg, var(--brand), var(--brand-2));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .2s ease;
  margin-top:6px;
}
.card:hover .card-link::after{transform:scaleX(1)}

.logo-strip{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:18px;
  padding-top:16px;
  border-top:1px solid rgba(40,28,20,.08);
}
.logo-chip{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(40,28,20,.10);
  background:rgba(255,255,255,.62);
  font-weight:800;
  color:var(--muted);
}

.about-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:20px;
  align-items:start;
}
.checklist{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.check-item{
  display:flex;
  gap:12px;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(40,28,20,.10);
  background:rgba(255,255,255,.64);
  box-shadow:0 10px 22px rgba(26,18,12,.05);
}
.check-mark{
  width:22px; height:22px;
  border-radius:9px;
  border:1px solid rgba(166,106,58,.25);
  background:linear-gradient(180deg, rgba(166,106,58,.20), rgba(215,167,106,.18));
  position:relative;
  margin-top:2px;
  flex:0 0 auto;
}
.check-mark::after{
  content:"";
  position:absolute;
  inset:0;
  margin:auto;
  width:10px; height:6px;
  border-left:3px solid rgba(42,91,78,.9);
  border-bottom:3px solid rgba(42,91,78,.9);
  transform:rotate(-45deg);
  top:6px;
}
.check-title{font-weight:900; margin-bottom:4px}
.check-text{color:var(--muted); font-weight:500; line-height:1.55}

.about-actions{
  margin-top:18px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.about-panel{
  border-radius:var(--radius-lg);
  border:1px solid rgba(40,28,20,.12);
  background:
    radial-gradient(900px 420px at 30% 0%, rgba(215,167,106,.26), transparent 55%),
    radial-gradient(700px 340px at 90% 30%, rgba(42,91,78,.16), transparent 55%),
    rgba(255,255,255,.62);
  box-shadow:var(--shadow-soft);
  padding:18px;
  overflow:hidden;
  position:relative;
}
.panel-photo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  min-width:100%;
  min-height:100%;
  object-fit:cover;
  object-position:center;
  opacity:.18;
  filter:saturate(1.08) contrast(1.05);
  transform:scale(1.04);
  z-index:0;
}
.about-panel .panel-head,
.about-panel .steps,
.about-panel .panel-media{
  position:relative;
  z-index:1;
}
.panel-head{margin-bottom:14px}
.panel-kicker{
  color:var(--muted);
  font-weight:800;
  letter-spacing:.18px;
  text-transform:uppercase;
  font-size:12px;
}
.panel-title{
  font-family:"Noto Serif", serif;
  font-size:28px;
  font-weight:600;
  margin-top:6px;
}
.steps{list-style:none; padding:0; margin:10px 0 0; display:flex; flex-direction:column; gap:12px}
.step{
  display:flex;
  gap:12px;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(40,28,20,.10);
  background:rgba(255,255,255,.62);
}
.step-num{
  width:44px; height:44px;
  border-radius:16px;
  background:rgba(166,106,58,.14);
  border:1px solid rgba(166,106,58,.20);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
}
.step-title{font-weight:900; margin-bottom:4px}
.step-text{color:var(--muted); font-weight:500; line-height:1.55}

.panel-media{
  margin-top:18px;
  height:150px;
  border-radius:22px;
  border:1px solid rgba(40,28,20,.10);
  background:rgba(20,14,10,.86);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.media-orb{
  position:absolute;
  inset:-120px -120px auto -120px;
  height:240px;
  background:radial-gradient(circle at 50% 50%, rgba(215,167,106,.45), transparent 60%);
}
.media-logo{position:relative}

.testimonials-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:16px;
}
.quote{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(40,28,20,.12);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow-soft);
}
.quote-stars{color:rgba(166,106,58,.9); letter-spacing:1px; margin-bottom:10px}
.quote-text{
  margin:0 0 12px;
  color:var(--muted);
  line-height:1.75;
  font-weight:500;
}
.quote-author{font-weight:900; color:var(--text)}

.contact-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:start;
}
.contact-copy{padding-right:6px}
.contact-bullets{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.bullet{
  display:flex; gap:12px;
  align-items:center;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(40,28,20,.10);
  background:rgba(255,255,255,.64);
  box-shadow:0 10px 22px rgba(26,18,12,.05);
  font-weight:700;
  color:var(--text);
}
.bullet-dot{
  width:10px; height:10px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  box-shadow:0 10px 18px rgba(166,106,58,.25);
}

.contact-visual{
  margin-top:18px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(40,28,20,.10);
  border-radius:var(--radius-lg);
  padding:18px;
  box-shadow:0 14px 30px rgba(26,18,12,.06);
}
.contact-visual-card{
  height:120px;
  border-radius:22px;
  background:
    radial-gradient(650px 220px at 15% 0%, rgba(215,167,106,.35), transparent 55%),
    radial-gradient(520px 220px at 95% 25%, rgba(42,91,78,.20), transparent 55%),
    rgba(255,255,255,.5);
  border:1px solid rgba(40,28,20,.10);
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:16px;
}
.contact-visual-card{
  position:relative;
  overflow:hidden;
}
.contact-photo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  min-width:100%;
  min-height:100%;
  object-fit:cover;
  object-position:center;
  opacity:.22;
  filter:saturate(1.08) contrast(1.05);
  transform:scale(1.05);
  z-index:0;
}
.contact-visual-chip,
.contact-visual-title{
  position:relative;
  z-index:1;
}
.contact-visual-chip{
  font-weight:900;
  color:var(--muted);
  font-size:12px;
  letter-spacing:.18px;
  text-transform:uppercase;
}
.contact-visual-title{
  font-family:"Noto Serif", serif;
  font-size:30px;
  font-weight:600;
  margin-top:6px;
}

.contact-form{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(40,28,20,.12);
  border-radius:var(--radius-lg);
  padding:18px;
  box-shadow:var(--shadow);
}

.form-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
.field{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.field-label{
  font-weight:900;
  color:var(--muted);
  font-size:13px;
  letter-spacing:.15px;
}
.field-input{
  width:100%;
  border-radius:14px;
  border:1px solid rgba(40,28,20,.16);
  background:rgba(255,255,255,.88);
  padding:12px 12px;
  font-family:inherit;
  font-size:14px;
  outline:none;
}
.field-input:focus{
  border-color:rgba(166,106,58,.35);
  box-shadow:0 0 0 4px rgba(166,106,58,.16);
}
.field-textarea{resize:vertical; min-height:120px}

.form-actions{
  display:flex;
  gap:12px;
  margin-top:14px;
  flex-wrap:wrap;
}
.form-hint{
  margin:14px 0 0;
  color:var(--muted);
  font-weight:600;
  font-size:13px;
  line-height:1.6;
}

.site-footer{
  border-top:1px solid rgba(40,28,20,.10);
  padding:34px 0;
  background:rgba(247,240,230,.35);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr .8fr;
  gap:18px;
  align-items:start;
}
.footer-text{
  color:var(--muted);
  margin:10px 0 0;
  line-height:1.7;
  font-weight:500;
}

.footer-links{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.footer-link{
  text-decoration:none;
  color:var(--muted);
  font-weight:800;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid transparent;
  width:fit-content;
}
.footer-link:hover{
  border-color:rgba(40,28,20,.12);
  background:rgba(255,255,255,.55);
  color:var(--text);
}

.footer-meta{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-end;
}
.footer-chip{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(40,28,20,.10);
  background:rgba(255,255,255,.55);
  font-weight:900;
  color:var(--muted);
  width:fit-content;
}
.footer-small{
  color:var(--muted);
  font-weight:700;
  text-align:right;
}

@media (max-width: 980px){
  .hero-slider{
    min-height:calc(82vh - 70px);
  }
  .hero-slide-overlay{
    background:linear-gradient(180deg, rgba(12,12,12,.66) 0%, rgba(12,12,12,.46) 45%, rgba(12,12,12,.38) 100%);
  }
  .hero-slide-title{
    max-width:100%;
  }
  .hero-grid{grid-template-columns: 1fr; gap:18px}
  .hero-highlights{grid-template-columns: 1fr; }
  .cards-grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .cards-grid--categories{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .testimonials-grid{grid-template-columns: 1fr}
  .about-grid{grid-template-columns: 1fr}
  .contact-grid{grid-template-columns: 1fr}
  .footer-grid{grid-template-columns: 1fr; }
  .footer-meta{align-items:flex-start}
  .header-cta{display:inline-flex}
}

@media (max-width: 820px){
  .header-cta{display:none}
}

@media (max-width: 720px){
  .hero-slider{
    min-height:70vh;
  }
  .hero-slide-content{
    padding:36px 0 72px;
  }
  .hero-slider-nav{
    width:40px;
    height:40px;
    font-size:18px;
  }
  .hero-slider-prev{left:10px}
  .hero-slider-next{right:10px}
  .header-inner{
    gap:8px;
    padding:12px 0;
  }
  .brand{
    min-width:0;
    flex:1 1 auto;
  }
  .brand-link{
    gap:8px;
  }
  .brand-icon{
    width:52px;
    height:52px;
  }
  .brand-wordmark{
    font-size:1.2rem;
    letter-spacing:-0.03em;
  }
  .nav{
    flex:0 0 0;
    width:0;
    height:0;
    margin:0;
    padding:0;
    overflow:visible;
  }
  .nav-toggle{display:inline-flex; align-items:center; justify-content:center}
  .nav-list{
    position:fixed;
    right:max(14px, env(safe-area-inset-right));
    top:calc(env(safe-area-inset-top, 0px) + 58px);
    z-index:60;
    max-width:min(260px, calc(100vw - 28px));
    flex-direction:column;
    align-items:flex-end;
    gap:10px;
    padding:12px;
    border-radius:18px;
    border:1px solid rgba(40,28,20,.14);
    background:rgba(255,255,255,.86);
    box-shadow:var(--shadow-soft);
    display:none;
  }
  .nav-list[data-visible="true"]{display:flex}
  .header-actions{
    flex:0 0 auto;
    gap:8px;
    min-width:0;
  }
  .lang-btn{
    padding:6px 10px;
  }
  .hero-highlights{gap:10px}
  .form-row{grid-template-columns: 1fr}
  .cards-grid{grid-template-columns: 1fr}
  .cards-grid--categories{grid-template-columns: 1fr}
  .visual-stats{flex-direction:column}
}

.hidden{display:none !important;}

.page-hero-spaced{
  padding-top:clamp(8px, 2vw, 18px);
}

.home-cta-row{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:28px;
}

.route-top--products{
  margin-bottom:8px;
}
.products-filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:8px 0 18px;
}
.products-filter-link{
  text-decoration:none;
  color:var(--text);
  border:1px solid var(--border);
  background:rgba(255,255,255,.8);
  border-radius:999px;
  padding:8px 14px;
  font-weight:700;
  font-size:13px;
}
.products-filter-link.is-active{
  background:#111;
  color:#fff;
  border-color:#111;
}

.location-teaser{
  background:#000;
  border-top:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.location-teaser-inner{
  min-height:56vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap:14px;
  color:#fff;
  padding:clamp(36px, 7vw, 92px) 0;
}
.location-teaser-title{
  color:#fff;
  letter-spacing:.04em;
  font-size:clamp(34px, 6vw, 74px);
}
.location-teaser-subtitle{
  color:rgba(255,255,255,.82);
  max-width:760px;
}
.location-teaser-address{
  margin:4px 0 0;
  color:rgba(255,255,255,.76);
  font-size:14px;
  letter-spacing:.04em;
}
.location-teaser-cta{
  margin-top:8px;
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 18px;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.78);
  color:#fff;
  background:transparent;
  font-size:12px;
  letter-spacing:.08em;
  transition:background .2s ease;
}
.location-teaser-cta:hover{
  background:rgba(255,255,255,.12);
}

.map-embed-wrap{
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid rgba(40,28,20,.12);
  box-shadow:0 18px 40px rgba(26,18,12,.08);
  aspect-ratio:16 / 9;
  max-height:min(56vh, 520px);
  background:rgba(255,255,255,.5);
}
.map-embed{
  width:100%;
  height:100%;
  min-height:280px;
  border:0;
  display:block;
}
.map-note{
  margin-top:14px;
  font-size:13px;
  color:var(--muted);
  font-weight:600;
  line-height:1.55;
}

.route-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:18px;
}
.route-titles{flex:1; text-align:left;}
.route-top--detail{
  margin-bottom:14px;
}

.products-route, .product-route{
  padding-top:20px;
}

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

.product-card{
  position:relative;
  border-radius:22px;
  border:1px solid rgba(40,28,20,.12);
  background:rgba(255,255,255,.70);
  box-shadow:0 18px 40px rgba(26,18,12,.08);
  overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease;
  min-height:280px;
}
.product-card:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 60px rgba(26,18,12,.12);
}
.product-card-link{
  position:absolute;
  inset:0;
  z-index:1;
  cursor:pointer;
}
.product-card .product-media{
  height:155px;
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg, rgba(0,0,0,.08), rgba(0,0,0,.16));
}
.product-card .product-media img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  min-width:100%;
  min-height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  filter:saturate(1.06) contrast(1.04);
}
.product-body{
  position:relative;
  z-index:3;
  padding:14px 14px 16px;
}
.product-top-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.product-title{
  margin:0;
  font-size:1.5rem;
  line-height:1.2;
  font-weight:700;
}
.product-short{
  margin:8px 0 10px;
  color:var(--muted);
  font-weight:600;
  line-height:1.7;
  font-size:1.05rem;
}
.product-price{
  font-weight:950;
  letter-spacing:.1px;
  margin-top:10px;
  color:var(--text);
}
.product-more{
  margin-top:12px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  color:var(--brand);
  font-weight:950;
}
.product-more-label::after{
  content:"→";
  display:inline-block;
  margin-left:8px;
}

.product-wa{
  position:relative;
  z-index:5;
  pointer-events:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:32px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid transparent;
  background:var(--wa);
  color:#fff;
  font-weight:800;
  font-size:12.5px;
  text-decoration:none;
  white-space:nowrap;
  box-shadow:0 2px 6px rgba(37,211,102,.3);
}
.product-wa:hover{
  background:var(--wa-hover);
  color:#fff;
}

.product-detail-layout{
  display:grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.95fr);
  gap:clamp(18px, 3vw, 28px);
  align-items:start;
}
#productDetailRoute .product-detail-layout > .product-media{
  border-radius:24px;
  border:1px solid rgba(40,28,20,.12);
  background:rgba(255,255,255,.65);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.product-main-media{
  padding:clamp(10px, 1.5vw, 16px);
  aspect-ratio:4 / 3;
  max-height:min(78vh, 880px);
  min-height:min(52vh, 560px);
  width:100%;
}
.product-main-media.is-zoomable{
  cursor:zoom-in;
}
.product-main-media.is-zoomable img{
  cursor:zoom-in;
}
.product-main-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:18px;
  display:block;
}
.product-thumbs{
  padding:0 12px 12px;
  display:flex;
  gap:10px;
  overflow:auto;
}
.thumb-btn{
  flex:0 0 auto;
  width:92px;
  height:64px;
  border-radius:14px;
  border:1px solid rgba(40,28,20,.12);
  background:rgba(255,255,255,.75);
  padding:0;
  cursor:pointer;
}
.thumb-btn img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.thumb-btn.is-active{
  outline:2px solid var(--brand);
  outline-offset:2px;
}

.product-lightbox[hidden]{
  display:none !important;
}
body.lightbox-open{
  overflow:hidden;
}
.product-lightbox{
  position:fixed;
  inset:0;
  z-index:300;
  display:grid;
  place-items:center;
  padding:clamp(12px, 4vw, 40px);
}
.product-lightbox-backdrop{
  position:absolute;
  inset:0;
  background:rgba(12,10,8,.82);
  backdrop-filter:blur(2px);
}
.product-lightbox-stage{
  position:relative;
  z-index:2;
  max-width:min(96vw, 1200px);
  max-height:min(88vh, 900px);
  width:auto;
  height:auto;
  display:flex;
  align-items:center;
  justify-content:center;
}
.product-lightbox-img{
  max-width:100%;
  max-height:min(88vh, 900px);
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:12px;
  box-shadow:0 24px 80px rgba(0,0,0,.45);
}
.product-lightbox-close{
  position:absolute;
  top:clamp(12px, 3vw, 28px);
  right:clamp(12px, 3vw, 28px);
  z-index:4;
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(20,18,16,.55);
  color:#fff;
  font-size:28px;
  line-height:1;
  cursor:pointer;
  display:grid;
  place-items:center;
  transition:background .15s ease, border-color .15s ease;
}
.product-lightbox-close:hover{
  background:rgba(40,36,32,.75);
  border-color:rgba(255,255,255,.35);
}
.product-lightbox-close:focus-visible{
  outline:3px solid var(--focus);
  outline-offset:2px;
}
.product-lightbox-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:4;
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(20,18,16,.45);
  color:#fff;
  font-size:32px;
  line-height:1;
  cursor:pointer;
  display:grid;
  place-items:center;
  transition:background .15s ease;
}
.product-lightbox-nav:hover{
  background:rgba(50,46,42,.72);
}
.product-lightbox-nav:focus-visible{
  outline:3px solid var(--focus);
  outline-offset:2px;
}
.product-lightbox-prev{
  left:clamp(8px, 2vw, 24px);
}
.product-lightbox-next{
  right:clamp(8px, 2vw, 24px);
}
.product-lightbox-nav[hidden]{
  display:none !important;
}
.product-lightbox-counter{
  position:absolute;
  bottom:clamp(16px, 4vw, 36px);
  right:clamp(16px, 4vw, 36px);
  z-index:4;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(20,18,16,.65);
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.92);
  font-weight:800;
  font-size:13px;
  letter-spacing:.06em;
}

/* Monochrome professional theme overrides */
:root{
  --bg0:#f2f2f2;
  --bg1:#ffffff;
  --surface:rgba(255,255,255,.88);
  --surface-2:rgba(255,255,255,.96);
  --text:#111111;
  --muted:#4d4d4d;
  --border:rgba(17,17,17,.18);
  --shadow:0 18px 50px rgba(0,0,0,.10);
  --shadow-soft:0 10px 24px rgba(0,0,0,.08);
  --brand:#111111;
  --brand-2:#2e2e2e;
  --brand-3:#000000;
  --brand-purple:#111111;
  --focus:rgba(0,0,0,.28);
}

body{
  background:
    radial-gradient(900px 400px at 18% 4%, rgba(0,0,0,.05), transparent 60%),
    radial-gradient(700px 420px at 85% 10%, rgba(0,0,0,.04), transparent 60%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
}

.site-header{
  background:rgba(255,255,255,.88);
  border-bottom:1px solid rgba(0,0,0,.12);
}

.brand-wordmark-accent{
  color:inherit;
}

.nav-link::after,
.card-link::after{
  background:linear-gradient(90deg, #111111, #333333);
}

.btn-primary{
  background:#111111;
  color:#ffffff;
}

.btn-primary:hover{
  background:#000000;
  box-shadow:0 4px 12px rgba(0,0,0,.24);
}

.lang-btn.is-active{
  background:rgba(0,0,0,.10);
}

.badge{
  background:rgba(0,0,0,.08);
  border:1px solid rgba(0,0,0,.14);
}

.highlight-icon{
  background:
    radial-gradient(10px 10px at 30% 30%, rgba(0,0,0,.24), rgba(0,0,0,0) 70%),
    linear-gradient(135deg, rgba(0,0,0,.12), rgba(0,0,0,.06));
  border:1px solid rgba(0,0,0,.14);
}

.visual-glow{
  background:
    radial-gradient(circle at 50% 40%, rgba(0,0,0,.14), transparent 60%),
    radial-gradient(circle at 60% 55%, rgba(0,0,0,.08), transparent 55%);
}

.card::before,
.visual-card::before,
.media-orb{
  background:radial-gradient(circle at 30% 40%, rgba(0,0,0,.14), transparent 60%);
}

.about-panel{
  background:
    radial-gradient(900px 420px at 30% 0%, rgba(0,0,0,.12), transparent 55%),
    radial-gradient(700px 340px at 90% 30%, rgba(0,0,0,.08), transparent 55%),
    rgba(255,255,255,.72);
}

.check-mark{
  border:1px solid rgba(0,0,0,.24);
  background:linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.10));
}

.check-mark::after{
  border-left:3px solid rgba(255,255,255,.92);
  border-bottom:3px solid rgba(255,255,255,.92);
}

.step-num{
  background:rgba(0,0,0,.10);
  border:1px solid rgba(0,0,0,.16);
}

.quote-stars{
  color:rgba(0,0,0,.75);
}

.contact-visual-card{
  background:
    radial-gradient(650px 220px at 15% 0%, rgba(0,0,0,.14), transparent 55%),
    radial-gradient(520px 220px at 95% 25%, rgba(0,0,0,.10), transparent 55%),
    rgba(255,255,255,.6);
}

.bullet-dot{
  background:linear-gradient(180deg, #111111, #3a3a3a);
  box-shadow:0 10px 18px rgba(0,0,0,.25);
}

.site-footer{
  background:rgba(245,245,245,.92);
}
.visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.product-info{
  border-radius:24px;
  border:1px solid rgba(40,28,20,.12);
  background:rgba(255,255,255,.70);
  box-shadow:0 18px 40px rgba(26,18,12,.06);
  padding:18px;
}
.product-kicker{
  color:var(--muted);
  font-weight:900;
  letter-spacing:.18px;
  text-transform:uppercase;
  font-size:12px;
  margin-bottom:8px;
}
.product-detail-title{margin:0 0 10px}
.product-detail-desc{margin:0 0 14px; color:var(--muted); font-weight:600; line-height:1.75}
.product-features-title{
  margin:16px 0 10px;
  font-size:15px;
  font-weight:950;
  color:var(--text);
}
.product-features{
  margin:0;
  padding-left:18px;
}
.feature-item{
  margin:8px 0;
  color:var(--muted);
  font-weight:650;
  line-height:1.55;
}
.product-actions{
  margin-top:16px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.wa-fab{
  position:fixed;
  right:20px;
  bottom:calc(20px + env(safe-area-inset-bottom, 0px));
  width:56px;
  height:56px;
  border-radius:50%;
  background:var(--wa);
  color:#fff;
  box-shadow:0 4px 16px rgba(37,211,102,.45), 0 2px 8px rgba(0,0,0,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:200;
  text-decoration:none;
  border:none;
  overflow:visible;
  flex-shrink:0;
}
.wa-fab:hover{
  background:var(--wa-hover);
  color:#fff;
  box-shadow:0 6px 20px rgba(37,211,102,.5), 0 2px 8px rgba(0,0,0,.14);
}
.wa-fab:focus{
  outline:3px solid rgba(37,211,102,.45);
  outline-offset:2px;
}
.wa-fab-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
}
.wa-fab-icon svg{
  width:28px;
  height:28px;
  display:block;
}
.wa-fab-text{
  position:absolute;
  right:64px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(40,28,20,.12);
  border-radius:999px;
  padding:10px 14px;
  font-weight:950;
  color:var(--text);
  opacity:0;
  transform:translateX(10px);
  transition:opacity .18s ease, transform .18s ease;
  white-space:nowrap;
}
.wa-fab:hover .wa-fab-text{
  opacity:1;
  transform:translateX(0);
}

.scroll-top-fab{
  position:fixed;
  right:20px;
  bottom:calc(88px + env(safe-area-inset-bottom, 0px));
  width:48px;
  height:48px;
  border-radius:50%;
  border:1px solid rgba(0,0,0,.18);
  background:#fff;
  color:#000;
  font-family:"Noto Serif", serif;
  font-size:24px;
  font-weight:700;
  line-height:1;
  display:grid;
  place-items:center;
  position:fixed;
  cursor:pointer;
  z-index:205;
  opacity:0;
  transform:translateY(10px);
  pointer-events:none;
  transition:opacity .2s ease, transform .2s ease, background .2s ease;
}
.scroll-top-fab.is-visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.scroll-top-fab:hover{
  background:#f2f2f2;
}
.scroll-top-fab-letter{
  position:relative;
  z-index:2;
}
.scroll-top-fab-arrow{
  position:absolute;
  top:4px;
  font-size:12px;
  font-weight:700;
  color:#000;
  animation:scrollFabArrowFloat 1.1s ease-in-out infinite;
}
.scroll-top-fab.is-scrolling{
  animation:scrollFabPop .42s ease;
}

@keyframes scrollFabArrowFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-3px)}
}
@keyframes scrollFabPop{
  0%{transform:translateY(0) scale(1)}
  40%{transform:translateY(-6px) scale(1.06)}
  100%{transform:translateY(0) scale(1)}
}

@media (max-width: 980px){
  .product-grid{grid-template-columns: repeat(2, minmax(0, 1fr));}
  .product-detail-layout{grid-template-columns: 1fr; }
  #productDetailRoute .product-main-media{
    aspect-ratio:16 / 10;
    max-height:min(70vh, 640px);
    min-height:min(42vh, 420px);
  }
}

@media (max-width: 720px){
  .product-grid{grid-template-columns: 1fr;}
  .wa-fab-text{display:none;}
  .scroll-top-fab{
    width:44px;
    height:44px;
    font-size:22px;
    right:14px;
    bottom:84px;
  }
}

/* Atelier Noir - location page */
.location-page{
  background:#000;
  color:#f4f4f4;
}
.location-page .site-header{
  background:rgba(0,0,0,.78);
  border-bottom:1px solid rgba(255,255,255,.16);
}
.location-page .nav-link,
.location-page .brand-wordmark,
.location-page .lang-btn{
  color:#efefef;
}
.location-page .lang-switch{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.22);
}
.location-page .lang-btn.is-active{
  background:rgba(255,255,255,.2);
  color:#fff;
}
.location-main{
  min-height:calc(100vh - 88px);
}
.location-map-section{
  position:relative;
  min-height:calc(100vh - 88px);
  overflow:hidden;
}
.location-map{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  background:#000;
  filter:grayscale(.24) contrast(1.06);
}
.location-panel{
  position:relative;
  z-index:420;
  width:min(460px, calc(100% - 36px));
  margin:clamp(16px, 3vw, 28px);
  padding:22px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(0,0,0,.62);
  backdrop-filter:blur(8px);
}
.location-kicker{
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#d0d0d0;
  margin-bottom:10px;
}
.location-title{
  margin:0 0 12px;
  font-family:"Noto Serif", serif;
  font-weight:600;
  line-height:1.2;
  font-size:clamp(28px, 4vw, 42px);
}
.location-copy{
  margin:0 0 16px;
  color:#d8d8d8;
  line-height:1.75;
}
.location-meta{
  border-top:1px solid rgba(255,255,255,.2);
  border-bottom:1px solid rgba(255,255,255,.2);
  padding:12px 0;
  display:flex;
  flex-direction:column;
  gap:8px;
  color:#e2e2e2;
  font-size:14px;
}
.location-cta{
  margin-top:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  color:#fff;
  border:1px solid rgba(255,255,255,.72);
  background:transparent;
  height:42px;
  padding:0 16px;
  letter-spacing:.08em;
  font-size:12px;
}
.location-cta:hover{
  background:rgba(255,255,255,.1);
}


