:root{
  --teal:#0d9488;
  --teal-dark:#0f766e;
  --teal-deep:#134e4a;
  --mint:#ecfdf9;
  --mint-2:#d4f3ec;
  --ink:#1f2d2b;
  --gray:#5b6b69;
  --line:#e2ebe9;
  --white:#fff;
  --shadow:0 8px 30px rgba(13,148,136,.12);
  --shadow-sm:0 2px 10px rgba(15,75,70,.08);
  --radius:18px;
  --max:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{line-height:1.2;margin:0 0 .4em;color:var(--teal-deep)}
h1{font-size:clamp(2rem,5.5vw,3.2rem);letter-spacing:-.5px}
h2{font-size:clamp(1.55rem,3.8vw,2.3rem)}
h3{font-size:1.15rem}
p{margin:0 0 1rem}
a{color:var(--teal-dark);text-decoration:none}
img,iframe{max-width:100%}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 20px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4em;
  background:var(--teal);color:#fff;font-weight:600;
  padding:.7em 1.3em;border-radius:999px;border:2px solid var(--teal);
  transition:.18s;cursor:pointer;white-space:nowrap;
}
.btn:hover{background:var(--teal-dark);border-color:var(--teal-dark);transform:translateY(-1px)}
.btn-lg{padding:.85em 1.7em;font-size:1.05rem}
.btn-sm{padding:.5em 1em;font-size:.92rem}
.btn-ghost{background:transparent;color:var(--teal-dark)}
.btn-ghost:hover{background:var(--mint);color:var(--teal-dark)}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:68px}
.brand{display:flex;align-items:center;gap:.6em;color:var(--ink)}
.brand-logo{height:46px;width:auto;display:block}
.brand-icon{width:34px;height:34px;fill:var(--teal);flex:none}
.brand-text strong{display:block;font-size:1.05rem;line-height:1.1;color:var(--teal-deep)}
.brand-text small{display:block;font-size:.74rem;color:var(--gray);letter-spacing:.3px}

.nav{display:flex;align-items:center;gap:.4rem}
.nav a{padding:.5em .85em;border-radius:8px;color:var(--ink);font-weight:500}
.nav a:not(.btn):hover{background:var(--mint);color:var(--teal-dark)}
.nav-cta{color:#fff!important;margin-left:.4rem}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;cursor:pointer}
.nav-toggle span{width:26px;height:2.5px;background:var(--teal-deep);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* Hero */
.hero{
  background:
    radial-gradient(1200px 500px at 80% -10%,var(--mint-2),transparent 60%),
    linear-gradient(180deg,var(--mint),#fff);
  padding:clamp(3rem,8vw,6rem) 0 clamp(2.5rem,6vw,4.5rem);
}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
.hero-text{max-width:680px}
.hero-media{position:relative;padding-top:100%;border-radius:24px;box-shadow:var(--shadow);border:6px solid #fff;overflow:hidden}
.hero-media img{
  position:absolute;top:0;left:0;
  width:100%;height:100%;object-fit:cover;
}
.hero-media-tag{
  position:absolute;left:1rem;bottom:1rem;
  background:rgba(19,78,74,.92);color:#fff;font-weight:600;font-size:.9rem;
  padding:.45em 1em;border-radius:999px;backdrop-filter:blur(4px);
}
.eyebrow{
  text-transform:uppercase;letter-spacing:2px;font-size:.8rem;font-weight:700;
  color:var(--teal);margin:0 0 .6rem;
}
.lead{font-size:clamp(1.05rem,2.2vw,1.25rem);color:var(--gray);max-width:60ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin:1.6rem 0 1.4rem}
.hero-badges{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;padding:0;margin:0;font-weight:500;color:var(--teal-deep)}
.hero-badges li{display:flex;align-items:center;gap:.45em;font-size:.95rem}
.hero-badges li::before{content:"✓";color:var(--teal);font-weight:800}

/* Quickbar */
.quickbar{background:var(--teal-deep)}
.quickbar-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.12)}
.quick{display:flex;align-items:center;gap:.8rem;padding:1.1rem 1.2rem;background:var(--teal-deep);color:#fff;transition:.18s}
.quick:hover{background:var(--teal-dark)}
.quick-ic{font-size:1.5rem;flex:none}
.quick small{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:1px;opacity:.75}
.quick strong{display:block;font-size:1rem}

/* Sections */
.section{padding:clamp(3rem,7vw,5.5rem) 0}
.section-alt{background:var(--mint)}
.section-head{max-width:640px;margin:0 0 2.4rem}
.section-head .eyebrow{margin-bottom:.4rem}

.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:2.5rem;align-items:start}
.prose p{color:var(--gray);font-size:1.05rem}
.value-list{list-style:none;margin:0;padding:0;display:grid;gap:.9rem}
.value-list li{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:1rem 1.2rem;
  box-shadow:var(--shadow-sm);
}
.value-list strong{display:block;color:var(--teal-deep)}
.value-list span{color:var(--gray);font-size:.95rem}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem;box-shadow:var(--shadow-sm);transition:.2s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--mint-2)}
.card-ic{
  width:54px;height:54px;display:grid;place-items:center;font-size:1.6rem;
  background:var(--mint);border-radius:14px;margin-bottom:1rem;
}
.card p{margin:0;color:var(--gray)}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.gallery figure{
  margin:0;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);background:#fff;
  position:relative;padding-top:72%;          /* ~4:3 Querformat, engine-unabhängig */
}
.gallery img{
  position:absolute;top:0;left:0;
  width:100%;height:100%;object-fit:cover;
  transition:transform .35s ease;
}
.gallery figure:hover img{transform:scale(1.05)}

/* Hours */
.hours-wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:start}
.hours{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.hours th,.hours td{padding:.95rem 1.2rem;text-align:left;border-bottom:1px solid var(--line)}
.hours tr:last-child th,.hours tr:last-child td{border-bottom:0}
.hours th{font-weight:600;color:var(--teal-deep);width:36%}
.hours td{color:var(--gray)}
.hours .muted{color:#9aa8a6}
.hours-note{background:var(--mint);border-radius:var(--radius);padding:1.6rem}
.hours-note .small,.small{font-size:.85rem;color:var(--gray)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:2rem;align-items:stretch}
.contact-info{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm)}
.contact-list{list-style:none;margin:0 0 1.5rem;padding:0;display:grid;gap:.9rem}
.contact-list li{display:flex;gap:.8rem;align-items:flex-start}
.contact-list span{font-size:1.2rem;flex:none}
.map-box{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);background:#fff;display:flex;flex-direction:column}
.map-box iframe{border:0;width:100%;height:340px;flex:1;min-height:300px}
.map-link{display:block;text-align:center;padding:.8rem;font-weight:600;border-top:1px solid var(--line)}

/* Footer */
.site-footer{background:var(--teal-deep);color:#cfeae5;padding:2.5rem 0 1.5rem}
.footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.5rem;align-items:flex-start}
.site-footer strong{color:#fff}
.footer-nav{display:flex;flex-wrap:wrap;gap:1.2rem}
.footer-nav a{color:#a7d8d0;font-weight:500}
.footer-nav a:hover{color:#fff}
.copyright{margin:1.8rem 0 0;font-size:.82rem;color:#7fb8b0;text-align:center;border-top:1px solid rgba(255,255,255,.12);padding-top:1.2rem}

/* Legal pages */
.legal{padding:clamp(2.5rem,6vw,4.5rem) 0;max-width:780px}
.legal h1{font-size:clamp(1.8rem,4vw,2.4rem)}
.legal h2{font-size:1.25rem;margin-top:2rem}
.legal p,.legal li{color:var(--gray)}
.back-link{display:inline-block;margin-bottom:1.5rem;font-weight:600}

/* Responsive */
@media (max-width:860px){
  .two-col,.hours-wrap,.contact-grid{grid-template-columns:1fr}
  .cards,.gallery{grid-template-columns:repeat(2,1fr)}
  .hero-inner{grid-template-columns:1fr}
  .hero-media{max-width:440px}
}
@media (max-width:760px){
  .brand-logo{height:40px}
  .nav-toggle{display:flex}
  .nav{
    position:fixed;inset:68px 0 auto 0;
    flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-bottom:1px solid var(--line);
    padding:.6rem 20px 1.2rem;box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .28s ease;
    max-height:calc(100vh - 68px);overflow:auto;
  }
  .nav.open{transform:translateY(0)}
  .nav a{padding:.85em .4em;border-radius:8px;border-bottom:1px solid var(--line)}
  .nav a:last-child{border-bottom:0}
  .nav-cta{margin:.6rem 0 0;text-align:center}
  .quickbar-inner{grid-template-columns:1fr}
  .quick{justify-content:flex-start}
}
@media (max-width:520px){
  .cards,.gallery{grid-template-columns:1fr}
  .hero-actions .btn{flex:1 1 100%}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important}
}
