/* ═══════════════════════════════════════════
   AlpenGlanz Service & Solutions — v5.0
   Professionelle Gebäudereinigung Rosenheim
   ═══════════════════════════════════════════ */

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#0B1929;--navy-mid:#122236;--navy-light:#1A3350;
  --silver:#A8B8C8;--cream:#F8F6F2;--white:#FFFFFF;
  --ink:#1A1A1A;--ink-soft:#555;--border:rgba(11,25,41,0.09);--gold:#C4A96A;
  --whatsapp:#25D366;--whatsapp-dark:#128C7E;
}
html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;background:var(--cream);color:var(--ink);line-height:1.6}

/* ── WHATSAPP FLOATING BUTTON ── */
.whatsapp-float{
  position:fixed;
  bottom:2rem;
  right:2rem;
  z-index:999;
  width:60px;
  height:60px;
  background:var(--whatsapp);
  color:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:2rem;
  text-decoration:none;
  box-shadow:0 4px 20px rgba(37,211,102,0.4);
  transition:transform .3s,box-shadow .3s;
  animation:whatsappPulse 2s ease-in-out infinite;
}
.whatsapp-float:hover{
  transform:scale(1.1);
  box-shadow:0 6px 30px rgba(37,211,102,0.6);
}
@keyframes whatsappPulse{
  0%,100%{box-shadow:0 4px 20px rgba(37,211,102,0.4)}
  50%{box-shadow:0 4px 30px rgba(37,211,102,0.7)}
}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 3rem;height:72px;background:rgba(11,25,41,0.97);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,0.07)}
.nav-logo img{height:46px;width:auto}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{font-size:0.72rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--silver);text-decoration:none;transition:color 0.2s}
.nav-links a:hover{color:#fff}
.nav-links a.active{color:var(--gold)}
.nav-cta{background:var(--gold)!important;color:var(--navy)!important;padding:0.5rem 1.3rem;border-radius:2px;font-weight:700!important}
.nav-phone{font-size:0.75rem;color:#D4DDE6;white-space:nowrap}
.nav-phone a{color:inherit;text-decoration:none}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.hamburger span{display:block;width:24px;height:2px;background:var(--silver);border-radius:2px}

/* ── HERO ── */
.hero{min-height:100vh;background:linear-gradient(140deg,#06101A 0%,#0D2039 50%,#112850 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:9rem 2rem 6rem;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 25% 75%,rgba(196,169,106,0.1) 0%,transparent 55%),radial-gradient(ellipse at 75% 25%,rgba(168,184,200,0.07) 0%,transparent 55%);pointer-events:none}
.hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
.hero-logo{width:min(340px,62vw);margin-bottom:2.8rem;animation:fadeUp 1s ease both;filter:drop-shadow(0 4px 24px rgba(0,0,0,0.4))}
.hero h1{font-family:'Lora',serif;font-size:clamp(1.5rem,3.8vw,2.6rem);font-weight:400;font-style:italic;color:rgba(255,255,255,0.92);margin-bottom:1rem;animation:fadeUp 1s 0.15s ease both;max-width:640px;line-height:1.35}
.hero-sub{font-size:0.82rem;color:var(--silver);letter-spacing:0.08em;margin-bottom:2.5rem;animation:fadeUp 1s 0.25s ease both}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;animation:fadeUp 1s 0.35s ease both}
.btn-p{background:var(--gold);color:var(--navy);padding:0.9rem 2.2rem;font-size:0.78rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;text-decoration:none;border-radius:2px;transition:opacity .2s,transform .2s;display:inline-block}
.btn-p:hover{opacity:.88;transform:translateY(-2px)}
.btn-o{border:1px solid rgba(255,255,255,0.28);color:rgba(255,255,255,0.85);padding:0.9rem 2.2rem;font-size:0.78rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;text-decoration:none;border-radius:2px;transition:border-color .2s,color .2s;display:inline-block}
.btn-o:hover{border-color:rgba(255,255,255,0.65);color:#fff}
.btn-w{background:var(--whatsapp);color:#fff;padding:0.9rem 2.2rem;font-size:0.78rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;text-decoration:none;border-radius:2px;transition:opacity .2s,transform .2s;display:inline-flex;align-items:center;gap:0.5rem}
.btn-w:hover{opacity:.88;transform:translateY(-2px)}
.hero-stats{display:flex;gap:3rem;margin-top:4rem;padding-top:2.5rem;border-top:1px solid rgba(255,255,255,0.1);animation:fadeUp 1s 0.45s ease both;flex-wrap:wrap;justify-content:center}
.sn{display:block;font-size:1.65rem;font-weight:700;color:var(--gold);font-family:'Lora',serif}
.sl{font-size:0.62rem;color:var(--silver);letter-spacing:0.08em;text-transform:uppercase}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* ── SHARED ── */
section{padding:5rem 2rem}
.inner{max-width:1160px;margin:0 auto}
.sec-label{font-size:0.63rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--gold);margin-bottom:0.7rem;display:flex;align-items:center;gap:0.7rem}
.sec-label::before{content:'';display:block;width:26px;height:1px;background:var(--gold)}
h2{font-family:'Lora',serif;font-size:clamp(1.7rem,3vw,2.4rem);font-weight:600;color:var(--navy);line-height:1.25;margin-bottom:0.85rem}
.sec-intro{font-size:0.93rem;color:var(--ink-soft);max-width:560px;line-height:1.85}

/* ── SERVICES ── */
.services{background:var(--white)}
.services-header{margin-bottom:3rem}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}

/* Minimal premium card */
.scard{background:var(--white);border:1px solid var(--border);border-radius:3px;overflow:hidden;transition:box-shadow .3s,transform .3s;display:flex;flex-direction:column}
.scard:hover{box-shadow:0 12px 40px rgba(11,25,41,0.11);transform:translateY(-4px)}
.scard-img{height:190px;overflow:hidden;position:relative}
.scard-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}
.scard:hover .scard-img img{transform:scale(1.06)}
.scard-body{padding:1.35rem 1.4rem 1.7rem;flex:1;display:flex;flex-direction:column;border-top:2px solid var(--gold)}
.scard h3{font-family:'Lora',serif;font-size:1.05rem;font-weight:600;color:var(--navy);margin-bottom:0.5rem;line-height:1.3}
.scard p{font-size:0.8rem;color:var(--ink-soft);line-height:1.75;margin-bottom:0.85rem}
.scard-list{list-style:none;display:flex;flex-direction:column;gap:0.26rem;margin-top:auto}
.scard-list li{font-size:0.74rem;color:var(--ink-soft);display:flex;align-items:baseline;gap:0.4rem}
.scard-list li::before{content:'—';color:var(--gold);font-size:0.58rem;flex-shrink:0}

/* ── WHY ── */
.why{background:var(--navy);position:relative;overflow:hidden}
.why::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(196,169,106,0.08) 0%,transparent 60%)}
.why .sec-label{color:var(--gold)}
.why h2{color:var(--white)}
.why .sec-intro{color:var(--silver)}
.why-top{margin-bottom:3rem;position:relative}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;position:relative}
.witem{padding-top:1.4rem;border-top:1px solid rgba(196,169,106,0.28)}
.witem-num{font-size:0.62rem;color:var(--gold);letter-spacing:0.12em;margin-bottom:0.55rem;font-weight:700}
.witem h4{font-family:'Lora',serif;font-size:1rem;color:#fff;margin-bottom:0.45rem}
.witem p{font-size:0.8rem;color:var(--silver);line-height:1.78}

/* ── PROCESS ── */
.process{background:var(--cream)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:3rem}
.pn{font-family:'Lora',serif;font-size:3.2rem;font-weight:600;color:rgba(11,25,41,0.07);line-height:1;margin-bottom:-0.5rem}
.process-grid h4{font-size:0.88rem;font-weight:700;color:var(--navy);margin-bottom:0.45rem}
.process-grid p{font-size:0.8rem;color:var(--ink-soft);line-height:1.72}

/* ── FAQ ── */
.faq{background:var(--white)}
.faq-header{margin-bottom:3rem}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.faq-item{border:1px solid var(--border);border-radius:3px;overflow:hidden;transition:box-shadow .2s}
.faq-item:hover{box-shadow:0 4px 18px rgba(11,25,41,0.07)}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:1.15rem 1.4rem;display:flex;justify-content:space-between;align-items:center;cursor:pointer;gap:1rem;font-family:'Montserrat',sans-serif}
.faq-q-text{font-size:0.87rem;font-weight:600;color:var(--navy);line-height:1.4}
.faq-icon{width:22px;height:22px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;transition:background .2s,transform .3s;line-height:1}
.faq-item.open .faq-icon{background:var(--gold);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a-inner{padding:0 1.4rem 1.2rem;font-size:0.82rem;color:var(--ink-soft);line-height:1.8;border-top:1px solid var(--border);padding-top:0.85rem}
.faq-item.open .faq-a{max-height:300px}

/* ── AREA ── */
.area-sec{background:var(--cream)}
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.area-tags{display:flex;flex-wrap:wrap;gap:0.45rem;margin-top:1.4rem}
.tag{padding:0.38rem 0.95rem;font-size:0.73rem;font-weight:500;border:1px solid var(--border);color:var(--ink-soft);border-radius:1px}
.tag.main{background:var(--navy);color:#fff;border-color:var(--navy)}
.area-card{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);border-radius:4px;padding:2.5rem 2.2rem;color:#fff;position:relative;overflow:hidden}
.area-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(196,169,106,0.13) 0%,transparent 60%)}
.av-title{font-family:'Lora',serif;font-size:1.3rem;font-weight:400;font-style:italic;color:var(--gold);margin-bottom:1.5rem;position:relative}
.ci{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.1rem;position:relative}
.ci-icon{font-size:1rem;flex-shrink:0;margin-top:2px}
.ci-label{font-size:0.6rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--silver);margin-bottom:0.15rem}
.ci-val{font-size:0.88rem;color:#fff;text-decoration:none;display:block;transition:color .2s}
.ci-val:hover{color:var(--gold)}
.ci-val.sm{font-size:0.8rem;line-height:1.6}

/* ── CONTACT ── */
.contact-sec{background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.cinfo-list{margin-top:1.8rem;display:flex;flex-direction:column;gap:1.1rem}
.cinfo-item{display:flex;gap:0.9rem;align-items:flex-start}
.cinfo-icon{font-size:1.1rem;flex-shrink:0}
.cinfo-lbl{font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:0.12rem}
.cinfo-val{font-size:0.9rem;color:var(--navy);font-weight:600;text-decoration:none;display:block}
.cinfo-val:hover{color:var(--gold)}
.fg{margin-bottom:1rem}
.fg label{display:block;font-size:0.68rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:0.4rem}
.fg input,.fg textarea,.fg select{width:100%;padding:0.78rem 0.95rem;border:1px solid #CDD6DF;background:var(--cream);font-family:'Montserrat',sans-serif;font-size:0.86rem;color:var(--ink);outline:none;border-radius:2px;transition:border-color .2s;-webkit-appearance:none;appearance:none}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--navy);background:#fff}
.fg textarea{height:110px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.sbtn{width:100%;background:var(--navy);color:#fff;padding:1rem;border:none;cursor:pointer;font-family:'Montserrat',sans-serif;font-size:0.76rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;border-radius:2px;transition:background .2s}
.sbtn:hover{background:var(--navy-light)}
.form-note{font-size:0.68rem;color:var(--ink-soft);margin-top:0.65rem}
.form-ok{display:none;background:#eaf7ee;border:1px solid #7dcf97;color:#2d7a4a;padding:1rem;border-radius:2px;font-size:0.84rem;margin-top:1rem;text-align:center}
.checklist{margin-top:1.8rem;font-size:0.83rem;color:var(--ink-soft);line-height:2.2}

/* ── FOOTER ── */
footer{background:var(--navy);padding:3.5rem 2rem 2rem;border-top:1px solid rgba(255,255,255,0.06)}
.footer-inner{max-width:1160px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem}
.footer-logo{height:54px;width:auto;display:block;margin-bottom:0.8rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,0.3))}
.footer-tag{font-size:0.8rem;color:var(--silver);line-height:1.8;max-width:255px}
.footer-col h5{font-size:0.62rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);margin-bottom:0.9rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:0.45rem}
.footer-col li{font-size:0.8rem;color:var(--silver)}
.footer-col a{color:var(--silver);text-decoration:none;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{padding-top:1.5rem;border-top:1px solid rgba(255,255,255,0.07);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:0.7rem;color:rgba(168,184,200,0.5)}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{font-size:0.7rem;color:rgba(168,184,200,0.5);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:#fff}

/* ── LEGAL PAGES (Impressum / Datenschutz) ── */
.legal-page{padding:8rem 2rem 4rem;background:var(--white);min-height:100vh}
.legal-inner{max-width:780px;margin:0 auto}
.legal-page h1{font-family:'Lora',serif;font-size:2rem;color:var(--navy);margin-bottom:0.5rem;padding-bottom:0.75rem;border-bottom:2px solid var(--gold)}
.legal-page h2{font-family:'Lora',serif;font-size:1.2rem;color:var(--navy);margin:2rem 0 0.8rem}
.legal-page h3{font-size:0.9rem;font-weight:700;color:var(--navy);margin:1.5rem 0 0.5rem;text-transform:uppercase;letter-spacing:0.06em}
.legal-page p,.legal-page li{font-size:0.85rem;color:var(--ink-soft);line-height:1.8}
.legal-page ul{padding-left:1.2rem;margin:0.5rem 0}
.legal-page a{color:var(--navy);font-weight:600}
.legal-page .updated{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border);font-size:0.75rem;color:#aaa}
.legal-nav{display:flex;gap:1rem;margin-bottom:2rem}
.legal-nav a{font-size:0.75rem;color:var(--silver);text-decoration:none;transition:color .2s}
.legal-nav a:hover{color:var(--gold)}
.legal-nav a.active{color:var(--gold);font-weight:600}

/* ── REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.services-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:960px){
  nav{padding:0 1.25rem}
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:72px;left:0;right:0;background:rgba(11,25,41,0.99);padding:1.5rem 2rem;gap:1.2rem;border-bottom:1px solid rgba(255,255,255,0.08)}
  .hamburger{display:flex}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid,.process-grid{grid-template-columns:1fr 1fr}
  .faq-grid{grid-template-columns:1fr}
  .area-grid,.contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .whatsapp-float{width:52px;height:52px;font-size:1.6rem;bottom:1rem;right:1rem}
}
@media(max-width:540px){
  .services-grid{grid-template-columns:1fr}
  .why-grid,.process-grid{grid-template-columns:1fr}
}

/* ── ACCESSIBILITY ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;transition-duration:0.01ms!important}
}
