@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:#f3ede1;
  --paper-2:#ece4d4;
  --card:#fbf7ef;
  --ink:#211c17;
  --ink-soft:#5a5046;
  --line:#d8cdb8;
  --wine:#7a2330;
  --wine-soft:#9c3b48;
  --green:#3a6b4f;
  --red:#9a3a2c;
  --gold:#a98a4b;
  --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;-webkit-overflow-scrolling:touch;width:100%;max-width:100%}
table.led{width:100%;border-collapse:collapse;font-size:.9rem;table-layout:auto}
/* Beschreibung darf umbrechen statt die Tabelle breit zu machen */
table.led td:nth-child(6){white-space:normal;word-break:break-word;max-width:260px}
table.led th:nth-child(6){white-space:normal}
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)}
/* Auf schmalen Bildschirmen kompakter, damit mehr Spalten sichtbar sind */
@media(max-width:1000px){
  table.led{font-size:.82rem}
  table.led th{padding:8px 9px}
  table.led td{padding:8px 9px}
}
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}
}

/* ===== Auszuege / Monats-Anhaenge ===== */
.auszug-monatsnav{display:flex;align-items:center;justify-content:center;gap:14px;margin:8px 0 4px}
.auszug-monatsnav .btn-pfeil{font-size:.85rem;color:var(--ink-soft);text-decoration:none;
  border:1px solid var(--line);border-radius:8px;padding:4px 10px;background:#fffdf8}
.auszug-monatsnav .btn-pfeil:hover{border-color:var(--gold);color:var(--ink)}
.auszug-monatsnav .monat-select{font-size:1.05rem;font-weight:600;text-align:center;
  padding:4px 10px;min-width:130px}

.auszug-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:18px}
@media(max-width:760px){.auszug-grid{grid-template-columns:1fr}}

.auszug-karte{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:16px 18px;display:flex;flex-direction:column}
.auszug-karte-kopf{display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--line);padding-bottom:8px;margin-bottom:10px}
.auszug-karte-kopf h2{font-size:1rem;margin:0;color:var(--wine)}

.auszug-karte .anhang-liste{list-style:none;padding:0;margin:0 0 10px;flex:1}
.auszug-karte .anhang-liste li{display:flex;align-items:center;gap:8px;
  padding:6px 0;border-bottom:1px dotted var(--line);font-size:.88rem}
.auszug-karte .anhang-liste li:last-child{border-bottom:none}
.auszug-karte .anhang-liste a{color:var(--ink);text-decoration:none;flex:1;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.auszug-karte .anhang-liste a:hover{color:var(--wine);text-decoration:underline}
.auszug-karte .muted{font-size:.78rem;color:var(--ink-soft)}
.auszug-karte .leer{font-style:italic;flex:1}

.auszug-upload{display:flex;align-items:center;gap:8px;margin-top:auto;
  padding-top:10px;border-top:1px solid var(--line)}
.auszug-upload input[type=file]{font-size:.8rem;flex:1;min-width:0}
.btn-klein{font-size:.8rem;padding:4px 10px;border-radius:7px;border:1px solid var(--line);
  background:#fffdf8;color:var(--ink);cursor:pointer;white-space:nowrap}
.btn-klein:hover{border-color:var(--gold)}
.btn-klein.danger{color:var(--wine);border-color:transparent;background:transparent;padding:4px 6px}
.btn-klein.danger:hover{text-decoration:underline}

/* CC-Import-Knopf in den Auszug-Karten */
.auszug-cc-import{margin-top:auto;padding-top:10px;border-top:1px solid var(--line)}
.auszug-cc-import .btn-klein{display:inline-block;text-decoration:none;
  background:var(--paper-2);border-color:var(--gold)}
.auszug-cc-import .btn-klein:hover{background:#fffdf8}

/* ===== Variante A: Bank+Bonierkassa links, CC-Karten rechts untereinander ===== */
.auszug-grid{display:grid;grid-template-columns:repeat(2,1fr);
  grid-auto-rows:min-content;gap:16px;margin-top:18px;align-items:start}
/* Spalte 1: Bankauszug (oben), Bonierkassa (unten) */
.auszug-grid .karte-bankauszug      {grid-column:1;grid-row:1}
.auszug-grid .karte-bonierkassa     {grid-column:1;grid-row:2}
/* Spalte 2: CC-Kassaschnitt (oben), CC-Händlerbeleg (unten) */
.auszug-grid .karte-cc_kassaschnitt {grid-column:2;grid-row:1}
.auszug-grid .karte-cc_haendlerbeleg{grid-column:2;grid-row:2}
@media(max-width:760px){
  .auszug-grid{grid-template-columns:1fr}
  .auszug-grid .auszug-karte{grid-column:1 !important;grid-row:auto !important}
}
