:root{
  --p-dark:#0c1e33;
  --p-dark2:#162b45;
  --p-pri:#1d7a52;
  --p-pri-d:#155f3f;
  --p-accent:#FFB703;
  --p-blue:#4c7faf;
  --p-purple:#7C5295;
  --p-red:#E63946;
  --p-bg:#f5f7fa;
  --p-card:#fff;
  --p-border:#e3e9ef;
  --p-muted:#7a8a99;
  --p-text:#1a2734;
}
*,*::before,*::after{box-sizing:border-box;}
html,body{font-family:'Inter','Segoe UI',Arial,sans-serif;background:var(--p-bg);color:var(--p-text);max-width:100%;overflow-x:hidden;}
a{color:var(--p-pri);text-decoration:none;}
a:hover{color:var(--p-pri-d);text-decoration:underline;}

/* Top-Strip */
.top-strip{background:var(--p-dark);color:#fff;font-weight:500;}
.top-strip a{color:#fff;text-decoration:none;}
.top-strip a:hover{color:var(--p-accent);}
/* Telefon UND Kontakt im Top-Strip: alles weiß, einheitlicher dezenter Look */
.top-strip .top-strip-cta,
.top-strip a[href^="tel:"]{display:inline-flex;align-items:center;gap:.4rem;color:#fff !important;padding:.22rem .55rem;font-weight:500;font-size:.85rem;transition:.15s;border-radius:6px;}
.top-strip .top-strip-cta i,
.top-strip a[href^="tel:"] i{color:#fff !important;font-size:1.05rem;line-height:1;}
.top-strip .top-strip-cta:hover,
.top-strip a[href^="tel:"]:hover{color:var(--p-accent) !important;background:rgba(255,255,255,.06);}
.top-strip .top-strip-cta:hover i,
.top-strip a[href^="tel:"]:hover i{color:var(--p-accent) !important;}

/* Dienstleister-Detail: Einsatzgebiete als saubere Pill-Reihe (mobile: umbrechen) */
.dl-detail-gebiete{margin:1.2rem 0 .4rem;display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;}
.dl-detail-gebiete-label{font-size:.85rem;color:var(--p-muted);font-weight:600;margin-right:.3rem;display:inline-flex;align-items:center;gap:.3rem;}
.dl-detail-gebiete-pill{background:#fff;color:var(--p-dark);border:1px solid var(--p-border);padding:.28rem .75rem;border-radius:99px;font-size:.78rem;font-weight:600;white-space:nowrap;}

/* Dienstleister-Detail: Leistungs-Liste – klar erkennbare Reihe mit Icon, Name, Pfeil */
.dl-leistungen-liste{display:flex;flex-direction:column;gap:.45rem;margin-top:.85rem;}
.dl-leistung{display:flex;align-items:center;gap:.85rem;padding:.7rem .9rem;background:#f6f8fb;border-radius:10px;border:1px solid #e3e9ef;text-decoration:none;color:var(--p-text);transition:.15s;}
.dl-leistung:hover{background:#e8f4ee;border-color:var(--p-pri);text-decoration:none;color:var(--p-text);transform:translateX(2px);}
.dl-leistung-ico{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#e8f4ee,#d3ecde);color:var(--p-pri);display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;}
.dl-leistung-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem;}
.dl-leistung-text strong{font-size:.95rem;color:var(--p-dark);line-height:1.25;}
.dl-leistung-text span{font-size:.78rem;color:var(--p-muted);line-height:1.35;}
.dl-leistung-arrow{color:var(--p-muted);font-size:1rem;flex-shrink:0;}

/* Nav – mit Milchglas-Effekt beim Scrollen */
.portal-nav{background:#fff;border-bottom:1px solid var(--p-border);padding:.55rem 0;box-shadow:0 2px 12px rgba(0,0,0,.04);transition:background .25s ease, backdrop-filter .25s ease, box-shadow .25s ease;}
.portal-nav.is-scrolled{
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(14px) saturate(180%);
  -webkit-backdrop-filter:blur(14px) saturate(180%);
  box-shadow:0 4px 20px rgba(12,30,51,.10);
  border-bottom-color:rgba(227,233,239,.6);
}
.portal-nav .dropdown-menu{background:#fff;}  /* Dropdown bleibt opak – keine Lese-Probleme */
.portal-nav .container{max-width:1320px;}
.portal-nav .navbar-brand{display:flex;align-items:center;gap:.6rem;padding:0;margin-right:.6rem;text-decoration:none!important;}
.portal-nav .navbar-brand:hover,.portal-nav .navbar-brand:focus,.portal-nav .navbar-brand:active{text-decoration:none!important;}
.portal-nav .navbar-brand *{text-decoration:none!important;}
/* Nav-Links: Icons + Text NICHT als gemeinsame Underline-Linie; nur der reine Text */
.portal-nav .nav-link i{text-decoration:none;display:inline-block;}
.portal-nav .nav-link:hover{text-decoration:none;}
.portal-nav .nav-link:hover span,.portal-nav .nav-link:hover{text-underline-offset:3px;}
.portal-nav .brand-mark{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,#0c4d33 0%,#1d7a52 60%,#34a36e 100%);color:#fff;font-weight:900;font-size:1.5rem;letter-spacing:-1px;line-height:1;flex-shrink:0;box-shadow:0 4px 12px rgba(12,30,51,.18);font-family:Inter,system-ui,sans-serif;}
.portal-nav .brand-text{display:flex;flex-direction:column;line-height:1.1;}
.portal-nav .brand-name{font-weight:800;font-size:1.05rem;color:var(--p-dark);letter-spacing:-.5px;}
.portal-nav .brand-sub{font-size:.68rem;color:var(--p-muted);font-weight:500;margin-top:2px;white-space:nowrap;}
.portal-nav .nav-link{color:#243b53;font-weight:500;padding:.45rem .7rem;}
/* Mobile (Hamburger-Menü): kleiner Abstand zwischen Brand und Menü.
   padding-top statt margin-top → schrumpft mit der Collapse-Animation sauber mit. */
@media(max-width:991.98px){
  .portal-nav .navbar-collapse{padding-top:.6rem;}
  .portal-nav .navbar-nav .nav-link{padding-top:.55rem;padding-bottom:.55rem;}
}
.portal-nav .nav-link:hover,.portal-nav .nav-link.active{color:var(--p-pri);}

/* Hamburger: Standard-Bootstrap, nur dezente Hover-Optik + sauberer Focus-Ring.
   WICHTIG: ab lg (≥992px) IMMER versteckt – egal was Bootstrap macht. */
.portal-nav .navbar-toggler{border:0;box-shadow:none;padding:.4rem .55rem;border-radius:8px;}
.portal-nav .navbar-toggler:focus{box-shadow:none;}
.portal-nav .navbar-toggler:focus-visible{box-shadow:0 0 0 3px rgba(29,122,82,.30);}
@media(min-width:992px){
  .portal-nav .navbar-toggler{display:none !important;}
}

.portal-nav .dropdown-menu{border:1px solid var(--p-border);border-radius:10px;padding:.6rem;box-shadow:0 8px 30px rgba(0,0,0,.1);}
.portal-nav .dropdown-item{padding:.55rem .8rem;border-radius:6px;}
.portal-nav .dropdown-item:hover{background:#e8f4ee;color:var(--p-pri);}
.portal-nav .dropdown-item i{color:var(--p-pri);margin-right:.4rem;}

/* Mega-Menu */
.nav-mega .mega-menu{min-width:min(880px, 92vw);max-width:92vw;}
.mega-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.4rem 1rem;}
.mega-col{display:flex;flex-direction:column;}
.mega-head{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.4rem;padding:.3rem 0;border-bottom:1.5px solid #e8f4ee;}
.mega-head i{margin-right:.3rem;}
.mega-item{display:flex;align-items:flex-start;gap:.4rem;padding:.32rem .4rem;font-size:.82rem;color:var(--p-text);text-decoration:none;border-radius:5px;line-height:1.3;hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto;overflow-wrap:break-word;word-break:normal;}
.mega-item i{color:var(--p-pri);width:14px;text-align:center;flex-shrink:0;line-height:1.3;margin-top:1px;}
.mega-item span,.mega-item{hyphenate-limit-chars:6 3 2;}
.mega-item:hover{background:#f0f6f3;color:var(--p-pri);text-decoration:none;}
.mega-all{display:block;margin-top:.4rem;padding:.3rem .4rem;font-size:.74rem;font-weight:600;color:var(--p-muted);text-decoration:none;}
.mega-all:hover{color:var(--p-pri);}
@media(max-width:1199px){.mega-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:991px){.nav-mega .mega-menu{min-width:auto;max-width:none;}.mega-grid{grid-template-columns:1fr 1fr;gap:.3rem .8rem;}}
@media(max-width:560px){.mega-grid{grid-template-columns:1fr;}}

/* Such-Box im Nav (kompakt) */
.nav-search{display:flex;align-items:stretch;background:#f3f6fa;border:1px solid var(--p-border);border-radius:10px;overflow:hidden;height:38px;margin-left:.4rem;}
.nav-search input{border:0;outline:0;background:transparent;padding:0 .8rem;font-size:.88rem;width:170px;min-width:0;color:var(--p-text);}
.nav-search input::placeholder{color:#9aa7b3;}
.nav-search button{border:0;background:var(--p-pri);color:#fff;padding:0 .9rem;cursor:pointer;}
.nav-search button:hover{background:var(--p-pri-d);}
@media(max-width:1199px){.nav-search input{width:130px;}}
@media(max-width:991px){.nav-search{margin:.8rem 0 0;width:100%;height:42px;}.nav-search input{width:100%;}}

/* Hero */
.hero{position:relative;background:linear-gradient(135deg,#0c1e33 0%,#162b45 50%,#1d7a52 100%);border-radius:22px;padding:5rem 2.5rem;color:#fff;overflow:hidden;margin-bottom:2rem;}
.hero::before{content:'';position:absolute;inset:0;background-image:
   radial-gradient(circle at 12% 18%, rgba(255,183,3,.18), transparent 35%),
   radial-gradient(circle at 90% 80%, rgba(255,255,255,.10), transparent 38%),
   radial-gradient(circle at 65% 30%, rgba(76,127,175,.18), transparent 40%);}
.hero-content{position:relative;max-width:780px;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.45rem;background:rgba(255,255,255,.12);backdrop-filter:blur(6px);padding:.35rem .8rem;border-radius:99px;font-size:.78rem;font-weight:600;letter-spacing:.3px;margin-bottom:1.2rem;border:1px solid rgba(255,255,255,.18);}
.hero-eyebrow i{color:var(--p-accent);}
.hero h1{font-size:clamp(2rem,5vw,3.4rem);font-weight:900;letter-spacing:-1px;line-height:1.05;margin-bottom:1rem;}
.hero h1 .highlight{color:var(--p-accent);}
.hero p{font-size:clamp(1rem,2vw,1.2rem);opacity:.95;margin-bottom:2rem;max-width:600px;}
.hero-search{background:#fff;border-radius:14px;padding:.55rem;display:flex;gap:.5rem;align-items:center;box-shadow:0 12px 28px rgba(0,0,0,.20);}
.hero-search input{flex:1;border:0;outline:0;padding:.9rem 1.1rem;font-size:1.05rem;color:var(--p-text);background:transparent;border-radius:10px;min-width:0;}
.hero-search button{background:var(--p-pri);color:#fff;border:0;border-radius:10px;padding:.9rem 1.6rem;font-weight:700;cursor:pointer;flex-shrink:0;}
.hero-search button:hover{background:var(--p-pri-d);}
.hero-search-hint{font-size:.8rem;opacity:.85;margin-top:.7rem;}
.hero-search-hint a{color:var(--p-accent);font-weight:600;}
.hero-trust{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:1.7rem;font-size:.85rem;}
.hero-trust span{display:inline-flex;align-items:center;gap:.4rem;}
.hero-trust i{color:var(--p-accent);}

/* === MASTER-KACHELN === */
.master-section{margin-bottom:3rem;}
.master-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;}
.master-card{position:relative;border-radius:20px;overflow:hidden;text-decoration:none;color:#fff;min-height:280px;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:0 10px 30px rgba(12,30,51,.12);transition:.3s cubic-bezier(.2,.8,.3,1);background:var(--bg);}
.master-card:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(12,30,51,.22);text-decoration:none;color:#fff;}
.master-card .master-bg{position:absolute;inset:0;background:var(--bg);}
.master-card .master-bg::before{content:'';position:absolute;inset:0;background:
  radial-gradient(circle at 80% 20%,rgba(255,255,255,.18),transparent 40%),
  radial-gradient(circle at 20% 80%,rgba(0,0,0,.15),transparent 40%);}
.master-card .master-bg::after{content:'';position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;border:2px solid rgba(255,255,255,.12);}
.master-content{position:relative;padding:2rem 1.7rem;display:flex;flex-direction:column;gap:.65rem;flex:1;justify-content:flex-end;}
.master-badge{position:absolute;top:1.2rem;right:1.2rem;background:rgba(255,255,255,.2);backdrop-filter:blur(6px);padding:.32rem .75rem;border-radius:99px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(255,255,255,.25);}
.master-icon{font-size:2.6rem;line-height:1;opacity:.95;margin-bottom:auto;align-self:flex-start;}
.master-title{font-size:1.45rem;font-weight:900;letter-spacing:-.5px;margin:0;line-height:1.15;}
.master-subline{font-size:.9rem;opacity:.92;margin:0;font-weight:500;}
.master-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.3rem;}
.master-tags span{background:rgba(255,255,255,.18);padding:.22rem .65rem;border-radius:99px;font-size:.72rem;font-weight:500;backdrop-filter:blur(4px);}
.master-tags .more-tag{background:rgba(0,0,0,.25);font-weight:700;}
.master-cta{display:inline-flex;align-items:center;gap:.5rem;font-size:.92rem;font-weight:700;margin-top:.8rem;padding:.65rem 0;border-top:1px solid rgba(255,255,255,.22);}
.master-cta i{transition:transform .25s;}
.master-card:hover .master-cta i{transform:translateX(5px);}
@media(max-width:1100px){.master-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.master-grid{grid-template-columns:1fr;}.master-card{min-height:240px;}.master-icon{font-size:2.2rem;}.master-title{font-size:1.25rem;}}

/* === PROCESS === */
.process-section{background:#fff;border:1px solid var(--p-border);border-radius:18px;padding:2rem;margin-bottom:3rem;}
.process-row{display:flex;align-items:stretch;gap:0;margin-top:1rem;flex-wrap:nowrap;}
.process-step{flex:1;padding:1.3rem;text-align:center;}
.process-step .step-num{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#1d7a52,#34a36e);color:#fff;font-weight:900;font-size:1.3rem;margin-bottom:.7rem;box-shadow:0 6px 14px rgba(29,122,82,.3);}
.process-step h4{font-weight:800;font-size:1.05rem;margin-bottom:.4rem;color:var(--p-dark);}
.process-step p{font-size:.88rem;color:var(--p-muted);margin:0;}
.process-arrow{display:flex;align-items:center;justify-content:center;color:var(--p-pri);font-size:1.8rem;padding:0 .5rem;flex:0 0 auto;}
@media(max-width:768px){.process-row{flex-direction:column;}.process-arrow{transform:rotate(90deg);padding:.3rem 0;}}

/* === DIENSTLEISTER-LISTE === */
.dl-section{margin-top:2.5rem;}
.dl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;}
.dl-card{background:#fff;border:1px solid var(--p-border);border-radius:14px;padding:1.3rem;display:flex;flex-direction:column;gap:.7rem;transition:.2s;height:100%;}
.dl-card-link{text-decoration:none;color:inherit;}
.dl-card-link:hover{text-decoration:none;color:inherit;}
.dl-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.08);border-color:var(--p-pri);}
/* Grid: alle Cards in derselben Row UND zwischen Rows gleich hoch */
.dl-grid{grid-auto-rows:1fr;}
.dl-head{display:flex;align-items:center;gap:.85rem;}
.dl-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,#1d7a52,#34a36e);color:#fff;font-weight:800;font-size:1rem;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}
.dl-avatar-logo{background:#fff;padding:4px;border:1px solid var(--p-border);}
.dl-avatar-logo img{max-width:100%;max-height:100%;object-fit:contain;}
.dl-firma{font-weight:800;color:var(--p-dark);font-size:1rem;line-height:1.2;hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto;overflow-wrap:anywhere;}
.dl-ansprech{font-size:.8rem;color:var(--p-muted);margin-top:2px;}
.dl-check{color:#1d7a52;font-size:1.3rem;margin-left:auto;line-height:1;}
/* Beschreibung: EXAKT 3 Zeilen Höhe – immer.
   Weniger Text → unten leer. Mehr Text → "…" nach Zeile 3. */
.dl-desc{
  font-size:.85rem !important;
  line-height:1.45 !important;
  color:#3b4d5e;
  margin:0;
  display:-webkit-box !important;
  display:-moz-box;
  -webkit-line-clamp:3 !important;
  -webkit-box-orient:vertical !important;
  overflow:hidden !important;
  height:calc(3em * 1.45) !important;   /* genau 3 Zeilen, nicht mehr nicht weniger */
  min-height:calc(3em * 1.45) !important;
  max-height:calc(3em * 1.45) !important;
  flex:0 0 auto !important;
}
/* Google-Bewertungs-Zeile: leerer Platz reserviert auch ohne Inhalt */
.dl-google{min-height:1.6em;flex:0 0 auto;}
/* Tag-Zeile: 2 Zeilen Platz, weniger ist ok, mehr wird gewrappt */
.dl-tags{min-height:calc(2 * 1.55em);align-content:flex-start;flex:0 0 auto;}
.dl-google{display:flex;align-items:center;gap:.4rem;margin:.5rem 0 .35rem;flex-wrap:wrap;}
.dl-google-stars i{font-size:.85rem;}
.dl-tags{display:flex;flex-wrap:wrap;gap:.3rem;}
.dl-tags span{background:#e8f4ee;color:#1d7a52;padding:.18rem .55rem;border-radius:99px;font-size:.7rem;font-weight:600;max-width:100%;overflow-wrap:anywhere;}
.dl-tags .more{background:#243b53;color:#fff;}
.dl-meta{display:flex;flex-wrap:wrap;gap:.7rem;font-size:.78rem;color:var(--p-muted);margin-top:auto;padding-top:.4rem;}
.dl-meta i{color:var(--p-pri);}
.dl-foot{display:flex;gap:.45rem;margin-top:auto;flex-wrap:wrap;padding-top:.7rem;}
.dl-btn{flex:1;text-align:center;padding:.5rem .8rem;border-radius:8px;font-size:.82rem;font-weight:700;text-decoration:none;transition:.15s;min-width:0;}
.dl-btn-call{background:var(--p-pri);color:#fff;}
.dl-btn-call:hover{background:var(--p-pri-d);color:#fff;text-decoration:none;}
.dl-btn-web{background:#f3f6fa;color:var(--p-dark);border:1px solid var(--p-border);}
.dl-btn-web:hover{background:var(--p-dark);color:#fff;text-decoration:none;}
@media(max-width:992px){.dl-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.dl-grid{grid-template-columns:1fr;}}

/* === REGION-PILLS === */
.region-pill{background:linear-gradient(135deg,#e8f4ee,#d3ecde);color:#1d7a52;padding:.55rem 1rem;border-radius:99px;text-decoration:none;font-weight:600;font-size:.85rem;transition:.2s;border:1px solid #d3ecde;}
.region-pill:hover{background:#1d7a52;color:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:0 6px 14px rgba(29,122,82,.25);}

/* === CITY-STRIP (SEO Internal Linking) === */
.city-strip{background:#fff;border:1px solid var(--p-border);border-radius:12px;padding:.85rem 1rem;display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;}
.city-strip-label{font-size:.82rem;font-weight:700;color:var(--p-dark);margin-right:.5rem;}
.city-pill{background:#f3f6fa;color:var(--p-dark);padding:.32rem .75rem;border-radius:99px;font-size:.78rem;text-decoration:none;font-weight:500;border:1px solid transparent;transition:.15s;}
.city-pill:hover{background:var(--p-pri);color:#fff;border-color:var(--p-pri);text-decoration:none;}

/* Kategorie-Streifen */
.kategorie-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:3rem;}
.kategorie-strip .kat{background:#fff;border-radius:14px;padding:1.3rem 1rem;text-align:center;border:2px solid var(--p-border);text-decoration:none;color:var(--p-text);transition:.2s;display:flex;flex-direction:column;align-items:center;gap:.5rem;}
.kategorie-strip .kat:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,.1);border-color:var(--p-pri);}
.kategorie-strip .kat i{font-size:1.8rem;}
.kategorie-strip .kat .kname{font-weight:700;font-size:.92rem;}
.kategorie-strip .kat .kcnt{font-size:.72rem;color:var(--p-muted);}
@media(max-width:992px){.kategorie-strip{grid-template-columns:repeat(2,1fr);}}

/* Service-Grid */
/* === Section-Titel (modern) === */
.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.4rem;flex-wrap:wrap;gap:1rem;}
.section-title h2{font-size:1.55rem;font-weight:800;margin:0;color:var(--p-dark);letter-spacing:-.5px;display:inline-flex;align-items:center;gap:.7rem;line-height:1.15;}
.section-title h2 .icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#e8f4ee,#d3ecde);color:var(--p-pri);font-size:1.25rem;flex-shrink:0;box-shadow:inset 0 0 0 1px rgba(29,122,82,.08);}
.section-title h2::after{content:'';flex:1;height:2px;background:linear-gradient(90deg,#e3e9ef,transparent);margin-left:.5rem;min-width:30px;border-radius:1px;display:none;}
@media(min-width:780px){.section-title h2::after{display:block;}}
.section-title > a{font-size:.85rem;color:var(--p-pri);font-weight:600;text-decoration:none;flex-shrink:0;}
.section-title > a:hover{color:var(--p-pri-d);text-decoration:underline;}
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;}
.service-card{background:#fff;border:1px solid var(--p-border);border-radius:14px;padding:1.4rem;text-decoration:none;color:var(--p-text);transition:.2s;display:flex;flex-direction:column;gap:.6rem;height:100%;position:relative;overflow:hidden;}
.service-card::before{content:'';position:absolute;left:0;top:0;width:4px;height:100%;background:var(--p-pri);transform:scaleY(0);transform-origin:top;transition:transform .25s;}
.service-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.08);text-decoration:none;border-color:var(--p-pri);}
.service-card:hover::before{transform:scaleY(1);}
.service-card .sicon{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,#e8f4ee,#d3ecde);color:var(--p-pri);display:inline-flex;align-items:center;justify-content:center;font-size:1.55rem;}
.service-card h3{font-size:1rem;font-weight:700;margin:0;color:var(--p-dark);hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto;word-break:break-word;overflow-wrap:anywhere;line-height:1.25;}
.service-card p{font-size:.85rem;color:var(--p-muted);margin:0;line-height:1.5;flex:1;hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto;overflow-wrap:anywhere;}
.service-card .more{margin-top:.55rem;font-size:.82rem;color:var(--p-pri);font-weight:600;display:inline-flex;align-items:center;gap:.3rem;}
.service-card.compact{padding:1.1rem;}
@media(max-width:992px){.service-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.service-grid{grid-template-columns:1fr;}}

/* Service-Landing */
.service-hero{background:linear-gradient(135deg,#0c1e33,#1d7a52);border-radius:18px;padding:3rem 2rem;color:#fff;margin-bottom:2rem;position:relative;overflow:hidden;}
.service-hero::before{content:'';position:absolute;right:-50px;top:-50px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(255,183,3,.18),transparent 60%);}
.service-hero h1{font-size:clamp(1.7rem,4vw,2.6rem);font-weight:900;letter-spacing:-.5px;line-height:1.1;margin-bottom:.8rem;}
.service-hero .lead-text{font-size:1.1rem;opacity:.95;max-width:680px;}
.service-hero .crumbs{font-size:.8rem;opacity:.8;margin-bottom:1rem;}
.service-hero .crumbs a{color:var(--p-accent);}
.service-hero .meta{display:flex;gap:1.3rem;flex-wrap:wrap;margin-top:1.5rem;font-size:.85rem;}
.service-hero .meta span{background:rgba(255,255,255,.15);padding:.4rem .85rem;border-radius:999px;backdrop-filter:blur(6px);}
.service-hero .meta i{color:var(--p-accent);margin-right:.3rem;}

.service-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;}
.service-feature{background:#fff;border:1px solid var(--p-border);border-radius:12px;padding:1.2rem;}
.service-feature i{font-size:1.6rem;color:var(--p-pri);display:block;margin-bottom:.5rem;}
.service-feature h4{font-size:1rem;font-weight:700;margin-bottom:.3rem;}
.service-feature p{font-size:.85rem;color:var(--p-muted);margin:0;}
@media(max-width:768px){.service-feature-grid{grid-template-columns:1fr;}}

/* Anfrage-Formular */
.request-card{background:#fff;border:1px solid var(--p-border);border-radius:18px;padding:2rem;position:sticky;top:90px;box-shadow:0 8px 28px rgba(0,0,0,.06);}
.request-card h3{font-size:1.2rem;font-weight:700;margin-bottom:.4rem;}
.request-card .sub{font-size:.85rem;color:var(--p-muted);margin-bottom:1.3rem;}
.request-card label{font-size:.82rem;font-weight:600;color:#3b4d5e;margin-bottom:.3rem;display:block;}
.request-card .form-control{border-radius:8px;border:1.5px solid var(--p-border);padding:.62rem .85rem;}
.request-card .form-control:focus{border-color:var(--p-pri);box-shadow:0 0 0 .2rem rgba(29,122,82,.15);}
.btn-request{background:var(--p-pri);color:#fff;font-weight:700;border:0;border-radius:10px;padding:.9rem;width:100%;font-size:1rem;cursor:pointer;}
.btn-request:hover{background:var(--p-pri-d);}
.request-card .small-note{font-size:.75rem;color:var(--p-muted);text-align:center;margin-top:.7rem;}

/* Such-Ergebnisse */
.search-result{background:#fff;border:1px solid var(--p-border);border-radius:12px;padding:1rem 1.2rem;margin-bottom:.75rem;display:flex;gap:1rem;align-items:center;text-decoration:none;color:var(--p-text);}
.search-result:hover{border-color:var(--p-pri);transform:translateX(4px);transition:.2s;}
.search-result .si{width:46px;height:46px;border-radius:10px;background:#e8f4ee;color:var(--p-pri);display:inline-flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;}
.search-result .sm-title{font-weight:700;color:var(--p-dark);}
.search-result .sm-meta{font-size:.8rem;color:var(--p-muted);}

/* Trust-Strip */
.trust-strip{background:#fff;border:1px solid var(--p-border);border-radius:14px;padding:1.6rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-bottom:2.5rem;}
.trust-item{display:flex;gap:.85rem;align-items:center;}
.trust-item .ti{width:46px;height:46px;border-radius:10px;background:linear-gradient(135deg,#e8f4ee,#d3ecde);color:var(--p-pri);display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;}
.trust-item strong{display:block;font-size:.92rem;color:var(--p-dark);}
.trust-item span{font-size:.8rem;color:var(--p-muted);}
@media(max-width:768px){.trust-strip{grid-template-columns:1fr 1fr;}}

/* Why-Section */
.why-section{background:linear-gradient(135deg,#fff 0%,#f0f6f3 100%);border-radius:18px;padding:2.5rem 2rem;border:1px solid var(--p-border);margin-bottom:3rem;}
.why-section h2{font-weight:800;color:var(--p-dark);margin-bottom:1.5rem;}
.why-section ul{padding-left:0;list-style:none;}
.why-section li{display:flex;gap:.7rem;margin-bottom:.7rem;}
.why-section li i{color:var(--p-pri);font-size:1.2rem;margin-top:.1rem;}
.why-section li strong{color:var(--p-dark);display:block;}
.why-section li span{font-size:.88rem;color:var(--p-muted);}

/* Cards für statische Seiten */
.static-card{background:#fff;border:1px solid var(--p-border);border-radius:14px;padding:2rem;margin-bottom:1.5rem;}
.static-card h2{font-weight:800;color:var(--p-dark);}
.static-card h3{font-size:1.1rem;font-weight:700;margin-top:1.5rem;}

/* Footer */
.portal-footer{background:var(--p-dark);color:#cdd9e3;padding:3.5rem 0 4.5rem;margin-top:4rem;}
.portal-footer .brand-footer{display:flex;align-items:center;gap:.6rem;color:#fff;font-weight:800;font-size:1.05rem;}
.portal-footer .brand-mark{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#0c4d33 0%,#1d7a52 60%,#34a36e 100%);color:#fff;font-weight:900;font-size:1.4rem;letter-spacing:-1px;line-height:1;font-family:Inter,system-ui,sans-serif;}
.portal-footer a{color:#cdd9e3;}
.portal-footer a:hover{color:var(--p-accent);text-decoration:none;}
.portal-footer .footer-title{color:#fff;font-weight:700;font-size:.95rem;margin-bottom:.8rem;}

/* Empty state */
.empty-state{text-align:center;padding:3rem 1rem;color:var(--p-muted);}
.empty-state i{font-size:3.5rem;color:#c8d4e0;}

/* === Such-AI-Box (Fallback bei 0 Treffern) === */
.search-ai{background:linear-gradient(135deg,#fff,#f6f8fb);border:1px solid var(--p-border);border-radius:16px;padding:1.4rem;margin-top:1rem;box-shadow:0 4px 14px rgba(12,30,51,.06);}
.search-ai-head{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem;padding-bottom:.85rem;border-bottom:1px solid #eef2f6;}
.search-ai-avatar{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,#1d7a52,#34a36e);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;box-shadow:0 4px 10px rgba(29,122,82,.25);}
.search-ai-head strong{color:var(--p-dark);font-size:.95rem;}
.search-ai-body{font-size:.92rem;line-height:1.55;color:#3b4d5e;}
.search-ai-body a{color:var(--p-pri);font-weight:600;}
.search-ai-body ul{padding-left:1.2rem;margin:.4rem 0;}
.search-ai-loading{display:flex;align-items:center;padding:.5rem 0;}
.search-ai-loading .dot{width:7px;height:7px;border-radius:50%;background:var(--p-pri);margin:0 3px;animation:n360-dot 1s infinite;}
.search-ai-loading .dot:nth-child(2){animation-delay:.15s;}
.search-ai-loading .dot:nth-child(3){animation-delay:.3s;}

/* === Mini-Button-Link (dezent, mobil-tauglich) === */
.btn-mini-link{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .95rem;background:#fff;border:1px solid var(--p-border);border-radius:99px;color:var(--p-pri);text-decoration:none;font-weight:600;font-size:.85rem;margin:.25rem;transition:.15s;}
.btn-mini-link:hover{background:var(--p-pri);color:#fff;border-color:var(--p-pri);text-decoration:none;}
.btn-mini-link i{color:inherit;}

@media(max-width:768px){
  .hero{padding:3rem 1.5rem;}
  .request-card{position:static;}
  .service-feature-grid{grid-template-columns:1fr;}
}

/* === COOKIE BANNER === */
.n360-cookie{position:fixed;bottom:1.5rem;left:1.5rem;right:1.5rem;z-index:9999;display:flex;justify-content:center;pointer-events:none;}
.n360-cookie.hidden{display:none;}
.n360-cookie-card{background:#fff;border-radius:18px;box-shadow:0 25px 50px rgba(12,30,51,.25), 0 0 0 1px rgba(12,30,51,.08);max-width:680px;width:100%;padding:1.8rem 1.8rem 1.4rem;position:relative;pointer-events:auto;animation:n360cb-slide .4s cubic-bezier(.2,.8,.3,1);}
@keyframes n360cb-slide{from{transform:translateY(30px);opacity:0;}to{transform:none;opacity:1;}}
.n360-cookie-close{position:absolute;top:.7rem;right:.85rem;background:transparent;border:0;font-size:1.6rem;line-height:1;color:#9aa7b3;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.15s;}
.n360-cookie-close:hover{background:#f0f4f8;color:#243b53;}
.n360-cookie-head{display:flex;gap:1rem;margin-bottom:1.1rem;}
.n360-cookie-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#1d7a52,#34a36e);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;box-shadow:0 6px 14px rgba(29,122,82,.3);}
.n360-cookie-head h3{font-size:1.1rem;font-weight:800;margin:.15rem 0 .35rem;color:#0c1e33;}
.n360-cookie-head p{font-size:.88rem;color:#5a6b7b;margin:0;line-height:1.45;}
.n360-cookie-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.2rem;background:#f6f8fb;padding:.8rem;border-radius:12px;}
.n360-cookie-opt{display:flex;gap:.7rem;align-items:flex-start;padding:.55rem .65rem;border-radius:8px;cursor:pointer;transition:.15s;font-weight:400;margin:0;}
.n360-cookie-opt:hover{background:#fff;}
.n360-cookie-opt.locked{cursor:default;opacity:.85;}
.n360-cookie-opt.locked:hover{background:transparent;}
.n360-cookie-opt input[type=checkbox]{margin-top:.15rem;width:18px;height:18px;accent-color:#1d7a52;cursor:pointer;flex-shrink:0;}
.n360-cookie-opt input[type=checkbox]:disabled{cursor:not-allowed;}
.n360-cookie-opt strong{display:block;font-size:.92rem;color:#0c1e33;font-weight:700;margin-bottom:.1rem;}
.n360-cookie-opt span{font-size:.78rem;color:#7a8a99;line-height:1.4;}
.n360-cookie-actions{display:flex;gap:.55rem;flex-wrap:wrap;justify-content:flex-end;margin-bottom:.85rem;}
.n360-cb{border:0;border-radius:10px;padding:.7rem 1.15rem;font-size:.88rem;font-weight:700;cursor:pointer;transition:.18s;display:inline-flex;align-items:center;gap:.4rem;font-family:inherit;}
.n360-cb-ghost{background:transparent;color:#7a8a99;}
.n360-cb-ghost:hover{background:#f0f4f8;color:#243b53;}
.n360-cb-secondary{background:#e8f4ee;color:#1d7a52;}
.n360-cb-secondary:hover{background:#d3ecde;}
.n360-cb-primary{background:linear-gradient(135deg,#1d7a52,#34a36e);color:#fff;box-shadow:0 6px 14px rgba(29,122,82,.3);}
.n360-cb-primary:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(29,122,82,.4);}
.n360-cookie-footer{text-align:center;font-size:.78rem;color:#9aa7b3;border-top:1px solid #eef2f6;padding-top:.7rem;}
.n360-cookie-footer a{color:#7a8a99;text-decoration:none;}
.n360-cookie-footer a:hover{color:#1d7a52;text-decoration:underline;}

/* Reopen-Button (Floating, dezent unten links) */
.n360-cookie-reopen{position:fixed;bottom:1rem;left:1rem;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.8);backdrop-filter:blur(8px);border:1px solid rgba(0,0,0,.06);color:#7a8a99;font-size:1rem;cursor:pointer;box-shadow:0 3px 10px rgba(0,0,0,.08);z-index:998;display:flex;align-items:center;justify-content:center;transition:.18s;opacity:.7;}
.n360-cookie-reopen.hidden{display:none;}
.n360-cookie-reopen:hover{opacity:1;transform:scale(1.1);color:#1d7a52;box-shadow:0 6px 16px rgba(0,0,0,.15);}

@media(max-width:600px){
  .n360-cookie{bottom:.6rem;left:.6rem;right:.6rem;}
  .n360-cookie-card{padding:1.3rem 1.2rem 1.1rem;border-radius:14px;}
  .n360-cookie-head h3{font-size:1rem;}
  .n360-cookie-head p{font-size:.83rem;}
  .n360-cookie-actions{flex-direction:column-reverse;}
  .n360-cb{width:100%;justify-content:center;}
  .n360-cookie-reopen{bottom:.5rem;left:.5rem;width:32px;height:32px;font-size:.9rem;opacity:.55;}
}

/* === KI-CHAT === */
#n360-chat-toggle{position:fixed;bottom:1.3rem;right:1.3rem;z-index:998;background:linear-gradient(135deg,#1d7a52,#34a36e);color:#fff;border:none;border-radius:32px;padding:.7rem 1.2rem .7rem 1rem;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.92rem;box-shadow:0 8px 22px rgba(29,122,82,.35);transition:.22s cubic-bezier(.2,.8,.3,1);font-family:inherit;
  /* iOS-Eigenheiten unterdrücken: kein eckiger Tap-Highlight, kein Default-Border-Look */
  -webkit-appearance:none;appearance:none;
  -webkit-tap-highlight-color:transparent;
  outline:none;
  /* Schatten + Rundung sauber zusammenführen → kein Pixel-Artefakt am Rand */
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
  transform:translateZ(0);
}
#n360-chat-toggle:focus,#n360-chat-toggle:active{outline:none;-webkit-tap-highlight-color:transparent;}
#n360-chat-toggle:hover{transform:translateY(-2px) translateZ(0);box-shadow:0 12px 28px rgba(29,122,82,.45);}
#n360-chat-toggle i{font-size:1.15rem;}
#n360-chat-toggle.open{display:none;}

#n360-chat-window{position:fixed;bottom:1.3rem;right:1.3rem;width:380px;max-width:calc(100vw - 2rem);max-height:min(600px, calc(100dvh - 2rem));height:75dvh;background:#fff;border-radius:18px;box-shadow:0 25px 50px rgba(12,30,51,.3),0 0 0 1px rgba(0,0,0,.06);z-index:9999;display:flex;flex-direction:column;overflow:hidden;animation:n360cb-slide .25s cubic-bezier(.2,.8,.3,1);box-sizing:border-box;}
#n360-chat-window.hidden{display:none;}
#n360-chat-window *{box-sizing:border-box;}

.n360-chat-head{background:linear-gradient(135deg,#0c1e33,#1d7a52);color:#fff;padding:.85rem 1rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-shrink:0;}
.n360-chat-head-info{display:flex;align-items:center;gap:.65rem;min-width:0;flex:1;}
.n360-chat-head-text{min-width:0;flex:1;line-height:1.15;}
.n360-chat-head-text strong{display:block;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.n360-chat-head-text span{display:block;font-size:.72rem;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.n360-chat-avatar{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.n360-chat-close{background:rgba(255,255,255,.12);border:0;color:#fff;width:38px;height:38px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:.15s;-webkit-tap-highlight-color:rgba(255,255,255,.3);}
.n360-chat-close:hover,.n360-chat-close:active{background:rgba(255,255,255,.25);}

.n360-chat-body{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;overscroll-behavior-y:contain;touch-action:pan-y;padding:1rem;background:#f5f7fa;display:flex;flex-direction:column;gap:.55rem;}
/* Header & Input-Leiste sollen NICHT scrollen können (sonst gibt iOS den Touch an die Seite weiter) */
.n360-chat-head,.n360-chat-input{touch-action:none;overscroll-behavior:contain;}
.n360-chat-input input{touch-action:manipulation;}
.n360-msg{max-width:90%;padding:.65rem .9rem;border-radius:14px;font-size:.9rem;line-height:1.45;animation:n360cb-slide .18s ease;word-break:break-word;overflow-wrap:anywhere;}
.n360-msg.bot{background:#fff;color:#243b53;border:1px solid #e3e9ef;border-bottom-left-radius:4px;align-self:flex-start;}
.n360-msg.me{background:linear-gradient(135deg,#1d7a52,#34a36e);color:#fff;border-bottom-right-radius:4px;align-self:flex-end;}
.n360-msg ul{margin:.3rem 0;padding-left:1.2rem;}
.n360-msg li{margin:.15rem 0;}
.n360-msg a{color:#1d7a52;font-weight:600;word-break:break-word;}
.n360-msg.me a{color:#fff;text-decoration:underline;}
.n360-msg.loading{display:flex;gap:4px;align-items:center;}
.n360-msg.loading .dot{width:8px;height:8px;border-radius:50%;background:#1d7a52;animation:n360-dot 1s infinite;}
.n360-msg.loading .dot:nth-child(2){animation-delay:.15s;} .n360-msg.loading .dot:nth-child(3){animation-delay:.3s;}
@keyframes n360-dot{0%,80%,100%{opacity:.3;transform:scale(.7);} 40%{opacity:1;transform:scale(1);}}

.n360-chips-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem;}
.n360-chip{background:#e8f4ee;color:#1d7a52;border:1px solid #d3ecde;border-radius:99px;padding:.35rem .8rem;font-size:.78rem;cursor:pointer;font-family:inherit;transition:.15s;white-space:nowrap;-webkit-tap-highlight-color:rgba(29,122,82,.2);}
.n360-chip:hover,.n360-chip:active{background:#1d7a52;color:#fff;border-color:#1d7a52;}

.n360-chat-input{display:flex;border-top:1px solid #e3e9ef;background:#fff;flex-shrink:0;padding-bottom:env(safe-area-inset-bottom);}
.n360-chat-input input{flex:1 1 auto;min-width:0;border:0;outline:0;padding:.95rem 1rem;font-size:16px;font-family:inherit;background:transparent;}  /* font-size:16px verhindert iOS-Auto-Zoom */
.n360-chat-input button{background:#1d7a52;color:#fff;border:0;padding:0 1.15rem;cursor:pointer;font-size:1.15rem;flex-shrink:0;-webkit-tap-highlight-color:rgba(255,255,255,.3);}
.n360-chat-input button:hover,.n360-chat-input button:active{background:#155f3f;}

/* === MOBILE: Vollbild-Modus === */
@media(max-width:700px){
  #n360-chat-toggle{bottom:1rem;right:1rem;padding:.65rem 1.1rem;font-size:.88rem;}
  #n360-chat-toggle span{display:none;}
  #n360-chat-window{
    position:fixed;
    inset:0;
    bottom:0;right:0;left:0;top:0;
    width:100%;max-width:none;
    height:100dvh;max-height:none;
    border-radius:0;
    animation:n360cb-slideup .25s cubic-bezier(.2,.8,.3,1);
  }
  .n360-chat-head{padding-top:max(.85rem, env(safe-area-inset-top));padding-left:max(1rem, env(safe-area-inset-left));padding-right:max(1rem, env(safe-area-inset-right));}
  .n360-chat-close{width:42px;height:42px;}  /* Touch-Target min 44px */
  .n360-chat-body{padding:.85rem;}
  .n360-msg{max-width:92%;font-size:.92rem;}
  /* Body-Scroll sperren wenn Chat offen ist (verhindert Body-Scroll hinter dem Chat) */
  html.n360-chat-open,body.n360-chat-open{overflow:hidden!important;height:100%;overscroll-behavior:none;}
  body.n360-chat-open{position:fixed;width:100%;left:0;right:0;top:var(--n360-scroll-lock,0);touch-action:none;}
}
@keyframes n360cb-slideup{from{transform:translateY(100%);opacity:.5;} to{transform:none;opacity:1;}}

/* (Trust-Marketing CSS entfernt – nicht mehr benötigt) */
