@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@400;500;600&display=swap');

:root{
  --paper:#f4f7fb;
  --paper-2:#e8eef6;
  --card:#ffffff;
  --ink:#16264d;
  --ink-soft:#4a5a78;
  --line:#d3deeb;
  --wine:#1d4ed8;
  --wine-soft:#1ea7c5;
  --green:#1e9e8a;
  --red:#9a3a2c;
  --gold:#c8922a;
  --shadow:0 1px 2px rgba(33,28,23,.06),0 8px 24px rgba(33,28,23,.07);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'IBM Plex Sans',sans-serif;
  color:var(--ink);
  background:var(--paper);
  background-image:radial-gradient(circle at 12% -10%,rgba(169,138,75,.10),transparent 45%),
                   radial-gradient(circle at 110% 0%,rgba(122,35,48,.07),transparent 40%);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
.mono{font-family:'IBM Plex Mono',monospace;font-variant-numeric:tabular-nums}

/* ---------- Layout ---------- */
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}
header.top{
  border-bottom:1px solid var(--line);
  background:linear-gradient(var(--paper),var(--paper-2));
}
.top-inner{display:flex;align-items:center;justify-content:space-between;
  padding:22px 0 18px;flex-wrap:wrap;gap:14px}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{max-height:42px;max-width:120px;object-fit:contain}
.brand h1{
  font-family:'Fraunces',serif;font-weight:600;font-size:1.6rem;
  letter-spacing:-.01em;margin:0;color:var(--ink);
}
.brand .sub{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--wine);font-weight:600}
nav a{
  font-size:.9rem;color:var(--ink-soft);text-decoration:none;
  margin-left:20px;padding-bottom:3px;border-bottom:2px solid transparent;
  transition:.15s;
}
nav a:hover{color:var(--ink);border-color:var(--gold)}
nav a.danger:hover{color:var(--wine);border-color:var(--wine)}
.badge{display:inline-block;background:var(--wine);color:#fff;font-size:.7rem;font-weight:700;
  padding:1px 7px;border-radius:10px;margin-left:3px;letter-spacing:.02em;vertical-align:1px}
.user-info{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;
  font-size:.85rem;color:var(--ink-soft);border-left:1px solid var(--line);margin-left:4px}
.role-badge{font-size:.65rem;padding:2px 6px;border-radius:4px;font-weight:600;
  text-transform:uppercase;letter-spacing:.04em}
.role-badge.admin{background:var(--wine);color:#fff}
.role-badge.chef{background:#3a6b4f;color:#fff}

main{padding:30px 0 60px}

/* ---------- KPI ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:16px;margin-bottom:28px}
.kpi{
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:18px 20px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.kpi .label{font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;margin-bottom:8px}
.kpi .val{font-family:'IBM Plex Mono',monospace;font-size:1.7rem;font-weight:600;
  font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.kpi .val .cur{font-size:.95rem;color:var(--ink-soft);margin-right:4px}
.kpi.big{grid-column:span 1}
.kpi.big .val{font-size:2.1rem}
.kpi.big::after{content:"";position:absolute;inset:0 0 auto auto;width:70px;height:70px;
  background:radial-gradient(circle,rgba(122,35,48,.12),transparent 70%);}
.val.pos{color:var(--green)} .val.neg{color:var(--red)}

/* ---------- Panels ---------- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow);margin-bottom:24px}
.panel-h{display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:10px}
.panel-h h2{font-family:'Fraunces',serif;font-weight:500;font-size:1.15rem;margin:0}
.panel-b{padding:18px 20px}

/* ---------- Formular ---------- */
form.add{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;align-items:end}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600}
.field.c2{grid-column:span 2}.field.c3{grid-column:span 3}
.field.c4{grid-column:span 4}.field.c6{grid-column:span 6}.field.c12{grid-column:span 12}
input,select,textarea{
  font-family:'IBM Plex Sans',sans-serif;font-size:.92rem;color:var(--ink);
  background:#fffdf8;border:1px solid var(--line);border-radius:8px;
  padding:9px 11px;transition:.15s;width:100%;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--wine-soft);
  box-shadow:0 0 0 3px rgba(122,35,48,.12)}
input.mono{font-family:'IBM Plex Mono',monospace}

.btn{
  font-family:'IBM Plex Sans',sans-serif;font-size:.9rem;font-weight:600;
  cursor:pointer;border:1px solid var(--wine);background:var(--wine);color:#fbf3ea;
  padding:9px 18px;border-radius:8px;transition:.15s;letter-spacing:.01em;
}
.btn:hover{background:var(--wine-soft);border-color:var(--wine-soft)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.ghost:hover{border-color:var(--ink-soft);background:#fff}
.btn.sm{padding:5px 10px;font-size:.8rem}

select.month{padding:7px 10px;border-radius:8px;font-weight:600}

/* ---------- Tabelle ---------- */
.table-scroll{overflow-x:auto}
table.led{width:100%;border-collapse:collapse;font-size:.9rem}
table.led th{
  text-align:left;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--line);
  white-space:nowrap;
}
table.led td{padding:11px 14px;border-bottom:1px solid #e7ddca;vertical-align:top}
table.led tr:last-child td{border-bottom:none}
table.led tr:hover td{background:rgba(169,138,75,.06)}
td.num{text-align:right;font-family:'IBM Plex Mono',monospace;font-variant-numeric:tabular-nums;white-space:nowrap}
.tag{display:inline-block;font-size:.72rem;font-weight:600;padding:2px 9px;border-radius:999px;
  letter-spacing:.03em}
.tag.ein{background:rgba(58,107,79,.14);color:var(--green)}
.tag.aus{background:rgba(154,58,44,.13);color:var(--red)}
.tag.bar{border:1px solid var(--line);color:var(--ink-soft)}
.tag.bank{border:1px solid var(--wine);color:var(--wine)}
.tag.karte{border:1px solid var(--gold);color:var(--gold)}
.tag.ob{background:rgba(122,35,48,.10);color:var(--wine)}
.amt-ein{color:var(--green);font-weight:600}
.amt-aus{color:var(--red);font-weight:600}
.del{background:none;border:none;color:#bba;cursor:pointer;font-size:1rem;padding:2px 6px;border-radius:6px}
.del:hover{color:var(--red);background:rgba(154,58,44,.1)}
.muted{color:#b7ac98}
.empty{text-align:center;color:var(--ink-soft);padding:40px 20px;font-style:italic}

/* ---------- Flash ---------- */
.flash{padding:11px 16px;border-radius:10px;margin-bottom:14px;font-size:.9rem;font-weight:500}
.flash.ok{background:rgba(58,107,79,.13);color:var(--green);border:1px solid rgba(58,107,79,.3)}
.flash.error{background:rgba(154,58,44,.12);color:var(--red);border:1px solid rgba(154,58,44,.3)}

/* ---------- Login ---------- */
.login-wrap{min-height:80vh;display:flex;align-items:center;justify-content:center}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);padding:38px 34px;width:100%;max-width:360px;text-align:center}
.login-card h1{font-family:'Fraunces',serif;font-weight:600;margin:0 0 4px}
.login-card .sub{color:var(--wine);font-size:.75rem;letter-spacing:.16em;
  text-transform:uppercase;font-weight:600;margin-bottom:24px}
.login-card form{display:flex;flex-direction:column;gap:14px}

/* ---------- Import ---------- */
.hint{font-size:.86rem;color:var(--ink-soft);margin:0 0 16px;line-height:1.6}
.drop{border:2px dashed var(--line);border-radius:14px;padding:34px;text-align:center;
  background:#fffdf8;margin-bottom:16px}
.drop input[type=file]{margin:14px auto 0;display:block;max-width:320px}
.preview{overflow-x:auto;border:1px solid var(--line);border-radius:10px;margin:6px 0 18px}
.preview table{font-size:.8rem;border-collapse:collapse;width:100%}
.preview th{background:var(--paper-2);font-family:'IBM Plex Mono',monospace;font-size:.74rem;
  padding:7px 10px;border-bottom:1px solid var(--line);white-space:nowrap;text-align:left}
.preview td{padding:6px 10px;border-bottom:1px solid #e7ddca;white-space:nowrap;font-family:'IBM Plex Mono',monospace;font-size:.78rem}
.map-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}

footer{border-top:1px solid var(--line);padding:20px 0;font-size:.78rem;color:#b0a48f;text-align:center}

@media(max-width:640px){
  form.add .field{grid-column:span 6 !important}
  form.add .field.c12{grid-column:span 12 !important}
  .brand h1{font-size:1.3rem}
}
