/* kontoauszug_web/static/app.css */
:root{
  --paper:#f6f5f1; --ink:#16211f; --ink-soft:#41524e; --surface:#fff; --line:#e4e2da;
  --accent:#0e6b61; --accent-strong:#0a564e; --accent-soft:#e4efec;
  --pos:#15803d; --pos-soft:#e7f3ea; --neg:#be123c; --neg-soft:#fbe9ee;
  --warn:#b45309; --warn-soft:#fbf0e1;
}
*{box-sizing:border-box;margin:0;padding:0}
html{background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased}
body{font-family:'Inter',system-ui,sans-serif;font-size:14px}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;letter-spacing:-.01em}
.tnum{font-variant-numeric:tabular-nums}
a{color:inherit;text-decoration:none}
/* Shell */
.app{display:flex;min-height:100vh}
.side{width:240px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column}
.brand{display:flex;align-items:center;gap:.65rem;height:64px;padding:0 1.1rem;border-bottom:1px solid var(--line)}
.wtile{width:32px;height:32px;border-radius:8px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif}
.bname{font-family:'Fraunces',serif;font-weight:600;line-height:1.05}
.bsub{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.nav{flex:1;padding:1rem .7rem;display:flex;flex-direction:column;gap:.25rem}
.nav-link{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--ink-soft)}
.nav-link:hover{background:var(--accent-soft);color:var(--accent-strong)}
.nav-link.active{background:var(--ink);color:#fff}
.userbox{border-top:1px solid var(--line);padding:.8rem 1.1rem;display:flex;align-items:center;justify-content:space-between}
.userbox .uname{font-size:.85rem;font-weight:600}.userbox .umail{font-size:11px;color:var(--ink-soft)}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.content{padding:1.5rem 2rem;max-width:1400px;width:100%;margin:0 auto}
/* Buttons / badges / card */
.btn{display:inline-flex;align-items:center;gap:.4rem;border-radius:9px;padding:.55rem .95rem;font-size:.85rem;font-weight:600;cursor:pointer;border:1px solid transparent}
.btn-p{background:var(--accent);color:#fff}.btn-p:hover{background:var(--accent-strong)}
.btn-s{background:var(--surface);border-color:var(--line);color:var(--ink)}.btn-s:hover{background:var(--paper)}
.btn-icon{background:var(--surface);border:1px solid var(--line);color:var(--ink-soft);width:30px;height:30px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.badge{display:inline-flex;align-items:center;gap:.25rem;border-radius:999px;padding:.12rem .5rem;font-size:11px;font-weight:600}
.b-green{background:var(--pos-soft);color:var(--pos)}.b-warn{background:var(--warn-soft);color:var(--warn)}
.b-neg{background:var(--neg-soft);color:var(--neg)}.b-slate{background:rgba(228,226,218,.6);color:var(--ink-soft)}
.b-accent{background:var(--accent-soft);color:var(--accent-strong)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.input{width:100%;border:1px solid var(--line);border-radius:9px;padding:.55rem .8rem;font-size:.9rem;background:#fff}
.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(14,107,97,.18)}
/* Login */
.login{min-height:100vh;display:grid}
@media(min-width:1024px){.login{grid-template-columns:1fr 1fr}}
.login-brand{display:none}
@media(min-width:1024px){.login-brand{display:flex;flex-direction:column;justify-content:space-between;background:var(--ink);color:#fff;padding:3rem}}
.login-form{display:flex;align-items:center;justify-content:center;padding:2rem}
/* Tabs / table */
.tabs{display:flex;gap:.3rem;border-bottom:1px solid var(--line);margin-top:1rem}
.tab{padding:.6rem .9rem;font-size:.85rem;font-weight:600;color:var(--ink-soft);border-bottom:2px solid transparent;cursor:pointer;display:flex;align-items:center;gap:.45rem}
.tab.active{color:var(--accent-strong);border-bottom-color:var(--accent)}
table.wt{width:100%;border-collapse:collapse}
.wt th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);padding:.55rem .8rem;border-bottom:1px solid var(--line);font-weight:600}
.wt td{padding:.55rem .8rem;border-bottom:1px solid #f1efe9;vertical-align:middle}
.wt tr[data-status] td:first-child{box-shadow:none}
.wt tr.s-sicher{box-shadow:inset 3px 0 var(--pos)}
.wt tr.s-unsicher{box-shadow:inset 3px 0 var(--warn);background:#fffdf8}
.wt tr.s-manuell{box-shadow:inset 3px 0 var(--accent)}
.wt tr.s-kein_beleg{box-shadow:inset 3px 0 #c9c6bc;color:var(--ink-soft)}
.wt tr.s-fehlend{box-shadow:inset 3px 0 var(--neg);background:#fffafb}
.amt{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}
.file{color:var(--accent-strong);font-size:12px}
/* Drawer */
.drawer-backdrop{position:fixed;inset:0;background:rgba(22,33,31,.18);z-index:40}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(460px,90vw);background:#fbfaf7;border-left:1px solid var(--line);box-shadow:-12px 0 28px rgba(22,33,31,.08);z-index:50;display:flex;flex-direction:column}
.drawer-head{padding:1.1rem 1.2rem;border-bottom:1px solid var(--line)}
.drawer-body{padding:1.1rem 1.2rem;overflow-y:auto;flex:1}
.lab{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);margin:.9rem 0 .3rem;font-weight:600}
[x-cloak]{display:none!important}
.toast{position:fixed;bottom:1.25rem;right:1.25rem;background:var(--ink);color:#fff;padding:.65rem 1rem;border-radius:9px;font-size:.85rem;z-index:60}
