/* ============================================================================
   Manea Konto + Auth — Precision-Designsystem (M2a, 2026-06-11)
   Token-Quelle: archiv-app/public/css/precision.css (Marke manea, Teal),
   Komponenten-Muster: backend/public/css/precision.css (card/btn/field/auth).
   Gilt NUR für Konto-/Auth-Seiten (layouts/konto + layouts/auth);
   die Marketing-Seiten behalten manea.css.
   Theme: html[data-theme="dark|light"] + html[data-brand="manea"],
   localStorage-Key 'maneaTheme' (gleicher Key wie Marketing-Seiten, gleiche Origin).
   Gliederung: 1 Tokens · 2 Basis · 3 Topbar/Shell · 4 Karten/Grid ·
               5 Buttons · 6 Formulare · 7 Auth-Split · 8 Kleinkram · 9 Responsive
   ========================================================================== */

/* ===== 1. Tokens (Werte exakt aus archiv-app precision.css, Marke manea) ===== */
:root{
  --font-display:"Funnel Display",system-ui,sans-serif;
  --font-sans:"Funnel Sans",system-ui,sans-serif;
  --font-mono:"Geist Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.2,.7,.2,1);
  --radius:4px; --radius-lg:8px;
  --ok:#34d3c0; --warn:#e6c46b; --err:#ff7d72; --info:#7fb4e8;
}
:root, html[data-brand="manea"]{ /* dark = Default */
  --bg:#111317; --bg-2:#0d0f13; --bg-deep:#0c0e12;
  --surface:#1b1f27; --surface-2:#232834; --surface-3:#2a2f3a;
  --line:#363b49; --line-2:#4a505f;
  --text:#e9eaef; --text-2:#b7bec6; --text-3:#8c95a0;
  --acc:#34d3c0; --acc-2:#5bf0dc; --acc-ink:#003731;
  --acc-dim:rgba(52,211,192,.09); --acc-line:rgba(52,211,192,.38);
}
html[data-theme="light"]{
  --bg:#f5f7f6; --bg-2:#eef1f0; --bg-deep:#e9eceb;
  --surface:#fff; --surface-2:#f1f4f3; --surface-3:#e6ebe9;
  --line:#e2e5e4; --line-2:#d0d5d3;
  --text:#14181a; --text-2:#45504d; --text-3:#76817d;
  --acc:#0e9c89; --acc-2:#0b7d6e; --acc-ink:#fff;
  --acc-dim:rgba(14,156,137,.08); --acc-line:rgba(14,156,137,.32);
  --ok:#1f9d63; --warn:#a9762a; --err:#bb4a3d; --info:#2f6fb0;
}

/* ===== 2. Basis ===== */
*{box-sizing:border-box}
html{scroll-behavior:smooth;color-scheme:dark}
html[data-theme="light"]{color-scheme:light}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);
  font-weight:300;font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(55rem 30rem at 80% -10%,var(--acc-dim),transparent 72%)}
a{color:inherit}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;margin:0}
b,strong{font-weight:600}
button{font-family:inherit}
p,ul,ol,dl,dd,figure{margin:0}
.mono{font-family:var(--font-mono);font-size:12.5px}
.muted{color:var(--text-3)}
img{max-width:100%}
:focus-visible{outline:2px solid var(--acc-line);outline-offset:2px}
.is-light{display:none}
html[data-theme="light"] .is-light{display:inline-block}
html[data-theme="light"] .is-dark{display:none}
.skip{position:absolute;left:-999px;top:0;background:var(--acc);color:var(--acc-ink);
  padding:10px 16px;border-radius:0 0 var(--radius-lg) 0;z-index:100}
.skip:focus{left:0}

/* ===== 3. Topbar / Shell (Konto-Seiten) ===== */
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:1rem;
  padding:.6rem 1.2rem;background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--font-display);
  font-weight:700;font-size:1.05rem;text-decoration:none}
.brand .sq{width:13px;height:13px;border-radius:3px;background:var(--acc)}
.brand .sub{font-family:var(--font-mono);font-size:.7rem;color:var(--text-3);font-weight:400;
  border-left:1px solid var(--line-2);padding-left:.55rem}
.tb-nav{display:flex;gap:.2rem;margin-left:1rem}
.tb-nav a{font-size:.85rem;color:var(--text-2);text-decoration:none;
  padding:.4rem .7rem;border-radius:var(--radius)}
.tb-nav a:hover{color:var(--text);background:var(--surface-2)}
.tb-nav a.on{color:var(--acc);background:var(--acc-dim)}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:.45rem}
.icon-btn{position:relative;width:34px;height:34px;border-radius:var(--radius);
  border:1px solid var(--line-2);background:transparent;color:var(--text);cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
.icon-btn:hover{border-color:var(--acc-line)}
.icon-btn svg{width:17px;height:17px}
.tb-link{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-mono);
  font-size:.74rem;color:var(--text-2);border:1px solid var(--line-2);border-radius:var(--radius);
  padding:.4rem .7rem;text-decoration:none}
.tb-link:hover{color:var(--text);border-color:var(--acc-line)}
.tb-link svg{width:14px;height:14px}
.wrap{max-width:1080px;margin:0 auto;padding:30px 22px 80px}
.u-narrow{max-width:760px}
.hrow{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px}
.hrow h1{font-size:1.45rem}
.hrow p{color:var(--text-3);font-size:.9rem;margin-top:4px}
.foot{border-top:1px solid var(--line);margin-top:40px;padding:1.1rem 1.2rem;
  display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;justify-content:space-between}

/* ===== 4. Karten / Grid ===== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);margin-bottom:16px}
.card-h{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-h h2{font-size:14px;font-weight:600;letter-spacing:-.01em}
.card-h p{font-size:12.5px;color:var(--text-3);margin-top:3px;font-weight:400;line-height:1.5}
.card-h .right{display:flex;align-items:center;gap:9px}
.card-b{padding:18px}
.card.danger{border-color:color-mix(in srgb,var(--err) 35%,transparent)}
.card.danger .card-h{border-bottom-color:color-mix(in srgb,var(--err) 30%,transparent)}
.card.danger .card-h h2{color:var(--err)}
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cards3 .card{margin-bottom:0;display:flex;flex-direction:column}
.cards3 .card-b{flex:1;display:flex;flex-direction:column;gap:10px}
.cards3 .card-b .btn{margin-top:auto;align-self:flex-start}

/* ===== 5. Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-weight:500;
  font-size:.78rem;padding:9px 15px;border-radius:var(--radius);border:1px solid var(--line);
  background:var(--surface);color:var(--text);cursor:pointer;text-decoration:none}
.btn:hover{border-color:var(--acc);color:var(--acc)}
.btn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.9}
.btn-primary{background:var(--acc);border-color:var(--acc);color:var(--acc-ink)}
.btn-primary:hover{color:var(--acc-ink);filter:brightness(1.08)}
.btn-danger{color:var(--err);border-color:color-mix(in srgb,var(--err) 45%,transparent)}
.btn-danger:hover{color:var(--err);border-color:var(--err);background:color-mix(in srgb,var(--err) 12%,transparent)}
.btn-ghost{background:transparent;border-color:transparent;color:var(--text-2)}
.btn-ghost:hover{border-color:var(--acc-line);color:var(--text)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.btn-block{width:100%;justify-content:center}

/* ===== 6. Formulare ===== */
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;color:var(--text-2);margin-bottom:7px}
.inp{width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:10px 13px;font-family:var(--font-sans);font-size:14px;color:var(--text)}
.inp:focus{outline:none;border-color:var(--acc)}
.hint{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3)}
.err-msg{display:block;margin-top:6px;font-size:12.5px;color:var(--err)}
.note{display:flex;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-lg);
  background:var(--surface-2);font-size:13px;color:var(--text-2);line-height:1.55;margin-bottom:16px}
.note svg{width:18px;height:18px;flex:none;margin-top:1px;fill:none;stroke:var(--acc);stroke-width:1.9}
.note.acc{border-color:var(--acc-line)}
.note b{color:var(--text)}
.banner-ok{margin:0 0 16px;padding:11px 16px;background:color-mix(in srgb,var(--ok) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--ok) 35%,transparent);color:var(--ok);
  border-radius:var(--radius-lg);font-size:13.5px}
.banner-err{margin:0 0 16px;padding:11px 16px;background:color-mix(in srgb,var(--err) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--err) 40%,transparent);color:var(--err);
  border-radius:var(--radius-lg);font-size:13.5px}

/* ===== 7. Auth-Split (Login/Registrierung/Reset/Verify) ===== */
.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth-brand{background:var(--bg-2);border-right:1px solid var(--line);padding:2.6rem 2.8rem;
  display:flex;flex-direction:column;gap:1.6rem}
.auth-tag{font-size:2rem;line-height:1.2;margin:1.2rem 0 0;max-width:22rem}
.auth-tag .hl{color:var(--acc);font-style:italic}
.auth-pts{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.9rem;
  font-size:.92rem;color:var(--text-2)}
.auth-pts li{display:flex;gap:.7rem;align-items:flex-start}
.auth-pts .ic{flex-shrink:0;width:30px;height:30px;border-radius:var(--radius);
  border:1px solid var(--line-2);display:grid;place-items:center;color:var(--acc)}
.auth-pts .ic svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.6}
.auth-foot{margin-top:auto}
.auth-form{display:grid;place-items:center;padding:2rem 1.4rem}
.auth-form .card{width:100%;max-width:24rem}
.auth-theme{position:fixed;top:1rem;right:1rem;z-index:50}
.auth-row{display:flex;align-items:center;justify-content:space-between;gap:.6rem;font-size:.82rem;margin:.7rem 0}
.auth-row label{display:flex;gap:.4rem;align-items:center}
.auth-row a{color:var(--text-2)}
.auth-row a:hover{color:var(--text)}
.authfoot{margin-top:1rem;font-family:var(--font-mono);font-size:.74rem;color:var(--text-3)}
.authfoot a{color:var(--acc);text-decoration:underline;text-underline-offset:2px}

/* ===== 8. Kleinkram: kv, pill, legal ===== */
.kv{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.kv .row{padding:13px 0;border-bottom:1px solid var(--line-2);display:flex;flex-direction:column;gap:4px}
.kv .k{font-size:12px;color:var(--text-3)}
.kv .v{font-family:var(--font-mono);font-size:13px;color:var(--text)}
.pill{font-family:var(--font-mono);font-size:11px;padding:4px 9px;border-radius:var(--radius);
  display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);color:var(--text-2)}
.pill .d{width:6px;height:6px;border-radius:50%}
.pill:not(.ok):not(.warn):not(.acc):not(.err):not(.info) .d{display:none}
.pill.ok{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 30%,transparent)}
.pill.ok .d{background:var(--ok)}
.pill.warn{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 30%,transparent)}
.pill.warn .d{background:var(--warn)}
.pill.acc{color:var(--acc);border-color:var(--acc-line)}
.pill.acc .d{background:var(--acc)}
.legal{font-family:var(--font-mono);font-size:.72rem;color:var(--text-3)}
.legal a{color:var(--acc);text-decoration:underline;text-underline-offset:2px}

/* ===== 9. Responsive ===== */
@media (max-width:980px){
  .cards3{grid-template-columns:1fr}
  .auth{grid-template-columns:1fr}
  .auth-brand{border-right:0;border-bottom:1px solid var(--line);padding:1.8rem 1.4rem}
  .auth-foot{margin-top:.4rem}
}
@media (max-width:720px){
  .topbar{flex-wrap:wrap;gap:.5rem}
  .tb-nav{margin-left:0;order:3;width:100%;overflow-x:auto}
  .kv{grid-template-columns:1fr}
  .hrow{flex-direction:column;align-items:flex-start}
}
