/* =========================================================================
   Blacksmith Finance – Fördercheck Landingpage
   Reconstructed stylesheet (externalised so the CSP needs no 'unsafe-inline').
   Design tokens & component values mirror the reference landing page 1:1.
   ========================================================================= */

/* ---- Self-hosted Inter (no external Google Fonts request → DSGVO-freundlich) */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;
  src:url('../fonts/inter-latin-400.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;
  src:url('../fonts/inter-latin-500.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;
  src:url('../fonts/inter-latin-600.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;
  src:url('../fonts/inter-latin-700.woff2') format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:800;font-display:swap;
  src:url('../fonts/inter-latin-800.woff2') format('woff2');}

:root{
  --primary:#60B9E3;
  --primary-dark:#3f9fcc;
  --dark:#221F20;
  --mid:#848483;
  --bg:#FFFFFF;
  --track:#E8E8E8;
  --danger:#c0392b;
  --danger-border:#e06a6a;
  --success:#2e9e6b;
  --radius:8px;
  --shadow:0 2px 12px rgba(0,0,0,0.08);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.12);
  --maxw:480px;
  --pad:16px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--dark);
  background:var(--bg);
  line-height:1.55;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{line-height:1.15;font-weight:800;letter-spacing:-0.02em}

/* ---- Utilities -------------------------------------------------------- */
.shell{max-width:var(--maxw);margin:0 auto;width:100%}
.section{padding:48px var(--pad)}
.is-hidden{display:none!important}
.sr-only{
  position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.eyebrow{
  display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--primary-dark);margin-bottom:12px;
}
svg{flex:none}

/* ---- CTA buttons ------------------------------------------------------ */
.widget-button{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;min-height:56px;background:var(--primary);color:#fff;
  border:none;border-radius:var(--radius);font-weight:600;font-size:1.05rem;
  font-family:inherit;
  box-shadow:0 6px 18px rgba(96,185,227,.4);cursor:pointer;
  transition:transform .2s ease,background .2s ease,box-shadow .2s ease;
}
.widget-button:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 10px 24px rgba(96,185,227,.5)}
.widget-button:active{transform:translateY(0)}
.widget-button:focus-visible{outline:3px solid var(--dark);outline-offset:3px}
.widget-button .widget-text{font-weight:600}
.widget-button svg{width:20px;height:20px}
.widget-button[disabled],.widget-button.is-loading{
  opacity:.7;cursor:progress;pointer-events:none;transform:none;
}

/* loading spinner inside submit button */
.btn-spinner{
  width:18px;height:18px;border-radius:50%;border:2.5px solid rgba(255,255,255,.45);
  border-top-color:#fff;animation:spin .7s linear infinite;display:none;
}
.widget-button.is-loading .btn-spinner{display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- Header ----------------------------------------------------------- */
.site-header{
  position:sticky;top:0;z-index:50;background:#fff;
  border-bottom:1px solid var(--track);
}
.header-inner{display:flex;align-items:center;padding:14px var(--pad)}
.logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:1.15rem;letter-spacing:-.02em}
.logo span b{color:var(--primary-dark)}

/* ---- Hero ------------------------------------------------------------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#f4fbfe 0%,#fff 100%)}
.hero .shell{padding:40px var(--pad) 48px;text-align:center}
.hero h1{font-size:2.05rem;font-weight:800;margin-bottom:16px}
.hero h1 .hl{color:var(--primary-dark)}
.hero .sub{font-size:1.05rem;color:var(--mid);margin-bottom:24px;font-weight:400}
.hero-figure{
  position:relative;border-radius:16px;overflow:hidden;margin:0 auto 28px;
  box-shadow:var(--shadow-lg);aspect-ratio:4/3;
}
.hero-figure img{width:100%;height:100%;object-fit:cover}
.hero-badge{
  position:absolute;left:12px;bottom:12px;background:rgba(255,255,255,.95);
  backdrop-filter:blur(4px);border-radius:10px;padding:8px 12px;display:flex;
  align-items:center;gap:8px;font-size:.82rem;font-weight:600;box-shadow:var(--shadow)
}
.hero-badge svg{width:18px;height:18px;color:var(--primary-dark)}
.hero .microtrust{margin-top:14px;font-size:.82rem;color:var(--mid);display:flex;align-items:center;justify-content:center;gap:6px}
.hero .microtrust svg{width:15px;height:15px;color:var(--primary-dark)}

/* ---- Trust tiles ------------------------------------------------------ */
.trust{background:#fff}
.trust-grid{display:grid;gap:12px}
.trust-tile{
  display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--track);
  border-radius:var(--radius);background:#fff;box-shadow:var(--shadow)
}
.trust-ico{
  flex:none;width:46px;height:46px;border-radius:11px;background:rgba(96,185,227,.12);
  display:flex;align-items:center;justify-content:center;color:var(--primary-dark)
}
.trust-ico svg{width:24px;height:24px}
.trust-tile h3{font-size:1rem;font-weight:700;margin-bottom:2px}
.trust-tile p{font-size:.86rem;color:var(--mid)}

/* ---- Stepper / quiz --------------------------------------------------- */
.stepper-sec{background:linear-gradient(180deg,#fff,#f7fbfd)}
.stepper-head{text-align:center;margin-bottom:24px}
.stepper-head h2{font-size:1.6rem;margin-bottom:8px}
.stepper-head p{color:var(--mid);font-size:.95rem}
.quiz-card{
  background:#fff;border:1px solid var(--track);border-radius:14px;
  box-shadow:var(--shadow);padding:24px 18px;
}
.progress-wrap{margin-bottom:20px}
.progress-meta{display:flex;justify-content:space-between;font-size:.78rem;color:var(--mid);font-weight:600;margin-bottom:8px}
.progress-track{height:8px;border-radius:99px;background:var(--track);overflow:hidden}
.progress-fill{height:100%;width:33.33%;background:var(--primary);border-radius:99px;transition:width .4s ease}
.quiz-step{display:none}
.quiz-step.active{display:block;animation:stepin .35s ease both}
@keyframes stepin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.quiz-q{font-size:1.25rem;font-weight:800;margin-bottom:6px;line-height:1.2}
.quiz-hint{font-size:.86rem;color:var(--mid);margin-bottom:18px}
.opt-list{display:flex;flex-direction:column;gap:10px}
.opt-btn{
  display:flex;align-items:center;gap:12px;width:100%;min-height:56px;
  padding:0 16px;border:2px solid var(--track);border-radius:var(--radius);
  background:#fff;color:var(--dark);font-weight:600;font-size:1rem;text-align:left;
  font-family:inherit;cursor:pointer;transition:border-color .2s,background .2s,transform .15s;
}
.opt-btn:hover{border-color:var(--primary);background:rgba(96,185,227,.06)}
.opt-btn:active{transform:scale(.99)}
.opt-btn:focus-visible{outline:3px solid var(--primary);outline-offset:2px}
.opt-btn .dot{flex:none;width:22px;height:22px;border-radius:50%;border:2px solid var(--mid);transition:.2s}
.opt-btn:hover .dot{border-color:var(--primary)}
/* selected (remembered) answer state */
.opt-btn.selected{border-color:var(--primary);background:rgba(96,185,227,.08)}
.opt-btn.selected .dot{border-color:var(--primary);background:var(--primary);box-shadow:inset 0 0 0 3px #fff}
.step-back{
  background:none;border:none;color:var(--mid);font-weight:600;font-size:.9rem;
  font-family:inherit;cursor:pointer;margin-top:16px;display:inline-flex;align-items:center;gap:6px;padding:6px 4px
}
.step-back svg{width:16px;height:16px}
.step-back:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}

/* ---- Lead form + DQ panels ------------------------------------------- */
.panel{display:none}
.panel.active{display:block;animation:stepin .35s ease both}
.lead-card,.dq-card{
  background:#fff;border:1px solid var(--track);border-radius:14px;
  box-shadow:var(--shadow);padding:24px 18px;
}
.lead-card h3{font-size:1.35rem;margin-bottom:6px}
.lead-card .lead-sub{color:var(--mid);font-size:.9rem;margin-bottom:20px}
.field{margin-bottom:14px}
.field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px}
.field label .opt{color:var(--mid);font-weight:400}
.field input[type="text"],.field input[type="email"],.field input[type="tel"]{
  width:100%;min-height:52px;padding:0 14px;border:2px solid var(--track);
  border-radius:var(--radius);font-size:1rem;font-family:inherit;color:var(--dark);
  background:#fff;transition:border-color .2s;
}
.field input:focus{outline:none;border-color:var(--primary)}
.field input:focus-visible{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(96,185,227,.25)}
.field.has-error input{border-color:var(--danger-border)}
.field-error{display:none;color:var(--danger);font-size:.78rem;font-weight:600;margin-top:6px}
.field.has-error .field-error{display:block}

.consent{display:flex;gap:10px;align-items:flex-start;margin:6px 0 18px;font-size:.82rem;color:var(--mid)}
.consent input{margin-top:3px;width:18px;height:18px;flex:none;accent-color:var(--primary)}
.consent label{cursor:pointer}
/* privacy-policy link clearly recognisable as a link (brand blue + underline) */
.consent a{color:var(--primary-dark);font-weight:600;text-decoration:underline}
.consent a:hover{color:var(--primary)}
.consent a:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:3px}
.consent.has-error label{color:var(--danger)}
.microcopy{font-size:.76rem;color:var(--mid);margin-top:14px;line-height:1.5}
.microcopy a{color:var(--primary-dark);text-decoration:underline}

/* honeypot – kept in the DOM for bots, removed from the visual + a11y tree */
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* inline form status (errors); success uses the modal */
.form-status{display:none;margin-bottom:14px;padding:12px 14px;border-radius:var(--radius);font-size:.86rem;font-weight:600;line-height:1.4}
.form-status.is-error{display:block;background:rgba(192,57,43,.08);border:1px solid var(--danger-border);color:var(--danger)}

/* disqualification panel */
.dq-card{text-align:center}
.dq-ico{width:56px;height:56px;border-radius:50%;background:rgba(96,185,227,.12);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:var(--primary-dark)}
.dq-ico svg{width:28px;height:28px}
.dq-card h3{font-size:1.3rem;margin-bottom:8px}
.dq-card p{color:var(--mid);font-size:.92rem;margin-bottom:18px}
.dq-card .field{text-align:left}
.dq-card .consent{text-align:left}

/* ---- Social proof ----------------------------------------------------- */
.proof{background:#f7fbfd}
.proof h2{font-size:1.5rem;text-align:center;margin-bottom:24px}
.t-card{
  background:#fff;border:1px solid var(--track);border-radius:14px;box-shadow:var(--shadow);
  padding:22px 18px;height:100%;display:flex;flex-direction:column;gap:14px
}
.t-card .stars{display:flex;gap:3px;color:var(--primary-dark)}
.t-card .stars svg{width:18px;height:18px}
.t-card blockquote{font-size:1.02rem;font-weight:600;line-height:1.4}
.t-card .who{display:flex;align-items:center;gap:10px;margin-top:auto}
.t-card .who img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.t-card .who .av{width:42px;height:42px;border-radius:50%;background:rgba(96,185,227,.15);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--primary-dark)}
.t-card .who b{display:block;font-size:.9rem}
.t-card .who span{font-size:.8rem;color:var(--mid)}

.t-card .who .review-source{font-size:.78rem;color:var(--primary-dark);font-weight:600}

/* Google reviews slider: scroll-snap track; autoplay + manual nav in main.js */
.proof-shell{position:relative;max-width:600px;margin:0 auto}
.proof-sub{text-align:center;color:var(--mid);font-size:.92rem;margin:-14px 0 22px}
.rev-slider{position:relative}
.rev-viewport{overflow:hidden}
.rev-track{display:flex;transition:transform .45s ease;will-change:transform;min-height:208px}
.rev-slide{flex:0 0 100%;min-width:0;display:flex;padding:4px 8px}
.rev-slide .t-card{width:100%}
.rev-loading{flex:0 0 100%;text-align:center;color:var(--mid);font-size:.9rem;padding:36px 0}
.rev-controls{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:18px}
.rev-arrow{
  flex:none;width:40px;height:40px;border-radius:50%;border:1px solid var(--track);background:#fff;
  color:var(--primary-dark);display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:border-color .2s,background .2s,transform .15s;
}
.rev-arrow:hover{border-color:var(--primary);background:rgba(96,185,227,.08)}
.rev-arrow:active{transform:scale(.94)}
.rev-arrow:focus-visible{outline:3px solid var(--primary);outline-offset:2px}
.rev-arrow svg{width:20px;height:20px}
.rev-dots{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;max-width:240px}
.rev-dot{
  width:8px;height:8px;border-radius:99px;background:var(--mid);opacity:.4;border:none;padding:0;
  cursor:pointer;transition:width .25s ease,opacity .25s ease,background .25s ease;
}
.rev-dot.active{opacity:1;background:var(--primary);width:22px}
.rev-dot:focus-visible{outline:2px solid var(--primary);outline-offset:3px}
.rev-google-btn{
  display:flex;align-items:center;gap:8px;width:max-content;max-width:100%;margin:24px auto 0;
  padding:12px 20px;border:1px solid var(--track);border-radius:var(--radius);background:#fff;
  color:var(--primary-dark);font-weight:600;font-size:.92rem;
  transition:border-color .2s,background .2s,transform .15s;
}
.rev-google-btn:hover{border-color:var(--primary);background:rgba(96,185,227,.06);transform:translateY(-1px)}
.rev-google-btn:focus-visible{outline:3px solid var(--primary);outline-offset:2px}
.rev-google-btn svg{width:16px;height:16px}

/* ---- Process / so geht's --------------------------------------------- */
.process{background:#f7fbfd}
.process-head{text-align:center;margin-bottom:28px}
.process-head h2{font-size:1.6rem;margin-bottom:8px}
.process-head p{color:var(--mid);font-size:.95rem}
.process-steps{list-style:none;display:flex;flex-direction:column;gap:20px}
.process-step{position:relative;display:flex;gap:16px;align-items:flex-start}
/* vertical connector between consecutive step bullets */
.process-step:not(:last-child)::before{
  content:"";position:absolute;left:21px;top:48px;bottom:-20px;width:2px;
  background:linear-gradient(180deg,rgba(96,185,227,.55),rgba(96,185,227,.25));
}
.ps-num{
  position:relative;z-index:1;flex:none;width:44px;height:44px;border-radius:50%;
  background:var(--primary);color:#fff;font-weight:800;font-size:1.15rem;
  display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(96,185,227,.4);
}
.ps-body{
  flex:1;min-width:0;background:#fff;border:1px solid var(--track);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:14px 16px;
}
.ps-top{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:4px}
.ps-top h3{font-size:1rem;font-weight:700}
.ps-time{
  flex:none;display:inline-flex;align-items:center;gap:5px;font-size:.74rem;font-weight:700;
  color:var(--primary-dark);background:rgba(96,185,227,.12);border-radius:99px;padding:4px 10px;white-space:nowrap;
}
.ps-time svg{width:13px;height:13px}
.ps-body p{font-size:.86rem;color:var(--mid)}
.process-payoff{
  display:flex;align-items:center;gap:14px;margin-top:24px;padding:16px 18px;border-radius:12px;
  background:linear-gradient(135deg,rgba(96,185,227,.16),rgba(96,185,227,.05));
  border:1px solid rgba(96,185,227,.32);
}
.pp-ico{
  flex:none;width:46px;height:46px;border-radius:11px;background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(96,185,227,.35);
}
.pp-ico svg{width:24px;height:24px}
.process-payoff p{font-size:.95rem;line-height:1.4}
.process-payoff b{color:var(--primary-dark);font-weight:800}

/* ---- FAQ -------------------------------------------------------------- */
.faq h2{font-size:1.5rem;text-align:center;margin-bottom:24px}
.widget-accordion{display:flex;flex-direction:column;gap:10px}
.acc-item{border:1px solid var(--track);border-radius:var(--radius);overflow:hidden;background:#fff}
.accordion-heading-container{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:16px;cursor:pointer;user-select:none;width:100%;background:none;border:none;
  font-family:inherit;text-align:left;color:var(--dark);
}
.accordion-heading-container:focus-visible{outline:3px solid var(--primary);outline-offset:-3px;border-radius:var(--radius)}
.accordion-heading-text{font-weight:700;font-size:1rem;color:var(--dark)}
.accordion-trigger{flex:none;color:var(--dark);transition:transform .3s ease;display:flex}
.accordion-trigger svg{width:22px;height:22px;display:block}
.acc-item.open .accordion-trigger{transform:rotate(45deg)}
.accordion-content{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--mid);font-size:.92rem}
.accordion-content .inner{padding:0 16px 16px}
.acc-item.open .accordion-content{max-height:280px}

/* ---- Closing CTA ------------------------------------------------------ */
.closing{position:relative;color:#fff;overflow:hidden;background:var(--dark)}
.closing .bgimg{position:absolute;inset:0}
.closing .bgimg img{width:100%;height:100%;object-fit:cover;opacity:.32}
.closing .shell{position:relative;text-align:center;padding:56px var(--pad)}
.closing h2{font-size:1.7rem;color:#fff;margin-bottom:12px}
.closing p{color:rgba(255,255,255,.82);margin-bottom:24px;font-size:1rem}

/* ---- Footer ----------------------------------------------------------- */
.site-footer{background:var(--dark);color:rgba(255,255,255,.7);font-size:.82rem}
.footer-inner{padding:32px var(--pad)}
.footer-links{display:flex;gap:18px;margin-bottom:14px;flex-wrap:wrap}
.footer-links a{font-weight:600;color:#fff;font-size:.85rem}
.footer-links a:hover{color:var(--primary)}
.footer-links a:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:4px}
.footer-micro{line-height:1.6;margin-bottom:14px}
.footer-copy{color:rgba(255,255,255,.5)}

/* ---- Reveal on scroll (replaces GSAP) -------------------------------- */
/* Hidden state is only applied once JS confirms support → no-JS shows all. */
body.js-anim .reveal{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
body.js-anim .reveal.is-visible{opacity:1;transform:none}

/* ---- Thank-you modal -------------------------------------------------- */
.thank-you-modal{
  position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:16px;
  background:rgba(34,31,32,.55);
}
.thank-you-modal.open{display:flex}
.thank-you-modal .ty-body{
  background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);max-width:380px;width:100%;
  padding:32px 24px;text-align:center;position:relative;
}
.thank-you-modal-close{
  position:absolute;top:14px;right:14px;width:30px;height:30px;color:var(--mid);
  display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;
}
.thank-you-modal-close svg{width:24px;height:24px}
.thank-you-modal-close:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}
.ty-ico{width:60px;height:60px;border-radius:50%;background:rgba(96,185,227,.14);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--primary-dark)}
.ty-ico svg{width:32px;height:32px}
.thank-you-modal h3{font-size:1.4rem;margin-bottom:8px}
.thank-you-modal p{color:var(--mid);font-size:.95rem}
.ty-demo{margin-top:14px;font-size:.74rem;color:var(--mid);background:rgba(96,185,227,.1);border-radius:6px;padding:8px 10px}

/* ---- Legal pages (Impressum / Datenschutz) --------------------------- */
.legal{padding:40px var(--pad) 64px}
.legal .back-link{display:inline-flex;align-items:center;gap:6px;color:var(--primary-dark);font-weight:600;font-size:.9rem;margin-bottom:24px}
.legal .back-link svg{width:16px;height:16px}
.legal h1{font-size:1.8rem;margin-bottom:8px}
.legal h2{font-size:1.2rem;margin:28px 0 8px}
.legal h3{font-size:1rem;margin:18px 0 6px}
.legal p,.legal li{font-size:.92rem;color:#3a3a3a;margin-bottom:10px;line-height:1.6}
.legal ul{padding-left:20px;margin-bottom:10px}
.legal a{color:var(--primary-dark);text-decoration:underline}
.legal .placeholder-note{
  background:#fff8e6;border:1px solid #f0d488;border-radius:var(--radius);
  padding:14px 16px;font-size:.86rem;color:#7a5b00;margin-bottom:24px;line-height:1.55;
}
.legal .updated{font-size:.8rem;color:var(--mid);margin-top:32px}

/* ---- 404 -------------------------------------------------------------- */
.notfound{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px var(--pad)}
.notfound h1{font-size:2.4rem;margin-bottom:10px}
.notfound p{color:var(--mid);margin-bottom:24px}
.notfound .widget-button{max-width:280px}

/* ---- Responsive ------------------------------------------------------- */
@media (min-width:600px){
  .hero h1{font-size:2.4rem}
  .trust-grid{grid-template-columns:1fr;gap:12px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
}
