:root{
  --bg:#fcf8f5;
  --text:#1f2a32;
  --muted:#54636c;
  --accent:#0a6f6c;
  --soft:#fffaf7;

  --peach-50:#fff6ef;
  --peach-90:#fff0e5;
  --peach-150:#ffe5d1;
  --peach-200:#ffdabf;
  --peach-line:#eacfbf;

  --warm-card:#fff1e6;
  --warm-muted:#6f635e;

  --construct-bg:#fff3c4;
  --construct-text:#473a14;
  --construct-line:#f0e0a6;

  --radius:14px;
  --header-height:72px;
  --container-max:1360px;
  --section-pad-y:clamp(48px, 7vw, 84px);
  --page-gutter:clamp(14px, 3.2vw, 40px);
  --shadow:0 10px 30px rgba(11,122,117,.1);
}

/* Base */
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  color:var(--text); background:var(--bg);
  line-height:1.72;
  font-size:clamp(17px, 1.6vw, 18.5px);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--page-gutter)}

.sr-only{position:absolute!important;left:-9999px}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;left:1rem;top:1rem;width:auto;height:auto;padding:.5rem .8rem;background:#fff;border:2px solid var(--accent);border-radius:8px;z-index:1000}

/* Bars */
.alert-bar{background:#14333b;color:#fff;padding:.55rem var(--page-gutter);font-size:.95rem;text-align:center}
.alert-bar a{color:#bfe7e5;text-underline-offset:2px}
.notice-bar{background:#0a6f6c10;color:#16383b;padding:.55rem var(--page-gutter);border-bottom:1px solid var(--peach-line);display:flex;gap:.8rem;justify-content:center;align-items:center}
.notice-bar .notice-close{background:transparent;border:0;font-size:1.1rem;cursor:pointer;line-height:1;color:#16383b}
.construction-bar{background:var(--construct-bg);color:var(--construct-text);padding:.55rem var(--page-gutter);border-bottom:1px solid var(--construct-line);display:flex;justify-content:center;align-items:center;gap:.8rem;text-align:center;font-size:.95rem}
.construction-close{background:transparent;border:0;font-size:1.1rem;line-height:1;cursor:pointer;color:var(--construct-text)}

/* Header */
.site-header{position:sticky;top:0;z-index:40;height:var(--header-height);background:rgba(252,248,245,.94);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--peach-line);display:flex;align-items:center;padding-inline:var(--page-gutter)}
.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.6rem 0}
.brand{font-weight:800;letter-spacing:.2px;color:var(--text);text-decoration:none;white-space:nowrap}
.main-nav{display:flex;align-items:center;gap:1rem}
.main-nav ul{list-style:none;display:flex;gap:clamp(.8rem, 2.2vw, 1.6rem);margin:0;padding:0;align-items:center}
.main-nav a{color:var(--text);text-decoration:none;font-weight:600;padding:.45rem .7rem;border-radius:10px}
.main-nav a:hover,.main-nav a.active{color:var(--accent);background:rgba(10,111,108,.08)}
.btn--nav{margin-left:.4rem;padding:.5rem .85rem;border-radius:10px}
.nav-toggle{display:none;background:transparent;border:0;font-size:1.2rem;cursor:pointer}

/* Bands */
.band{padding:var(--section-pad-y) 0}
.band--soft{background:linear-gradient(180deg, rgba(10,111,108,.06) 0%, var(--peach-50) 45%, var(--peach-90) 100%)}
.band--card{background:var(--peach-150);border-top:1px solid var(--peach-line);border-bottom:1px solid var(--peach-line)}
.band--line{border-top:1px solid var(--peach-line);border-bottom:1px solid var(--peach-line)}

/* Hero */
.hero-band{position:relative;min-height:clamp(320px, 52vh, 520px);display:flex;align-items:end}
.hero-media{position:absolute;inset:0;overflow:hidden}
.hero-media picture,.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-band::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(14,16,20,.46) 0%, rgba(14,16,20,.32) 45%, rgba(14,16,20,.12) 100%),
    radial-gradient(120% 80% at 50% 0%, rgba(255,190,170,.15), transparent 70%),
    radial-gradient(120% 80% at 50% 100%, rgba(170,190,200,.10), transparent 70%);
  z-index:-1;
}
.hero-content{position:relative;padding:calc(var(--section-pad-y)*.55) 0;display:grid;gap:.8rem}
.hero-content h1{margin:0;font-size:clamp(1.6rem, 3.2vw, 2.4rem);font-weight:800;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.38)}
.hero-content .lead{color:#eef4f4;max-width:70ch;text-shadow:0 1px 8px rgba(0,0,0,.28)}
.hero-cta{display:flex;gap:.9rem;align-items:center;flex-wrap:wrap;margin-top:.6rem}

/* Badges */
.badges{display:flex;flex-wrap:wrap;gap:.5rem;margin:.8rem 0 0;padding:0;list-style:none}
.badges li{display:flex;align-items:center;gap:.45rem;background:#ffffffc2;color:#1e2b30;border:1px solid #ffffff70;border-radius:999px;padding:.35rem .7rem;font-weight:600;font-size:.95rem;backdrop-filter:blur(2px)}
.i{display:inline-block;width:1rem;height:1rem}
.i-fmh{background:conic-gradient(from 180deg,#0a6f6c,#0a6f6c)}
.i-hin{background:linear-gradient(45deg,#0a6f6c, #6fbab7)}
.i-pin{background:#0a6f6c;border-radius:2px}
/* grüner Würfel für DE-Badge */
.i-lang-de{width:1rem;height:1rem;background:#0a6f6c;border-radius:2px;box-shadow:inset 0 0 0 2px #ffffff40;display:inline-block}

/* About */
.about-grid{display:grid;grid-template-columns:minmax(0,1fr) min(440px, 38vw);gap:clamp(1rem, 3vw, 2rem);align-items:center}
.portrait img{border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.08)}

/* Quick info */
.quick-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(.8rem, 2.2vw, 1.1rem)}
.quick-info article{background:var(--warm-card);padding:1.2rem 1.3rem;border-radius:14px;border:1px solid var(--peach-line);min-height:120px;display:flex;flex-direction:column;justify-content:center}
.quick-info h3{margin:0 0 .4rem;color:var(--accent)}
.tight li{margin:.25rem 0}

/* Accordion (Kartenstil) */
.accordion details{background:#fff;border:1px solid var(--peach-line);border-radius:12px;padding:.6rem .9rem;margin:.6rem 0;overflow:hidden}
.accordion summary{cursor:pointer;font-weight:700;outline:none;list-style:none}
.accordion summary::-webkit-details-marker{display:none}
.accordion .acc-body{margin-top:.5rem;color:var(--muted)}

/* Contact / appointment */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(.8rem, 2.2vw, 1.1rem);margin:0 0 1.2rem}
.card{background:#fff;border:1px solid var(--peach-line);border-radius:14px;padding:1.2rem}
.map{border-radius:12px;overflow:hidden;min-height:240px;background:var(--peach-90);border:1px solid var(--peach-line)}
.map iframe{display:block;width:100%;height:360px;border:0}
.hint{color:var(--warm-muted);font-size:.95rem;margin-top:.6rem}

/* Legal */
.legal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}

/* Footer */
.site-footer{background:linear-gradient(180deg, var(--peach-150) 0%, var(--peach-200) 100%);border-top:1px solid var(--peach-line);padding:clamp(14px, 2.5vw, 24px) 0;text-align:center;color:#6f6a66}

/* Buttons & links */
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;background:var(--accent);color:#fff;padding:.7rem 1.1rem;border-radius:12px;text-decoration:none;font-weight:700;letter-spacing:.2px;box-shadow:var(--shadow)}
.btn:hover{filter:brightness(.96)}
.btn--ghost{background:transparent;color:#fff;border:1.5px solid #ffffffb8}
.btn--nav{background:var(--accent);color:#fff}
.btn:focus-visible{outline:3px solid #94d7d4;outline-offset:2px}
.link{font-weight:700;color:var(--accent)}
.link:hover{text-decoration:underline}

/* Responsive nav */
@media (max-width:760px){
  .nav-toggle{display:inline-block}
  .main-nav ul{display:none}
  .main-nav[aria-hidden="false"] ul{display:flex;flex-direction:column;background:var(--bg);padding:.6rem;margin-top:.6rem;border-radius:10px}
  .btn--nav{display:none}
}

/* Anchors / focus */
section{scroll-margin-top:calc(var(--header-height) + 18px)}
.main-nav a.active{box-shadow:inset 0 -3px 0 rgba(10,111,108,.16)}
.main-nav a:focus-visible{outline:2px solid var(--accent)}

/* Reduced motion */
@media (prefers-reduced-motion:no-preference){
  .btn{transition:transform .12s ease, filter .12s ease}
  .btn:hover{transform:translateY(-1px)}
}

/* ===== Dropdown-Pfeile für alle <details>/<summary> ===== */
details > summary{
  position:relative;display:flex;align-items:center;gap:.6rem;cursor:pointer;
  list-style:none;outline:none;padding:.2rem .1rem;padding-right:2rem;min-height:44px;
  font-weight:700;color:var(--text);
}
details > summary::-webkit-details-marker{display:none}
details > summary::after{
  content:"";position:absolute;right:.75rem;top:50%;
  width:.75rem;height:.75rem;border-right:2.5px solid var(--accent);border-bottom:2.5px solid var(--accent);
  transform:translateY(-50%) rotate(-45deg);transition:transform .18s ease;pointer-events:none;
}
details[open] > summary::after{transform:translateY(-50%) rotate(45deg)}
details > summary:focus-visible{outline:3px solid #94d7d4;outline-offset:4px;border-radius:8px}
@media (prefers-reduced-motion:no-preference){
  @keyframes accFadeIn{from{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}
  .accordion details[open] .acc-body{animation:accFadeIn .16s ease-out}
}
