/* ============================================================
   Kurt Mager Solutions — Anfrage-Konfigurator (Designkonzept)
   Ländle Digital
============================================================ */
:root{
  --green:#1366c8; --green-600:#0f57aa; --green-700:#0b4789; --green-50:#e8f1fc;
  --navy:#15314f; --navy-600:#1e3f64; --navy-800:#0e2236;
  --ink:#0f1b2a; --slate:#56657a; --muted:#7e8da0;
  --line:#e4e9f0; --line-2:#eef2f7;
  --bg:#ffffff; --soft:#f4f7fb; --soft-2:#eef3f8;
  --white:#fff; --danger:#dc2626;
  --r:16px; --r-sm:11px; --r-lg:22px;
  --sh-sm:0 1px 2px rgba(15,27,42,.06), 0 1px 3px rgba(15,27,42,.05);
  --sh:0 10px 30px -12px rgba(15,49,79,.18);
  --sh-lg:0 30px 60px -22px rgba(15,49,79,.30);
  --ring:0 0 0 4px rgba(19,102,200,.16);
  --shell:1160px;
  --grad:linear-gradient(120deg,var(--green) 0%, #1f6fd0 48%, var(--navy-600) 100%);
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --disp:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
svg:not([width]){max-width:3rem;max-height:3rem}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-family:var(--disp);line-height:1.12;letter-spacing:-.018em;font-weight:700}
p{margin:0}
ul,ol{margin:0;padding:0;list-style:none}
button{font-family:inherit}
.shell{width:100%;max-width:var(--shell);margin-inline:auto;padding-inline:24px}

/* ---------- buttons ---------- */
.btn{
  --bgc:var(--ink);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-weight:600;font-size:.95rem;line-height:1;cursor:pointer;
  padding:.85em 1.3em;border-radius:999px;border:1.5px solid transparent;
  background:var(--bgc);color:var(--fg);transition:transform .15s,box-shadow .2s,background .2s,color .2s,border-color .2s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{--bgc:var(--green);box-shadow:0 8px 20px -8px rgba(19,102,200,.6)}
.btn--primary:hover{--bgc:var(--green-600);box-shadow:0 12px 26px -8px rgba(19,102,200,.7)}
.btn--ghost{--bgc:transparent;--fg:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink);background:var(--soft)}
.btn--lg{padding:1.05em 1.7em;font-size:1.02rem}
.btn--sm{padding:.66em 1.05em;font-size:.88rem}
.btn--block{width:100%}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}

/* ---------- eyebrow / titles ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--disp);font-weight:600;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--green-600);background:var(--green-50);padding:.45em .9em;border-radius:999px;
}
.eyebrow--center{margin-inline:auto}
.eyebrow--light{color:#bcd9fb;background:rgba(255,255,255,.08)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(19,102,200,.18)}
.eyebrow--light .dot{background:#8fc2f7;box-shadow:0 0 0 4px rgba(143,194,247,.18)}
.sec__title{font-size:clamp(1.7rem,3.4vw,2.5rem);margin:.5rem 0 .7rem}
.sec__title--light{color:#fff}
.sec__sub{color:var(--slate);max-width:60ch;font-size:1.05rem}
.eyebrow--center+.sec__title,.config__head{text-align:center}
.config__head{max-width:680px;margin:0 auto 2.6rem;display:flex;flex-direction:column;align-items:center}
.config__head .sec__sub{margin-inline:auto}

/* ============================================================ TOPBAR ============================================================ */
.topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.topbar__inner{display:flex;align-items:center;gap:20px;height:72px}
.brand{display:flex;align-items:center;gap:11px}
.brand__mark{
  display:grid;place-items:center;width:42px;height:42px;border-radius:11px;
  background:var(--green);color:#fff;font-family:var(--disp);font-weight:700;font-size:1.15rem;letter-spacing:-.04em;
  box-shadow:0 6px 14px -6px rgba(19,102,200,.7);
}
.brand__text{font-family:var(--disp);font-weight:600;font-size:1rem;line-height:1.05;letter-spacing:-.02em}
.brand__text small{display:block;font-family:var(--font);font-weight:500;font-size:.68rem;letter-spacing:.02em;color:var(--slate)}
.topbar__nav{display:flex;gap:6px;margin-left:8px}
.topbar__nav a{padding:.5em .8em;border-radius:9px;font-weight:500;font-size:.94rem;color:var(--slate);transition:color .15s,background .15s}
.topbar__nav a:hover{color:var(--ink);background:var(--soft)}
.topbar__actions{margin-left:auto;display:flex;align-items:center;gap:14px}
.topbar__phone{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.92rem;color:var(--ink)}
.topbar__phone svg{color:var(--green)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;margin-left:auto;cursor:pointer}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.topbar__mobile{display:none;flex-direction:column;gap:4px;padding:12px 24px 20px;border-bottom:1px solid var(--line);background:#fff}
.topbar__mobile.open{display:flex}
.topbar__mobile a{padding:.8em .6em;font-weight:500;color:var(--ink);border-radius:9px}
.topbar__mobile a:hover{background:var(--soft)}
.topbar__mobile .btn{margin-top:6px}

/* ============================================================ HERO ============================================================ */
.hero{position:relative;overflow:hidden;background:var(--soft)}
.hero__bg{position:absolute;inset:0;background:
  radial-gradient(60% 80% at 85% 10%, rgba(19,102,200,.10), transparent 60%),
  radial-gradient(55% 70% at 5% 90%, rgba(21,49,79,.10), transparent 55%);
}
.hero__bg::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--line-2) 1px,transparent 1px),linear-gradient(90deg,var(--line-2) 1px,transparent 1px);
  background-size:46px 46px;-webkit-mask-image:radial-gradient(80% 60% at 50% 30%,#000,transparent 75%);mask-image:radial-gradient(80% 60% at 50% 30%,#000,transparent 75%);}
.hero__inner{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center;padding:78px 24px 92px}
.hero__title{font-size:clamp(2.1rem,5vw,3.55rem);line-height:1.04;margin:1.1rem 0 1.1rem}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__sub{font-size:1.14rem;color:var(--slate);max-width:54ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin:2rem 0 1.8rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px 26px}
.hero__trust li{font-size:.95rem;color:var(--slate)}
.hero__trust strong{color:var(--ink);font-family:var(--disp)}

/* teaser card */
.hero__card{perspective:1400px}
.tcard{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;box-shadow:var(--sh-lg);
  transform:rotate3d(1,-1,0,1deg);animation:float 7s ease-in-out infinite;
}
@keyframes float{50%{transform:translateY(-10px) rotate3d(1,-1,0,1deg)}}
.tcard__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.tcard__step{font-size:.8rem;color:var(--slate);font-weight:600}
.tcard__pill{font-size:.72rem;font-weight:600;color:var(--green-600);background:var(--green-50);padding:.35em .7em;border-radius:999px}
.tcard__bar{height:7px;border-radius:999px;background:var(--soft-2);overflow:hidden;margin-bottom:18px}
.tcard__bar span{display:block;height:100%;background:var(--grad);border-radius:999px}
.tcard__q{font-family:var(--disp);font-weight:600;font-size:1.08rem;margin-bottom:13px}
.tcard__chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.chip{font-size:.85rem;font-weight:500;padding:.5em .8em;border-radius:10px;border:1.5px solid var(--line);color:var(--slate);background:#fff}
.chip.is-on{border-color:var(--green);color:var(--green-700);background:var(--green-50);font-weight:600}
.tcard__est{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:15px;background:var(--soft);border-radius:var(--r-sm);margin-bottom:14px}
.tcard__est .muted{display:block;font-size:.72rem;color:var(--slate);margin-bottom:3px}
.tcard__est strong{font-family:var(--disp);font-size:.98rem}
.tcard__est .pn{color:var(--green-700)}
.tcard__est .pn i{color:var(--muted);font-style:normal;font-weight:500;font-size:.8rem}
.tcard__foot{display:flex;align-items:center;gap:.5em;font-size:.85rem;color:var(--green-700);font-weight:600}
.tcard__foot svg{color:var(--green)}

/* ============================================================ STRIP ============================================================ */
.strip{border-block:1px solid var(--line);background:#fff}
.strip__inner{display:flex;flex-wrap:wrap;align-items:center;gap:14px 34px;padding:22px 24px}
.strip__label{font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.strip__items{display:flex;flex-wrap:wrap;gap:10px 26px}
.strip__items li{font-family:var(--disp);font-weight:600;color:var(--navy);font-size:1.02rem;position:relative;opacity:.85}
.strip__items li::before{content:"";position:absolute;left:-14px;top:50%;width:5px;height:5px;border-radius:50%;background:var(--green);transform:translateY(-50%)}
.strip__items li:first-child::before{display:none}

/* ============================================================ CONFIGURATOR ============================================================ */
.config{padding:84px 0 90px;background:linear-gradient(180deg,var(--bg),var(--soft) 60%)}
.config__grid{display:grid;grid-template-columns:1fr 340px;gap:30px;align-items:start}
.config__main{min-width:0}
.wizard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);overflow:hidden}

/* progress */
.wizard__progress{display:flex;gap:4px;padding:20px 26px;border-bottom:1px solid var(--line-2);overflow-x:auto;scrollbar-width:none}
.wizard__progress::-webkit-scrollbar{display:none}
.pstep{display:flex;align-items:center;gap:9px;flex:0 0 auto;opacity:.55;transition:opacity .25s}
.pstep__num{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--soft-2);color:var(--slate);font-size:.8rem;font-weight:700;font-family:var(--disp);transition:.25s}
.pstep__label{font-size:.84rem;font-weight:600;color:var(--slate);white-space:nowrap}
.pstep__sep{width:18px;height:1.5px;background:var(--line);flex:0 0 auto;border-radius:2px}
.pstep.is-active{opacity:1}
.pstep.is-active .pstep__num{background:var(--green);color:#fff;box-shadow:var(--ring)}
.pstep.is-active .pstep__label{color:var(--ink)}
.pstep.is-done{opacity:1;cursor:pointer}
.pstep.is-done .pstep__num{background:var(--green-50);color:var(--green-700)}

/* step body */
.wizard__body{padding:30px 32px 8px;min-height:340px}
.step{animation:fadeUp .4s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.step__head{margin-bottom:22px}
.step__kicker{font-family:var(--disp);font-weight:600;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:var(--green-600)}
.step__title{font-size:1.5rem;margin:.35rem 0 .35rem}
.step__desc{color:var(--slate);font-size:.98rem}

/* option grid */
.opts{display:grid;gap:12px}
.opts--2{grid-template-columns:repeat(2,1fr)}
.opts--3{grid-template-columns:repeat(3,1fr)}
.opt{
  position:relative;display:flex;flex-direction:column;gap:6px;cursor:pointer;
  padding:16px 16px;border:1.6px solid var(--line);border-radius:var(--r-sm);background:#fff;
  transition:border-color .18s,box-shadow .18s,transform .12s,background .18s;
}
.opt:hover{border-color:#c5d2e0;transform:translateY(-2px);box-shadow:var(--sh-sm)}
.opt input{position:absolute;opacity:0;pointer-events:none}
.opt__ic{width:38px;height:38px;display:grid;place-items:center;border-radius:10px;background:var(--soft);color:var(--navy);transition:.18s}
.opt__ic svg{width:21px;height:21px}
.opt__t{font-family:var(--disp);font-weight:600;font-size:1.01rem}
.opt__d{font-size:.84rem;color:var(--slate);line-height:1.45}
.opt__check{position:absolute;top:12px;right:12px;width:22px;height:22px;border-radius:50%;border:1.6px solid var(--line);display:grid;place-items:center;transition:.18s}
.opt__check svg{width:13px;height:13px;color:#fff;opacity:0;transform:scale(.5);transition:.18s}
.opt.is-on{border-color:var(--green);background:var(--green-50);box-shadow:0 0 0 1px var(--green)}
.opt.is-on .opt__ic{background:var(--green);color:#fff}
.opt.is-on .opt__check{background:var(--green);border-color:var(--green)}
.opt.is-on .opt__check svg{opacity:1;transform:scale(1)}
.opt:focus-within{outline:none;box-shadow:var(--ring)}

/* sub-block / fields */
.fieldset{margin-top:26px}
.fieldset__legend{font-family:var(--disp);font-weight:600;font-size:1.05rem;margin-bottom:4px}
.fieldset__hint{font-size:.86rem;color:var(--slate);margin-bottom:14px}
.field{margin-bottom:16px}
.field label,.lbl{display:block;font-weight:600;font-size:.9rem;margin-bottom:7px}
.lbl .opt-tag{font-weight:500;color:var(--muted);font-size:.82rem}
.input,.select,.textarea{
  width:100%;font-family:inherit;font-size:.98rem;color:var(--ink);
  padding:.8em .95em;border:1.6px solid var(--line);border-radius:var(--r-sm);background:#fff;transition:border-color .15s,box-shadow .15s;
}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--green);box-shadow:var(--ring)}
.textarea{resize:vertical;min-height:96px}
.input.err,.textarea.err{border-color:var(--danger);box-shadow:0 0 0 4px rgba(220,38,38,.12)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.err-msg{color:var(--danger);font-size:.82rem;margin-top:6px;display:none}
.err-msg.show{display:block}

/* range / quantity */
.range{margin-top:8px}
.range__row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.range__val{font-family:var(--disp);font-weight:700;font-size:1.25rem;color:var(--green-700)}
input[type=range]{-webkit-appearance:none;width:100%;height:6px;border-radius:999px;background:var(--soft-2);outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--green);cursor:pointer;border:3px solid #fff;box-shadow:0 2px 8px rgba(19,102,200,.5)}
input[type=range]::-moz-range-thumb{width:22px;height:22px;border:3px solid #fff;border-radius:50%;background:var(--green);cursor:pointer;box-shadow:0 2px 8px rgba(19,102,200,.5)}

/* dropzone */
.drop{
  border:2px dashed var(--line);border-radius:var(--r);padding:30px 20px;text-align:center;cursor:pointer;
  transition:.18s;background:var(--soft);color:var(--slate);
}
.drop:hover,.drop.drag{border-color:var(--green);background:var(--green-50);color:var(--green-700)}
.drop__ic{width:46px;height:46px;margin:0 auto 10px;display:grid;place-items:center;border-radius:12px;background:#fff;color:var(--green);box-shadow:var(--sh-sm)}
.drop strong{color:var(--ink)}
.drop small{display:block;margin-top:4px;font-size:.8rem}
.drop.has-file{border-style:solid;border-color:var(--green);background:#fff;color:var(--ink)}
.file-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.file-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--soft);border-radius:10px;font-size:.9rem}
.file-item .x{margin-left:auto;cursor:pointer;color:var(--slate);border:0;background:none;font-size:1.1rem;line-height:1}
.file-item .x:hover{color:var(--danger)}
.file-item svg{color:var(--green);flex:0 0 auto}

/* checkbox */
.check{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;color:var(--slate);cursor:pointer}
.check input{margin-top:2px;width:18px;height:18px;accent-color:var(--green);flex:0 0 auto}

/* wizard nav */
.wizard__nav{display:flex;align-items:center;gap:14px;padding:20px 32px 26px;border-top:1px solid var(--line-2)}
.wizard__nav .btn--primary{margin-left:auto}
#btnPrev{visibility:hidden}
.wizard.has-prev #btnPrev{visibility:visible}
.wizard__hint{font-size:.84rem;color:var(--muted);margin-left:auto}
.wizard__nav .btn--primary+.wizard__hint,.wizard__hint+.btn--primary{margin-left:14px}
.wizard__hint{margin-left:auto}

/* ============================================================ SUMMARY ============================================================ */
.config__aside{position:sticky;top:90px}
.summary{background:var(--navy);color:#dbe6f2;border-radius:var(--r-lg);padding:22px;box-shadow:var(--sh)}
.summary__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.summary__head h3{color:#fff;font-size:1.18rem}
.summary__live{display:inline-flex;align-items:center;gap:.45em;font-size:.74rem;font-weight:600;color:#8fc2f7;text-transform:uppercase;letter-spacing:.05em}
.pulse{width:8px;height:8px;border-radius:50%;background:#3d8ee0;box-shadow:0 0 0 0 rgba(61,142,224,.7);animation:pulse 1.8s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 9px rgba(61,142,224,0)}100%{box-shadow:0 0 0 0 rgba(61,142,224,0)}}
.summary__body{display:flex;flex-direction:column;gap:1px;border-radius:var(--r-sm);overflow:hidden;margin-bottom:16px}
.srow{display:flex;justify-content:space-between;gap:12px;padding:11px 14px;background:rgba(255,255,255,.04);font-size:.9rem}
.srow__k{color:#9fb2c9;flex:0 0 auto}
.srow__v{text-align:right;font-weight:600;color:#fff}
.srow__v.empty{color:#62768f;font-weight:500;font-style:italic}
.srow__v .tag{display:inline-block;background:rgba(143,194,247,.16);color:#bcd9fb;border-radius:6px;padding:.1em .5em;margin:2px 0 0 5px;font-size:.8rem;font-weight:600}
.estimate{border-top:1px solid rgba(255,255,255,.1);padding-top:16px;display:grid;gap:11px}
.est-row{display:flex;justify-content:space-between;align-items:center;gap:10px}
.est-row .k{font-size:.84rem;color:#9fb2c9}
.est-row .v{font-family:var(--disp);font-weight:600;font-size:.96rem;color:#fff;text-align:right}
.est-row .v.good{color:#8fc2f7}
.price-scale{display:inline-flex;gap:3px;align-items:center}
.price-scale b{font-family:var(--disp);color:#8fc2f7;font-size:1.05rem}
.price-scale .off{color:#4d6280}
.summary__note{font-size:.76rem;color:#8197b0;margin-top:14px;line-height:1.5}

/* ============================================================ FEATURES ============================================================ */
.feat{padding:84px 0;background:#fff}
.feat__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.fcard{padding:26px 22px;border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,#fff,var(--soft));transition:transform .18s,box-shadow .2s}
.fcard:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.fcard__ic{display:grid;place-items:center;width:48px;height:48px;border-radius:13px;background:var(--green-50);color:var(--green-700);font-size:1.4rem;margin-bottom:16px}
.fcard h3{font-size:1.12rem;margin-bottom:8px}
.fcard p{font-size:.92rem;color:var(--slate)}

/* ============================================================ FLOW ============================================================ */
.flow{padding:84px 0;background:var(--navy);position:relative;overflow:hidden}
.flow::before{content:"";position:absolute;inset:0;opacity:.4;background:radial-gradient(50% 60% at 80% 0%,rgba(19,102,200,.4),transparent 60%)}
.flow .shell{position:relative}
.flow__steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s}
.flow__steps li{padding:26px 22px;border:1px solid rgba(255,255,255,.12);border-radius:var(--r);background:rgba(255,255,255,.04)}
.flow__n{font-family:var(--disp);font-weight:700;font-size:1.6rem;color:#8fc2f7;display:block;margin-bottom:12px}
.flow__steps h3{color:#fff;font-size:1.1rem;margin-bottom:8px}
.flow__steps p{color:#a9bbd0;font-size:.9rem}

/* ============================================================ FOOTER ============================================================ */
.footer{background:var(--navy-800);color:#a9bbd0}
.footer__inner{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:36px;padding:60px 24px 44px}
.brand--footer .brand__text{color:#fff}
.brand--footer .brand__text small{color:#8197b0}
.footer__brand p{margin-top:16px;max-width:34ch;font-size:.92rem}
.footer__col h4{color:#fff;font-family:var(--disp);font-size:.95rem;margin-bottom:14px;letter-spacing:.02em}
.footer__col ul{display:grid;grid-template-columns:1fr 1fr;gap:6px 18px}
.footer__col li{font-size:.9rem}
.footer address{font-style:normal;font-size:.92rem;line-height:1.7}
.footer a:hover{color:#fff}
.footer__bar{border-top:1px solid rgba(255,255,255,.08)}
.footer__bar-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;padding:18px 24px;font-size:.82rem;color:#7088a3}
.footer__credit strong{color:#cdd9e7}

/* ============================================================ SUCCESS ============================================================ */
.done{text-align:center;padding:20px 10px 30px;animation:fadeUp .5s both}
.done__badge{width:84px;height:84px;border-radius:50%;margin:0 auto 22px;display:grid;place-items:center;background:var(--green-50);color:var(--green);position:relative}
.done__badge svg{width:42px;height:42px}
.done__badge::after{content:"";position:absolute;inset:-8px;border-radius:50%;border:2px solid var(--green);opacity:0;animation:ring 1.2s ease-out forwards}
@keyframes ring{0%{transform:scale(.6);opacity:.6}100%{transform:scale(1.15);opacity:0}}
.done h3{font-size:1.7rem;margin-bottom:10px}
.done p{color:var(--slate);max-width:46ch;margin:0 auto 8px}
.done__ref{display:inline-flex;align-items:center;gap:.5em;margin-top:18px;padding:.7em 1.2em;background:var(--soft);border-radius:999px;font-family:var(--disp);font-weight:600}
.done__ref b{color:var(--green-700)}
.done__actions{margin-top:26px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ============================================================ RESPONSIVE ============================================================ */
@media (max-width:980px){
  .hero__inner{grid-template-columns:1fr;gap:36px;padding:54px 24px 64px}
  .hero__card{max-width:420px}
  .config__grid{grid-template-columns:1fr}
  .config__aside{position:static;order:-1}
  .summary{display:grid}
  .feat__grid{grid-template-columns:repeat(2,1fr)}
  .flow__steps{grid-template-columns:repeat(2,1fr)}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .topbar__nav,.topbar__phone{display:none}
  .topbar__actions .btn{display:none}
  .burger{display:flex}
  .opts--2,.opts--3{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .wizard__body{padding:24px 20px 6px}
  .wizard__progress{padding:16px 18px}
  .wizard__nav{padding:18px 20px 22px}
  .pstep__label{display:none}
  .pstep__sep{width:10px}
  .footer__inner{grid-template-columns:1fr}
  .footer__col ul{grid-template-columns:1fr 1fr}
}
@media (max-width:430px){
  .feat__grid,.flow__steps{grid-template-columns:1fr}
  .hero__title{font-size:2rem}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* ============================================================ ORIGINAL-ALIGNED ADD-ONS ============================================================ */
/* top contact strip */
.topstrip{background:var(--soft-2);border-bottom:1px solid var(--line)}
.topstrip__inner{display:flex;gap:26px;align-items:center;height:40px}
.topstrip__inner .spacer{margin-left:auto}
.topstrip a{display:inline-flex;align-items:center;gap:.45em;font-weight:500;font-size:.85rem;color:var(--slate)}
.topstrip a:hover{color:var(--green-700)}
.topstrip svg{color:var(--green)}
@media (max-width:600px){.topstrip{display:none}}

/* uppercase corporate nav (closer to original) */
.topbar__nav--corp a{text-transform:uppercase;font-size:.82rem;letter-spacing:.03em;font-weight:600}

/* about / Komplettlösungen */
.about{padding:84px 0;background:#fff}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.about__grid h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:18px}
.about__intro p{color:var(--slate);margin-bottom:14px;font-size:1.04rem}
.about__intro p strong{color:var(--ink)}
.checklist{display:flex;flex-direction:column;gap:6px;background:linear-gradient(180deg,#fff,var(--soft));
  border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:0 30px 60px -40px rgba(10,58,102,.4)}
.checklist li{display:flex;gap:16px;align-items:flex-start;padding:16px 16px;border-radius:16px;transition:background .2s}
.checklist li:hover{background:var(--blue-50)}
.checklist .ck{flex:0 0 auto;width:46px;height:46px;border-radius:13px;color:#fff;display:grid;place-items:center;
  background:linear-gradient(135deg,#2a8be8,var(--navy));box-shadow:0 10px 20px -10px rgba(19,102,200,.6)}
.checklist .ck svg{width:22px;height:22px}
.checklist p{font-size:.98rem;color:var(--slate)}
.checklist p strong{font-family:var(--disp);display:block;margin-bottom:2px;color:var(--ink);font-size:1.05rem}

/* products grid */
.produkte{padding:84px 0;background:var(--soft)}
.prod__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.prodcard{background:#fff;border:1px solid var(--line);border-left:3px solid var(--green);border-radius:var(--r);padding:22px 20px;transition:transform .18s,box-shadow .2s}
.prodcard:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.prodcard__chev{color:var(--green);font-weight:700;font-family:var(--disp);font-size:1.05rem;letter-spacing:-.05em}
.prodcard h3{font-size:1.04rem;margin:6px 0 6px}
.prodcard p{font-size:.87rem;color:var(--slate)}

/* contact section */
.contact{padding:84px 0;background:var(--navy);position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;inset:0;opacity:.4;background:radial-gradient(50% 60% at 12% 100%,rgba(19,102,200,.4),transparent 60%)}
.contact .shell{position:relative}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:center}
.contact__info h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:16px}
.contact__info p{color:#a9bbd0;margin-bottom:18px;max-width:46ch}
.contact__info address{font-style:normal;color:#c4d2e2;font-size:1.04rem;line-height:1.9}
.contact__info address a{color:#fff}
.contact__info address a:hover{color:#8fc2f7}
.contact__card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:32px}
.contact__card h3{color:#fff;font-size:1.35rem;margin-bottom:10px}
.contact__card p{color:#a9bbd0;margin-bottom:22px}
.contact__card .btn{width:100%;margin-bottom:10px}

/* footer 4-col + socials */
.footer__inner--4{grid-template-columns:1.5fr .9fr .9fr 1.2fr}
.socials{display:flex;gap:10px;margin-top:18px}
.social{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.08);color:#cdd9e7;transition:.18s}
.social:hover{background:var(--green);color:#fff;transform:translateY(-2px)}
.social svg{width:18px;height:18px}

@media (max-width:980px){
  .about__grid,.contact__grid{grid-template-columns:1fr;gap:30px}
  .prod__grid{grid-template-columns:repeat(2,1fr)}
  .footer__inner--4{grid-template-columns:1fr 1fr}
}
@media (max-width:430px){.prod__grid{grid-template-columns:1fr}}

/* hero: zwei gleichwertige Tool-Karten */
.hero--tools{padding:60px 0 70px}
.hero--tools .shell{position:relative}
.hero__lead{max-width:780px;margin-bottom:32px}
.hero__lead .hero__title{margin:14px 0 14px}
.toolcards{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.toolcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:var(--sh);transition:transform .18s,box-shadow .2s}
.toolcard:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.toolcard__ic{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;background:var(--green-50);color:var(--green-700);margin-bottom:18px}
.toolcard__ic svg{width:27px;height:27px}
.toolcard--calc .toolcard__ic{background:rgba(21,49,79,.08);color:var(--navy)}
.toolcard h2{font-size:1.45rem;margin-bottom:10px}
.toolcard>p{color:var(--slate);margin-bottom:18px}
.toolcard__pts{display:flex;flex-direction:column;gap:9px;margin-bottom:24px;flex:1 1 auto}
.toolcard__pts li{display:flex;gap:.6em;align-items:flex-start;font-size:.92rem;color:var(--ink)}
.toolcard__pts li svg{width:16px;height:16px;color:var(--green);flex:0 0 auto;margin-top:3px}
.toolcard--calc .toolcard__pts li svg{color:var(--navy)}
.toolcard .btn{margin-top:auto}
.btn--navy{background:var(--navy);color:#fff;box-shadow:0 8px 20px -8px rgba(21,49,79,.55)}
.btn--navy:hover{background:var(--navy-800);box-shadow:0 12px 26px -8px rgba(21,49,79,.65)}
.hero__trust--center{justify-content:center;margin-top:30px;gap:14px 30px;text-align:center}
@media (max-width:820px){.toolcards{grid-template-columns:1fr}}

/* topbar: robust gegen Überlauf auf kleineren Desktops */
.topbar__inner{gap:16px}
.topbar__nav--corp{gap:2px}
.topbar__nav--corp a{font-size:.8rem;letter-spacing:.015em;padding:.5em .68em}
@media (max-width:1100px){
  .topbar__nav{display:none}
  .burger{display:flex}
}

/* ============================================================
   WEBUNDO — projektspezifische Komponenten · Ländle Digital
   Palette: Blau (Aktion) · Navy (dunkel) · Grün (Häkchen/Logo) · Sky (Icon-Kreise)
============================================================ */
:root{
  --blue:#1366c8; --blue-600:#0f57aa; --blue-700:#0b4789; --blue-50:#e8f1fc; --blue-bright:#1a82e2;
  --sky:#4db3d4; --sky-50:#e6f5fa;
  --leaf:#5fa733; --leaf-600:#4f8e2a; --leaf-50:#eef6e6;
  /* Navy an Webundo-Markenfarbe angleichen */
  --navy:#0a3a66; --navy-600:#0d4576; --navy-800:#072845;
}
/* Logo im Header */
.brand__logo{height:46px;width:auto;display:block}
.brand__logo svg{height:46px;width:auto;display:block}
.topbar__nav a.is-active,.topbar__nav a[aria-current="page"]{color:var(--blue-bright)}
.topbar__nav--corp a{color:var(--ink)}
.topbar__nav--corp a:hover{color:var(--blue);background:var(--blue-50)}

/* grüne Häkchen-Listen (Markenakzent) */
.tlist{display:grid;gap:11px}
.tlist li{display:flex;gap:11px;align-items:flex-start;font-size:.97rem;color:var(--ink)}
.tlist li svg{width:18px;height:18px;color:var(--leaf);flex:0 0 auto;margin-top:3px}
.tlist--lg li{font-size:1.05rem;font-weight:500}
.tlist--chk li svg{color:var(--leaf)}

/* ---------- Page-Hero mit Bild ---------- */
.phero{position:relative;overflow:hidden;background:var(--navy);color:#fff;min-height:380px;display:flex;align-items:center}
.phero__img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.5}
.phero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--navy) 8%,rgba(10,58,102,.72) 46%,rgba(10,58,102,.15) 100%)}
.phero .shell{position:relative;z-index:2;padding:64px 24px}
.phero__eyebrow{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#bcd9fb;background:rgba(255,255,255,.1);padding:.45em .9em;border-radius:999px;margin-bottom:18px}
.phero h1{font-size:clamp(2rem,5vw,3.4rem);text-transform:uppercase;line-height:1.06;max-width:16ch;color:#fff}
.phero__sub{font-size:1.12rem;color:#d2e0f2;max-width:52ch;margin:18px 0 26px}
.phero__cta{display:flex;flex-wrap:wrap;gap:14px}

/* Startseite-Hero (heller, mit Bild rechts) */
.hhero{position:relative;overflow:hidden;background:#fff;border-bottom:1px solid var(--line)}
.hhero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding:76px 0 84px}
.hhero__text{display:flex;flex-direction:column;justify-content:center;padding:0}
.hhero__media{position:relative}
.hhero__media .img{position:relative;aspect-ratio:4 / 3.1;border-radius:26px;background-size:cover;background-position:center;box-shadow:0 42px 90px -44px rgba(10,58,102,.55),0 8px 24px -16px rgba(10,58,102,.4)}
.hhero__media::after{content:"";position:absolute;inset:0;border-radius:26px;pointer-events:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5)}
.hhero h1{font-size:clamp(2.2rem,5.2vw,3.7rem);text-transform:uppercase;line-height:1.04;color:var(--blue);letter-spacing:-.01em}
.hhero__claim{font-size:clamp(1.25rem,2.6vw,1.7rem);font-weight:700;color:var(--ink);margin:18px 0 22px;font-family:var(--disp)}
.hhero__sub{color:var(--slate);font-size:1.08rem;max-width:50ch;margin-bottom:8px}
.hhero__sub+.hhero__sub{margin-top:10px}
.hhero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}

/* ---------- Value-Props-Band (unter Hero) ---------- */
.valband{background:linear-gradient(180deg,var(--blue-50),#fff);border-bottom:1px solid var(--line)}
.valband__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:34px 24px}
.valprop{display:flex;gap:14px;align-items:flex-start}
.valprop__ic{flex:0 0 auto;width:44px;height:44px;display:grid;place-items:center;color:var(--navy)}
.valprop__ic svg{width:30px;height:30px}
.valprop h3{font-size:1.02rem;margin-bottom:4px}
.valprop p{font-size:.9rem;color:var(--slate);line-height:1.45}
.valband--simple .valprop__ic{color:var(--leaf)}

/* ---------- Icon-Kreise ---------- */
.iccircle{flex:0 0 auto;width:54px;height:54px;border-radius:50%;display:grid;place-items:center;color:#fff}
.iccircle svg{width:27px;height:27px}
.iccircle--sky{background:var(--sky)} .iccircle--blue{background:var(--blue)}
.iccircle--navy{background:var(--navy)} .iccircle--dark{background:#0c1f33}
.iccircle--grey{background:#8a98a8}

/* ---------- 3 Service-Säulen (Start) ---------- */
.pillars{padding:70px 0 78px;background:#fff}
.pillars__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.pillar{display:flex;flex-direction:column}
.pillar__head{display:flex;align-items:center;gap:16px;margin-bottom:6px}
.pillar__head h2{font-size:1.7rem;text-transform:uppercase;letter-spacing:-.01em}
.pillar__sub{color:var(--slate);font-weight:600;margin:6px 0 20px;padding-left:70px}
.pillar .tlist{margin-bottom:24px;flex:1 1 auto}
.pillar .btn{align-self:flex-start;margin-top:auto}

/* ---------- Service-Sortiment / Leistungen (4-spaltig) ---------- */
.svcsec{padding:72px 0;background:#fff}
.svcsec__title{text-align:center;font-size:clamp(1.6rem,3.4vw,2.3rem);margin-bottom:44px}
.svcgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.svc__head{display:flex;align-items:center;gap:14px;margin-bottom:18px;min-height:58px}
.svc__head h3{font-size:1.12rem;line-height:1.2}
.svc .tlist li{font-size:.94rem}

/* ---------- Partner / Marken ---------- */
.partners{padding:64px 0;background:linear-gradient(180deg,#fff,var(--blue-50))}
.partners__grid{display:grid;grid-template-columns:1fr 1.6fr;gap:44px;align-items:center}
.partners__intro .eyebrow{margin-bottom:14px}
.partners__intro h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:14px}
.partners__intro p{color:var(--slate)}
.logos{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.logos__item{background:#fff;border:1px solid var(--line);border-radius:14px;height:96px;display:grid;place-items:center;padding:16px;box-shadow:var(--sh-sm);transition:transform .18s,box-shadow .2s}
.logos__item:hover{transform:translateY(-3px);box-shadow:var(--sh)}
.logos__item span{font-family:var(--disp);font-weight:800;font-size:1.05rem;color:var(--navy);letter-spacing:.01em;text-align:center}
.logos__item small{display:block;font-weight:600;font-size:.7rem;color:var(--slate);letter-spacing:.04em}

/* ---------- Branchenfokus ---------- */
.branchen{padding:64px 0;background:var(--soft)}
.branchen__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:18px;margin-top:36px}
.branche{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.branche__ic{width:58px;height:58px;display:grid;place-items:center;color:var(--slate);transition:.18s}
.branche__ic svg{width:42px;height:42px}
.branche span{font-family:var(--disp);font-weight:700;font-size:1.02rem;color:var(--slate)}
.branche:hover .branche__ic{color:var(--blue);transform:translateY(-3px)}
.branche:hover span{color:var(--ink)}

/* ---------- 3 Schritte ---------- */
.steps3{padding:80px 0;background:linear-gradient(180deg,#fff,var(--soft));text-align:center}
.steps3__row{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch;margin-top:48px;counter-reset:s}
.step3{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:10px;text-align:left;
  background:#fff;border:1px solid var(--line);border-radius:22px;padding:38px 30px 30px;
  box-shadow:0 26px 50px -34px rgba(10,58,102,.32);transition:transform .3s cubic-bezier(.16,.7,.2,1),box-shadow .3s}
.step3:hover{transform:translateY(-6px);box-shadow:0 34px 60px -34px rgba(10,58,102,.42)}
.step3__n{position:absolute;top:-22px;left:30px;width:48px;height:48px;border-radius:14px;
  display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:1.4rem;color:#fff;
  background:linear-gradient(135deg,#2a8be8,var(--navy));box-shadow:0 12px 22px -10px rgba(10,58,102,.6)}
.step3__ic{width:56px;height:56px;display:grid;place-items:center;color:var(--blue);border-radius:15px;
  background:var(--blue-50);margin:10px 0 4px}
.step3__ic svg{width:30px;height:30px}
.step3 h3{font-size:1.22rem}
.step3 p{color:var(--slate);font-size:.96rem}
.step3__arrow{display:none}

/* ---------- CTA-Band (Navy, Papierflieger) ---------- */
.ctaband{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.ctaband::before{content:"";position:absolute;inset:0;opacity:.5;background:radial-gradient(50% 120% at 85% 0,rgba(19,102,200,.55),transparent 60%)}
.ctaband__inner{position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:30px;align-items:center;padding:42px 24px}
.ctaband__ic{width:92px;height:92px;border-radius:50%;border:2px solid rgba(255,255,255,.45);display:grid;place-items:center;color:#fff}
.ctaband__ic svg{width:46px;height:46px}
.ctaband h2{font-size:clamp(1.5rem,3vw,2.05rem);color:#fff;margin-bottom:8px}
.ctaband p{color:#c4d6ee;max-width:52ch}
.ctaband .btn{white-space:nowrap}

/* ---------- "Wenn Standardwege nicht reichen" Situationen ---------- */
.situ{padding:64px 0;background:var(--soft)}
.situ__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:36px}
.situbox{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;text-align:center}
.situbox__ic{width:56px;height:56px;border-radius:14px;margin:0 auto 14px;display:grid;place-items:center;background:var(--blue-50);color:var(--blue)}
.situbox__ic svg{width:28px;height:28px}
.situbox h3{font-size:1.04rem;margin-bottom:6px}
.situbox p{font-size:.88rem;color:var(--slate)}

/* ---------- Vorteil + Vergleichsgrafik ---------- */
.vorteil{padding:74px 0;background:#fff}
.vorteil__grid{display:grid;grid-template-columns:.9fr 1.25fr;gap:48px;align-items:center}
.vorteil h2{font-size:clamp(1.7rem,3.2vw,2.3rem)}
.vorteil h2 em{font-style:normal;color:var(--blue);display:block}
.vorteil .tlist{margin-top:24px}
.vorteil .tlist li{font-size:1.06rem;font-weight:500}
.vorteil .tlist li svg{width:22px;height:22px}
.compare{background:var(--soft);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,3vw,34px);box-shadow:var(--sh)}
.compare__h{text-align:center;font-size:1.4rem;margin-bottom:4px}
.compare__h b{color:var(--blue)}
.compare__sub{text-align:center;color:var(--slate);margin-bottom:24px}
.compare__sub b{color:var(--danger)}
.compare__cols{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center}
.compare__card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px 16px;text-align:center}
.compare__tag{display:inline-block;font-weight:800;font-size:.72rem;letter-spacing:.06em;padding:.4em .8em;border-radius:999px;margin-bottom:14px}
.compare__card--bad .compare__tag{color:var(--danger);background:#fdecec;border:1px solid #f6c9c9}
.compare__card--good .compare__tag{color:var(--blue);background:var(--blue-50);border:1px solid #c5dcf6}
.compare__big{font-family:var(--disp);font-weight:800;font-size:2.4rem;line-height:1}
.compare__card--bad .compare__big{color:var(--danger)}
.compare__card--good .compare__big{color:var(--blue)}
.compare__lbl{font-size:.84rem;color:var(--slate);margin-top:4px}
.compare__dots{display:flex;flex-wrap:wrap;gap:3px;justify-content:center;margin:14px auto 0;max-width:170px}
.compare__dots i{width:9px;height:9px;border-radius:2px;background:#cdd9e7}
.compare__card--good .wmark{width:62px;height:62px;border-radius:50%;margin:6px auto 0;display:grid;place-items:center;background:var(--blue-50)}
.compare__card--good .wmark svg{width:34px;height:34px}
.compare__sum{font-size:.92rem;color:var(--ink);margin-top:16px}
.compare__sum b{display:block;font-family:var(--disp);font-size:1.15rem;margin-top:4px}
.compare__card--bad .compare__sum b{color:var(--danger)}
.compare__card--good .compare__sum b{color:var(--leaf-600)}
.compare__vs{width:48px;height:48px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:.9rem}
.compare__result{margin-top:20px;background:var(--leaf-50);border:1px solid #cfe6bd;border-radius:var(--r);padding:20px 24px;display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center}
.compare__result .ric{width:50px;height:50px;border-radius:50%;background:#fff;display:grid;place-items:center;color:var(--leaf-600)}
.compare__result .rbig{font-family:var(--disp);font-weight:800;font-size:1.9rem;color:var(--leaf-600);line-height:1}
.compare__result .rsmall{font-size:.82rem;color:var(--slate)}
.compare__result .rpct{text-align:center}
.compare__result .rpct b{font-family:var(--disp);font-weight:800;font-size:1.7rem;color:var(--leaf-600)}
.compare__foot{text-align:center;font-size:.78rem;color:var(--muted);margin-top:14px}

/* ---------- Mehrwert-Kacheln ---------- */
.mehrwert{padding:64px 0;background:linear-gradient(180deg,#fff,var(--blue-50))}
.mehrwert__grid{display:grid;grid-template-columns:.95fr 1.4fr;gap:44px;align-items:center}
.mehrwert h2{font-size:clamp(1.7rem,3.2vw,2.3rem);margin-bottom:14px}
.mehrwert>.shell>.mehrwert__grid>div:first-child p{color:var(--slate);font-size:1.05rem}
.mwtiles{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.mwtile{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px 12px;text-align:center;box-shadow:var(--sh-sm)}
.mwtile__ic{width:50px;height:50px;margin:0 auto 12px;display:grid;place-items:center;color:var(--blue)}
.mwtile__ic svg{width:34px;height:34px}
.mwtile span{font-weight:700;font-family:var(--disp);font-size:.92rem;color:var(--ink);line-height:1.25;display:block}

/* ---------- Footer (Webundo) ---------- */
.wfooter{background:var(--navy-800);color:#a9bbd0}
.wfooter__inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px;padding:60px 24px 44px}
.wfooter h4{color:var(--blue-bright);font-family:var(--disp);font-size:1.05rem;margin-bottom:18px}
.wfooter a:hover{color:#fff}
.wfooter__links{display:flex;flex-wrap:wrap;gap:10px 22px}
.wfooter__links a{font-weight:600;color:#cdd9e7}
.wfooter address{font-style:normal;display:grid;gap:14px}
.wfooter address a,.wfooter address span{display:flex;align-items:center;gap:12px;color:#cdd9e7}
.wfooter address svg{width:20px;height:20px;color:var(--blue-bright);flex:0 0 auto}
.wfooter__bar{border-top:1px solid rgba(255,255,255,.08);text-align:center;padding:18px 24px;font-size:.85rem;color:#7088a3}
.wfooter__bar a:hover{color:#fff}

/* ---------- Unternehmen-spezifisch ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:54px 0}
.stat{text-align:center}
.stat b{display:block;font-family:var(--disp);font-weight:800;font-size:clamp(2rem,4vw,2.8rem);color:var(--blue)}
.stat span{color:var(--slate);font-weight:600}
.values__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.valuecard{background:#fff;border:1px solid var(--line);border-top:3px solid var(--blue);border-radius:var(--r);padding:28px 24px;transition:transform .18s,box-shadow .2s}
.valuecard:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.valuecard__ic{width:50px;height:50px;border-radius:13px;background:var(--blue-50);color:var(--blue);display:grid;place-items:center;margin-bottom:16px}
.valuecard__ic svg{width:26px;height:26px}
.valuecard h3{font-size:1.15rem;margin-bottom:8px}
.valuecard p{color:var(--slate);font-size:.95rem}

/* ---------- Kontakt-Formular ---------- */
.kontaktsec{padding:72px 0;background:var(--soft)}
.kontakt__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:44px;align-items:start}
.kontakt__info h2{font-size:clamp(1.7rem,3.2vw,2.3rem);margin-bottom:14px}
.kontakt__info p{color:var(--slate);margin-bottom:24px;max-width:46ch}
.kontakt__info address{font-style:normal;display:grid;gap:18px}
.kontakt__info address>div{display:flex;gap:14px;align-items:flex-start}
.kontakt__info .ic{flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:var(--blue-50);color:var(--blue);display:grid;place-items:center}
.kontakt__info .ic svg{width:22px;height:22px}
.kontakt__info b{display:block;font-family:var(--disp)}
.kontakt__info a{color:var(--blue)}
.formcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(24px,3vw,36px);box-shadow:var(--sh)}

/* ---------- legal pages ---------- */
.legal{padding:60px 0 80px;background:#fff}
.legal .shell{max-width:820px}
.legal h1{font-size:2rem;margin-bottom:8px}
.legal h2{font-size:1.25rem;margin:32px 0 10px;color:var(--navy)}
.legal p,.legal li{color:var(--slate);margin-bottom:10px;line-height:1.7}
.legal ul{list-style:disc;padding-left:22px;margin-bottom:14px}
.legal a{color:var(--blue)}

/* ---------- responsive ---------- */
@media (max-width:1100px){
  .branchen__grid{grid-template-columns:repeat(4,1fr);gap:26px}
  .mwtiles{grid-template-columns:repeat(5,1fr)}
}
@media (max-width:980px){
  .hhero__inner{grid-template-columns:1fr;gap:32px;padding:40px 0 52px}
  .hhero__text{padding:0;order:-1}
  .hhero__media .img{aspect-ratio:16 / 10}
  .valband__grid{grid-template-columns:1fr 1fr}
  .pillars__grid{grid-template-columns:1fr;gap:48px}
  .pillar__sub{padding-left:0}
  .svcgrid{grid-template-columns:1fr 1fr}
  .partners__grid,.vorteil__grid,.mehrwert__grid,.kontakt__grid{grid-template-columns:1fr;gap:32px}
  .logos{grid-template-columns:repeat(4,1fr)}
  .branchen__grid{grid-template-columns:repeat(3,1fr)}
  .steps3__row{grid-template-columns:1fr;gap:30px}
  .step3__arrow{transform:rotate(90deg);margin:0}
  .situ__grid{grid-template-columns:1fr 1fr}
  .mwtiles{grid-template-columns:repeat(3,1fr)}
  .values__grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:30px}
  .ctaband__inner{grid-template-columns:1fr;text-align:center;gap:18px;justify-items:center}
  .wfooter__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .valband__grid,.svcgrid,.situ__grid{grid-template-columns:1fr}
  .logos{grid-template-columns:repeat(3,1fr)}
  .branchen__grid{grid-template-columns:repeat(2,1fr)}
  .mwtiles{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:1fr 1fr}
  .compare__cols{grid-template-columns:1fr}
  .compare__vs{margin:4px auto}
  .compare__result{grid-template-columns:1fr;text-align:center;justify-items:center}
  .wfooter__inner{grid-template-columns:1fr}
}

/* ---------- Ergänzungen: Unternehmen / Kontakt / 5er-Grid ---------- */
.svcgrid--auto{grid-template-columns:repeat(5,1fr)}
.wmv{padding:64px 0;background:var(--soft)}
.wmv__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:8px}
.wmvcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 24px;box-shadow:var(--sh-sm)}
.wmvcard__ic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;margin-bottom:14px}
.wmvcard__ic svg{width:26px;height:26px}
.wmvcard--why .wmvcard__ic{background:#fdecec;color:#d23b3b}
.wmvcard--vision .wmvcard__ic{background:var(--leaf-50);color:var(--leaf-600)}
.wmvcard--mission .wmvcard__ic{background:var(--blue-50);color:var(--blue)}
.wmvcard h3{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:8px}
.wmvcard p{font-size:1.05rem;color:var(--ink);font-weight:500;line-height:1.5}

.team{padding:70px 0;background:#fff}
.team__grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.team__intro h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:16px}
.team__intro p{color:var(--slate);font-size:1.05rem;margin-bottom:12px}
.team__intro p strong{color:var(--ink)}
.person{display:flex;gap:22px;align-items:center;background:var(--soft);border:1px solid var(--line);border-left:3px solid var(--blue);border-radius:var(--r-lg);padding:26px}
.person__av{flex:0 0 auto;width:92px;height:92px;border-radius:50%;display:grid;place-items:center;background:var(--navy);color:#fff;font-family:var(--disp);font-weight:800;font-size:1.9rem;letter-spacing:.02em}
.person h3{font-size:1.3rem}
.person .role{color:var(--blue);font-weight:700;font-family:var(--disp);margin:2px 0 8px}
.person p{color:var(--slate);font-size:.95rem}

.milestones{padding:0 0 70px;background:#fff}
.mstone{display:flex;gap:20px;align-items:flex-start;max-width:640px}
.mstone__dot{flex:0 0 auto;width:16px;height:16px;border-radius:50%;background:var(--blue);margin-top:5px;box-shadow:0 0 0 5px var(--blue-50)}
.mstone__date{font-family:var(--disp);font-weight:700;color:var(--navy)}
.mstone p{color:var(--slate);margin-top:4px}

.kmap{width:100%;height:300px;border:0;border-radius:var(--r);margin-top:24px;filter:saturate(.95)}
.kontakt__form .field{margin-bottom:16px}
.kontakt__form label{display:block;font-weight:600;font-size:.9rem;margin-bottom:7px}
.kontakt__form .req{color:var(--danger)}

@media (max-width:980px){
  .svcgrid--auto{grid-template-columns:repeat(2,1fr)}
  .wmv__grid{grid-template-columns:1fr}
  .team__grid{grid-template-columns:1fr;gap:28px}
}
@media (max-width:600px){
  .svcgrid--auto{grid-template-columns:1fr}
  .person{flex-direction:column;text-align:center}
}

/* Header Scroll-Schatten */
.topbar.is-scrolled{box-shadow:0 4px 20px -10px rgba(10,58,102,.28)}
.kfdone{margin-top:18px;background:var(--leaf-50);border:1px solid #cfe6bd;border-radius:var(--r);padding:16px 20px;color:var(--leaf-600);font-weight:600;display:flex;gap:10px;align-items:center}
.kfdone svg{width:20px;height:20px;flex:0 0 auto}

/* ============================================================
   WEBUNDO — PREMIUM / ANIMATIONS LAYER · Ländle Digital
   Scroll-Reveal · Micro-Interactions · 10/10 UX
============================================================ */

/* Scroll-Fortschrittsbalken */
.scrollprog{position:fixed;top:0;left:0;height:3px;width:0;z-index:9999;
  background:linear-gradient(90deg,var(--blue),var(--sky) 60%,var(--leaf));
  box-shadow:0 0 12px rgba(19,102,200,.5);transition:width .08s linear}

/* Reveal-on-Scroll (nur wenn JS Klasse .anim setzt & keine reduzierte Bewegung) */
html.anim :where(.reveal,.sec__title,.svcsec__title,.valprop,.pillar,.svc,.situbox,.mwtile,
  .wmvcard,.valuecard,.branche,.step3,.logos__item,.compare,.about__intro,.checklist li,
  .costbox,.leadcard,.result__3yr,.person,.mstone,.stat,.partners__intro,.team__intro,.tchip,
  .compare__result,.scorewrap){
  opacity:0;transform:translateY(30px);
  transition:opacity .7s cubic-bezier(.16,.7,.2,1) var(--rd,0ms),transform .7s cubic-bezier(.16,.7,.2,1) var(--rd,0ms);
  will-change:opacity,transform}
html.anim :where(.reveal,.sec__title,.svcsec__title,.valprop,.pillar,.svc,.situbox,.mwtile,
  .wmvcard,.valuecard,.branche,.step3,.logos__item,.compare,.about__intro,.checklist li,
  .costbox,.leadcard,.result__3yr,.person,.mstone,.stat,.partners__intro,.team__intro,.tchip,
  .compare__result,.scorewrap).in{opacity:1;transform:none}
html.anim .reveal--scale{transform:scale(.94)}
html.anim .reveal--left{transform:translateX(-36px)}
html.anim .reveal--right{transform:translateX(36px)}

/* ---------- Button-Politur: ruhig & hochwertig (kein Blinken) ---------- */
.btn{letter-spacing:.005em}
.btn--primary{background:var(--blue);box-shadow:0 6px 16px -8px rgba(19,102,200,.55)}
.btn--primary:hover{background:var(--blue-600);box-shadow:0 12px 24px -10px rgba(19,102,200,.6)}
.btn svg{transition:transform .25s ease}
.btn:hover svg{transform:translateX(3px)}

/* ---------- Header: Navigation Unterstrich + Shrink ---------- */
.topbar{transition:height .25s,box-shadow .25s,background .25s}
.topbar__nav--corp a{position:relative}
.topbar__nav--corp a::after{content:"";position:absolute;left:11px;right:11px;bottom:7px;height:2px;
  border-radius:2px;background:linear-gradient(90deg,var(--blue),var(--sky));
  transform:scaleX(0);transform-origin:left;transition:transform .28s cubic-bezier(.16,.7,.2,1)}
.topbar__nav--corp a:hover{background:transparent;color:var(--blue)}
.topbar__nav--corp a:hover::after,.topbar__nav--corp a.is-active::after{transform:scaleX(1)}
.topbar.is-scrolled .topbar__inner{height:64px}
.brand__logo{transition:transform .25s}
.brand:hover .brand__logo{transform:scale(1.04)}

/* ---------- Icon-Kreise: Verlauf + Hover ---------- */
.iccircle{transition:transform .3s cubic-bezier(.16,.7,.2,1),box-shadow .3s}
.iccircle--sky{background:linear-gradient(135deg,#5ec3e3,#3a9fc4);box-shadow:0 10px 22px -10px rgba(77,179,212,.8)}
.iccircle--blue{background:linear-gradient(135deg,#2a8be8,var(--blue));box-shadow:0 10px 22px -10px rgba(19,102,200,.8)}
.iccircle--navy{background:linear-gradient(135deg,#13507f,var(--navy));box-shadow:0 10px 22px -10px rgba(10,58,102,.7)}
.iccircle--dark{background:linear-gradient(135deg,#16344f,#0c1f33)}
.pillar:hover .iccircle,.svc:hover .iccircle{transform:translateY(-3px) rotate(-4deg)}

/* ---------- Karten-Hover-Politur ---------- */
.svc,.valuecard,.wmvcard,.situbox,.mwtile,.logos__item,.fcard{transition:transform .3s cubic-bezier(.16,.7,.2,1),box-shadow .3s,border-color .3s}
.svc{padding:22px;border:1px solid transparent;border-radius:var(--r)}
.svc:hover{transform:translateY(-5px);box-shadow:var(--sh);border-color:var(--line);background:linear-gradient(180deg,#fff,var(--blue-50))}
.situbox:hover,.mwtile:hover,.wmvcard:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.branche{transition:transform .3s}
.valprop{transition:transform .3s}
.valprop:hover{transform:translateY(-3px)}
.valprop:hover .valprop__ic{transform:scale(1.08)}
.valprop__ic{transition:transform .3s}

/* ---------- Eyebrow-Punkt: sanftes Pulsieren ---------- */
.eyebrow .dot{animation:dotpulse 2.4s ease-in-out infinite}
@keyframes dotpulse{0%,100%{box-shadow:0 0 0 0 rgba(19,102,200,.28)}50%{box-shadow:0 0 0 6px rgba(19,102,200,0)}}

/* ---------- Startseite-Hero: Mesh, Verlaufswort, Badge, Scroll-Cue ---------- */
.hhero{position:relative}
.hhero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.9;
  background:radial-gradient(45% 55% at 12% 18%,rgba(19,102,200,.10),transparent 60%),
             radial-gradient(40% 50% at 30% 95%,rgba(95,167,51,.08),transparent 60%)}
.hhero .shell{position:relative;z-index:1}
.hhero h1 .g{background:linear-gradient(120deg,var(--blue),var(--sky) 55%,var(--leaf));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hhero__text>*{opacity:0;transform:translateY(22px);animation:heroIn .8s cubic-bezier(.16,.7,.2,1) forwards}
.hhero__text>h1{animation-delay:.05s}
.hhero__text>.hhero__claim{animation-delay:.16s}
.hhero__text>.hhero__sub:nth-of-type(1){animation-delay:.26s}
.hhero__text>.hhero__sub:nth-of-type(2){animation-delay:.34s}
.hhero__text>.hhero__cta{animation-delay:.44s}
@keyframes heroIn{to{opacity:1;transform:none}}
.hhero__media{opacity:0;transform:translateY(22px);animation:heroIn .9s cubic-bezier(.16,.7,.2,1) .25s forwards}
.hbadge{position:absolute;z-index:2;left:-22px;bottom:26px;background:#fff;border:1px solid var(--line);
  border-radius:18px;padding:15px 20px;box-shadow:0 26px 50px -22px rgba(10,58,102,.45);display:flex;align-items:center;gap:14px;
  animation:floaty 6s ease-in-out infinite}
.hbadge__ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(135deg,#6fbf3f,#4f8e2a);box-shadow:0 8px 18px -8px rgba(95,167,51,.7)}
.hbadge__ic svg{width:24px;height:24px}
.hbadge b{font-family:var(--disp);font-weight:800;font-size:1.5rem;color:var(--navy);display:block;line-height:1}
.hbadge span{font-size:.82rem;color:var(--slate)}
@keyframes floaty{50%{transform:translateY(-10px)}}
@media (max-width:980px){.hbadge{left:auto;right:16px;bottom:16px}}
@media (max-width:560px){.hbadge{display:none}}

/* ---------- Page-Hero: Parallax + Entrance ---------- */
.phero__img{will-change:transform}
.phero .shell>*{opacity:0;transform:translateY(24px);animation:heroIn .75s cubic-bezier(.16,.7,.2,1) forwards}
.phero .phero__eyebrow{animation-delay:.05s}
.phero h1{animation-delay:.14s}
.phero .phero__sub{animation-delay:.24s}
.phero .phero__cta{animation-delay:.34s}

/* ---------- Partner-Marquee ---------- */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee__track{display:flex;gap:18px;width:max-content;animation:marquee 34s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee .logos__item{width:158px;height:92px;flex:0 0 auto}
@keyframes marquee{to{transform:translateX(calc(-50% - 9px))}}

/* ---------- Live-/Ergebniszahlen: weiches Aufblenden ---------- */
.livecard__eu .num,.result__euro .num{font-variant-numeric:tabular-nums;transition:color .2s}
.result__hero{position:relative}
.result__hero::after{content:"";position:absolute;inset:0;border-radius:var(--r-lg);pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}

/* ---------- reduzierte Bewegung respektieren ---------- */
@media (prefers-reduced-motion:reduce){
  .hhero__text>*,.hhero__media,.phero .shell>*{animation:none!important;opacity:1!important;transform:none!important}
  .marquee__track{animation:none}
  .hbadge,.eyebrow .dot{animation:none}
}

/* Marquee-Logos von Reveal ausnehmen (laufen permanent) */
html.anim .marquee .logos__item{opacity:1!important;transform:none!important}

/* ============================================================
   WEBUNDO — Conversion-Kontaktformular + Mobil-Optimierung
============================================================ */
.formcard__head{margin-bottom:20px}
.formcard__head h3{font-size:1.32rem;margin-bottom:5px}
.formcard__head p{color:var(--slate);font-size:.95rem}
.field .flabel{display:block;font-weight:600;font-size:.9rem;margin-bottom:9px}
.field .opt{font-weight:500;color:var(--muted);font-size:.82rem}
.topicchips{display:flex;flex-wrap:wrap;gap:9px}
.topicchip{border:1.5px solid var(--line);background:#fff;color:var(--slate);font-weight:600;font-size:.9rem;padding:.62em 1.05em;border-radius:999px;cursor:pointer;transition:border-color .15s,background .15s,color .15s}
.topicchip:hover{border-color:#c5d2e0}
.topicchip.is-on{border-color:var(--blue);background:var(--blue-50);color:var(--blue-700)}
.ftrust{display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:center;margin-top:14px}
.ftrust span{display:inline-flex;align-items:center;gap:.45em;font-size:.84rem;font-weight:600;color:var(--slate)}
.ftrust svg{width:15px;height:15px;color:var(--leaf);flex:0 0 auto}
.formcard__alt{text-align:center;margin-top:18px;font-size:.92rem;color:var(--slate)}
.formcard__alt a{color:var(--blue);font-weight:700}

/* ---------- Mobil-Feinschliff (volle Touch-Tauglichkeit) ---------- */
@media (max-width:600px){
  /* iOS-Auto-Zoom auf Formularfelder verhindern (>=16px) */
  .input,.select,.textarea{font-size:16px}
  .shell{padding-inline:18px}
  .btn{padding:.9em 1.25em}
  .btn--lg{padding:.95em 1.4em;font-size:1rem}
  .sec__title{font-size:1.5rem}
  .phero{min-height:320px}
  .phero h1{font-size:1.9rem}
  .hhero h1{font-size:2rem}
  .topicchip,.bchip,.btn{min-height:44px}
  .kontakt__info address>div{align-items:center}
}
@media (max-width:380px){
  .grid-2{grid-template-columns:1fr}
  .hbadge{display:none}
}

/* ============================================================
   WEBUNDO — Promobar (Fokus auf Einsparrechner)
============================================================ */
.promobar{position:relative;background:linear-gradient(90deg,var(--navy) 0%,var(--blue) 100%);color:#fff}
.promobar__link{display:flex;align-items:center;justify-content:center;gap:.55em;flex-wrap:wrap;padding:9px 46px;font-size:.9rem;font-weight:500;line-height:1.3;color:#fff;text-align:center}
.promobar__link svg{width:18px;height:18px;flex:0 0 auto;color:#bcd9fb}
.promobar__link strong{font-weight:800;color:#fff}
.promobar__cta{font-weight:800;background:rgba(255,255,255,.16);padding:.24em .85em;border-radius:999px;white-space:nowrap;transition:background .15s}
.promobar__link:hover .promobar__cta{background:rgba(255,255,255,.3)}
.promobar__x{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:0;color:#fff;opacity:.7;font-size:1.3rem;line-height:1;cursor:pointer;padding:4px 9px;border-radius:8px}
.promobar__x:hover{opacity:1;background:rgba(255,255,255,.12)}
.promobar.hide{display:none}
@media(max-width:600px){.promobar__hideMob{display:none}.promobar__link{padding:8px 34px;font-size:.82rem;gap:.45em}}

/* zwei Header-Buttons sauf engeren Desktops zusammenhalten */
@media(max-width:1180px) and (min-width:1101px){.topbar__actions .btn--ghost{display:none}}

/* ============================================================
   WEBUNDO — Fußzeile (übersichtlich, 4 Spalten, WhatsApp + LinkedIn)
============================================================ */
.wfooter__brand .wfooter__logo{display:flex;align-items:center;gap:11px;font-family:var(--disp);font-weight:800;font-size:1.4rem;letter-spacing:.02em;color:#fff;margin-bottom:14px}
.wfooter__brand .wfooter__logo svg{width:36px;height:36px;flex:0 0 auto}
.wfooter__brand p{color:#9fb2c9;font-size:.92rem;line-height:1.6;max-width:34ch;margin-bottom:20px}
.wfooter__list{display:flex;flex-direction:column;gap:11px}
.wfooter__list a{color:#cdd9e7;font-weight:500;font-size:.95rem;transition:color .15s,padding .15s}
.wfooter__list a:hover{color:#fff;padding-left:3px}
.social--wa:hover{background:#25d366;color:#fff}
.wfooter address{display:grid;gap:14px}
.wfooter address span,.wfooter address a{display:flex;align-items:flex-start;gap:11px;color:#cdd9e7;font-size:.95rem;line-height:1.4}
.wfooter address svg{width:19px;height:19px;color:var(--blue-bright);flex:0 0 auto;margin-top:1px}
@media (max-width:980px){
  .wfooter__inner{grid-template-columns:1fr 1fr;gap:32px}
  .wfooter__brand{grid-column:1 / -1}
}
@media (max-width:560px){
  .wfooter__inner{grid-template-columns:1fr;gap:30px}
}
