:root{
  --bg:#f4f8ff; --fg:#0f1a2d; --muted:#5a6f8f; --card:#f8fbff; --border:#d6e4ff; --accent:#1a4dff; --accent-2:#3b82f6;
  --shadow-1:0 1px 2px rgba(0,0,0,.06), 0 1px 1px rgba(0,0,0,.04);
  --shadow-2:0 10px 30px rgba(0,0,0,.10);
  --space-2:8px; --space-3:12px; --space-4:16px; --space-6:24px; --space-8:32px; --space-12:48px; --space-16:64px; --space-20:80px;
  --radius:14px; --radius-sm:10px; --header-h:64px; --header-offset:84px;
  --font-sans:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji;
  --fs-1:clamp(2.3rem, 4.2vw, 3.2rem); --fs-2:clamp(1.6rem, 2.6vw, 2.1rem); --fs-3:clamp(1.125rem, 2vw, 1.25rem); --fs-body:1rem;
  --container:1140px; --gutter:min(4vw, 24px);

  --ctrl-bg: color-mix(in oklab, var(--bg) 72%, transparent);
  --ctrl-fg: var(--fg);
  --ctrl-border: var(--border);
  --ctrl-bg-hover: color-mix(in oklab, var(--accent) 20%, var(--bg) 80%);
}

@font-face{
  font-family: 'Manrope Var';
  src: url('assets/fonts/Manrope[wght].woff2') format('woff2-variations');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* Erzwinge Manrope + Bold für den Hero-Titel */
.hero__title{
  font-family: 'Manrope Var', system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial, sans-serif;
  font-weight: 700;
  /* falls Browser mit VF zickt: Achse explizit setzen */
  font-variation-settings: 'wght' 700;
  /* Browser darf notfalls synthetisch fetten */
  font-synthesis-weight: auto;
}

#contactForm .check input[type="checkbox"] {
  width: 15px;
  height: 15px;
  flex-shrink: 0;
  accent-color: var(--accent);
  border-radius: 4px;
  cursor: pointer;
}

#contactForm .check span {
  font-size: 0.95rem;
  line-height: 1;
  user-select: none;
}

.hero__title {
  font-family: 'Manrope', var(--font-sans);
  font-weight: 700;
}

.hero__sub {
  font-size: clamp(1.05rem, 1.7vw, 1.25rem);
  font-weight: 400;
  color: var(--muted);
  max-width: 680px;
  margin-inline: auto;
}

*,*::before,*::after{box-sizing:border-box} html,body{scroll-padding-top:var(--header-offset)} 
body,h1,h2,h3,h4,p,figure,blockquote,dl,dd,ul{margin:0}
img,svg{display:block;max-width:100%} button,input,select,textarea{font:inherit}
:focus-visible{outline:2px solid currentColor;outline-offset:2px}
ul{padding-left:1.1rem}


.brand img {
  height: 2.75rem;
  width: auto;
  display: block;
}


.notice{
  background: #e6f0ff;          
  color: #1f3b6e;               
  padding: 0.75rem 0;
  border-top: 1px solid #c8dcff;
  border-bottom: 1px solid #c8dcff;
  margin-top: var(--space-8);           
}
.notice p{
  margin: 0;
  text-align: center;
  font-size: .95rem;
  font-weight: 600;
}


.hero{
  margin-bottom: 0;      
  padding-bottom: 1rem;  
}

:root {
  --faq-answer: #4f6487;   
}

:root[data-theme="dark"] {
  --faq-answer: #dce8ff; 
}


html,body{background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:var(--fs-body)}
html{overflow:hidden;height:100%}
/* Use the same page gradient as index on every subpage */
body:not(#index){
  --ink:#0f1a2d;
  --soft-ink:#5a6f8f;
  --paper:#eef4ff;
  --panel:#f8fbff;
  --line:color-mix(in oklab, #13233a 16%, #f8fbff);
  --brand:#1a4dff;
  --brand-strong:#0f3fb8;
  --highlight:#3b82f6;
  --bg:var(--paper);
  --fg:var(--ink);
  --muted:var(--soft-ink);
  --card:var(--panel);
  --border:var(--line);
  --accent:var(--brand);
  --shadow-1:0 6px 16px rgba(17,26,36,.08);
  --shadow-2:0 14px 34px rgba(17,26,36,.12);
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  background:linear-gradient(180deg, #f4f8ff 0%, #e9f0ff 100%);
  color:var(--fg);
}
body:not(#index) main{
  flex:1 0 auto;
}
:root[data-theme="dark"] body:not(#index){
  --ink:#eef4ff;
  --soft-ink:#a9bddc;
  --paper:#060f1f;
  --panel:#0b1730;
  --line:#22385d;
  --brand:#3f72ff;
  --brand-strong:#74a5ff;
  --highlight:#5ea0ff;
  --bg:var(--paper);
  --fg:var(--ink);
  --muted:var(--soft-ink);
  --card:var(--panel);
  --border:var(--line);
  --accent:var(--brand);
  --shadow-1:0 8px 20px rgba(0,0,0,.3);
  --shadow-2:0 18px 40px rgba(0,0,0,.46);
  background:linear-gradient(180deg, #050d1b 0%, #0a1730 100%);
}
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container.narrow{max-width:800px}
.section{padding-block:var(--space-16)}
.section__header{margin-bottom:var(--space-8)}
.section__header.center{text-align:center}
.section h2{font-size:var(--fs-2);line-height:1.2;margin-bottom:var(--space-2);letter-spacing:.2px}
h1{font-size:var(--fs-1);line-height:1.08;margin-bottom:var(--space-4);letter-spacing:.2px}
h3{font-size:1.25rem;margin-bottom:.4rem}
h4{font-size:1.06rem;margin-bottom:.3rem}
.text-muted,.muted{color:var(--muted)}
a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
hr.stroke-divider{height:2px;border:0;background:var(--border);opacity:1;margin-block:var(--space-12)}
hr.stroke-divider.tight{margin-block:var(--space-6)}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-1);padding:var(--space-8)}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1rem;border-radius:12px;border:1px solid var(--border);cursor:pointer;transition:transform .15s ease, box-shadow .15s ease, background .2s ease}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-ghost{background:transparent;color:var(--fg)}
.btn__spinner{display:none;width:1rem;height:1rem;border:2px solid currentColor;border-top-color:transparent;border-radius:999px;animation:spin .6s linear infinite;margin-left:.5rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus-visible{position:fixed;left:var(--gutter);top:var(--gutter);width:auto;height:auto;padding:.5rem .75rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:9999;overflow:visible}


.site-header{position:sticky;top:0;z-index:1000;background:color-mix(in oklab, var(--bg) 94%, transparent);backdrop-filter:saturate(1.2) blur(10px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);padding-block:var(--space-4);min-height:var(--header-h)}
.brand{display:flex;align-items:center;gap:.6rem;color:inherit;font-weight:800;letter-spacing:.2px}
.brand__text{white-space:nowrap}
.site-nav ul{display:flex;gap:var(--space-6);align-items:center;list-style:none;margin:0;padding:0}
.site-nav a{color:inherit;padding:.4rem .3rem;border-radius:8px}
.site-nav a:hover{text-decoration:none;background:color-mix(in oklab, var(--accent) 12%, transparent);color:#fff}
.theme-toggle{border-radius:999px;padding:.5rem;width:2.4rem;height:2.4rem;display:inline-grid;place-items:center}
.icon-theme{display:block}

/* Match index header look on all non-index pages without touching index itself */
body:not(#index) .site-header{
  border-bottom:0;
  background:linear-gradient(
    180deg,
    color-mix(in oklab, #f4f8ff 90%, transparent) 0%,
    color-mix(in oklab, #e9f0ff 90%, transparent) 100%
  );
  backdrop-filter:saturate(1.2) blur(14px);
  -webkit-backdrop-filter:saturate(1.2) blur(14px);
  box-shadow:0 1px 0 var(--border);
}
:root[data-theme="dark"] body:not(#index) .site-header{
  background:linear-gradient(
    180deg,
    color-mix(in oklab, #050d1b 90%, transparent) 0%,
    color-mix(in oklab, #0a1730 90%, transparent) 100%
  );
}
body:not(#index) .header-inner{min-height:66px;padding-block:.46rem}
body:not(#index) .brand{font-weight:800;letter-spacing:.02em}
body:not(#index) .brand__text{font-size:.96rem}
body:not(#index) .site-nav a{
  padding:.5rem .85rem;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:560;
  transition:all .2s ease;
}
body:not(#index) .site-nav a:hover{
  color:var(--fg);
  background:color-mix(in oklab, var(--accent) 12%, transparent);
  border-color:color-mix(in oklab, var(--accent) 28%, transparent);
}
body:not(#index) .site-footer{
  margin-top:auto;
  border-top:1px solid var(--border);
  background:linear-gradient(
    180deg,
    color-mix(in oklab, #f4f8ff 92%, transparent) 0%,
    color-mix(in oklab, #e9f0ff 92%, transparent) 100%
  );
}
:root[data-theme="dark"] body:not(#index) .site-footer{
  background:linear-gradient(
    180deg,
    color-mix(in oklab, #050d1b 92%, transparent) 0%,
    color-mix(in oklab, #0a1730 92%, transparent) 100%
  );
}


.hero--clean{background:linear-gradient(180deg, color-mix(in oklab, var(--accent) 10%, transparent), transparent)}
.hero__content{max-width:720px;margin-inline:auto;text-align:center}
.hero__title{margin-bottom:var(--space-4)}
.hero__sub{color:var(--muted);font-size:var(--fs-3);margin-bottom:var(--space-6)}
.hero__cta{display:flex;gap:var(--space-4);justify-content:center}


.grid{display:grid;gap:var(--space-6)}
.grid-3-2-1{grid-template-columns:repeat(3,1fr)}
@media (max-width:1200px){.grid-3-2-1{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid-3-2-1{grid-template-columns:1fr}}
.card__icon svg{width:32px;height:32px;margin-bottom:.5rem}
.list{margin-top:.6rem}



.gallery-slider{
  display: flex;
  align-items: center;
  gap: var(--gap);
  position: relative; 
}

.gallery-slider .slider-track{
  flex: 1 1 auto;
  padding: 0 var(--space-2) var(--space-2) var(--space-2) !important; 
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;           
  -ms-overflow-style: none;        
}
.gallery-slider .slider-track::-webkit-scrollbar{ display: none !important; } 


.slider-btn{
  position: static !important;
  transform: none !important;
  top: auto; left: auto; right: auto;
  flex: 0 0 auto;
  filter: none; 
}
.slider-btn.prev{ margin-right: var(--space-4); }
.slider-btn.next{ margin-left: var(--space-4); }


.gallery-slider.is-zoomed .slider-btn{ display: none !important; }

.gallery-slider{--gap:var(--space-4);position:relative}
.slider-track{display:flex;gap:var(--gap);overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;padding:0 48px var(--space-2) 48px}
.slider-track::-webkit-scrollbar{height:8px}
.slider-track::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}
.slide{flex:0 0 calc((100% - (var(--gap) * 3)) / 4);scroll-snap-align:start;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--card);box-shadow:var(--shadow-1);cursor:pointer}
.slide img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;transition:transform .2s ease}
.slide:hover img{transform:scale(1.03)}
.slider-btn{
  position:absolute; top:50%; transform:translateY(-50%);
  border-radius:999px; width:40px; height:40px; display:grid; place-items:center;
  background: var(--ctrl-bg);
  backdrop-filter: blur(6px);
  border:1px solid var(--ctrl-border);
  cursor:pointer; color: var(--ctrl-fg);
  transition: background .2s ease, color .2s ease, box-shadow .2s ease;
  filter: drop-shadow(0 2px 5px rgba(0,0,0,.35));
  z-index:3;
}
.slider-btn:hover{box-shadow:var(--shadow-2)}
.slider-btn.prev{left:6px}
.slider-btn.next{right:6px}
@media (max-width:1200px){.slide{flex-basis:calc((100% - (var(--gap) * 3)) / 4)}}
@media (max-width:900px){.slide{flex-basis:calc((100% - (var(--gap) * 2)) / 3)}}
@media (max-width:640px){.slide{flex-basis:calc((100% - (var(--gap) * 1)) / 2)}}
@media (max-width:420px){.slide{flex-basis:100%} .slider-track{padding-inline:36px}}


.form-grid{display:grid;gap:var(--space-6)}
.form-grid.calc-grid{grid-template-columns:repeat(3,1fr)}
.calc-form fieldset{grid-column:1 / -1;border:1px dashed var(--border);border-radius:var(--radius-sm);padding:var(--space-4)}
.opt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-top:.4rem}
@media (max-width:900px){.opt-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.opt-grid{grid-template-columns:1fr}}
.calc-result{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6);margin-top:var(--space-6);padding:var(--space-4);border:1px solid var(--border);border-radius:var(--radius-sm);background:color-mix(in oklab, var(--accent) 6%, transparent)}
.calc-result .total{font-size:1.25rem}
@media (max-width:900px){.form-grid.calc-grid{grid-template-columns:1fr 1fr} .calc-result{grid-template-columns:1fr;gap:var(--space-4)}}


label>span{display:block;margin-bottom:.45rem;font-weight:600}
label.full{grid-column:1/-1}
input,select,textarea{width:100%;border:1px solid var(--border);border-radius:12px;padding:.7rem .9rem;background:var(--bg);color:var(--fg)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:2px}
.check{display:flex;gap:.6rem;align-items:center}
.check input{width:1.1rem;height:1.1rem}
.form-actions{display:flex;gap:var(--space-4);justify-content:flex-end;margin-top:var(--space-6)}
.form-status{margin-top:var(--space-4)}

#contactForm .check.full {
  margin-bottom: 0; 
}

#contactForm .form-actions {
  margin-top: var(--space-3); 
}


input[type=range]{-webkit-appearance:none;appearance:none;height:6px;border-radius:999px;background:var(--border)}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.2)}
input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent);border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.2)}
output{display:inline-block;margin-top:.4rem;font-weight:600;color:var(--muted)}


.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);align-items:start}
@media (max-width:900px){.contact-wrap{grid-template-columns:1fr}}
.contact-list{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}


.section--bleed{padding-block:var(--space-12);margin-inline:calc(50% - 50vw)}
.map-embed{width:100%;max-width:100%;overflow:hidden}
.map-embed iframe{display:block;width:100%;height:460px;border:0}
.site-footer{
  margin-top:0;
  padding-block:clamp(2rem, 3.5vw, 3rem);
  border-top:1px solid var(--border);
  background:color-mix(in oklab, var(--bg) 90%, transparent);
}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1.2fr;gap:1.2rem;align-items:start}
@media (max-width:1000px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.footer-grid{grid-template-columns:1fr}}
.footer-logo{margin-top:.5rem;opacity:.85}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.site-footer h4{
  margin-bottom:.5rem;
  font-size:.72rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
}
.site-footer a{color:var(--fg);text-decoration:none}
.site-footer a:hover{text-decoration:underline}
.brand-col .tagline{margin-top:.42rem;color:var(--muted)}


@keyframes spin{to{transform:rotate(360deg)}}
.reveal{opacity:0;transform:translateY(12px);transition:opacity .5s ease, transform .5s ease}
.reveal.is-visible{opacity:1;transform:none}
.card{transition:box-shadow .2s ease, transform .2s ease}
.card:hover{box-shadow:var(--shadow-2);transform:translateY(-2px)}


:root[data-theme="dark"]{
  --bg:#050d1b; --fg:#eef4ff; --muted:#a9bddc; --card:#0b1730; --border:#22385d; --accent:#3f72ff; --accent-2:#74a5ff;
  --ctrl-bg: color-mix(in oklab, var(--bg) 46%, transparent);
  --ctrl-fg: #ffffff;
  --ctrl-border: #36507a;
  --ctrl-bg-hover: color-mix(in oklab, var(--accent) 34%, var(--bg) 66%);
}
:root[data-theme="dark"] .lightbox__backdrop{background:rgba(0,0,0,.75)}


.lightbox{position:fixed;inset:0;display:none;place-items:center;z-index:3000}
.lightbox[aria-hidden="false"]{display:grid}
.lightbox__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.lightbox__figure{position:relative;max-width:min(1100px,90vw);max-height:86vh;margin:0}
.lightbox__img{display:block;max-width:100%;max-height:80vh;border-radius:var(--radius)}
.lightbox__caption{margin-top:.5rem;color:#fff;text-align:center}
.lightbox__close{position:absolute;top:.5rem;right:.5rem;background:#00000080;color:#fff;border-color:transparent}


.fab{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:.6rem;z-index:1200}
.fab__btn{display:inline-flex;align-items:center;justify-content:center;min-width:120px;padding:.65rem .9rem;border-radius:999px;border:1px solid var(--ctrl-border);background:var(--ctrl-bg);backdrop-filter:blur(6px);text-decoration:none;color:var(--fg);box-shadow:var(--shadow-1)}
.fab__btn:hover{box-shadow:var(--shadow-2);background:var(--ctrl-bg-hover);color:#fff}


#leistungen.section,#bilder.section,#rechner.section,#kontakt.section{padding-top:var(--space-6)}


.site-footer a[href^="mailto:"],
.site-footer a.js-protected-email,
.contact-list a[href^="mailto:"],
.contact-list a.js-protected-email,
.footer-inner a[href^="mailto:"]{
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
  hyphens: manual;
}

body{
  overflow-x:hidden;
  overflow-y:auto;
  height:100%;
}


.fab__btn{
  min-width: 48px;
  width: 48px;
  height: 48px;
  padding: 0;
  border-radius: 999px;
}
.fab__btn svg{ width: 22px; height: 22px; }


.contact-list li{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:baseline;
  column-gap:.4rem;
}
.contact-list li > a[href^="mailto:"],
.contact-list li > a.js-protected-email,
.contact-list li > a[href^="tel:"]{
  white-space: nowrap;
  overflow: visible;
  text-overflow: unset;
  min-width: 0;
}



.icon-theme{display:inline-block; line-height:1; font-size:1rem}
.icon-sun{display:none}
:root[data-theme="dark"] .icon-moon{display:none}
:root[data-theme="dark"] .icon-sun{display:inline-block; color:#fff}


.contact-wrap{align-items:stretch}
.contact-wrap > .card, .contact-wrap > .contact-info{height:100%; display:flex; flex-direction:column}
.contact-form .form-actions{margin-top:auto}


.form-note{display:block; margin-top:.3rem; color:var(--muted); font-size:.9em}



.theme-toggle{display:inline-grid;place-items:center}
.icon-theme{display:inline-grid;place-items:center;line-height:1}
.icon-theme .ico{display:block;width:18px;height:18px}
.icon-sun{display:none}
:root[data-theme="dark"] .icon-moon{display:none}
:root[data-theme="dark"] .icon-sun{display:inline-grid}



hr.stroke-divider{margin: var(--space-8) 0 var(--space-3) !important;}
hr.stroke-divider.tight{margin: var(--space-6) 0 var(--space-2) !important;}

.section__header{margin-bottom:var(--space-6) !important;}


.contact-box, .contact-box * {
  text-align: center !important;
}


.contact-info{ text-align:center; }
.contact-info h3, .contact-info p{ text-align:inherit; }
.contact-info .contact-list{ justify-items:center; }

.contact-info {
  display: flex;
  flex-direction: column;
  justify-content: center; 
  align-items: center;     
  text-align: center;
}

.contact-info .contact-list {
  margin-top: 1rem;         
}

.contact-info .contact-list {
  display: inline-block; 
  text-align: left;      
}

.contact-info .contact-list li {
  display: block; 
  margin: 4px 0;
}

.contact-info .contact-list li:last-child {
  margin-top: 12px;  
  margin-bottom: 8px; 
}


.slider-track{scroll-behavior: auto;} 
.slider-btn{width:44px;height:44px}
.slider-btn svg{width:22px;height:22px}


.lightbox__nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:46px; height:46px; display:grid; place-items:center;
  border-radius:999px; border:1px solid var(--ctrl-border);
  background: var(--ctrl-bg); backdrop-filter: blur(6px);
  color: var(--ctrl-fg); box-shadow: var(--shadow-1);
  cursor:pointer; transition: background .2s ease, box-shadow .2s ease;
}
.lightbox__nav:hover{background: var(--ctrl-bg-hover); box-shadow: var(--shadow-2); color:#fff}
.lightbox__prev{left:-58px}
.lightbox__next{right:-58px}
@media (max-width: 900px){
  .lightbox__prev{left:6px}
  .lightbox__next{right:6px}
}


.slide img{aspect-ratio: 16/10;}

#lightbox[aria-hidden="false"] .slider-btn,
#lightbox[aria-hidden="false"] ~ .slider-btn,
#lightbox[aria-hidden="false"] ~ .gallery .slider-btn {
  display: none !important;
}



  flex: 0 0 calc((100% - (var(--gap) * 2)) / 3) !important;
}
@media (max-width:900px){
  .gallery-slider .slide{
    
    flex-basis: calc((100% - (var(--gap) * 1)) / 2) !important;
  }
}
@media (max-width:640px){
  .gallery-slider .slide{
    
    flex-basis: 100% !important;
  }
}


.gallery-slider{ --gap: var(--space-6); }




.gallery-slider .slide{
  flex: 0 0 calc((100% - var(--gap)) / 2) !important;
}
@media (max-width:900px){
  .gallery-slider .slide{
    flex-basis: calc((100% - var(--gap)) / 2) !important;
  }
}
@media (max-width:640px){
  .gallery-slider .slide{
    flex-basis: 100% !important;
  }
}
.gallery-slider{ --gap: var(--space-6); }


.content {
  max-width: 65ch;
  line-height: 1.6;
}

.content h2 {
  font-size: 1.4rem;
  margin-top: 2.2rem;
  margin-bottom: 0.8rem;
  padding-bottom: 0.3rem;
  border-bottom: 2px solid var(--accent, #13233a);
}

.content p {
  margin-bottom: 1rem;
}

.content ul {
  margin: 0 0 1.2rem 1.5rem;
  padding: 0;
}

.content li {
  margin-bottom: 0.4rem;
}

.content hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 2rem 0;
}


.header-socials {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-right: 6px; 
}
.header-socials .social-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 999px;
  border: 1px solid var(--ctrl-border, var(--border));
  background: var(--ctrl-bg, color-mix(in oklab, var(--bg) 72%, transparent));
  color: var(--ctrl-fg, var(--fg));
  text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease, color .2s ease;
  backdrop-filter: blur(6px);
}
.header-socials .social-btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-2);
  background: var(--ctrl-bg-hover, color-mix(in oklab, var(--accent) 20%, var(--bg) 80%));
  color: #fff;
}
.header-socials .social-btn svg { display:block; }
@media (max-width: 420px){
  .header-socials { gap: 8px; }
}


.contact-form.card{ padding-bottom: calc(var(--space-8) - 60px); }
.contact-form .form-actions{ margin-top: calc(var(--space-6) + 60px); }


button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}


:root[data-theme="dark"] .brand img,
:root[data-theme="dark"] img[alt="FGS Gebäudeservice Logo"]{
  
  filter: brightness(0) invert(1);
}


body#index main > section.section {
  padding-top: var(--space-5) !important;
  padding-bottom: var(--space-5) !important;
}

body#index hr.stroke-divider,
body#index hr.stroke-divider.tight {
  margin-block: var(--space-8) !important;
}

body#index .section__header {
  margin-bottom: var(--space-6) !important;
}



body#index .hero.hero--clean {
  
  padding-top: calc(var(--header-offset) + var(--space-2)) !important;
}


body#index .hero {
  padding-bottom: var(--space-6) !important;
}


body#index .notice {
  margin-top: var(--space-8) !important;
}

.faq-item {
  min-height: 120px;     
}


.faq-item summary {
  display: grid;
  grid-template-columns: 24px 1fr; 
  align-items: center;
  gap: 12px;
  min-height: 96px;      
  cursor: pointer;
}


.faq-item .faq-q {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}


.faq-item[open] {
  min-height: auto;      
}


.cta-banner{
  position: relative;
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: var(--space-8);
  padding: clamp(18px, 2.8vw, 28px);
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 2px);
  background:
    radial-gradient(1200px 1200px at 110% -10%, color-mix(in oklab, var(--accent) 16%, transparent) 0%, transparent 45%),
    linear-gradient(180deg, color-mix(in oklab, var(--accent) 6%, transparent), transparent);
  box-shadow: var(--shadow-1);
  overflow: hidden;
}

.cta-title{ font-size: clamp(1.6rem, 2.4vw, 2rem); line-height: 1.2; letter-spacing: .2px; margin-bottom: .2rem; }
.cta-sub{ color: var(--muted); margin-bottom: var(--space-4); }

.cta-steps{
  display: flex; flex-wrap: wrap; gap: .6rem;
  margin: 0 0 var(--space-4) 0; padding: 0; list-style: none;
}
.cta-steps .step{
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .5rem .75rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: color-mix(in oklab, var(--bg) 80%, transparent);
  font-weight: 600; font-size: .98rem;
}
.cta-steps .num{
  width: 24px; height: 24px; display: grid; place-items: center;
  border-radius: 999px;
  background: var(--accent);
  color: #fff; font-weight: 800; font-size: .9rem;
}

.cta-actions{ display:flex; align-items:center; gap: .9rem; flex-wrap: wrap; }
.cta-btn{
  position: relative;
  padding-right: 1rem;
  overflow: hidden;
}
.cta-btn .cta-arrow{
  width: 20px; height: 20px;
  margin-left: .25rem;
  transform: translateX(0);
  transition: transform .25s ease;
}
.cta-btn:hover .cta-arrow{ transform: translateX(4px); }

.cta-note{ color: var(--muted); font-size: .95rem; }

.cta-perks{
  align-self: center;
  display: grid; gap: .6rem;
}
.cta-perks .perk{
  display: grid; grid-template-columns: 24px 1fr; align-items: center; gap: .6rem;
  padding: .55rem .7rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: color-mix(in oklab, var(--bg) 86%, transparent);
  font-weight: 600;
}
.cta-perks .perk svg{ width: 20px; height: 20px; }


.cta-btn::after{
  content:""; position:absolute; inset:0;
  border-radius: inherit;
  box-shadow: 0 0 0 0 color-mix(in oklab, var(--accent) 35%, transparent);
  opacity: .0; pointer-events: none;
}
@keyframes ring {
  0% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--accent) 35%, transparent); opacity:.6; }
  100%{ box-shadow: 0 0 0 14px transparent; opacity: 0; }
}
.cta-btn.is-attention::after{ animation: ring 1.8s ease-out infinite; }

.cta-blob{
  position:absolute; right:-120px; bottom:-120px; width: 260px; height: 260px;
  border-radius: 50%;
  filter: blur(28px);
  background: radial-gradient(circle at 30% 30%, color-mix(in oklab, var(--accent) 40%, transparent), transparent 60%);
  animation: floaty 8s ease-in-out infinite;
  opacity: .6;
}
@keyframes floaty{
  0%{ transform: translateY(0) scale(1); }
  50%{ transform: translateY(-10px) scale(1.03); }
  100%{ transform: translateY(0) scale(1); }
}


@media (prefers-reduced-motion: reduce){
  .cta-btn .cta-arrow,
  .cta-btn.is-attention::after,
  .cta-blob{ animation: none; transition: none; }
}


@media (max-width: 900px){
  .cta-banner{ grid-template-columns: 1fr; }
  .cta-perks{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px){
  .cta-perks{ grid-template-columns: 1fr; }
  .cta-actions{ flex-direction: column; align-items: flex-start; }
}


:root[data-theme="dark"] .cta-banner{
  background:
    radial-gradient(900px 900px at 110% -10%, color-mix(in oklab, var(--accent) 20%, transparent) 0%, transparent 45%),
    linear-gradient(180deg, color-mix(in oklab, var(--accent) 10%, transparent), transparent);
}
:root[data-theme="dark"] .cta-steps .step{ background: color-mix(in oklab, var(--bg) 70%, transparent); }
:root[data-theme="dark"] .cta-perks .perk{ background: color-mix(in oklab, var(--bg) 70%, transparent); }


.cta-banner{ position: relative; overflow: hidden; }
.cta-banner::before{
  content:"";
  position:absolute; inset:-20%;
  background: linear-gradient(120deg, transparent 45%, rgba(255,255,255,.18) 50%, transparent 55%);
  transform: translateX(-120%) rotate(0.001deg);
  pointer-events: none;
}
@keyframes ctaShimmer{ to { transform: translateX(120%); } }

@media (min-width: 901px) and (prefers-reduced-motion: no-preference){
  .cta-banner.is-animated::before{
    animation: ctaShimmer 4.8s ease-in-out infinite;
  }
}
@media (prefers-reduced-motion: reduce){
  .cta-banner::before{ animation: none !important; }
}


body#angebot main > section.section{
  padding-top: var(--space-6) !important;
  padding-bottom: var(--space-6) !important;
}
body#angebot hr.stroke-divider,
body#angebot hr.stroke-divider.tight{
  margin-block: var(--space-8) !important;
}
body#angebot .section__header{
  margin-bottom: var(--space-6) !important;
}


.process-grid{
  counter-reset: step;
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1200px){
  .process-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px){
  .process-grid{ grid-template-columns: 1fr; }
}
.process-item{
  list-style: none;
  position: relative;
  padding: var(--space-6) var(--space-6) var(--space-6) calc(var(--space-6) + 48px);
  border-radius: var(--radius);
  transition: transform .2s ease, box-shadow .2s ease;
}
.process-item::before{
  content: counter(step);
  counter-increment: step;
  position: absolute;
  left: 16px; top: 16px;
  width: 34px; height: 34px;
  border-radius: 999px;
  display: grid; place-items: center;
  font-weight: 800;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--fg);
}
.process-item h3{ margin-bottom: .35rem; }
.process-item p{ color: var(--muted); }
.process-item:hover{ transform: translateY(-2px); box-shadow: var(--shadow-2); }
.process-cta.center{ text-align: center; }

#angebot-cta {
  scroll-margin-top: 150px; 
}


.menu-toggle{ display:none; }
@media (max-width:640px){
  .site-nav{ display:none; }               
  .menu-toggle{ display:inline-grid; }     
  .header-socials{ display:none !important; } 
}

.mobile-menu[hidden]{ display:none !important; }
@media (max-width:640px){
  .mobile-menu{
    display:block;
    position:relative;
    z-index:999;
    background: var(--card);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    box-shadow: var(--shadow-1);
  }

.mobile-menu{
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition: opacity .24s ease, transform .24s ease;
}
.mobile-menu.is-open{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

  .mobile-menu ul{
    list-style:none; margin:0; padding:.25rem var(--gutter, 16px);
    display:flex; flex-direction:column; gap:.35rem;
  }
  .mobile-menu a{
    display:block; padding:.7rem .8rem; border-radius:8px; color:inherit; text-decoration:none;
  }
  .mobile-menu a:hover{ background: color-mix(in oklab, var(--accent) 12%, transparent); color:#fff; text-decoration:none; }
  .mobile-menu .menu-sep hr{ border:0; height:1px; background: var(--border); margin:.25rem 0; opacity:.9; }
}



.menu-toggle .hamburger rect{ fill: currentColor; }
.menu-toggle{ color: var(--text, #0f1a2d); background:none; border:0; cursor:pointer; }
:root[data-theme='dark'] .menu-toggle{ color:#fff; }


.mobile-menu .theme-toggle{ text-align:center; padding:.8rem; cursor:pointer; }



.menu-toggle{ display:none; color:var(--fg); background:transparent; border:0; padding:10px; border-radius: var(--radius-sm); }
.menu-toggle:focus{ outline:2px solid var(--border); outline-offset:2px; }
.menu-toggle .hamburger rect{ fill: currentColor; }

@media (max-width:820px){
  .site-nav{ display:none; }
  .menu-toggle{ display:inline-grid; }
  .header-socials{ display:none !important; }  
  .theme-toggle{ display:none !important; }   
}


.mobile-menu[hidden]{ display:none !important; }
@media (max-width:820px){
  .mobile-menu{
    display:block; position:relative; z-index:999;
    background: var(--card);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    box-shadow: var(--shadow-1);
  }
  .mobile-menu ul{ list-style:none; margin:0; padding:.25rem var(--gutter, 16px); display:flex; flex-direction:column; gap:.35rem; }
  .mobile-menu a, .mobile-menu button{
    display:block; width:100%; text-align:left;
    padding:.7rem .8rem; border-radius:8px; color:inherit; text-decoration:none; background:transparent; border:0; font: inherit; cursor:pointer;
  }
  .mobile-menu a:hover, .mobile-menu button:hover{ background: color-mix(in oklab, var(--accent) 12%, transparent); color:#fff; }
  .mobile-menu .menu-sep hr{ border:0; height:1px; background: var(--border); margin:.25rem 0; opacity:.9; }
}



body.noscroll{ overflow:hidden; }


body#angebot .hero.hero--clean {
  padding-top: calc(var(--header-offset) + var(--space-2)) !important;
}




.form-hint{
  display:block;
  max-width: var(--container);
  margin: 0 auto var(--space-6);
  padding: .9rem 1rem;
  border-radius: var(--radius-sm);
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  color: var(--fg);
}
.form-hint.ok{
  background: #eaf2ff;
  border-color: #bfd5ff;
  color: #1b3f82;
}
.form-hint.err{
  background: #dce9ff;
  border-color: #99b8ff;
  color: #1a3570;
}


input.invalid, textarea.invalid, select.invalid{
  border-color:#2f63ff !important;
  box-shadow: 0 0 0 3px rgba(47,99,255,.18);
}
label.check.error{
  outline: 2px solid #2f63ff;
  outline-offset: 2px;
  border-radius: 10px;
}

/* Map consent overlay */
/* --- Map blurred preview --- */
.map-embed{ position: relative; }
.map-embed .map-blur{
  display:block;
  width:100%;
  height:460px;
  object-fit:cover;
  filter: blur(2px) saturate(0.9);
  transform: scale(1.02);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}
:root[data-theme="dark"] .map-embed .map-blur{ filter: blur(2px) saturate(0.9) brightness(0.9); }

/* Place consent box on top of the image */
.map-embed .map-consent{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background: linear-gradient(180deg, color-mix(in oklab, var(--bg) 10%, transparent), transparent);
  border:0; /* we already have the image; the dashed border is not needed here */
  padding: var(--space-6);
}

.map-embed{position:relative}
.map-consent{position:relative; display:flex; align-items:center; justify-content:center; min-height:420px; background:linear-gradient(180deg, color-mix(in oklab, var(--accent) 8%, transparent), transparent); border:1px dashed var(--border); border-radius: var(--radius); padding: var(--space-8);}
.map-consent__inner{max-width:720px; text-align:center; background: var(--card); border:1px solid var(--border); border-radius: var(--radius); padding: var(--space-6); box-shadow: var(--shadow-1);}
.map-consent__title{margin:0 0 .35rem 0; font-size: 1.2rem;}
.map-consent__text{color: var(--muted); margin-bottom: var(--space-4);}
.map-consent__buttons{display:flex; flex-wrap:wrap; gap: .6rem; justify-content:center; margin-bottom: .6rem;}
.map-consent__hint{display:block; color: var(--muted);}
@media (max-width:640px){
  .map-consent{min-height:300px; padding: var(--space-4);}
  .map-consent__inner{padding: var(--space-4);}
  .map-consent__buttons .btn{flex:1 1 auto; min-width: 180px;}
}
:root[data-theme="dark"] .map-consent{background:linear-gradient(180deg, color-mix(in oklab, var(--accent) 14%, transparent), transparent);}


/* Utility: hidden */
.is-hidden{display:none !important;}

/* Floating 'Nicht mehr automatisch laden' button (only when map is rendered) */
.map-never-btn{
  position:absolute;
  inset: 12px 12px auto auto;
  z-index: 3;
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font: inherit;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--card) 85%, transparent);
  backdrop-filter: blur(6px);
  padding: .45rem .7rem;
  border-radius: var(--radius);
  cursor:pointer;
  box-shadow: var(--shadow-1);
}
.map-never-btn:hover{filter: brightness(0.98);}
:root[data-theme="dark"] .map-never-btn{background: color-mix(in oklab, var(--panel) 72%, transparent);}

/* Make sure map container can anchor the button */
.map-embed{position:relative;}
@media (max-width:640px){
  .map-never-btn{inset: 8px 8px auto auto; padding:.4rem .6rem;}
}

body.lb-open{overflow:hidden}


/* === Desktop: Lock page scroll when lightbox is open (no wheel scroll on images) === */
@media (hover: hover) and (pointer: fine){
  body.lb-open { overflow: hidden; }
}

/* === Mobile: make gallery previews larger === */
@media (max-width: 640px){
  /* reduce side padding so images can grow */
  .slider-track{ padding-inline: 16px !important; }
  .gallery-slider{ --gap: var(--space-4); }
  .gallery-slider .slide{
    flex-basis: 100% !important;
    max-width: 100%;
  }
  .slide img{
    aspect-ratio: 4 / 3; /* a bit taller than 16/10 to look larger on phones */
    height: auto;
  }
}

/* Optional debug switch: disable motion only when explicitly enabled */
html[data-disable-motion="true"]{
  scroll-behavior:auto !important;
}
html[data-disable-motion="true"] *,
html[data-disable-motion="true"] *::before,
html[data-disable-motion="true"] *::after{
  animation:none !important;
  transition:none !important;
}
html[data-disable-motion="true"] .reveal,
html[data-disable-motion="true"] .hero-enter,
html[data-disable-motion="true"] .reveal-stagger > *{
  opacity:1 !important;
  transform:none !important;
}