/* ============================================================
   HOME.CSS — paginalayout homepage/blauwdruk
   Alleen layout-klassen; tokens via var(--rui-*) uit raids-ui.css.
   Spec: docs/superpowers/specs/2026-06-19-homepage-redesign-design.md
   ============================================================ */

/* page wrapper */
.wrap{max-width:1120px;margin:0 auto;padding:18px 16px 64px}

/* two-column homepage grid */
.home-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width:900px){.home-grid{grid-template-columns:1.55fr 1fr;align-items:start}}

/* vertical stack of sections */
.stack{display:grid;gap:16px}

/* section header */
.sec-head{display:flex;align-items:center;gap:10px;margin:26px 2px 12px}
.sec-head h2{margin:0;font-size:var(--rui-fs-xl);font-weight:700;font-family:var(--rui-font)}
.sec-head .grow{flex:1}

/* feature grid (landing value props) */
.feat-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media (min-width:620px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:900px){.feat-grid{grid-template-columns:repeat(4,1fr)}}

/* auth split layout */
.auth-grid{display:grid;grid-template-columns:1fr;gap:18px;max-width:940px;margin:0 auto;align-items:stretch}
@media (min-width:820px){.auth-grid{grid-template-columns:1fr .85fr}}

/* auth form card */
.auth-card{padding:26px 24px}
@media (max-width:560px){.auth-card{padding:22px 18px}}

/* auth icon */
.auth-ic{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;background:var(--rui-accent-soft);color:var(--rui-accent-strong);border:1px solid var(--rui-accent-line);margin-bottom:16px}
.auth-ic svg{width:24px;height:24px}

/* auth heading */
.auth-head .eyebrow{margin-bottom:6px}
.auth-head h2{font-family:var(--rui-font);margin:0;font-size:var(--rui-fs-2xl);font-weight:700;letter-spacing:-.01em}
.auth-head p{color:var(--rui-muted);margin:8px 0 22px}

/* auth footer note */
.auth-foot{text-align:center;color:var(--rui-muted);font-size:var(--rui-fs-md);margin:18px 0 0}

/* auth aside / aside column */
.auth-aside{display:flex;flex-direction:column;background:radial-gradient(130% 120% at 100% 0%,var(--rui-accent-soft) 0,transparent 58%),var(--rui-card-2);border:1px solid var(--rui-line);border-radius:var(--rui-r-4);padding:26px 24px}
.auth-aside .eyebrow{margin-bottom:10px}
.auth-aside h3{font-family:var(--rui-font);margin:0 0 16px;font-size:var(--rui-fs-lg)}
.auth-aside ul{margin:0;padding:0;list-style:none;display:grid;gap:14px}
.auth-aside li{display:flex;gap:11px;align-items:flex-start;color:var(--rui-muted);font-size:var(--rui-fs-md);line-height:1.4}
.auth-aside li svg{width:20px;height:20px;color:var(--rui-accent-strong);flex:0 0 auto;margin-top:1px}
.auth-aside .spacer{flex:1;min-height:14px}

/* alert-soft (auth / form feedback) */
.alert-soft{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-radius:var(--rui-r-2);font-size:var(--rui-fs-md);font-weight:600;margin-bottom:14px;line-height:1.4}
.alert-soft svg{width:18px;height:18px;flex:0 0 auto;margin-top:1px}
.alert-soft.warn{background:var(--rui-warn-soft);color:var(--rui-warn)}
.alert-soft.ok{background:var(--rui-ok-soft);color:var(--rui-ok)}
.alert-soft.danger{background:var(--rui-danger-soft);color:var(--rui-danger)}

/* form: subtiele hulp-? in labels (geen zware knop-box) */
.rui .field > label{position:relative}
.rui .field > label .rui-btn.icon{float:right;min-height:0;height:22px;width:22px;padding:0;border:0;background:transparent;color:var(--rui-faint)}
.rui .field > label .rui-btn.icon:hover{color:var(--rui-accent-strong);background:transparent;border:0}
.rui .field > label .rui-btn.icon svg{width:16px;height:16px}
/* form: wachtwoord-toon/verberg-oog netjes op veld-hoogte (44px) i.p.v. losse kleine box */
.rui .field .rui-btn.icon[onclick*="togglePassword"]{align-self:stretch;min-height:44px;height:auto;width:44px;color:var(--rui-muted)}
.rui .field .rui-btn.icon[onclick*="togglePassword"]:hover{color:var(--rui-text);border-color:var(--rui-accent-line)}

/* sign-up: 2-koloms veld-grid voor korte velden (stapelt mobiel) */
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:0 16px;align-items:start}
@media (max-width:560px){.field-row{grid-template-columns:1fr}}
/* sign-up: inline veld-hulp (disclosure i.p.v. modal) */
.field-more{margin:8px 0 0;padding:10px 12px;background:var(--rui-accent-soft);border:1px solid var(--rui-accent-line);border-radius:var(--rui-r-2);font-size:var(--rui-fs-md);color:var(--rui-muted);line-height:1.5}
.field-more strong{color:var(--rui-text);font-weight:600}
