:root{
  --bg:#f6f4ef;
  --bg-2:#fbfaf7;
  --card:#ffffff;
  --text:#1e293b;
  --muted:#556274;
  --line:#dfe5ec;
  --brand:#153b63;
  --brand-2:#255f99;
  --accent:#0f766e;
  --header-h:100px;
  --radius:18px;
  --shadow:0 10px 30px rgba(15,23,42,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-snap-type:y proximity}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
main{padding-top:var(--header-h)}
.site-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);z-index:1000}
.header-inner{max-width:1280px;height:100px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.header-nav{display:flex;gap:14px;align-items:center}
.header-nav a{font-size:.86rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#334155;padding:10px 6px;border-radius:8px}
.header-nav a:hover{background:#eef3f8;color:var(--brand)}
.left-nav{justify-content:flex-start}
.right-nav{justify-content:flex-end}
.logo-wrap{display:flex;align-items:center;justify-content:flex-start;min-width:auto;flex:0 0 auto}
.logo-img{height:70px;object-fit:contain}
.header-right{display:flex;align-items:center;gap:12px;margin-left:auto}
.lang-dropdown{position:relative}
.lang-btn{border:1px solid var(--line);background:#fff;padding:8px 10px;border-radius:10px;color:var(--brand);cursor:pointer;font-weight:600}
.lang-menu{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);min-width:220px;padding:8px}
.lang-item{display:block;padding:8px 10px;border-radius:8px;font-size:.9rem}
.lang-item.active{background:#edf5ff;color:var(--brand)}
.lang-item.disabled{color:#94a3b8}
.mobile-menu-btn{display:none;border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 10px;cursor:pointer}
.mobile-menu{display:none;max-width:1280px;margin:0 auto;padding:10px 18px 16px;background:#fff;border-top:1px solid var(--line)}
.mobile-menu a{display:block;padding:10px 12px;border-radius:10px;color:var(--muted)}
.mobile-menu a:hover{background:#f2f6fb;color:var(--brand)}
.section{min-height:calc(100svh - var(--header-h));padding:36px 20px;display:flex;align-items:center;scroll-snap-align:start;scroll-snap-stop:always}
.container{max-width:1280px;margin:0 auto;width:100%}
.hero{background:linear-gradient(rgba(246,244,239,.72),rgba(246,244,239,.72)), url('../img/hero.webp') center/cover no-repeat}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}
.hero-card{background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.8);padding:28px;border-radius:22px;box-shadow:var(--shadow)}
.kicker{font-size:.88rem;color:var(--brand);font-weight:700;letter-spacing:.06em;text-transform:uppercase}
h1{font-size:clamp(1.8rem,4vw,3.1rem);line-height:1.1;margin:10px 0 12px;color:#0f172a}
.lead{font-size:1.05rem;color:#334155;margin:0 0 16px}
.check-list{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.check-list li{display:flex;gap:10px;align-items:flex-start;color:#1f2937}
.check-list li::before{content:"√";color:var(--accent);font-weight:800;margin-top:-1px}
.hero-panel{background:#fff;border:1px solid var(--line);border-radius:22px;padding:20px;box-shadow:var(--shadow)}
.hero-panel h3{margin:0 0 10px;color:var(--brand)}
.hero-panel p{margin:0;color:var(--muted);line-height:1.6}
.btn-row{margin-top:18px;display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 14px;border-radius:12px;border:1px solid var(--line);font-weight:600}
.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn.ghost{background:#fff;color:var(--brand)}
.offwhite{background:var(--bg-2)}
.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}
.section-title{font-size:clamp(1.5rem,3vw,2.2rem);margin:0 0 14px;color:#10243a}
.section-sub{margin:0 0 18px;color:var(--muted);line-height:1.6}
.feature-list{display:grid;gap:14px}
.feature-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.feature-item h4{margin:0 0 6px;font-size:1rem;display:flex;gap:8px;align-items:flex-start}
.feature-item h4::before{content:"√";color:var(--accent);font-weight:800}
.feature-item p{margin:0;color:var(--muted);font-size:.94rem;line-height:1.5}
.link-blue{color:var(--brand-2);font-style:italic;font-weight:600}
.img-cards{display:grid;gap:18px}
.img-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:var(--shadow)}
.img-card img{width:100%;height:auto;object-fit:contain;border-radius:12px;background:#eceff4}
.img-card small{display:block;color:var(--muted);padding:8px 4px 2px}.img-card small:empty{display:none}
.table-wrap{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:var(--shadow);overflow:auto}
.matrix{width:100%;border-collapse:collapse;table-layout:fixed}
.matrix th,.matrix td{border:1px solid var(--line);padding:10px;text-align:center;vertical-align:middle;font-size:.95rem}
.matrix th{background:#f7fafc;color:#1e3a5f}
.matrix td:first-child,.matrix th:first-child{text-align:center;width:31%}
.matrix .icon-cell{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:10px;text-align:left}
.matrix .icon-cell img{width:78px;height:78px;flex:0 0 78px;object-fit:contain;border-radius:10px;background:#eef2f7;border:1px solid var(--line)}
.matrix .icon-cell span{font-size:.88rem;line-height:1.2;word-break:normal;overflow-wrap:normal}
.tick{font-weight:800;color:var(--accent);font-size:1.15rem}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.step{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.step-num{width:34px;height:34px;border-radius:999px;background:#eaf2ff;color:var(--brand);display:grid;place-items:center;font-weight:800;margin-bottom:10px}
.step h3{margin:0 0 8px;font-size:1rem}
.step p{margin:0;color:var(--muted);font-size:.93rem;line-height:1.5}
.info-card-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center}
.side-image-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:var(--shadow)}
.side-image-card img{width:100%;height:auto;object-fit:contain;border-radius:12px;background:#edf2f7}
.about-text{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow);font-size:1.02rem;line-height:1.72;color:#243244}
.about-text strong{font-size:1.08rem}
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:24px;align-items:start}
.contact-card,.form-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:var(--shadow)}
.contact-lines{display:grid;gap:12px}
.half-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.half-row .contact-line,.half-row .notice{margin-top:14px;padding:12px;border-radius:12px;background:#fdecec;border:1px solid #f5c2c2;color:#5a2b2b;font-size:.92rem}
.half-row .notice{display:flex;align-items:center}
.contact-line{border:1px solid var(--line);border-radius:12px;padding:12px;background:#f4f6f8}
.contact-line b{display:block;color:var(--brand);margin-bottom:4px}
.notice{margin-top:14px;padding:12px;border-radius:12px;background:#f3f8ff;border:1px solid #d8e6fb;color:#27415f;font-size:.92rem}
form .grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{display:block;font-weight:600;font-size:.92rem;margin:0 0 6px;color:#334155}
input,textarea,select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:#fff;font:inherit}
textarea{min-height:130px;resize:vertical}
.field{margin-bottom:12px}
.checkbox{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:var(--muted)}
.checkbox input{width:auto;margin-top:3px}
.form-actions{display:flex;justify-content:flex-end}
.alert{padding:12px;border-radius:12px;margin-bottom:12px;font-size:.92rem}
.alert.success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}
.alert.error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}
.legal-page{padding:34px 20px 48px;min-height:calc(100svh - var(--header-h) - 90px)}
.legal-box{max-width:980px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;box-shadow:var(--shadow)}
.legal-box h1{font-size:2rem;margin:0 0 10px}
.legal-box h2{font-size:1.1rem;margin:22px 0 8px;color:var(--brand)}
.legal-box p,.legal-box li{color:#334155;line-height:1.65}
.site-footer{border-top:1px solid var(--line);background:#fff}
.footer-inner{max-width:1280px;margin:0 auto;padding:14px 20px;display:flex;gap:14px;justify-content:space-between;align-items:center;flex-wrap:wrap}
.footer-brand{font-size:.9rem;color:var(--muted)}
.footer-links{display:flex;gap:10px;flex-wrap:wrap}
.footer-links a{font-size:.9rem;color:var(--brand)}
.floating-actions{position:fixed;right:16px;bottom:16px;display:grid;gap:10px;z-index:999}
.fab{width:72px;min-height:72px;border-radius:18px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--brand)}
.fab span{font-size:1.25rem;line-height:1}
.fab small{font-size:.7rem;font-weight:700}
.fab:hover{transform:translateY(-1px)}
.sr-only{position:absolute;left:-9999px}

.about-style-section{background:#d9d9d9}
.about-template{max-width:1200px}
.about-template h2{margin:0 0 14px;font-size:clamp(1.5rem,2.5vw,2rem);line-height:1.2;color:#2b2f35;font-weight:800}
.about-template h3{margin:0 0 18px;font-size:clamp(1rem,1.8vw,1.35rem);line-height:1.3;color:#363b42;font-weight:700}
.about-template p{font-size:clamp(.92rem,1.2vw,1.06rem);line-height:1.62;color:#363b42;margin:0 0 14px}
.about-template ul{list-style:none;padding:0;margin:0 0 18px;display:grid;gap:12px}
.about-template li{font-size:clamp(.92rem,1.15vw,1.03rem);line-height:1.5;color:#363b42;padding-left:1.7rem;position:relative}
.about-template li::before{content:"✅";position:absolute;left:0;top:.05rem}
@media (max-width:1100px){
  .header-nav{display:none}
  .mobile-menu-btn{display:block}
  .mobile-menu[hidden]{display:none}
  .mobile-menu:not([hidden]){display:block}
  .hero-grid,.two-col,.info-card-layout,.contact-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:720px){
  .logo-img{height:58px}
  .lang-btn{padding:7px 9px}
  .header-inner{gap:8px}
  .logo-wrap{min-width:auto}
  .header-right{gap:8px}
  .section{padding:24px 14px}
  .hero-card,.hero-panel,.contact-card,.form-card,.legal-box{padding:16px}
  .btn-row{display:grid;grid-template-columns:1fr}
  form .grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .floating-actions{right:10px;bottom:10px;gap:8px}
  .fab{width:64px;min-height:64px;border-radius:14px}
  .fab small{font-size:.64rem}
}

@media (max-width:900px){.half-row{grid-template-columns:1fr}.matrix th,.matrix td{padding:7px 6px}.matrix{font-size:.84rem}.matrix td:first-child,.matrix th:first-child{width:36%}.matrix th{font-size:.78rem;line-height:1.15}.matrix .icon-cell{gap:8px}.matrix .icon-cell img{width:64px;height:64px;flex-basis:64px}.matrix .icon-cell span{font-size:.78rem;line-height:1.15}}
@media (max-width:600px){.table-wrap{padding:6px}.matrix{font-size:.72rem}.matrix th,.matrix td{padding:5px 3px}.matrix td:first-child,.matrix th:first-child{width:42%}.matrix th{font-size:.68rem;line-height:1.1}.matrix .icon-cell{gap:6px;align-items:center}.matrix .icon-cell img{width:52px;height:52px;flex-basis:52px}.matrix .icon-cell span{font-size:.64rem;line-height:1.08;word-break:normal;overflow-wrap:anywhere}}


/* v1.4 table rebuild */
.matrix-rebuild th,.matrix-rebuild td{font-size:.9rem}
.matrix-rebuild th:first-child,.matrix-rebuild td:first-child{width:160px;text-align:center}
.matrix-rebuild .icon-only{padding:10px 8px;text-align:center}
.matrix-rebuild .icon-only img{height:110px;width:auto;max-width:100%;object-fit:contain;background:transparent;border:0;border-radius:0;display:block;margin:0 auto}
@media (max-width:900px){
  .matrix-rebuild th{font-size:.76rem;line-height:1.15}
  .matrix-rebuild th:first-child,.matrix-rebuild td:first-child{width:120px}
  .matrix-rebuild .icon-only img{height:86px}
}
@media (max-width:600px){
  .matrix-rebuild th{font-size:.64rem}
  .matrix-rebuild th:first-child,.matrix-rebuild td:first-child{width:86px}
  .matrix-rebuild .icon-only img{height:58px}
  .matrix-rebuild th,.matrix-rebuild td{padding:4px 2px}
}


/* === Kontakt: Mini-Karten Styling (Override) === */
#kontakt .contact-line{
  background:#f4f6f8 !important;
  border-color:#e2e6ea !important;
}
#kontakt .notice{
  background:#fdecec !important;
  border:1px solid #f5c2c2 !important;
  color:var(--text) !important;
}

/* Unterlagen: Fußnote unter Wunschkennzeichen */
.feature-list .mini-note{
  margin-top:6px;
  font-size:8pt;
  font-style:italic;
  color:#8a8f98;
  line-height:1.25;
}

/* Service Landing Pages */
.service-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch}
.service-card,.service-media,.service-box,.service-cta{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}
.service-card{padding:24px}
.service-copy{margin:0;color:var(--muted);line-height:1.7}
.service-media{padding:12px;display:flex;align-items:center}
.service-media img{width:100%;height:auto;border-radius:12px;background:#eceff4}
.service-two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.service-box{padding:20px}
.service-list{margin:0;padding-left:18px;display:grid;gap:10px;color:#334155;line-height:1.55}
.service-steps{margin:0;padding-left:20px;display:grid;gap:10px;color:#334155;line-height:1.55}
.faq-wrap{display:grid;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.faq-item summary{cursor:pointer;font-weight:700;color:#10243a}
.faq-item p{margin:10px 0 2px;color:#475569;line-height:1.6}
.service-links-title{margin-top:24px}
.service-links{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.service-link{display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px;font-weight:600;color:#1e3a5f}
.service-link:hover{background:#eef3f8}
.service-cta{margin-top:24px;padding:20px}
.service-cta h3{margin:0 0 8px;color:var(--brand)}
.service-cta p{margin:0 0 14px;color:var(--muted);line-height:1.6}

@media (max-width:1100px){
  .service-grid,.service-two-col,.service-links{grid-template-columns:1fr}
}
