:root{
  --bg:#ffffff;
  --text:#0b0b0c;
  --muted:#5b5b60;
  --line:#e9e9ee;
  --soft:#f6f6f8;
  --accent:#0b0b0c;
  --radius:18px;
  --shadow: 0 14px 40px rgba(11,11,12,.08);
  --shadow-soft: 0 10px 28px rgba(11,11,12,.06);
  --max: 1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:var(--bg);
  line-height:1.55;
}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}

.container{max-width:var(--max); margin:0 auto; padding:0 22px}
.section{padding:86px 0}
.section--tight{padding:64px 0}
.section-title{
  font-size:42px;
  letter-spacing:-.02em;
  line-height:1.08;
  margin:0 0 14px;
}
.section-lead{color:var(--muted); margin:0 0 30px; max-width:66ch}

.header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(233,233,238,.7);
}
.header__inner{display:flex; align-items:center; justify-content:space-between; gap:18px; padding:14px 0}
.brand{display:flex; align-items:center; gap:12px}
.brand img{height:88px; width:auto}
.brand span{font-weight:650; letter-spacing:.03em; font-size:14px}
.nav{display:flex; align-items:center; gap:18px}
.nav a{
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(11,11,12,.78);
  padding:10px 10px;
  border-radius:12px;
}
.nav a:hover{background:var(--soft); color:var(--text)}
.nav .btn{padding:11px 14px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:13px 18px;
  border-radius:999px;
  border:1px solid rgba(11,11,12,.14);
  background:#fff;
  color:var(--text);
  font-weight:650;
  box-shadow: 0 10px 24px rgba(11,11,12,.05);
}
.btn:hover{transform: translateY(-1px); box-shadow: var(--shadow-soft)}
.btn--primary{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
  box-shadow: 0 16px 34px rgba(11,11,12,.18);
}
.btn--primary:hover{box-shadow: 0 18px 40px rgba(11,11,12,.22)}
.btn--ghost{background:transparent; box-shadow:none}
.btn--ghost:hover{background:var(--soft)}
.btn--small{padding:10px 14px; font-size:14px}

.burger{display:none; border:1px solid rgba(11,11,12,.14); background:#fff; border-radius:12px; padding:10px 12px}
.burger svg{width:20px; height:20px}
.mobile{
  display:none;
  border-top:1px solid var(--line);
  padding:10px 0 18px;
}
.mobile a{display:block; padding:12px 10px; border-radius:12px; font-size:14px}
.mobile a:hover{background:var(--soft)}
.mobile .btn{margin-top:8px; width:100%}

.hero{
  padding:70px 0 44px;
}
.hero__grid{
  display:grid;
  grid-template-columns: 1.12fr .88fr;
  gap:34px;
  align-items:center;
}
.kicker{
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(11,11,12,.58);
  margin:0 0 12px;
}
.hero h1{
  font-size:58px;
  line-height:1.02;
  letter-spacing:-.03em;
  margin:0 0 18px;
}
.hero p{
  margin:0 0 24px;
  color:var(--muted);
  max-width:60ch;
  font-size:18px;
}
.hero__actions{display:flex; gap:12px; flex-wrap:wrap; margin-bottom:26px}
.badges{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
.badge{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px 14px;
  background:#fff;
}
.badge strong{display:block; font-size:14px; margin-bottom:6px}
.badge span{color:var(--muted); font-size:13px}

.hero__card{
  border-radius:26px;
  overflow:hidden;
  border:1px solid rgba(233,233,238,.8);
  box-shadow: var(--shadow);
  background:#fff;
}
.hero__media{
  position:relative;
  aspect-ratio: 4 / 5;
  background: #111;
}
.hero__media img{width:100%; height:100%; object-fit:cover; filter: grayscale(.15) contrast(1.06)}
.hero__media::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.16), rgba(0,0,0,.55));
}
.hero__stamp{
  position:absolute; left:18px; bottom:18px; right:18px;
  color:#fff;
  z-index:2;
}
.hero__stamp .tag{
  display:inline-flex; gap:8px; align-items:center;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  opacity:.92;
  margin-bottom:10px;
}
.hero__stamp .tag span{padding:6px 10px; border:1px solid rgba(255,255,255,.26); border-radius:999px; backdrop-filter: blur(6px); background:rgba(0,0,0,.18)}
.hero__stamp strong{display:block; font-size:18px; letter-spacing:-.01em; line-height:1.2}
.hero__stamp small{display:block; opacity:.86; margin-top:6px}

.grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap:18px}
.card{
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding:18px;
  background:#fff;
  box-shadow: 0 10px 22px rgba(11,11,12,.04);
}
.card h3{margin:0 0 8px; font-size:18px}
.card p{margin:0; color:var(--muted)}
.icon{
  width:38px; height:38px; border-radius:14px;
  display:grid; place-items:center;
  border:1px solid rgba(11,11,12,.12);
  background: var(--soft);
  margin-bottom:12px;
}

.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:28px;
  align-items:start;
}
.figure{
  border-radius:26px;
  overflow:hidden;
  border:1px solid rgba(233,233,238,.8);
  box-shadow: var(--shadow);
}
.figure img{width:100%; height:100%; object-fit:cover; aspect-ratio: 16/10; filter: grayscale(.08) contrast(1.04)}
.figure--tall img{aspect-ratio: 4/5}

.gallery{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}
.gitem{
  position:relative;
  border-radius: 18px;
  overflow:hidden;
  border:1px solid rgba(233,233,238,.9);
  background:#fff;
  aspect-ratio: 4 / 3;
  cursor: zoom-in;
}
.gitem img{width:100%; height:100%; object-fit:cover; transition: transform .35s ease; filter: contrast(1.03)}
.gitem:hover img{transform: scale(1.05)}
.gitem::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.14));
  opacity:.75;
}

.prices{
  overflow:hidden;
  border-radius: 22px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow: 0 14px 34px rgba(11,11,12,.06);
}
.table-wrap{overflow:auto}
table{border-collapse:collapse; width:100%; min-width:820px}
th, td{padding:14px 14px; border-bottom:1px solid var(--line); text-align:center; white-space:nowrap}
th:first-child, td:first-child{text-align:left}
thead th{
  background: var(--soft);
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(11,11,12,.65);
}
tbody tr:hover td{background: rgba(246,246,248,.55)}
.note{color:var(--muted); font-size:14px; margin-top:14px}
.note ul{margin:10px 0 0 18px}
.note li{margin:6px 0}

.faq{display:grid; grid-template-columns: 1fr 1fr; gap:14px}
details{
  border:1px solid var(--line);
  border-radius: 18px;
  padding:14px 16px;
  background:#fff;
}
summary{cursor:pointer; font-weight:650}
details p{color:var(--muted); margin:10px 0 0}

.contact{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:start;
}
.form{
  border:1px solid var(--line);
  border-radius: 22px;
  padding:18px;
  background:#fff;
  box-shadow: 0 14px 32px rgba(11,11,12,.06);
}
.field{display:grid; gap:8px; margin-bottom:12px}
label{font-size:13px; color:rgba(11,11,12,.72)}
input, textarea{
  width:100%;
  padding:12px 12px;
  border-radius: 14px;
  border:1px solid rgba(11,11,12,.16);
  background:#fff;
  font:inherit;
}
textarea{min-height:120px; resize:vertical}
input:focus, textarea:focus{outline: none; border-color: rgba(11,11,12,.38); box-shadow: 0 0 0 4px rgba(11,11,12,.06)}
.small{font-size:13px; color:var(--muted)}
.hint{font-size:12px; color:var(--muted); line-height:1.4}
.kontaktbox{
  border:1px solid var(--line);
  border-radius: 22px;
  padding:18px;
  background:var(--soft);
}
.kontaktbox strong{display:block; margin-bottom:6px}
.kontaktbox a{color:var(--text); text-decoration:underline; text-underline-offset:4px}
.kontaktbox .row{margin:10px 0; color:var(--muted)}
.mapbox{
  margin-top:14px;
  border-radius: 18px;
  overflow:hidden;
  border:1px solid rgba(11,11,12,.12);
  background:#fff;
}
.mapplaceholder{
  aspect-ratio: 16/9;
  display:grid;
  place-items:center;
  padding:18px;
  background: linear-gradient(135deg, rgba(11,11,12,.06), rgba(11,11,12,.02));
  text-align:center;
}
.footer{
  border-top:1px solid var(--line);
  padding:34px 0 28px;
  color:var(--muted);
  font-size:13px;
}
.footer__grid{display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; align-items:center}
.footer a{color:inherit; text-decoration:underline; text-underline-offset:4px}
.toast{
  position:fixed; left:18px; bottom:18px; z-index:60;
  display:flex; gap:10px; align-items:center;
  background: #25D366; color:#fff;
  padding:12px 14px;
  border-radius: 999px;
  box-shadow: 0 18px 40px rgba(0,0,0,.22);
}
.toast a{color:#fff; text-decoration:underline; text-underline-offset:4px}
.toast svg{width:18px; height:18px}
.hidden{display:none !important}

/* Lightbox */
.lightbox{
  position:fixed; inset:0; z-index:80;
  background: rgba(11,11,12,.78);
  backdrop-filter: blur(8px);
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
}
.lightbox.open{display:flex}
.lightbox__inner{
  max-width: 1100px; width:100%;
  background:#000;
  border-radius: 18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.18);
  box-shadow: 0 24px 70px rgba(0,0,0,.36);
  position:relative;
}
.lightbox__inner img{width:100%; height:auto; display:block}
.lightbox__close{
  position:absolute; top:12px; right:12px;
  border:1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.35);
  color:#fff;
  border-radius: 999px;
  padding:10px 12px;
  cursor:pointer;
}
.lightbox__close:hover{background: rgba(0,0,0,.52)}

/* Responsive */
@media (max-width: 980px){
  .brand img{height:72px}
  .hero__grid{grid-template-columns: 1fr; gap:18px}
  .hero h1{font-size:46px}
  .badges{grid-template-columns: 1fr; }
  .grid-3{grid-template-columns: 1fr}
  .split{grid-template-columns: 1fr}
  .gallery{grid-template-columns: repeat(2, 1fr)}
  .faq{grid-template-columns: 1fr}
  .contact{grid-template-columns: 1fr}
  table{min-width: 720px}
  .nav{display:none}
  .burger{display:inline-flex}
  .mobile{display:none}
  .mobile.open{display:block}
}
@media (max-width: 520px){
  .brand img{height:60px}
  .hero h1{font-size:38px}
  .section-title{font-size:34px}
  .gallery{grid-template-columns: 1fr}
}
/* Legal pages */
.legal h2{margin: 18px 0 8px; font-size: 18px}
.legal h3{margin: 14px 0 8px; font-size: 16px}
.legal p{line-height: 1.7}
.legal ul{margin: 10px 0 14px 18px}
.legal li{margin: 6px 0}
.toast:hover{filter:brightness(0.95)}
