/* laundrify website-v2 — /home design language (LOCKED)
   Source of truth: ../brand/DESIGN.md + ../tools/tokens.json.
   Ported from the bake-off reference (refined-v2/light.html); brush-stroke blob
   replaced by the real tools/blobs/ output. Externalized for the design/ deliverable. */

:root{
  --primary:#71aef8; --active:#3b76bc; --deep:#2c415b;
  --tint:#eaf6ff; --paper:#f7f8fa; --panel:#ffffff;
  --ink:#22324a; --mut:#62748c; --faint:#9aabbf;
  --line:#e4ebf3; --line-2:#eef3f8;
  --green:#76c785; --orange:#feba2d; --red:#ff7070;
  --disp:'Overlock', system-ui, sans-serif;
  --body:'Manrope', system-ui, sans-serif;
  --r:8px; --r-sm:6px; --r-lg:10px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.ico{display:inline-block;width:1em;height:1em;vertical-align:-.14em}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip-path:inset(50%);white-space:nowrap}
.ico svg{width:100%;height:100%;display:block}
h1,h2,h3{font-family:var(--disp);font-weight:700;letter-spacing:-.015em;text-wrap:pretty}

/* soft pale-blue organic blob backdrop (tools/blobs/) — tinted via currentColor */
.blob{position:absolute;z-index:0;pointer-events:none;color:var(--primary);opacity:.16}
.blob svg{width:100%;height:100%;display:block;fill:currentColor}

/* restrained accent text gradient — headline/accents only */
.grad{background:linear-gradient(96deg,var(--active),var(--primary));
  -webkit-background-clip:text;background-clip:text;color:transparent}

.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-weight:600;
  font-size:12.5px;letter-spacing:.04em;color:var(--active);background:var(--tint);
  border:1px solid #d6ebff;border-radius:999px;padding:7px 14px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 3px rgba(118,199,133,.22)}
.eyebrow .dot.live{animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(118,199,133,.45)}70%{box-shadow:0 0 0 6px rgba(118,199,133,0)}}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-weight:700;
  font-size:14.5px;border-radius:var(--r);padding:12px 20px;cursor:pointer;transition:.18s;border:1px solid transparent}
.btn-primary{background:var(--active);color:#fff;
  box-shadow:0 10px 24px -12px rgba(59,118,188,.7)}
.btn-primary:hover{background:#3369a8;box-shadow:0 12px 28px -12px rgba(59,118,188,.8);transform:translateY(-1px)}
.btn-light{background:#fff;color:var(--active);border-color:var(--line)}
.btn-light:hover{border-color:var(--primary);box-shadow:0 8px 20px -12px rgba(59,118,188,.5)}

/* ---- header (condensing) ----
   default = compact chrome WITH the buy button (the no-JS state); JS adds
   .top at scrollY≈0 (transparent, borderless, slightly larger) and .no-cta
   while the hero's own CTA is on screen (button fades but keeps its space —
   no horizontal nav reflow when it appears) */
header{position:sticky;top:0;z-index:50;background:rgba(247,248,250,.82);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  transition:background .35s,border-color .35s}
header.top{background:transparent;border-bottom-color:transparent;backdrop-filter:none}
.nav{height:66px;display:flex;align-items:center;justify-content:space-between;gap:24px;
  transition:height .35s}
.brand img{height:26px;display:block;transition:height .35s}
.navlinks{display:flex;align-items:center;gap:28px;font-size:14.5px;font-weight:600;color:var(--ink);
  transition:gap .35s,font-size .35s}
header.top .nav{height:80px}
header.top .brand img{height:30px}
header.top .navlinks{gap:34px;font-size:15.5px}
.nav .btn-primary{transition:opacity .3s,translate .3s,background .18s,box-shadow .18s,transform .18s}
header.no-cta .nav .btn-primary{opacity:0;translate:0 -8px;visibility:hidden;pointer-events:none;
  transition:opacity .3s,translate .3s,visibility 0s .3s}
.navlinks a{position:relative;padding:4px 0;transition:color .18s}
.navlinks a:hover{color:var(--active)}
.navlinks a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:2px;
  background:var(--primary);border-radius:2px;transition:right .22s}
.navlinks a:hover::after{right:0}
.navlinks .drop{display:inline-flex;align-items:center;gap:5px}
.menu{display:none}

/* ---- hero ---- */
/* faint gradient wash anchors the hero with light, not a graphic shape (DESIGN.md §6) */
/* pulled up under the sticky header (negative margin + compensating padding) so the wash
   continues behind the transparent .top header instead of cutting off at the section edge */
.hero{position:relative;margin-top:-81px;padding:98px 0 0;overflow:hidden;
  background:radial-gradient(820px 460px at 88% -6%,rgba(113,174,248,.10),transparent 62%)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
h1{font-size:clamp(40px,5.6vw,66px);line-height:1.02;font-weight:900;margin:22px 0 0}
.lede{font-size:18.5px;color:var(--mut);max-width:32ch;margin:20px 0 0;text-wrap:pretty}
.cta-row{margin-top:30px;display:flex;flex-wrap:wrap;align-items:center;gap:18px}
.price{font-size:13.5px;color:var(--mut)}
.price b{color:var(--ink);font-weight:700}
/* product lifted by a soft radial glow (not a blob) — deliberate integration (DESIGN.md §6) */
.product{position:relative;display:grid;place-items:center;min-height:380px}
.product::before{content:"";position:absolute;z-index:0;width:80%;height:80%;border-radius:50%;
  background:radial-gradient(closest-side,rgba(113,174,248,.22),transparent 72%);filter:blur(8px)}
.product img{position:relative;z-index:1;width:86%;max-width:340px;display:block;
  filter:drop-shadow(0 26px 40px rgba(44,65,91,.16))}
.product .tag{position:absolute;z-index:2;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:8px 12px;
  font-size:12.5px;font-weight:600;color:var(--deep);box-shadow:0 10px 26px -16px rgba(44,65,91,.4);
  animation:floaty 5.5s ease-in-out infinite;transition:translate .35s ease-out;will-change:transform,translate}
/* gentle continuous float; JS adds a cursor-dodge via the `translate` property (composes with this transform) */
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.product .tag .ico{color:var(--active);font-size:14px}
.product .tag .dot{width:7px;height:7px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 3px rgba(118,199,133,.22)}
.product .tag.t1{top:7%;left:10%;animation-duration:5.2s}
.product .tag.t2{top:44%;right:-6%;animation-duration:6.4s;animation-delay:-1.8s}  /* below the rear pins — covering them made the product look odd (Mike) */
.product .tag.t3{bottom:5%;left:7%;animation-duration:5.8s;animation-delay:-3.2s}

/* ---- power-curve divider (lighter touch) ---- */
.curve{margin:44px auto;display:flex;justify-content:center}
.curve img{width:min(340px,66%);height:auto;display:block}

/* ---- live-stat band (clean white card below hero — no decorative background) ---- */
.stat-band{position:relative;z-index:2;margin-top:40px}
.stat-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:24px 26px;box-shadow:0 26px 60px -34px rgba(44,65,91,.45)}
.stat-head{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--body);font-weight:700;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--mut);margin-bottom:18px}
.stat-head .live{display:inline-flex;align-items:center;gap:7px;color:var(--active);text-transform:none;letter-spacing:0}
.stat-head .live .dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 1.8s infinite}
.stat-cells{position:relative;z-index:1;display:grid;grid-template-columns:repeat(3,1fr)}
.cell{text-align:center;padding:4px 22px;position:relative}
.cell+.cell::before{content:"";position:absolute;left:0;top:12%;bottom:12%;width:1px;background:var(--line)}
.cell .top .ico{color:var(--primary);font-size:18px}
.cell .num{font-family:var(--disp);font-weight:900;font-size:clamp(30px,3.4vw,38px);line-height:1;
  margin-top:8px;color:var(--deep)}
.cell .num .u{font-size:16px;color:var(--active);margin-left:3px;font-weight:700}
.cell .lab{font-size:13px;color:var(--mut);margin-top:8px}

/* ---- section scaffolding ---- */
.sec{padding:90px 0;position:relative}
.sec-head{margin-bottom:42px}
.kicker{display:block;font-family:var(--body);font-weight:700;font-size:13px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--active);margin-bottom:10px}
h2{font-size:clamp(28px,3.4vw,40px);line-height:1.04;font-weight:700;margin:0}
.sub{color:var(--mut);font-size:16.5px;margin:12px 0 0;max-width:54ch;text-wrap:pretty}

/* ---- setup stepper (DESIGN.md §5) ---- */
.steps{display:grid;grid-template-columns:.82fr 1.18fr;gap:30px;align-items:stretch}
.step{display:flex;gap:16px;width:100%;text-align:left;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px;
  cursor:pointer;transition:.18s;font-family:var(--body);color:var(--ink)}
.step+.step{margin-top:14px}
.step:hover{border-color:var(--primary)}
.step .idx{flex:none;width:44px;height:44px;border-radius:var(--r-sm);display:grid;place-items:center;
  font-family:var(--disp);font-weight:900;font-size:18px;color:var(--faint);
  background:var(--paper);border:1px solid var(--line);transition:.18s}
.step .t{display:block;font-family:var(--disp);font-weight:700;font-size:17px;letter-spacing:-.015em}
.step p{margin:3px 0 0;font-size:13.5px;color:var(--mut);line-height:1.45}
.step[aria-selected="true"]{border-color:var(--primary);background:var(--tint);
  box-shadow:inset 3px 0 0 var(--active)}
.step[aria-selected="true"] .idx{background:var(--active);color:#fff;border-color:var(--active)}

/* panel = viz card: white, gentle glow inside; the illustrations bring their own blob.
   Illustration sits a few px above the card's bottom edge (Mike: the near-flush look with a
   small breathing gap wins) — no min-height, the grid row sizes the panel. */
.panel{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  height:100%;overflow:hidden;display:none;flex-direction:column}
.panel.on{display:flex;animation:panelfade .3s ease-out}
@keyframes panelfade{from{opacity:0}to{opacity:1}}
/* inner wrapper carries the padding so the mobile accordion can collapse to true zero height */
.panel-in{display:flex;flex-direction:column;flex:1;min-height:0;padding:24px 24px 0}
/* (panel interior glow removed 2026-06-11 — glows live in the hero only) */
.panel-tag{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;
  font-family:var(--body);font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--mut)}
.panel-tag .ico{color:var(--active);font-size:15px}
.panel-illus{position:relative;z-index:1;flex:1;display:grid;place-items:end center;padding:8px 0}
/* panel 1's illustration has the small gap baked into the asset (39px source ≈ the same few px) */
#step-panel-1 .panel-illus{padding-bottom:0}
.panel-illus img{max-width:74%;max-height:290px;width:auto;height:auto;display:block}

/* ---- features grid ("Alles, was dein Gerät kann") ----
   Decided 2026-06-11 via design/features-variants.html: simplified SVG viz won over the
   flat-illustration interiors (illustrations stay the setup stepper's voice). */
/* section separation utility: a faded hairline mid-gap (end-fade DNA of the heartbeat
   divider) — available per transition; features now uses the white band instead */
.sec-divider{height:1px;width:min(620px,70%);margin:0 auto;
  background:linear-gradient(90deg,transparent,#d6dce4 22%,#d6dce4 78%,transparent)}
/* centred on --at instead of 50% (clamped so the line never leaves the viewport on mobile) */
.sec-divider.off{margin-left:max(14px,calc(var(--at,40%) - min(620px,70%)/2))}
/* features = white band (cards are rich enough to stand on white — locked 2026-06-11) */
.feats{background:#fff;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.feat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:24px}
/* card border = subtle grey gradient, as if lit from above-left (Mike's Rand-Gradient) */
.feat{grid-column:span 2;position:relative;display:flex;flex-direction:column;
  border:1px solid transparent;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(var(--panel),var(--panel)) padding-box,
    linear-gradient(168deg,#eaeef4 0%,#dde4ec 55%,#d2dbe6 100%) border-box;
  transition:box-shadow .18s,transform .18s}
.feat.big{grid-column:span 3}
.feat:hover{box-shadow:0 22px 48px -26px rgba(44,65,91,.45);transform:translateY(-2px)}
/* hover: a blue border accent follows the cursor (--mx/--my set by JS), fading back into
   the resting grey gradient away from it — masked to the 1px border ring only */
.feat::after{content:"";position:absolute;inset:0;z-index:2;border-radius:var(--r-lg);
  padding:1px;pointer-events:none;opacity:0;transition:opacity .25s;
  background:radial-gradient(480px circle at var(--mx,50%) var(--my,50%),
    var(--primary),rgba(113,174,248,0) 78%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude}
.feat:hover::after{opacity:1}
.feat-viz{position:relative;flex:none;background:var(--paper);border-bottom:1px solid var(--line-2);
  overflow:hidden}
.feat.big .feat-viz{height:252px}
.feat.small .feat-viz{height:172px}
/* viz surface = chart paper: faint neutral dot raster under a soft top sheen */
.feat-viz::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(180deg,rgba(255,255,255,.5),rgba(255,255,255,0) 55%),
    radial-gradient(circle,rgba(44,65,91,.08) 1px,transparent 1.3px);
  background-size:auto,20px 20px;background-position:0 0,10px 12px}
.feat-viz>*{position:relative;z-index:1}
.feat-body{padding:20px 22px 24px}
.feat-body h3{font-size:20px;line-height:1.15;margin:0}
.feat.small .feat-body h3{font-size:17.5px}
.feat-body p{margin:7px 0 0;font-size:14px;color:var(--mut);line-height:1.55}

/* simplified SVG viz interiors */
.vz{position:absolute;inset:0;padding:18px;display:flex;flex-direction:column}
.vz .live{position:absolute;top:14px;right:14px;display:inline-flex;align-items:center;gap:7px;
  background:var(--tint);border:1px solid rgba(113,174,248,.45);border-radius:999px;
  padding:5px 11px;font-size:11.5px;font-weight:700;color:var(--active)}
.vz .live .dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 1.8s infinite}
.vz svg.chart{flex:1;width:100%;min-height:0;display:block}
/* chartbox: relative wrapper so the live endpoint can be a round HTML dot — an svg <circle>
   would turn elliptic when preserveAspectRatio:none stretches the chart (visible on mobile) */
.vz-chartbox{position:relative;flex:1;min-height:0;display:flex;flex-direction:column}
.vz-chartbox svg.chart{height:100%}
.vz-live-dot{position:absolute;left:83.7%;top:40.6%;width:9px;height:9px;margin:-4.5px 0 0 -4.5px;
  border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(118,199,133,.22)}
.vz-kpis{flex:none;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.vz-kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 10px;
  display:flex;align-items:center;gap:9px}
.vz-kpi .ico{color:var(--active);font-size:16px;flex:none}
.vz-kpi .v{font-family:var(--disp);font-weight:900;font-size:15px;color:var(--deep);line-height:1.1;
  white-space:nowrap}
.vz-kpi .k{font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);margin-bottom:2px}
.vz-phone{position:absolute;left:50%;bottom:-34px;translate:-72% 0;width:158px;height:240px;
  background:#fff;border:1.5px solid var(--faint);border-radius:22px;padding:14px 12px;
  box-shadow:0 18px 40px -24px rgba(44,65,91,.4)}
.vz-phone .notch{width:52px;height:5px;border-radius:3px;background:var(--line);margin:0 auto 14px}
.vz-phone .ph-line{height:9px;border-radius:5px;background:var(--line-2);margin:9px 4px}
.vz-phone .ph-line.w1{width:70%}.vz-phone .ph-line.w2{width:52%}
.vz-phone .ph-block{height:46px;border-radius:var(--r-sm);background:var(--line-2);margin:12px 4px}
.vz-toast{position:absolute;left:50%;top:46px;translate:-26% 0;width:248px;white-space:nowrap;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:12px 14px;
  display:flex;align-items:center;gap:11px;box-shadow:0 16px 36px -18px rgba(44,65,91,.45)}
.vz-toast .chk{flex:none;width:30px;height:30px;border-radius:50%;background:var(--green);
  display:grid;place-items:center;color:#fff;font-size:17px}
.vz-toast .t{font-family:var(--disp);font-weight:700;font-size:14.5px;color:var(--ink);line-height:1.2}
.vz-toast .s{font-size:11.5px;color:var(--mut);margin-top:2px}
.vz-hub{position:absolute;inset:0}
.vz-hub svg.wires{position:absolute;inset:0;width:100%;height:100%}
.vz-hub .node{position:absolute;display:grid;place-items:center;background:#fff;
  border:1px solid var(--line);border-radius:50%;box-shadow:0 10px 24px -14px rgba(44,65,91,.35)}
.vz-hub .node img{display:block;width:62%;height:62%;object-fit:contain}
.vz-hub .core{width:58px;height:58px;left:50%;top:50%;translate:-50% -50%;border-color:#d6ebff}
.vz-hub .core img{width:56%;height:56%;border-radius:8px}
.vz-hub .sat{width:46px;height:46px;translate:-50% -50%}

/* smart-home compatibility strip at the end of the features band */
.compat{margin-top:58px;text-align:center}
.compat p{font-size:14px;color:var(--mut);margin:0 0 22px}
.compat a{color:var(--active);font-weight:600;text-decoration:underline;text-underline-offset:3px}
.compat a:hover{color:#3369a8}
.compat-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:18px 44px}
.compat-logos img{height:26px;width:auto;opacity:.75;filter:grayscale(.25);transition:.18s}
.compat-logos img[alt="Amazon Alexa"]{height:38px}   /* roundel, not a horizontal lockup */
.compat-logos img:hover{opacity:1;filter:none}

/* ---- viz placeholder (temporary — swapped for real assets per section) ---- */
.viz-ph{display:grid;place-items:center;min-height:330px;padding:24px;text-align:center;
  background:rgba(255,255,255,.55);border:1.5px dashed var(--faint);border-radius:var(--r-lg);
  color:var(--mut);font-size:13.5px}

/* ---- tech specs ("Auf einen Blick") ---- */
/* datasheet figure = the locked viz-panel treatment (DESIGN.md §5): gradient border +
   chart-paper dot raster; thin tick-ended dimension brackets with Overlock numerals */
.spec-fig{position:relative;margin:0;border:1px solid transparent;border-radius:var(--r-lg);
  overflow:hidden;
  background:linear-gradient(var(--panel),var(--panel)) padding-box,
    linear-gradient(168deg,#eaeef4 0%,#dde4ec 55%,#d2dbe6 100%) border-box}
.spec-fig::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(180deg,rgba(255,255,255,.5),rgba(255,255,255,0) 55%),
    radial-gradient(circle,rgba(44,65,91,.08) 1px,transparent 1.3px);
  background-size:auto,20px 20px;background-position:0 0,10px 12px}
.spec-fig svg{position:relative;display:block;width:100%;height:auto}
.spec-fig image{filter:drop-shadow(0 16px 22px rgba(44,65,91,.16))}
.dim line{stroke:var(--faint);stroke-width:1.3}
.dim .ext{stroke:var(--line);stroke-width:1;stroke-dasharray:3 4}
.dim text{font-family:var(--disp);font-weight:900;font-size:19px;fill:var(--deep);letter-spacing:-.01em}
.dim .u{fill:var(--active);font-size:14px;font-weight:700}

.specs-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
/* spec rows carry the KPI-card DNA: uppercase faint label above an Overlock value,
   separated by hairlines instead of card chrome */
.spec-list{display:grid;grid-template-columns:1fr 1fr;gap:0 44px;margin:0}
.spec{border-top:1px solid var(--line);padding:18px 0 20px}
.spec dt{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.spec dd{margin:6px 0 0;font-family:var(--disp);font-weight:700;font-size:20px;
  letter-spacing:-.01em;color:var(--deep);line-height:1.2}

/* ---- laundrify plus teaser ---- */
/* faint gradient wash lifts the teaser off the paper (DESIGN.md §6) — no band, no tint fill */
.plus{background:radial-gradient(760px 420px at 10% 8%,rgba(113,174,248,.08),transparent 62%)}
.plus-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.plus-list{list-style:none;margin:30px 0 0;padding:0;display:grid;gap:20px}
.plus-list li{display:flex;gap:14px}
.plus-list .chk{flex:none;margin-top:1px;width:26px;height:26px;border-radius:50%;
  background:var(--tint);border:1px solid #d6ebff;color:var(--active);
  display:grid;place-items:center;font-size:14px}
.plus-list .t{display:block;font-family:var(--disp);font-weight:700;font-size:17.5px;letter-spacing:-.015em}
.plus-list p{margin:2px 0 0;font-size:14px;color:var(--mut);line-height:1.5}
.plus-cta{margin-top:34px}

/* ---- plus viz: app-fragment collage — 5 overlapping cards, blur = "ohne plus".
   Cards float gently (hero-tag DNA) and couple with the bullet list: hovering a bullet
   (or a card) lifts its card to the front; the rest step back behind a soft blur.
   Lift uses translate/scale so it composes with the floaty transform animation. ---- */
.plus-viz{position:relative;min-height:500px}
.plus-blob{inset:-4% -7%;opacity:.13}
.pv-card{position:absolute;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:0 18px 44px -24px rgba(44,65,91,.45);padding:14px 16px;
  animation:floaty 6.2s ease-in-out infinite;
  transition:translate .35s ease,scale .35s ease,filter .35s ease,opacity .35s ease,box-shadow .35s ease}
.pv-history{animation-duration:7.1s;animation-delay:-2.1s}
.pv-cycles{animation-duration:6.6s;animation-delay:-3.4s}
.pv-comp{animation-duration:5.7s;animation-delay:-1.2s}
.pv-note{animation-duration:6.9s;animation-delay:-4.3s}
/* lift = the "mit plus" moment: the raised card's own locked elements unblur (€, old months,
   old rows); the other cards just recede via opacity — no whole-card blur (it would fight
   the in-card locked-blur metaphor; Mike 2026-06-12) */
.plus-viz.focus .pv-card{opacity:.6}
.plus-viz.focus .pv-card.lift{opacity:1;z-index:9;translate:0 -5px;scale:1.04;
  box-shadow:0 30px 60px -28px rgba(44,65,91,.55)}
.plus-list [data-card]{cursor:pointer}
.pv-card.lift .pv-blur{filter:blur(0)}   /* €, −21 % … any pv-blur on the lifted card */
.pv-history.lift .pv-locked{filter:blur(0);opacity:1}
.pv-history.lift .pv-locked rect{fill:var(--primary);stroke:none}  /* unlocked months join the blue */
.pv-history.lift .pv-months span{filter:blur(0);opacity:1}
.pv-cycles.lift .pv-row-locked{filter:blur(0);opacity:1}
.pv-label{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  color:var(--faint);margin-bottom:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Kostenanzeige: KPI cells side by side (dashboard-card pattern) */
.pv-kpis{left:0;top:0;width:70%;z-index:3;display:flex;flex-wrap:wrap}
.pv-kpis{animation-delay:-.6s}
.pv-kpis .pv-label{width:100%}
.pv-kpi{flex:1;display:flex;align-items:center;justify-content:center;gap:9px;padding:2px 6px}
.pv-kpi+.pv-kpi{border-left:1px solid var(--line-2)}
.pv-kpi .ico{color:var(--active);font-size:16px;flex:none}
.pv-kpi .k{font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--faint)}
.pv-kpi .v{font-family:var(--disp);font-weight:900;font-size:16px;color:var(--deep);line-height:1.15;white-space:nowrap}
/* the € value stays blurred in the resting state — it only unblurs while the card is lifted */
.pv-blur{filter:blur(5px);transition:filter .5s ease}
/* unbegrenzte Statistiken: months beyond the free 3-month window blurred */
.pv-history{right:0;top:16%;width:46%;z-index:5}  /* stats + comp float ABOVE the cycle list (Mike) */
.pv-bars{display:block;width:100%}
.pv-bars rect{fill:var(--tint);stroke:#d6ebff;transition:fill .5s ease}
.pv-bars .pv-open rect{fill:var(--primary);stroke:none}
.pv-bars .pv-locked{filter:blur(2.5px);opacity:.8;transition:filter .5s ease,opacity .5s ease}
.pv-bars .pv-zero rect{fill:var(--line-2);stroke:none}   /* Nov+Dez: noch keine Daten */
.pv-months{display:flex;justify-content:space-between;padding:4px 3px 0;font-size:9px;color:var(--faint)}
.pv-months span:nth-child(-n+7){filter:blur(2px);opacity:.7;transition:filter .5s ease,opacity .5s ease}
/* unbegrenzte Programm-Details: list with the 4-week cut-off.
   Row line 1 = name + timestamp; line 2 = tiny KPI trio (deliberately small, needn't be legible) */
.pv-cycles{left:3%;top:21%;width:50%;z-index:4}
.pv-row{padding:9px 0}
.pv-row+.pv-row{border-top:1px solid var(--line-2)}
.pv-row .r1{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.pv-row .n{font-size:12px;font-weight:600;color:var(--ink);line-height:1.25}
.pv-row .d{font-size:10px;color:var(--faint);white-space:nowrap}
.pv-row .r2{display:flex;justify-content:space-evenly;margin-top:6px;white-space:nowrap}
.pv-row .r2>span{display:inline-flex;align-items:center;gap:4px}
.pv-row .r2 .ico{font-size:10px;color:var(--mut)}  /* muted — the icons shouldn't pop */
.pv-row .r2 .sk{width:26px;height:7.5px;border-radius:4px;background:var(--line-2)}  /* skeleton: values don't matter here */
.pv-row-locked{filter:blur(2.5px);opacity:.75;transition:filter .5s ease,opacity .5s ease}
.pv-cut{display:flex;align-items:center;gap:8px;font-size:9.5px;font-weight:600;letter-spacing:.05em;
  text-transform:uppercase;color:var(--faint);margin:4px 0}
.pv-cut::before,.pv-cut::after{content:"";flex:1;border-top:1px dashed var(--faint);opacity:.55}
.pv-comp{right:2%;top:48%;width:38%;z-index:5}
.pv-delta{font-family:var(--disp);font-weight:900;font-size:30px;line-height:1;color:var(--green)}
.pv-comp p{margin:6px 0 0;font-size:11px;color:var(--mut);line-height:1.45;max-width:150px}
.pv-note{right:8%;bottom:0;width:56%;z-index:6}  /* notification stays topmost */
.pv-note-head{display:flex;align-items:center;gap:11px}
.pv-note-head img{width:34px;height:34px;border-radius:8px;display:block}
.pv-note-head .t{font-family:var(--disp);font-weight:700;font-size:15px;color:var(--ink);line-height:1.2}
.pv-note-head .s{font-size:11px;color:var(--mut);margin-top:1px}
.pv-actions{display:flex;gap:8px;margin-top:12px}
.pv-act{flex:auto;text-align:center;font-size:11.5px;font-weight:700;color:var(--active);white-space:nowrap;
  background:var(--tint);border:1px solid #d6ebff;border-radius:var(--r-sm);padding:7px 9px}

/* ---- ratings ("Was unsere Nutzer sagen") ----
   Summary rail = chrome-free (spec-list DNA: the reviews are the cards, no card-on-card);
   selected distribution row reuses the stepper's selected treatment (tint + inset active bar).
   Stars = --orange (status amber, sparingly — the one warm trust signal); data bars stay blue. */
/* white glow under the section divider: half-ellipse pinned to the section's top edge —
   shines only downward (the section box clips it = hard border to the plus section above) */
.ratings{background:radial-gradient(1500px 600px at 40% 0,rgba(255,255,255,.95),rgba(255,255,255,0) 70%)}
.ratings-grid{display:grid;grid-template-columns:.95fr 2.05fr;gap:52px;align-items:start}
.rate-rail{position:sticky;top:96px}
.rate-avg{display:flex;align-items:flex-end;gap:16px}
.rate-avg .num{font-family:var(--disp);font-weight:900;font-size:clamp(48px,5vw,60px);
  line-height:.85;color:var(--deep);letter-spacing:-.02em}
.rate-avg .cnt{display:block;font-size:13px;color:var(--mut);margin-top:7px}
/* star rows: outline base + a clipped filled overlay = the precise 4,6/5 partial fill */
.stars{position:relative;display:inline-block;color:var(--orange);line-height:0}
.stars .row{display:flex;gap:3px}
.stars .row .st{flex:none}
.stars .fill{position:absolute;left:0;top:0;overflow:hidden}
.st{width:17px;height:17px}
.stars.sm .st{width:13px;height:13px}
.rate-dist{margin-top:26px;display:grid;gap:0}
.dist{position:relative;display:grid;grid-template-columns:32px 1fr 42px;align-items:center;gap:10px;
  width:100%;border:1px solid transparent;background:none;font-family:var(--body);cursor:pointer;
  padding:4px 10px;border-radius:var(--r-sm);
  transition:background .18s,border-color .18s,box-shadow .18s,opacity .25s,filter .25s}
.dist:hover{background:rgba(113,174,248,.06)}
.dist .r{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--mut)}
.dist .r .st{width:11px;height:11px;color:var(--faint)}
.dist .bar{height:9px;background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden}
/* bar fills = --orange: they count stars, so they carry the stars' color (not data-blue) */
.dist .bar-fill{display:block;height:100%;width:var(--w);background:var(--orange);border-radius:3px;
  transform-origin:left;transition:transform .8s cubic-bezier(.22,.7,.3,1) var(--d,0s),background .18s}
.rate-dist.pre .bar-fill{transform:scaleX(0)}
.dist:nth-child(2){--d:.07s}.dist:nth-child(3){--d:.14s}.dist:nth-child(4){--d:.21s}.dist:nth-child(5){--d:.28s}
.dist .c{font-size:12.5px;color:var(--mut);text-align:right;font-variant-numeric:tabular-nums}
/* selected = the setup-step treatment: faint wash + hairline + the radius-clipped inset bar
   (its "(" bracket look is intentional — same DNA as .step[aria-selected]) */
.dist[aria-pressed="true"]{background:rgba(113,174,248,.09);border-color:#d6ebff;
  box-shadow:inset 3px 0 0 var(--active)}
.dist[aria-pressed="true"] .c{color:var(--active);font-weight:700}
/* with an active star filter the other rows step back (compat-logo DNA); hover brings one back */
.rate-dist:has([aria-pressed="true"]) .dist[aria-pressed="false"]{opacity:.45;filter:grayscale(.5)}
.rate-dist:has([aria-pressed="true"]) .dist[aria-pressed="false"]:hover{opacity:1;filter:none}
.rate-src{margin-top:28px}
.rate-lab{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip{font-family:var(--body);font-size:12.5px;font-weight:600;color:var(--mut);
  background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);
  padding:7px 12px;cursor:pointer;transition:.18s}
.chip:hover{border-color:var(--primary);color:var(--active)}
.chip.on{background:var(--active);border-color:var(--active);color:#fff}
.rate-sort{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.rate-sort .rate-lab{margin-right:4px;display:inline-flex;align-items:center;gap:6px}
.rate-sort .rate-lab .ico{font-size:17px}
.rate-sort .hint{margin-left:auto;display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;color:var(--faint)}
.rate-sort .hint .ico{font-size:15px}
.rate-sort .hint[hidden]{display:none}
/* masonry flow: equal width, individual heights (CSS multi-column, like the wireframe) */
.review-list{columns:2;gap:20px}
.review{break-inside:avoid;margin:0 0 20px;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:20px 22px}
.review-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.review .src{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.review .q{margin:12px 0 0;font-size:14.5px;line-height:1.55;color:var(--ink)}
.review footer{display:flex;justify-content:space-between;gap:10px;margin-top:14px;
  font-size:12.5px;color:var(--faint)}
.review-empty{padding:42px 24px;text-align:center;background:rgba(255,255,255,.55);
  border:1.5px dashed var(--faint);border-radius:var(--r-lg);color:var(--mut);font-size:13.5px}
.review-empty p{margin:0 0 14px}

/* ---- FAQ teaser ---- */
/* white band (features-band DNA); narrow reading column; rows = spec-list hairline DNA,
   the chevron disc = plus-list checkmark DNA */
.faq{background:#fff;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.faq-wrap{max-width:800px}
.faq-list{border-bottom:1px solid var(--line)}
.qa{border-top:1px solid var(--line);interpolate-size:allow-keywords}
.qa summary{display:flex;align-items:center;gap:16px;padding:19px 4px;cursor:pointer;list-style:none}
.qa summary::-webkit-details-marker{display:none}
.qa .q{flex:1;font-family:var(--disp);font-weight:700;font-size:18px;letter-spacing:-.015em;
  transition:color .18s}
.qa summary:hover .q{color:var(--active)}
.qa .x{flex:none;width:26px;height:26px;border-radius:50%;background:var(--tint);
  border:1px solid #d6ebff;color:var(--active);display:grid;place-items:center;
  font-size:13px;transition:transform .3s ease}
.qa[open] .x{transform:rotate(180deg)}
.qa p{margin:0;padding:0 46px 20px 0;max-width:62ch;font-size:14.5px;color:var(--mut);line-height:1.6}
/* open/close animates where ::details-content is supported; degrades to instant elsewhere */
.qa::details-content{block-size:0;overflow:hidden;
  transition:block-size .32s ease,content-visibility .32s allow-discrete}
.qa[open]::details-content{block-size:auto}
.faq-cta{margin:42px auto 0;display:flex;width:fit-content}
/* arrow link (reference vocabulary: icon nudges right on hover) */
.more{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14.5px;color:var(--active)}
.more .ico{font-size:15px;transition:transform .18s}
.more:hover .ico,.post:hover .more .ico{transform:translateX(4px)}

/* ---- blog + newsletter ---- */
/* quiet white hairline cards — no cursor-ring (that stays the feature grid's signature) */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:24px;transition:.18s}
.post:hover{border-color:var(--primary);transform:translateY(-2px);
  box-shadow:0 22px 48px -26px rgba(44,65,91,.35)}
.post .date{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.post h3{font-size:19px;line-height:1.25;margin:10px 0 0}
.post p{flex:1;margin:10px 0 0;font-size:14px;color:var(--mut);line-height:1.55}
.post .more{margin-top:18px;font-size:13.5px}
.news{margin-top:46px;text-align:center}
.news h3{font-size:22px;margin:0}
.news p{margin:8px 0 0;font-size:14.5px;color:var(--mut)}
.news-form{margin:22px auto 0;display:flex;justify-content:center;flex-wrap:wrap;gap:10px;max-width:440px}
.news-form input{flex:1;min-width:220px;font:600 14.5px/1.4 var(--body);color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:12px 16px;
  transition:border-color .18s,box-shadow .18s}
.news-form input::placeholder{color:var(--faint);font-weight:500}
.news-form input:focus-visible{outline:none;border-color:var(--active);
  box-shadow:0 0 0 3px rgba(113,174,248,.25)}

/* ---- dark moment: final CTA + footer (DESIGN.md §5) ---- */
/* faint primary wash instead of the reference blob (blobs stay viz-only, §6) —
   the hero's light, inverted, bookending the page */
.final{position:relative;background:var(--deep);color:#fff;overflow:hidden}
.final::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(820px 420px at 50% -10%,rgba(113,174,248,.16),transparent 62%)}
.final-in{position:relative;text-align:center;padding:96px 0 100px}
.final .eyebrow{background:rgba(113,174,248,.14);border-color:rgba(113,174,248,.4);color:#bcdcff}
.final h2{font-size:clamp(32px,4.4vw,52px);font-weight:900;margin:20px auto 0;max-width:22ch;color:#fff}
.final h2 .grad{background:linear-gradient(96deg,#8cc0ff,var(--primary));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.final .btn-primary{margin-top:30px;padding:15px 26px;font-size:15px;
  background:var(--primary);color:#0e2540;box-shadow:0 14px 34px -14px rgba(113,174,248,.8)}
.final .btn-primary:hover{background:#8cc0ff}
.final .price{display:block;margin-top:18px;color:#a6b8cd}
.final .price b{color:#fff}
.final :focus-visible{outline-color:var(--primary)}

/* body>footer: the page footer only — bare `footer` would also hit the review cards' <footer> */
/* -1px: overlaps .final so DPR-fractional rounding can't leak a paper-colored seam
   between the two dark blocks (visible as a faint full-width line at the divider's y) */
body>footer{background:var(--deep);color:#a6b8cd;margin-top:-1px}
/* padding LONGHANDS only — a shorthand here would wipe .wrap's 24px side gutters */
/* CTA→footer divider = the faded-hairline DNA (sec-divider), in the dark band's white */
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;
  padding-top:60px;padding-bottom:44px;position:relative}
.foot::before{content:"";position:absolute;top:0;left:24px;right:24px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08) 22%,
    rgba(255,255,255,.08) 78%,transparent)}.foot-brand img{height:26px;display:block}
.foot .tagline{margin:16px 0 0;max-width:26ch;font-size:14px;color:#8298b2}
.foot h4{font-family:var(--body);font-weight:700;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:#fff;margin:0 0 14px}
.foot ul{list-style:none;margin:0;padding:0}
.foot li+li{margin-top:9px}
.foot a{font-size:14px;transition:color .18s}
.foot a:hover{color:#fff}
.copy{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;padding-bottom:20px;
  font-size:12.5px;color:#7e93ac}
body>footer :focus-visible{outline-color:var(--primary)}

@media (max-width:880px){
  .blog-grid{grid-template-columns:1fr}
  .qa p{padding-right:0}
  .news-form input{font-size:16px}  /* <16px would trigger iOS focus auto-zoom */
  .foot{grid-template-columns:1fr 1fr;gap:34px 30px}
  /* small screens: full-width @ .08 reads as a uniform (or invisible) line — go shorter,
     centered (sec-divider proportions) and slightly brighter so the end-fade is perceptible */
  .foot::before{left:50%;right:auto;translate:-50% 0;width:min(620px,78%);
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.26) 26%,
      rgba(255,255,255,.26) 74%,transparent)}
  .foot-brand{grid-column:1/-1}
  .ratings-grid{grid-template-columns:1fr;gap:38px}
  .rate-rail{position:static}
  .dist{padding:11px 10px}        /* touch-target height */
  .chip{padding:10px 14px}
  .rate-sort .hint{margin-left:0;width:100%;order:-1}  /* own row, ABOVE the sort chips */
  .specs-grid,.plus-grid{grid-template-columns:1fr;gap:36px}
  .viz-ph{min-height:240px}
  .plus-viz{min-height:560px;max-width:480px;margin:0 auto;width:100%}
  .plus-viz .pv-kpis{width:100%}
  .plus-viz .pv-history{top:22%}
  /* wide enough that name + timestamp keep one line; may overlap the stats card —
     fine, it floats above it (Mike 2026-06-12) */
  .plus-viz .pv-cycles{width:62%}
  .plus-viz .pv-comp{right:0;width:42%;top:52%}
  .plus-viz .pv-note{width:80%}
  .plus-viz .pv-actions{flex-wrap:wrap}
  .plus-viz .pv-months{font-size:8px}
  .feat-grid{grid-template-columns:1fr}
  .feat,.feat.big{grid-column:auto}
  /* setup stepper → accordion: each panel sits directly below its step (display:contents
     interleaves the two wrappers); switching collapses the old card and expands the new
     one via the grid-template-rows 0fr→1fr trick (no fade) */
  .steps{display:flex;flex-direction:column;gap:0}  /* desktop grid gap would pad even collapsed panels */
  .steps [role="tablist"],.steps .panels{display:contents}
  /* illustration ABOVE its step (Mike 2026-06-11) */
  #step-panel-1{order:1;margin-top:0}#step-tab-1{order:2}
  #step-panel-2{order:3}#step-tab-2{order:4}
  #step-panel-3{order:5}#step-tab-3{order:6}
  .step+.step{margin-top:0}
  #step-tab-2,#step-tab-3{margin-top:14px}
  .panel,.panel.on{display:grid;height:auto;animation:none;margin-top:0;
    grid-template-rows:0fr;border-width:0;
    transition:grid-template-rows .4s ease,margin .4s ease,border-width .4s ease}
  .panel.on{grid-template-rows:1fr;margin-top:14px;border-width:1px}
  /* tab 1 has no top margin (it was the first item), so panel 1 supplies the gap itself */
  #step-panel-1.on{margin-bottom:14px}
  .panel-in{overflow:hidden;transition:padding .4s ease}
  .panel:not(.on) .panel-in{padding-top:0;padding-bottom:0}
  .panel-illus img{max-width:86%;max-height:240px}
  .navlinks,.btn .full{display:none}
  .menu{display:grid;place-items:center;width:42px;height:42px;border:1px solid var(--line);
    border-radius:var(--r-sm);background:#fff}
  .hero-grid{grid-template-columns:1fr}
  .stat-cells{grid-template-columns:1fr;gap:6px}
  .cell{padding:14px}
  .cell+.cell::before{display:none;top:auto;left:12%;right:12%;width:auto;height:1px}
  .cell+.cell{border-top:1px solid var(--line)}
  .product{min-height:300px;order:-1}
  .product .tag.t1{left:0}
  .product .tag.t2{right:0}
}
@media (max-width:680px){.review-list{columns:1}}
/* narrow phones: the KPI icons step aside so value+unit keep one line within the trio */
@media (max-width:480px){
  .vz-kpi{padding:8px;justify-content:center}
  .vz-kpi .ico{display:none}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
:focus-visible{outline:2px solid var(--active);outline-offset:3px;border-radius:var(--r-sm)}
