/* onboarding.lwyrup.eu — eigenständiges Stylesheet
 * Farben und Stil orientieren sich an www.lwyrup.eu, sind aber bewusst
 * separat gepflegt -- diese App soll nicht von der Hugo-Site abhängen.
 */

:root{
  --bg:#fbfbfa; --fg:#1c1c1e; --muted:#6b6b70; --line:#e6e6e3;
  --card:#ffffff; --accent:#1f6f5c; --accent-fg:#ffffff;
  --error:#8b1f15; --error-bg:#fdecea; --error-line:#e6b2ab;
  --shadow:0 4px 24px rgba(0,0,0,.06);
  --radius:12px; --wrap:880px;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#121311; --fg:#ececeb; --muted:#9a9a9f; --line:#2a2b28;
    --card:#1b1c1a; --accent:#3fae93; --accent-fg:#06241d;
    --error:#f5c8c0; --error-bg:#3a1612; --error-line:#7a2c25;
    --shadow:0 4px 24px rgba(0,0,0,.4);
  }
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--fg);
  line-height:1.5;
}
.wrap{max-width:var(--wrap); margin:0 auto; padding:0 20px}

a{color:var(--accent); text-underline-offset:2px}

.skip-link{position:absolute; left:-999px; top:0}
.skip-link:focus{left:8px; top:8px; background:var(--card); padding:8px 12px; border-radius:8px; z-index:10}

/* ===== Topbar ===== */
.topbar{
  border-bottom:1px solid var(--line); background:var(--bg);
  position:sticky; top:0; z-index:5;
}
.topbar .wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding-top:14px; padding-bottom:14px; gap:16px; flex-wrap:wrap;
}
.brand{font-weight:600; color:var(--fg); text-decoration:none; letter-spacing:.02em}
.brand strong{letter-spacing:.08em; color:var(--accent)}
.back{font-size:.9rem; color:var(--muted); text-decoration:none}
.back:hover{color:var(--fg)}

/* ===== Intro ===== */
.intro{margin:32px 0 8px}
.intro h1{margin:0 0 .4em; font-size:1.7rem; line-height:1.2}
.intro .lede{font-size:1.05rem; color:var(--muted); margin:0 0 .8em; max-width:62ch}
.intro .hint{color:var(--muted); font-size:.95rem; margin:0; max-width:62ch}

/* ===== Status + Errors ===== */
.status{padding:14px 16px; border-radius:10px; margin:16px 0; line-height:1.45}
.status-error{background:var(--error-bg); border:1px solid var(--error-line); color:var(--error)}
.status ul{margin:.4em 0 0; padding-left:1.4em}
.status li{margin:2px 0}

.card{
  background:var(--card); border:1px solid var(--line);
  border-radius:var(--radius); padding:24px;
  margin:32px 0; box-shadow:var(--shadow);
}
.card-success{border-color:var(--accent)}
.card-success h1{margin:0 0 .4em}

/* ===== Form ===== */
.lead-form{display:flex; flex-direction:column; gap:22px; margin:24px 0; max-width:780px}
.lead-form fieldset{
  border:1px solid var(--line); border-radius:var(--radius);
  padding:18px 20px; background:var(--card); margin:0;
}
.lead-form fieldset.inner{
  background:transparent; border-style:dashed;
  padding:14px 16px; margin-top:10px;
}
.lead-form legend{font-weight:600; padding:0 6px; color:var(--fg); font-size:1rem}
.lead-form .hint{font-size:.88rem; color:var(--muted); margin:.2em 0 .8em}
.lead-form .hint-consent{margin-top:1em}
.lead-form .hint-captcha{color:var(--error)}

.field{display:flex; flex-direction:column; gap:6px; margin:10px 0; font-size:.95rem}
.field>span{color:var(--fg)}
.field em{color:var(--error); font-style:normal; margin-left:2px}
.field input[type=text],
.field input[type=email],
.field input[type=tel],
.field input[type=url],
.field select,
.field textarea{
  font:inherit; padding:8px 10px;
  border:1px solid var(--line); border-radius:8px;
  background:var(--bg); color:var(--fg); min-height:38px;
}
.field textarea{resize:vertical; min-height:80px}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:2px solid var(--accent); outline-offset:1px; border-color:var(--accent);
}
.field input[type=range]{padding:0; border:0; background:transparent}
.field-error input, .field-error select, .field-error textarea{
  border-color:var(--error); outline-color:var(--error);
}
.field-error>span{color:var(--error)}

.row{display:grid; gap:14px}
.row-2{grid-template-columns:1fr 1fr}
.row-3{grid-template-columns:1fr 1fr 1fr}
@media (max-width:640px){
  .row-2, .row-3{grid-template-columns:1fr}
}
.field-inline{flex-direction:row; align-items:center; gap:10px; margin-top:34px}
.field-inline input{margin:0}

.checkgrid{
  display:grid; gap:6px 14px; margin:8px 0;
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
}
.checkgrid-inline{grid-template-columns:repeat(auto-fill, minmax(150px, 1fr))}
.check{
  display:flex; gap:8px; align-items:flex-start;
  font-size:.92rem; line-height:1.35; cursor:pointer;
}
.check input{margin-top:3px; flex:0 0 auto}

.consent{
  display:flex; gap:10px; align-items:flex-start;
  padding:10px 0; font-size:.95rem; line-height:1.45;
}
.consent input{margin-top:4px; flex:0 0 auto}
.consent.field-error{color:var(--error)}

.captcha{margin:14px 0; min-height:60px}
.captcha .frc-captcha{max-width:100%}

.submit-row{margin-top:6px}
.btn{
  display:inline-block; padding:12px 22px; border-radius:10px;
  border:1px solid transparent; font:inherit; font-weight:600;
  cursor:pointer; text-decoration:none;
}
.btn-primary{background:var(--accent); color:var(--accent-fg)}
.btn-primary:hover{filter:brightness(0.95)}
.btn[disabled]{opacity:.6; cursor:wait}

/* ===== Footer ===== */
.footer{
  border-top:1px solid var(--line); margin-top:48px;
  padding:18px 0; color:var(--muted); font-size:.85rem;
}
.footer .wrap{display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px}
.footer a{color:var(--muted)}
.footer a:hover{color:var(--fg)}
