:root{
  --rf-anthracite:#23272F;
  --rf-teal:#2F7E7A;
  --rf-teal-dark:#266764;
  --rf-teal-light:#EAF6F5;
  --rf-grey:#F3F5F6;
  --rf-white:#FFFFFF;
  --rf-border:#DDE5E7;
  --rf-muted:#5C636B;
}
*{ -webkit-font-smoothing:antialiased; }
body{
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--rf-anthracite);
  background:var(--rf-white);
  line-height:1.6;
}
h1,h2,h3,h4{ font-weight:700; letter-spacing:-0.02em; line-height:1.12; }
.lead-muted{ color:var(--rf-muted); }
a{ text-decoration:none; }

/* ---- Buttons ---- */
.btn{ font-weight:600; border-radius:.7rem; padding:.7rem 1.25rem; }
.btn-rf{ background:var(--rf-teal); color:#fff; border:1px solid var(--rf-teal); }
.btn-rf:hover,.btn-rf:focus{ background:var(--rf-teal-dark); border-color:var(--rf-teal-dark); color:#fff; }
.btn-rf-outline{ background:#fff; color:var(--rf-anthracite); border:1.5px solid var(--rf-border); }
.btn-rf-outline:hover,.btn-rf-outline:focus{ border-color:var(--rf-anthracite); color:var(--rf-anthracite); }
.btn:focus-visible{ outline:3px solid var(--rf-teal); outline-offset:2px; box-shadow:none; }

/* ---- Navbar ---- */
.navbar{ background:rgba(255,255,255,.9); backdrop-filter:blur(10px); border-bottom:1px solid var(--rf-border); }
.rf-logo{ font-weight:800; font-size:1.4rem; letter-spacing:-.03em; line-height:1; }
.rf-logo .repar{ color:var(--rf-anthracite); }
.rf-logo .fix{ color:var(--rf-teal); }
.rf-logo small{ display:block; font-size:.62rem; font-weight:500; letter-spacing:.01em; color:var(--rf-muted); margin-top:2px; }
.navbar .nav-link{ color:var(--rf-anthracite); font-weight:500; }
.navbar .nav-link:hover{ color:var(--rf-teal); }

/* ---- Hero ---- */
.hero{ background:var(--rf-grey); }
.hero h1{ font-size:clamp(2rem,4.4vw,3.25rem); font-weight:800; }
.hero--sub h1{ font-size:clamp(1.7rem,3.6vw,2.7rem); }
.eyebrow{ font-size:.8rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--rf-teal); }
/* hero checklist */
.hero-checks{ list-style:none; padding:0; margin:0; display:grid; gap:.6rem; }
.hero-checks li{ display:flex; align-items:center; gap:.7rem; font-weight:600; color:var(--rf-anthracite); }
.hero-checks .ck{ flex:none; width:24px; height:24px; border-radius:.5rem; background:var(--rf-teal); display:grid; place-items:center; }
.hero-checks .ck svg{ width:14px; height:14px; color:#fff; }

/* ---- Breadcrumb ---- */
.bc{ font-size:.85rem; color:var(--rf-muted); margin-bottom:1rem; }
.bc a{ color:var(--rf-muted); }
.bc a:hover{ color:var(--rf-teal); }
.bc .sep{ margin:0 .45rem; opacity:.45; }

/* ---- Intake wizard card ---- */
.intake-card{ background:#fff; border:1px solid var(--rf-border); border-radius:1.25rem; box-shadow:0 24px 60px -34px rgba(35,39,47,.45); overflow:hidden; }
.intake-head{ padding:1.4rem 1.5rem 0; }
.intake-title-row{ display:flex; align-items:center; justify-content:space-between; margin-bottom:.85rem; }
.intake-title-row strong{ font-size:1.1rem; color:var(--rf-anthracite); font-weight:700; }
.badge-mini{ background:var(--rf-teal-light); color:var(--rf-teal-dark); font-weight:700; font-size:.78rem; padding:.25rem .7rem; border-radius:99px; }
.intake-progress{ height:8px; background:var(--rf-grey); border-radius:99px; overflow:hidden; }
.intake-progress span{ display:block; height:100%; width:33.33%; background:var(--rf-teal); border-radius:99px; transition:width .35s; }
.intake-step-label{ font-size:.74rem; color:var(--rf-muted); font-weight:700; margin-top:.5rem; text-transform:uppercase; letter-spacing:.05em; }
.intake-app{ padding:1rem 1.5rem 1.6rem; }
.q-title{ font-size:1.18rem; color:var(--rf-anthracite); font-weight:700; margin:.35rem 0 1.05rem; letter-spacing:-.01em; }

.obj-grid{ display:grid; grid-template-columns:1fr 1fr; gap:.6rem; }
.choice{ position:relative; display:flex; flex-direction:column; align-items:center; text-align:center; gap:.45rem; border:1.6px solid var(--rf-border); border-radius:.85rem; padding:1rem .6rem; cursor:pointer; background:#fff; transition:.13s; font-size:.98rem; font-weight:600; color:var(--rf-anthracite); }
.choice .ci{ display:inline-flex; }
.choice .ci svg{ width:28px; height:28px; color:var(--rf-teal); stroke-width:1.7; fill:none; }
.choice:hover{ border-color:var(--rf-teal); background:var(--rf-teal-light); }
.choice.sel{ border-color:var(--rf-teal); background:var(--rf-teal-light); box-shadow:0 0 0 3px var(--rf-teal-light); }
.choice .chk{ position:absolute; top:.5rem; right:.5rem; width:20px; height:20px; border-radius:99px; border:2px solid var(--rf-border); display:grid; place-items:center; color:#fff; font-size:.72rem; }
.choice.sel .chk{ background:var(--rf-teal); border-color:var(--rf-teal); }

.ifield{ margin-bottom:1rem; }
.ifield label{ display:block; font-weight:700; color:var(--rf-anthracite); font-size:.88rem; margin-bottom:.45rem; }
.ichips{ display:flex; flex-wrap:wrap; gap:.5rem; }
.ichip{ border:1.6px solid var(--rf-border); background:#fff; border-radius:99px; padding:.5rem 1rem; cursor:pointer; font-weight:600; color:var(--rf-anthracite); font-size:.9rem; font-family:inherit; transition:.12s; }
.ichip:hover{ border-color:var(--rf-teal); }
.ichip.sel{ background:var(--rf-teal); border-color:var(--rf-teal); color:#fff; }
.intake-app input{ width:100%; border:1.6px solid var(--rf-border); border-radius:.7rem; padding:.78rem .9rem; font-size:1rem; color:var(--rf-anthracite); font-family:inherit; }
.intake-app input:focus{ outline:0; border-color:var(--rf-teal); box-shadow:0 0 0 3px var(--rf-teal-light); }
.two{ display:grid; grid-template-columns:1fr 1fr; gap:.7rem; }
@media(max-width:480px){ .two{ grid-template-columns:1fr; } }
.upload{ display:flex; align-items:center; gap:.6rem; border:1.6px dashed var(--rf-border); border-radius:.7rem; padding:.85rem 1rem; cursor:pointer; color:var(--rf-muted); font-size:.9rem; font-weight:600; transition:.13s; }
.upload:hover{ border-color:var(--rf-teal); background:var(--rf-grey); }
.upload input{ display:none; }
.upload svg{ width:20px; height:20px; color:var(--rf-teal); flex:none; }

.inav{ display:flex; gap:.7rem; margin-top:1.3rem; }
.inav .btn{ flex:1; }
.inav .btn-back{ flex:0 0 auto; background:#fff; color:var(--rf-anthracite); border:1.6px solid var(--rf-border); padding:.7rem 1rem; }
.inav .btn-back:hover{ border-color:var(--rf-anthracite); }
.ihint{ font-size:.8rem; color:var(--rf-muted); text-align:center; margin-top:.75rem; }
.ihint.warn{ color:#d23a2c; }
.done{ text-align:center; padding:.5rem 0; }
.done .big{ width:62px; height:62px; border-radius:50%; background:var(--rf-teal); margin:0 auto .8rem; display:grid; place-items:center; }
.done .big svg{ width:30px; height:30px; color:#fff; stroke-width:3; fill:none; }
.done h3{ font-size:1.4rem; margin:.3rem 0; color:var(--rf-anthracite); }
.done p{ color:var(--rf-muted); font-size:.95rem; }
.summary{ background:var(--rf-grey); border:1px solid var(--rf-border); border-radius:.8rem; padding:1rem; text-align:left; margin:1rem 0; font-size:.92rem; }
.summary div{ display:flex; justify-content:space-between; gap:1rem; padding:.3rem 0; border-bottom:1px dashed var(--rf-border); }
.summary div:last-child{ border:0; }
.summary b{ color:var(--rf-anthracite); text-align:right; }

/* ---- Sections ---- */
.section{ padding:5.5rem 0; }
.section-sm{ padding:3.5rem 0; }
.section-grey{ background:var(--rf-grey); }
.section-dark{ background:var(--rf-anthracite); color:#fff; }
.section-dark .lead-muted{ color:#AEB4BB; }
.kick{ font-size:.8rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--rf-teal); }
.section-dark .kick{ color:#7FC9C4; }
h2.section-title{ font-size:clamp(1.6rem,3.2vw,2.4rem); }

/* ---- Prose ---- */
.prose{ max-width:46rem; }
.prose p{ color:var(--rf-anthracite); }

/* ---- Answer / Kurzantwort box ---- */
.answer-box{ background:var(--rf-teal-light); border:1px solid var(--rf-teal); border-radius:1.1rem; padding:1.5rem 1.6rem; }
.answer-box p{ margin-bottom:.6rem; }
.answer-box p:last-child{ margin-bottom:0; }

/* ---- Damage chips ---- */
.dmg{ display:flex; flex-wrap:wrap; gap:.6rem; }
.dmg span{ background:#fff; border:1px solid var(--rf-border); border-radius:99px; padding:.5rem 1.05rem; font-weight:600; font-size:.92rem; color:var(--rf-anthracite); }
.section-grey .dmg span{ background:#fff; }

/* ---- Compare repair vs replace ---- */
.cmp{ border:1px solid var(--rf-border); border-radius:1rem; padding:1.6rem; height:100%; background:#fff; }
.cmp.good{ border-color:var(--rf-teal); background:var(--rf-teal-light); }
.cmp h3{ font-size:1.12rem; margin-bottom:.4rem; }
.cmp ul{ list-style:none; padding:0; margin:.6rem 0 0; }
.cmp li{ padding:.5rem 0; border-bottom:1px solid var(--rf-border); display:flex; gap:.6rem; align-items:flex-start; font-weight:500; color:var(--rf-anthracite); }
.cmp.good li{ border-color:rgba(47,126,122,.25); }
.cmp li:last-child{ border:0; }
.cmp li svg{ flex:none; width:18px; height:18px; margin-top:.18rem; color:var(--rf-teal); }
.cmp.warn li svg{ color:var(--rf-muted); }

/* ---- Cost factors ---- */
.cost-list{ list-style:none; padding:0; margin:0; display:grid; gap:1rem; }
.cost-list li{ display:flex; gap:.85rem; align-items:flex-start; }
.cost-list .ci{ flex:none; width:34px; height:34px; border-radius:.6rem; background:var(--rf-teal-light); color:var(--rf-teal); display:grid; place-items:center; }
.cost-list .ci svg{ width:18px; height:18px; }
.cost-list b{ display:block; color:var(--rf-anthracite); }
.cost-list span.t{ color:var(--rf-muted); font-size:.95rem; }

/* ---- Service cards ---- */
.svc-card{ background:#fff; border:1px solid var(--rf-border); border-radius:1rem; height:100%; padding:1.5rem; display:flex; flex-direction:column; transition:.2s; }
.svc-card:hover{ border-color:var(--rf-teal); transform:translateY(-3px); box-shadow:0 24px 48px -34px rgba(35,39,47,.5); }
.svc-ic{ width:46px; height:46px; border-radius:.7rem; background:var(--rf-teal-light); display:grid; place-items:center; margin-bottom:1rem; color:var(--rf-teal); flex:none; }
.svc-ic svg{ width:26px; height:26px; }
.svc-card h3{ font-size:1.12rem; }
.svc-card p{ color:var(--rf-muted); font-size:.95rem; flex:1; }
.svc-link{ color:var(--rf-teal); font-weight:600; font-size:.95rem; display:inline-flex; align-items:center; gap:.4rem; }
.svc-link:hover{ color:var(--rf-teal-dark); gap:.6rem; }
.svc-card.highlight{ background:var(--rf-teal-light); border-color:var(--rf-teal); }

/* ---- Steps ---- */
.step{ padding:1.5rem; border-left:1px solid rgba(255,255,255,.14); height:100%; }
.step-num{ font-weight:800; font-size:1.05rem; color:#7FC9C4; }
.step-bar{ height:3px; background:rgba(255,255,255,.14); border-radius:2px; margin:.9rem 0 1.1rem; position:relative; overflow:hidden; }
.step-bar span{ position:absolute; inset:0; background:var(--rf-teal); transform:translateX(-100%); border-radius:2px; transition:transform .9s cubic-bezier(.2,.7,.2,1); }
.step.in span{ transform:translateX(0); }
.step h3{ font-size:1.1rem; color:#fff; }
.step p{ color:#AEB4BB; font-size:.95rem; margin-bottom:0; }
@media (min-width:768px){ .step.first{ border-left:0; padding-left:0; } }

/* ---- Why bullets ---- */
.why-list{ list-style:none; padding:0; margin:0; }
.why-list li{ display:flex; align-items:center; gap:.75rem; padding:.7rem 0; border-bottom:1px solid var(--rf-border); font-weight:600; }
.why-list li:last-child{ border-bottom:0; }
.why-chk{ flex:none; width:28px; height:28px; border-radius:.5rem; background:var(--rf-teal); display:grid; place-items:center; }
.why-chk svg{ width:15px; height:15px; color:#fff; }
.why-panel{ background:var(--rf-teal-light); border:1px solid var(--rf-teal); border-radius:1.1rem; padding:2rem; }

/* ---- Audience ---- */
.aud-card{ border:1px solid var(--rf-border); border-radius:1rem; padding:1.5rem; height:100%; background:#fff; }
.aud-tag{ font-size:.75rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--rf-teal); }
.aud-card h3{ font-size:1.1rem; margin:.5rem 0; }
.aud-card p{ color:var(--rf-muted); font-size:.95rem; margin:0; }

/* ---- Region inline links (invisible, natural prose) ---- */
.r-link{ color:inherit; text-decoration:none; font-weight:inherit; cursor:inherit; }
.r-link:hover,.r-link:active{ color:inherit; text-decoration:none; }
.r-link:focus-visible{ outline:2px solid var(--rf-teal); outline-offset:2px; border-radius:3px; }

/* ---- FAQ ---- */
.accordion-button{ font-weight:600; color:var(--rf-anthracite); }
.accordion-button:not(.collapsed){ background:var(--rf-teal-light); color:var(--rf-anthracite); box-shadow:none; }
.accordion-button:focus{ box-shadow:0 0 0 3px rgba(47,126,122,.3); border-color:var(--rf-teal); }
.accordion-item{ border:1px solid var(--rf-border); border-radius:.8rem !important; margin-bottom:.6rem; overflow:hidden; }
.accordion-body{ color:var(--rf-muted); }

/* ---- Final CTA ---- */
.final-cta{ background:var(--rf-teal); color:#fff; }
.final-cta h2{ color:#fff; }
.final-cta .btn{ background:#fff; color:var(--rf-teal-dark); }
.final-cta .btn:hover{ background:var(--rf-anthracite); color:#fff; }

/* ---- Footer ---- */
footer{ background:var(--rf-anthracite); color:#AEB4BB; padding:3.5rem 0 2rem; }
footer .rf-logo .repar{ color:#fff; }
footer h4{ color:#fff; font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; }
footer a{ color:#AEB4BB; }
footer a:hover{ color:#fff; }
.foot-bottom{ border-top:1px solid rgba(255,255,255,.14); padding-top:1.4rem; font-size:.85rem; }

a:focus-visible,.nav-link:focus-visible,.sel-btn:focus-visible{ outline:3px solid var(--rf-teal); outline-offset:2px; }
@media (prefers-reduced-motion:reduce){ *{ transition:none !important; } html{ scroll-behavior:auto; } }
html{ scroll-behavior:smooth; }
