:root{
  --bg:#ece6db;
  --bg-2:#ece6db;
  --panel:#f7f3ea;
  --panel-2:#f7f3ea;
  --line:#d4cdbd;
  --line-2:#d4cdbd;
  --line-3:#bbb29e;
  --ink:#1d2a23;
  --ink-2:#5c6a5f;
  --mute:#7a8378;
  --blue:#1f5f43;
  --blue-2:#1f5f43;
  --blue-dark:#17472f;
  --blue-soft:#1f5f43;
  --live:#1f5f43;
  --amber:#c08a2d;
  --max:1320px;
  --gutter:clamp(20px,4vw,48px);
  --r:14px;
  --sans:"Geist",ui-sans-serif,system-ui;
  --serif:"Instrument Serif",ui-serif,Georgia,serif;
  --mono:"Geist Mono",ui-monospace,SFMono-Regular,Menlo;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01","ss02","cv11";overflow-x:clip}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.mono{font-family:var(--mono);font-feature-settings:"tnum","zero"}
.serif-em{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:-.01em}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:48px;padding:0 22px;border-radius:10px;font-size:14px;font-weight:500;letter-spacing:-.005em;border:1px solid var(--line-2);color:var(--ink);background:transparent;transition:.2s;white-space:nowrap}
.btn:hover{border-color:var(--line-3);background:rgba(29,42,35,.06);color:#1d2a23}
.btn-primary{background:#1f5f43;border:1px solid #1f5f43;color:#f7f3ea;font-weight:600;box-shadow:0 6px 14px -4px rgba(29,42,35,.18),0 2px 4px -1px rgba(29,42,35,.08)}
.btn-primary:hover{background:#17472f;border-color:#17472f;transform:translateY(-1px);box-shadow:0 10px 22px -6px rgba(29,42,35,.22),0 3px 6px -1px rgba(29,42,35,.12)}
.btn-primary::after{content:"→";font-weight:500;transition:transform .25s}
.btn-primary:hover::after{transform:translateX(4px)}
.btn-lg{height:56px;padding:0 28px;font-size:15px;border-radius:12px}
.btn-xl{height:64px;padding:0 36px;font-size:16px;border-radius:14px}
.btn-ghost{background:rgba(29,42,35,.04)}
.btn-tel{height:48px;border-radius:10px;display:inline-flex;align-items:center;gap:10px;padding:0 18px;font-family:var(--mono);font-size:13px;letter-spacing:-.01em;color:var(--ink);border:1px solid var(--line-2);background:rgba(29,42,35,.04);transition:.2s}
.btn-tel:hover{border-color:var(--line-3);background:rgba(29,42,35,.06)}
.btn-tel .ico{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:#dae3d6;border:1px solid rgba(31,95,67,.35);color:#1f5f43;flex-shrink:0}
.btn-tel .ico svg{width:14px;height:14px}
.btn-tel .l{font-family:var(--sans);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--mute);font-weight:500;line-height:1.2;display:block}
.btn-tel .n{display:block;line-height:1.2}

.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 14px 7px 10px;border:1px solid var(--line-2);background:rgba(247,243,234,.5);border-radius:999px;font-size:13px;color:var(--ink-2);backdrop-filter:blur(8px)}
.eyebrow .pulse{width:7px;height:7px;border-radius:50%;background:var(--live);box-shadow:0 0 0 4px rgba(31,95,67,.18);animation:pulse 2s infinite}
@keyframes pulse{50%{opacity:.5}}

.label-sm{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute)}

/* ============ NAV ============ */
.nav{position:sticky;top:0;z-index:80;background:rgba(236,230,219,.72);backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--line)}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.brand{display:flex;align-items:center;gap:12px;font-weight:600;letter-spacing:-.02em}
.brand-mark{width:38px;height:38px;border-radius:10px;background:#1f5f43;display:grid;place-items:center;box-shadow:0 4px 10px -2px rgba(29,42,35,.18);font-family:var(--sans);font-weight:700;color:#f7f3ea;font-size:14px;letter-spacing:-.04em;position:relative;overflow:hidden}
.brand-mark::after{content:none}
.brand-mark span{position:relative;z-index:1}
.brand-name{font-size:18px;color:var(--ink);letter-spacing:-.025em}
.brand-name b{color:var(--blue-2)}
.nav-links{display:flex;gap:4px;padding:4px;border:1px solid var(--line);border-radius:999px;background:rgba(29,42,35,.04)}
.nav-links a{padding:8px 16px;font-size:14px;color:var(--ink-2);border-radius:999px;transition:.2s;font-weight:500}
.nav-links a:hover{color:#1d2a23;background:rgba(29,42,35,.08)}
.nav-cta{display:flex;align-items:center;gap:12px}
@media(max-width:960px){.nav-links{display:none}.btn-tel .l,.btn-tel .n{display:none}.btn-tel{width:48px;padding:0;justify-content:center}}
@media(max-width:520px){.brand-name{display:none}}

/* ============ HERO ============ */
.hero{position:relative;padding:72px 0 80px;overflow:hidden}
.hero::before{content:none}
.hero::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(212,205,189,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(212,205,189,.04) 1px,transparent 1px);background-size:80px 80px;mask:radial-gradient(800px 480px at 50% 25%,#000 30%,transparent 80%);pointer-events:none}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
@media(max-width:1080px){.hero-grid{grid-template-columns:1fr;gap:48px}}
.hero h1{font-weight:500;font-size:clamp(44px,6.2vw,82px);line-height:1;letter-spacing:-.045em;margin:24px 0 0;color:#1d2a23;text-wrap:balance}
.hero h1 em{font-family:var(--serif);font-weight:400;font-style:italic;letter-spacing:-.025em;color:#1f5f43;padding-right:.04em}
.hero-sub{margin:32px 0 0;max-width:560px}
.hero-sub p{margin:0;font-size:20px;line-height:1.45;color:var(--ink);font-weight:400;letter-spacing:-.015em}
.hero-sub p b{color:#1d2a23;font-weight:500}
.hero-sub .frust{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:15px;color:var(--ink-2);font-weight:400}
.hero-sub .frust::before{content:"";width:18px;height:1px;background:var(--blue-2)}
.hero-cta{margin-top:40px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-trust{margin-top:36px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.hero-trust .av{display:flex}
.hero-trust .av img{width:36px;height:36px;border-radius:50%;border:2.5px solid var(--bg);margin-left:-12px;object-fit:cover}
.hero-trust .av img:first-child{margin-left:0}
.hero-trust .t{display:flex;flex-direction:column;gap:2px}
.hero-trust .stars{color:var(--amber);letter-spacing:1.5px;font-size:14px}
.hero-trust .t b{font-weight:500;font-size:14px}
.hero-trust .t span{font-size:12px;color:var(--mute)}

/* hero panel — human + live data */
.hero-panel{position:relative;aspect-ratio:5/6;max-height:680px;border-radius:24px;overflow:hidden;border:1px solid var(--line-2);background:#1d2a23;box-shadow:0 60px 120px -40px rgba(0,0,0,.7),0 0 0 1px rgba(31,95,67,.18)}
.hero-panel .photo{position:absolute;inset:0;background-image:url('https://framerusercontent.com/images/J0wFKGkcAoDIgiBO6XRFvGYhws.png?width=900');background-size:cover;background-position:center 15%;filter:saturate(.85) contrast(1.05)}
.hero-panel .photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(29,42,35,.35) 0%,transparent 25%,transparent 55%,rgba(29,42,35,.78) 100%)}

/* top status bar */
.hp-top{position:absolute;top:18px;left:18px;right:18px;display:flex;justify-content:space-between;align-items:center;z-index:3}
.hp-status{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;background:rgba(247,243,234,.85);backdrop-filter:blur(14px);border:1px solid rgba(29,42,35,.12);border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#1d2a23}
.hp-status .d{width:7px;height:7px;border-radius:50%;background:var(--live);box-shadow:0 0 0 4px rgba(31,95,67,.22);animation:pulse 2s infinite}
.hp-clock{font-family:var(--mono);font-size:11px;color:#1d2a23;letter-spacing:.1em;padding:8px 12px;background:rgba(247,243,234,.85);backdrop-filter:blur(14px);border:1px solid rgba(29,42,35,.12);border-radius:999px}

/* floating person card */
.hp-person{position:absolute;left:18px;bottom:18px;z-index:3;display:flex;align-items:center;gap:12px;padding:12px 16px 12px 12px;background:rgba(247,243,234,.92);backdrop-filter:blur(18px);border:1px solid rgba(29,42,35,.12);border-radius:14px;max-width:calc(100% - 36px);box-shadow:0 20px 50px -20px rgba(0,0,0,.4)}
.hp-person .av{width:44px;height:44px;border-radius:50%;background:center/cover #1a2440;background-image:url('https://framerusercontent.com/images/J0wFKGkcAoDIgiBO6XRFvGYhws.png?width=200');flex-shrink:0;position:relative;border:2px solid rgba(31,95,67,.5)}
.hp-person .av::after{content:"";position:absolute;right:-2px;bottom:-2px;width:12px;height:12px;border-radius:50%;background:var(--live);border:2px solid #f7f3ea;box-shadow:0 0 0 2px rgba(31,95,67,.3);animation:pulse 2s infinite}
.hp-person .meta h5{margin:0;font-size:14px;color:#1d2a23;font-weight:500;letter-spacing:-.015em}
.hp-person .meta p{margin:2px 0 0;font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.04em}
.hp-person .meta p b{color:var(--live);font-weight:500}

/* live activity card stacked above person */
.hp-event{position:absolute;right:18px;bottom:88px;z-index:3;width:230px;padding:14px;background:rgba(247,243,234,.92);backdrop-filter:blur(18px);border:1px solid rgba(29,42,35,.12);border-radius:14px;box-shadow:0 20px 50px -20px rgba(0,0,0,.4);display:flex;flex-direction:column;gap:8px;animation:slideUp .6s cubic-bezier(.2,.7,.2,1) both;animation-delay:.4s}
@keyframes slideUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.hp-event .hd{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--live)}
.hp-event .hd::before{content:"✓";font-size:11px}
.hp-event .hd span:last-child{color:var(--mute)}
.hp-event h5{margin:0;font-size:14px;color:#1d2a23;font-weight:500;letter-spacing:-.015em;line-height:1.3}
.hp-event p{margin:0;font-size:11.5px;color:var(--ink-2);line-height:1.4}
.hp-event .tags{display:flex;gap:4px;margin-top:2px}
.hp-event .tags i{font-style:normal;font-size:10px;padding:2px 6px;background:rgba(31,95,67,.18);border:1px solid rgba(31,95,67,.3);border-radius:4px;color:var(--blue-soft);font-family:var(--mono)}

/* KPI bar on top */
.hp-kpi{position:absolute;top:64px;right:18px;z-index:3;display:flex;flex-direction:column;gap:6px;padding:14px 16px;background:rgba(247,243,234,.92);backdrop-filter:blur(18px);border:1px solid rgba(29,42,35,.12);border-radius:14px;min-width:170px;box-shadow:0 20px 50px -20px rgba(0,0,0,.4)}
.hp-kpi .row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding:4px 0;border-bottom:1px dashed rgba(29,42,35,.12)}
.hp-kpi .row:last-child{border:0}
.hp-kpi .row .k{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--mute)}
.hp-kpi .row .v{font-family:var(--mono);font-size:15px;font-weight:500;color:#1d2a23}
.hp-kpi .row .v small{color:var(--live);font-weight:400;font-size:11px}

@media(max-width:600px){.hp-kpi{display:none}.hp-event{width:auto;right:18px;left:18px;bottom:90px}}

/* logos bar */
.logos{margin-top:88px;padding:32px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;z-index:1}
.logos-row{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.logos-lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);flex-shrink:0}
.logos-set{display:flex;gap:48px;align-items:center;flex-wrap:wrap;flex:1;justify-content:flex-end;opacity:.7}
.logo-mark{font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:-.01em;color:var(--ink-2);text-transform:uppercase;display:inline-flex;align-items:center;gap:6px}
.logo-mark.serif{font-family:var(--serif);font-style:italic;font-weight:400;font-size:22px;letter-spacing:-.02em;text-transform:none}
.logo-mark.mono{font-family:var(--mono);font-size:13px;font-weight:500;text-transform:lowercase;letter-spacing:.02em}
.logo-mark .dot{width:6px;height:6px;border-radius:50%;background:var(--ink-2)}
.logo-mark.box{padding:6px 10px;border:1px solid var(--ink-2);font-size:12px;border-radius:4px}

/* ============ SECTION CHROME ============ */
section{padding:104px 0;position:relative}
.sec-hd{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end;margin-bottom:64px}
@media(max-width:760px){.sec-hd{grid-template-columns:1fr}}
.sec-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px 6px 10px;border-radius:999px;background:rgba(31,95,67,.12);color:var(--blue-soft);font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.04em;border:1px solid rgba(31,95,67,.22);text-transform:uppercase}
.sec-pill .n{font-size:10px;padding:2px 6px;border-radius:4px;background:rgba(31,95,67,.18);color:var(--blue-soft);letter-spacing:.06em}
.sec-h{font-weight:500;font-size:clamp(32px,4.4vw,58px);line-height:1.04;letter-spacing:-.035em;margin:18px 0 0;color:#1d2a23;text-wrap:balance;max-width:900px}
.sec-h em{font-family:var(--serif);font-style:italic;font-weight:400;color:#1f5f43}
.sec-sub{margin-top:18px;color:var(--ink-2);font-size:18px;max-width:580px}

/* ============ REFERENZEN ============ */
#referenzen{padding-top:80px}
.ref-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:linear-gradient(180deg,rgba(247,243,234,.6),rgba(247,243,234,.6));margin-bottom:32px}
@media(max-width:880px){.ref-strip{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.ref-strip{grid-template-columns:1fr}}
.ref-num{padding:28px 24px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:6px;text-align:left}
.ref-num:last-child{border-right:0}
@media(max-width:880px){.ref-num:nth-child(2n){border-right:0}.ref-num:nth-child(-n+2){border-bottom:1px solid var(--line)}}
@media(max-width:480px){.ref-num{border-right:0;border-bottom:1px solid var(--line)}.ref-num:last-child{border-bottom:0}}
.ref-num .v{font-size:clamp(36px,4vw,52px);font-weight:500;letter-spacing:-.035em;line-height:1;color:#1d2a23;font-variant-numeric:tabular-nums}
.ref-num .v small{color:var(--blue-soft);font-weight:500}
.ref-num .l{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-top:4px}
.ref-num .d{font-size:12.5px;color:var(--ink-2);margin-top:8px;line-height:1.4}

.ref-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:760px){.ref-grid{grid-template-columns:1fr}}
.ref{position:relative;padding:32px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(247,243,234,.45),rgba(247,243,234,.45));display:flex;flex-direction:column;gap:24px;transition:.3s;overflow:hidden}
.ref:hover{border-color:var(--line-3);transform:translateY(-3px)}
.ref::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 240px at 0% 0%,rgba(31,95,67,.12),transparent 60%);opacity:0;transition:.3s;pointer-events:none}
.ref:hover::before{opacity:1}
.ref-head{display:flex;justify-content:space-between;align-items:center}
.ref-head .stars{color:var(--amber);letter-spacing:2px;font-size:15px}
.ref-head .logo{font-family:var(--mono);font-size:12px;color:var(--ink-2);letter-spacing:.04em;display:inline-flex;align-items:center;gap:8px;padding:5px 10px;border:1px solid var(--line-2);border-radius:6px;background:rgba(29,42,35,.04)}
.ref-q{margin:0;font-size:20px;line-height:1.4;color:#1d2a23;font-weight:400;letter-spacing:-.015em;flex:1}
.ref-q::before{content:"\201E";color:var(--blue-2);font-size:1.1em;line-height:0;vertical-align:-.25em;margin-right:.05em;font-family:var(--serif)}
.ref-q::after{content:".\201C";color:var(--blue-2);font-size:1.1em;line-height:0;vertical-align:-.25em;margin-left:.05em;font-family:var(--serif)}
.ref-result{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:12px;background:rgba(63,123,255,.08);border:1px solid rgba(63,123,255,.18)}
.ref-result .icon{width:36px;height:36px;border-radius:10px;background:rgba(31,95,67,.18);border:1px solid rgba(31,95,67,.3);display:grid;place-items:center;color:var(--blue-2);flex-shrink:0}
.ref-result .icon svg{width:18px;height:18px}
.ref-result .txt{display:flex;flex-direction:column;gap:0}
.ref-result .v{font-size:18px;font-weight:600;color:#1d2a23;letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1.1}
.ref-result .l{font-size:12px;color:var(--ink-2);margin-top:2px}
.ref-foot{display:flex;align-items:center;gap:12px;padding-top:20px;border-top:1px solid var(--line)}
.ref-foot img{width:44px;height:44px;border-radius:50%;object-fit:cover}
.ref-foot .nm{font-size:15px;font-weight:500;letter-spacing:-.01em}
.ref-foot .rl{font-size:12.5px;color:var(--mute)}

/* ============ 4 OPTIONS — BIGGER, NUMBERED, ICON ============ */
.opts4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:1080px){.opts4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.opts4{grid-template-columns:1fr}}
.opt4{position:relative;padding:30px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(247,243,234,.5),rgba(247,243,234,.5));display:flex;flex-direction:column;gap:20px;min-height:340px;transition:.3s;overflow:hidden}
.opt4:hover{border-color:var(--line-3);transform:translateY(-3px);background:#dae3d6}
.opt4::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#1f5f43;opacity:0;transition:.3s}
.opt4:hover::before{opacity:1}
.opt4-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.opt4-num{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--blue-soft);padding:6px 10px 6px 8px;border:1px solid rgba(31,95,67,.3);border-radius:8px;background:rgba(31,95,67,.1);letter-spacing:.04em;display:inline-flex;align-items:center;gap:6px}
.opt4-num::before{content:"";width:6px;height:6px;border-radius:2px;background:var(--blue-2)}
.opt4-icon{width:48px;height:48px;border-radius:12px;background:#dae3d6;border:1px solid rgba(31,95,67,.3);display:grid;place-items:center;color:#1f5f43}
.opt4-icon svg{width:24px;height:24px}
.opt4 h3{margin:0;font-size:22px;font-weight:500;letter-spacing:-.025em;line-height:1.15;color:#1d2a23}
.opt4 h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--blue-soft)}
.opt4 p{margin:0;font-size:14.5px;color:var(--ink-2);line-height:1.55;flex:1}
.opt4-foot{display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.opt4-foot .tag{color:var(--mute)}
.opt4-foot .arrow{color:var(--blue-2);display:inline-flex;align-items:center;gap:6px;transition:.2s}
.opt4:hover .opt4-foot .arrow{transform:translateX(4px);color:#1d2a23}

/* ============ MUNICH STRIP ============ */
.strip{margin-top:104px}
.strip-inner{display:grid;grid-template-columns:1fr 1.15fr;border-radius:24px;overflow:hidden;border:1px solid #17472f;background:#1f5f43;min-height:520px}
@media(max-width:900px){.strip-inner{grid-template-columns:1fr}}
.strip-img{background-size:cover;background-position:center;position:relative;min-height:340px;filter:saturate(.9) contrast(1.05)}
.strip-img::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(31,95,67,0) 55%,#1f5f43)}
.strip-img .tag{position:absolute;top:24px;left:24px;display:inline-flex;align-items:center;gap:8px;padding:7px 14px 7px 10px;background:rgba(29,42,35,.5);backdrop-filter:blur(14px);border:1px solid rgba(247,243,234,.22);border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#f7f3ea;z-index:2}
.strip-img .tag::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--live);box-shadow:0 0 0 4px rgba(31,95,67,.22);animation:pulse 2s infinite}
.strip-body{padding:64px 56px;display:flex;flex-direction:column;justify-content:center;gap:24px}
@media(max-width:600px){.strip-body{padding:40px 28px}}
.strip-body h3{font-weight:500;font-size:clamp(30px,3.8vw,48px);letter-spacing:-.03em;line-height:1.1;margin:0;color:#f7f3ea;text-wrap:balance}
.strip-body h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:#dae3d6}
.strip-body p{margin:0;color:rgba(247,243,234,.82);font-size:17px;line-height:1.6;max-width:520px}
.strip-body p b{color:#f7f3ea;font-weight:500}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:999px;background:rgba(29,42,35,.06);border:1px solid var(--line-2);font-size:13px;color:var(--ink)}
.chip::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--live)}

/* strip-body green CTA overrides */
.strip-body .eyebrow{background:rgba(247,243,234,.12);border-color:rgba(247,243,234,.22);color:#f7f3ea}
.strip-body .eyebrow .pulse{background:#dae3d6;box-shadow:0 0 0 4px rgba(218,227,214,.22)}
.strip-body .chip{background:rgba(247,243,234,.1);border-color:rgba(247,243,234,.22);color:#f7f3ea}
.strip-body .chip::before{background:#dae3d6}
.strip-body .btn-primary{background:#f7f3ea;border-color:#f7f3ea;color:#1f5f43;box-shadow:0 6px 14px -4px rgba(0,0,0,.22),0 2px 4px -1px rgba(0,0,0,.12)}
.strip-body .btn-primary:hover{background:#fff;border-color:#fff;color:#17472f}

/* ============ ABLAUF — 4 BIG STEPS ============ */
#ablauf .sec-hd{margin-bottom:48px}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;position:relative}
@media(max-width:1080px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:32px 28px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(247,243,234,.55),rgba(247,243,234,.55));display:flex;flex-direction:column;gap:18px;min-height:340px;transition:.3s}
.step:hover{border-color:var(--line-3);transform:translateY(-3px)}
.step-day{display:flex;justify-content:space-between;align-items:center}
.step-day .day{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-soft);padding:5px 10px;border:1px solid rgba(31,95,67,.3);border-radius:6px;background:rgba(31,95,67,.1)}
.step-day .pill{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.step-num{font-family:var(--serif);font-style:italic;font-weight:400;font-size:96px;letter-spacing:-.04em;line-height:.85;color:var(--blue-2);opacity:.95;margin-top:-8px}
.step h3{margin:0;font-size:22px;font-weight:500;letter-spacing:-.025em;line-height:1.1;color:#1d2a23}
.step p{margin:0;font-size:14.5px;color:var(--ink-2);line-height:1.55}
.step-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--ink-2)}
.step-list li{display:grid;grid-template-columns:14px 1fr;gap:8px;line-height:1.5}
.step-list li::before{content:"";grid-column:1;width:6px;height:6px;border-radius:50%;background:var(--blue-2);margin-top:7px}

/* ============ SERVICES — 3 EQUAL CARDS ============ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:980px){.svc-grid{grid-template-columns:1fr}}
.svc{position:relative;padding:36px;border:1px solid var(--line);border-radius:20px;background:linear-gradient(180deg,rgba(247,243,234,.5),rgba(247,243,234,.5));display:flex;flex-direction:column;gap:24px;transition:.3s;overflow:hidden}
.svc:hover{transform:translateY(-4px);border-color:var(--line-3)}
.svc.featured{background:#dae3d6;border-color:#1f5f43;box-shadow:0 10px 30px -10px rgba(29,42,35,.15)}
.svc.featured::before{content:none}
.svc-head{position:relative;display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:20px;border-bottom:1px solid var(--line)}
.svc-no-big{font-family:var(--serif);font-style:italic;font-weight:400;font-size:64px;letter-spacing:-.04em;line-height:.85;color:var(--blue-2)}
.svc-tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);padding:5px 10px;border:1px solid var(--line-2);border-radius:6px;background:rgba(29,42,35,.04);align-self:flex-end}
.svc.featured .svc-tag{color:var(--blue-soft);border-color:rgba(31,95,67,.4);background:rgba(31,95,67,.1)}
.svc h3{margin:0;font-size:28px;font-weight:500;letter-spacing:-.03em;line-height:1.1;color:#1d2a23;position:relative}
.svc h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--blue-soft)}
.svc ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;position:relative}
.svc li{display:grid;grid-template-columns:22px 1fr;gap:10px;font-size:14.5px;line-height:1.55;color:var(--ink-2)}
.svc li b{color:#1d2a23;font-weight:500}
.svc li .ico{width:18px;height:18px;border-radius:50%;border:1px solid var(--blue-2);background:radial-gradient(circle,var(--blue) 0 35%,transparent 36%);margin-top:2px}
.svc .svc-cta{margin-top:auto;position:relative}
.svc .svc-cta .btn{width:100%}

/* ============ TEAM — DIFFERENTIATED ============ */
#team{padding-top:80px}
.team-grid{display:grid;grid-template-columns:1.15fr 1fr 1fr;gap:18px}
@media(max-width:980px){.team-grid{grid-template-columns:1fr}}
.mem{position:relative;border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--panel);transition:.3s;display:flex;flex-direction:column}
.mem:hover{border-color:var(--line-3);transform:translateY(-4px)}
.mem.lead{border-color:rgba(31,95,67,.4);background:linear-gradient(180deg,rgba(31,95,67,.1),rgba(247,243,234,.5));box-shadow:0 30px 60px -30px rgba(31,95,67,.3)}
.mem-img{aspect-ratio:4/5;background-size:cover;background-position:center top;position:relative}
.mem.lead .mem-img{aspect-ratio:1/1.1}
.mem-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(29,42,35,.88))}
.mem-badge{position:absolute;top:16px;left:16px;display:inline-flex;align-items:center;gap:7px;padding:6px 11px;border-radius:999px;background:rgba(29,42,35,.5);backdrop-filter:blur(10px);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#f7f3ea;border:1px solid rgba(247,243,234,.22);z-index:1}
.mem-badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--live);box-shadow:0 0 0 3px rgba(31,95,67,.22)}
.mem.lead .mem-badge{background:#1f5f43;border-color:#17472f;color:#f7f3ea}
.mem-lead-tag{position:absolute;top:16px;right:16px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#f7f3ea;padding:5px 10px;background:#1f5f43;border:1px solid #17472f;border-radius:6px;z-index:1;box-shadow:0 4px 10px -2px rgba(29,42,35,.18)}
.mem-name{position:absolute;left:24px;right:24px;bottom:22px;z-index:1}
.mem-name h4{margin:0;font-size:24px;font-weight:500;letter-spacing:-.025em;color:#f7f3ea;line-height:1.05}
.mem-name h4 em{font-family:var(--serif);font-style:italic;font-weight:400;color:#dae3d6}
.mem-name p{margin:4px 0 0;font-size:13px;color:rgba(247,243,234,.85);font-family:var(--mono);letter-spacing:.04em}
.mem-body{padding:0;display:flex;flex-direction:column}
.mem-quote{padding:18px 22px;font-size:13.5px;color:var(--ink-2);line-height:1.5;border-bottom:1px solid var(--line);font-style:italic}
.mem-quote::before{content:"\201E";color:var(--blue-2);font-size:1.3em;font-family:var(--serif);font-style:italic;line-height:0;vertical-align:-.3em;margin-right:.05em}
.mem-quote::after{content:".\201C";color:var(--blue-2);font-size:1.3em;font-family:var(--serif);font-style:italic;line-height:0;vertical-align:-.3em;margin-left:.05em}
.mem-stats{display:grid;grid-template-columns:repeat(3,1fr)}
.mem-stat{padding:18px 14px;border-right:1px solid var(--line);text-align:left}
.mem-stat:last-child{border-right:0}
.mem-stat .v{font-size:22px;font-weight:500;letter-spacing:-.02em;color:#1d2a23;line-height:1;font-variant-numeric:tabular-nums}
.mem-stat .v em{font-family:var(--serif);font-style:italic;color:var(--blue-soft);font-weight:400}
.mem-stat .l{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-top:6px}

/* ============ BIG QUOTE ============ */
.bigq{padding:120px 0;text-align:center;position:relative;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.bigq::before{content:none}
.bigq blockquote{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(32px,5.2vw,68px);letter-spacing:-.025em;line-height:1.12;max-width:1100px;margin:0 auto;color:#1d2a23;position:relative;text-wrap:balance}
.bigq blockquote::before{content:"\201E";color:var(--blue-2);margin-right:.04em}
.bigq blockquote::after{content:".\201C";color:var(--blue-2);margin-left:.04em}
.bigq cite{display:block;margin-top:36px;font-style:normal;font-family:var(--mono);font-size:12px;color:var(--mute);letter-spacing:.16em;text-transform:uppercase}

/* ============ CONTACT — BIG ============ */
#kontakt{padding:104px 0 120px;position:relative}
#kontakt::before{content:none}
.contact-card{position:relative;display:grid;grid-template-columns:1.1fr 1fr;border-radius:24px;overflow:hidden;border:1px solid var(--line-2);background:linear-gradient(135deg,rgba(247,243,234,.6),rgba(247,243,234,.6));backdrop-filter:blur(12px);box-shadow:0 60px 120px -40px rgba(0,0,0,.6)}
@media(max-width:960px){.contact-card{grid-template-columns:1fr}}
.contact-left{padding:64px 56px;display:flex;flex-direction:column;gap:24px}
@media(max-width:600px){.contact-left{padding:40px 28px}}
.contact-left h3{font-weight:500;font-size:clamp(34px,4.2vw,52px);line-height:1.05;letter-spacing:-.035em;margin:0;color:#1d2a23;text-wrap:balance}
.contact-left h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--blue-soft)}
.contact-left .lede{font-size:17px;color:var(--ink-2);max-width:480px;margin:0;line-height:1.55}
.contact-meta{display:flex;flex-direction:column;gap:16px;padding-top:24px;border-top:1px solid var(--line);margin-top:auto}
.contact-meta .row{display:flex;align-items:center;gap:14px}
.contact-meta .ico{width:36px;height:36px;border-radius:10px;background:rgba(31,95,67,.18);border:1px solid rgba(31,95,67,.3);color:var(--blue-2);display:grid;place-items:center;flex-shrink:0}
.contact-meta .ico svg{width:16px;height:16px}
.contact-meta .k{font-family:var(--mono);font-size:10px;color:var(--mute);text-transform:uppercase;letter-spacing:.12em;display:block}
.contact-meta .v{color:var(--ink);font-size:14.5px;font-weight:500;display:block;line-height:1.3}
.contact-right{padding:64px 56px;border-left:1px solid var(--line);background:rgba(236,230,219,.4)}
@media(max-width:960px){.contact-right{border-left:0;border-top:1px solid var(--line);padding:40px 28px}}
.form{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field{display:flex;flex-direction:column;gap:6px;position:relative}
.field.full{grid-column:1/-1}
.field label{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.field input,.field textarea{font:inherit;color:var(--ink);background:#f7f3ea;border:1px solid var(--line-2);padding:14px 16px;border-radius:10px;outline:none;transition:.2s;font-size:15px}
.field input:focus,.field textarea:focus{border-color:var(--blue-2);background:rgba(29,42,35,.06);box-shadow:0 0 0 4px rgba(31,95,67,.12)}
.field textarea{min-height:110px;resize:vertical;font-family:inherit}
.form .submit-wrap{grid-column:1/-1;display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:8px}
.form .privacy{font-size:12px;color:var(--mute);max-width:380px;line-height:1.5}

/* ============ FOOTER ============ */
footer{padding:80px 0 36px;border-top:1px solid var(--line)}
.foot{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;align-items:start}
@media(max-width:880px){.foot{grid-template-columns:1fr 1fr;gap:32px}}
.foot p{margin:18px 0 0;max-width:340px;color:var(--ink-2);font-size:14px;line-height:1.55}
.foot-col h5{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--mute);margin:0 0 18px;font-weight:500}
.foot-col a{display:block;font-size:14.5px;color:var(--ink-2);padding:5px 0;transition:.2s}
.foot-col a:hover{color:#1d2a23}
.foot-bot{margin-top:56px;padding-top:28px;border-top:1px solid var(--line);display:flex;justify-content:space-between;color:var(--mute);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;flex-wrap:wrap;gap:12px}

/* ============ MODAL ============ */
.modal-overlay{position:fixed;inset:0;background:rgba(29,42,35,.7);backdrop-filter:blur(12px);z-index:200;display:none;align-items:center;justify-content:center;padding:24px;opacity:0;transition:.25s}
.modal-overlay.open{display:flex;opacity:1}
.modal{position:relative;width:100%;max-width:540px;border-radius:24px;border:1px solid var(--line-2);background:linear-gradient(180deg,rgba(247,243,234,.95),rgba(247,243,234,.95));backdrop-filter:blur(20px);box-shadow:0 60px 120px -30px rgba(0,0,0,.7),0 0 0 1px rgba(31,95,67,.18);padding:36px;max-height:calc(100vh - 48px);overflow-y:auto;transform:translateY(12px) scale(.98);transition:.3s cubic-bezier(.2,.7,.2,1)}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
.modal::before{content:none}
.modal-close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:10px;background:rgba(29,42,35,.06);border:1px solid var(--line-2);color:var(--ink-2);display:grid;place-items:center;cursor:pointer;transition:.2s;z-index:2}
.modal-close:hover{background:rgba(29,42,35,.12);color:#1d2a23}
.modal-head{position:relative;margin-bottom:24px}
.modal-head .pill{display:inline-flex;align-items:center;gap:8px;padding:5px 12px 5px 8px;font-family:var(--mono);font-size:11px;color:var(--blue-soft);border:1px solid rgba(31,95,67,.3);border-radius:999px;background:rgba(31,95,67,.1);letter-spacing:.06em;text-transform:uppercase}
.modal-head .pill .d{width:6px;height:6px;border-radius:50%;background:var(--live);box-shadow:0 0 0 3px rgba(31,95,67,.18)}
.modal-head h3{margin:14px 0 6px;font-size:28px;font-weight:500;letter-spacing:-.03em;line-height:1.1;color:#1d2a23}
.modal-head h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--blue-soft)}
.modal-head p{margin:0;color:var(--ink-2);font-size:14.5px;line-height:1.5}
.modal .form{grid-template-columns:1fr 1fr}

/* picker */
.picker{position:fixed;top:50%;right:18px;transform:translateY(-50%);z-index:90;display:flex;flex-direction:column;gap:6px;background:rgba(247,243,234,.78);backdrop-filter:blur(14px);border:1px solid var(--line-2);border-radius:12px;padding:10px}
.picker a{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-2);padding:7px 12px;border-radius:8px;transition:.2s}
.picker a:hover{color:#1d2a23;background:rgba(29,42,35,.1)}
.picker a.cur{background:#1f5f43;color:#f7f3ea}
.picker .ph{font-family:var(--mono);font-size:9px;letter-spacing:.14em;color:var(--mute);text-transform:uppercase;padding:2px 12px}
@media(max-width:1200px){.picker{display:none}}

/* ============ MOBILE OVERRIDES ============ */
@media(max-width:760px){
  section{padding:72px 0}
  .sec-hd{margin-bottom:36px}
  .hero{padding:48px 0 64px}
  .hero h1{margin-top:18px}
  .hero-cta .btn{flex:1 1 auto}
  .ref{padding:24px}
  .ref-q{font-size:18px}
  .opt4{padding:24px;min-height:auto}
  .svc{padding:28px}
  .step{padding:24px}
  .step-num{font-size:72px}
  .contact-left,.contact-right{padding:36px 24px}
  .modal{padding:28px 22px}
  .modal .form{grid-template-columns:1fr}
}

/* ============ Unterseiten ============ */
.nav-links a[aria-current="page"]{color:#1d2a23;background:rgba(29,42,35,.08)}

/* Seitenkopf */
.page-head{padding:72px 0 0}
.page-head .sec-hd{margin-bottom:40px}
.page-lede{color:var(--ink-2);font-size:18px;max-width:660px;margin:18px 0 0;line-height:1.6}
.page-lede b{color:#1d2a23;font-weight:500}

/* Fliesstext / Recht */
.prose{max-width:780px;margin:0 auto}
.prose h3{font-size:24px;font-weight:500;letter-spacing:-.02em;color:#1d2a23;margin:40px 0 12px}
.prose h4{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin:28px 0 8px}
.prose p{color:var(--ink-2);font-size:15.5px;line-height:1.65;margin:0 0 14px}
.prose ul{color:var(--ink-2);font-size:15.5px;line-height:1.65;padding-left:20px;margin:0 0 14px}
.prose li{margin:4px 0}
.prose a{color:var(--blue-2);text-decoration:underline;text-underline-offset:2px}
.prose .ph{background:rgba(192,138,45,.16);border:1px solid rgba(192,138,45,.45);border-radius:6px;padding:1px 7px;color:#8a5e12;font-family:var(--mono);font-size:13px;white-space:nowrap}

/* FAQ */
.faq{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq details{border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,rgba(247,243,234,.55),rgba(247,243,234,.55));overflow:hidden;transition:.3s}
.faq details[open]{border-color:var(--line-3)}
.faq summary{list-style:none;cursor:pointer;padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:18px;font-size:17.5px;font-weight:500;letter-spacing:-.015em;color:#1d2a23}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);font-size:24px;line-height:1;color:var(--blue-2);transition:.3s;flex-shrink:0}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details>p{margin:0;padding:0 24px 24px;color:var(--ink-2);font-size:15.5px;line-height:1.6;max-width:720px}

/* Jotform */
.jotframe{width:100%;border:0;border-radius:14px;min-height:760px;background:var(--panel);display:block}

/* Leistungs-Detail: Punkteliste */
.lead-points{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:760px){.lead-points{grid-template-columns:1fr}}
.lead-points li{display:grid;grid-template-columns:22px 1fr;gap:12px;font-size:15px;line-height:1.55;color:var(--ink-2);padding:20px;border:1px solid var(--line);border-radius:14px;background:rgba(247,243,234,.5)}
.lead-points li b{color:#1d2a23;font-weight:500}
.lead-points li .ico{width:18px;height:18px;border-radius:50%;border:1px solid var(--blue-2);background:radial-gradient(circle,var(--blue) 0 35%,transparent 36%);margin-top:2px}

/* opt4 als Link */
a.opt4{cursor:pointer}

/* einfache CTA-Leiste */
.cta-simple{margin-top:24px;border:1px solid #17472f;background:#1f5f43;border-radius:24px;padding:56px 48px;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
@media(max-width:600px){.cta-simple{padding:40px 28px}}
.cta-simple h3{font-weight:500;font-size:clamp(26px,3vw,40px);letter-spacing:-.03em;line-height:1.1;margin:0;color:#f7f3ea;max-width:20ch}
.cta-simple h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:#dae3d6}
.cta-simple .actions{display:flex;gap:12px;flex-wrap:wrap}
.cta-simple .btn-primary{background:#f7f3ea;border-color:#f7f3ea;color:#1f5f43}
.cta-simple .btn-primary:hover{background:#fff;border-color:#fff;color:#17472f}
.cta-simple .btn-tel{background:rgba(247,243,234,.12);border-color:rgba(247,243,234,.3);color:#f7f3ea}
.cta-simple .btn-tel:hover{background:rgba(247,243,234,.2);border-color:rgba(247,243,234,.5)}
.cta-simple .btn-tel .ico{background:rgba(247,243,234,.15);border-color:rgba(247,243,234,.3);color:#f7f3ea}
.cta-simple .btn-tel .l{color:rgba(247,243,234,.7)}
