:root{
  --bg:#eef1f5; --paper:#ffffff; --ink:#1a2430; --mut:#6b7885; --line:#dde3ea;
  --accent:#2b6cb0; --accent-d:#215389; --ok:#1f7a54; --warn:#b7791f; --err:#c0392b;
  --soft:#eaf1f8; --shadow:0 1px 3px rgba(26,36,48,.07),0 6px 20px rgba(26,36,48,.05);
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.55}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

.top{display:flex;align-items:center;gap:22px;background:var(--paper);border-bottom:1px solid var(--line);padding:0 22px;height:58px;position:sticky;top:0;z-index:10}
.brand{font-weight:800;font-size:20px;color:var(--ink);letter-spacing:-.02em;text-decoration:none}
.brand span{color:var(--accent)}
.top nav{display:flex;gap:4px;flex:1;overflow-x:auto}
.top nav a{color:var(--mut);font-weight:500;font-size:14px;padding:8px 12px;border-radius:8px;white-space:nowrap;text-decoration:none}
.top nav a:hover{background:var(--soft);color:var(--accent)}
.top nav a.active{background:var(--soft);color:var(--accent);font-weight:600}
.logout{color:var(--mut);font-size:13px}

.wrap{max-width:960px;margin:26px auto;padding:0 20px}
h1{font-size:24px;letter-spacing:-.02em;margin:0 0 14px}
h3{margin:0 0 12px}
.mut{color:var(--mut)}
.hint{font-size:12.5px;color:var(--mut);margin:6px 0 0}

.card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:20px;box-shadow:var(--shadow);margin-bottom:18px}
.note{background:#fdf6e6;border:1px solid #f0e0b6;border-left:4px solid var(--warn);border-radius:0 10px 10px 0;padding:12px 16px;margin:0 0 18px;font-size:14px}
.ok{color:var(--ok);font-weight:600}
.err{color:var(--err);font-weight:600}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.stat{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow)}
.stat .k{display:block;font-size:12px;color:var(--mut);text-transform:uppercase;letter-spacing:.04em}
.stat b{font-size:24px;letter-spacing:-.02em}
.quick{display:flex;flex-wrap:wrap;gap:10px}

.btn{display:inline-block;background:var(--accent);color:#fff;border:none;border-radius:10px;padding:11px 18px;font-size:14.5px;font-weight:600;cursor:pointer;text-decoration:none;font-family:inherit}
.btn:hover{background:var(--accent-d);text-decoration:none}
.btn.ghost{background:#fff;color:var(--accent);border:1px solid var(--line)}
.btn.ghost:hover{background:var(--soft)}

.form label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:12px}
.form input,.form textarea,.form select{display:block;width:100%;margin-top:5px;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:14px;font-weight:400;color:var(--ink);background:#fff}
.form input:focus,.form textarea:focus,.form select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(43,108,176,.14)}
.form fieldset{border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin:0 0 18px}
.form legend{font-weight:700;font-size:13px;color:var(--accent);padding:0 6px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form.narrow{max-width:340px}

.auth{max-width:380px;margin:8vh auto}
.auth h1{margin-bottom:18px}
.auth form{display:flex;flex-direction:column;gap:14px}
.auth label{display:flex;flex-direction:column;font-size:13px;font-weight:600;color:var(--ink);gap:6px}
.auth input{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:15px;font-weight:400;background:#fff}
.auth input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(43,108,176,.14)}
.auth .btn{width:100%;margin-top:4px;padding:12px}
.split{display:grid;grid-template-columns:1fr 340px;gap:18px;align-items:start}

table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--mut);padding:8px 10px;border-bottom:2px solid var(--line)}
td{padding:10px;border-bottom:1px solid var(--line);vertical-align:top}
tr:last-child td{border-bottom:none}

.foot{max-width:960px;margin:20px auto 50px;padding:0 20px;font-size:12.5px;color:var(--mut)}

@media(max-width:720px){
  .stats{grid-template-columns:1fr 1fr}.split{grid-template-columns:1fr}.form .row{grid-template-columns:1fr}
}

/* --- Rechnungen --- */
.pagehead{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}
.pagehead h1{margin:0}
.actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;align-items:center}
.btn.small{padding:7px 12px;font-size:13px}
.btn.danger{color:var(--err);border-color:#e6c3bc}
.btn.danger:hover{background:#fbecea}
.r{text-align:right}

.chip{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:3px 9px;border-radius:20px;vertical-align:middle}
.chip-o{background:#fdf0d8;color:#8a5a00}
.chip-p{background:#dcf3e8;color:#1f7a54}
.chip-s{background:#eceff2;color:#6b7885}

.items{width:100%;margin:8px 0}
.items th{font-size:11px}
.items td{padding:5px 4px;border-bottom:none}
.items .ti{width:100%;padding:8px 9px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14px;background:#fff}
.items .ti:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(43,108,176,.12)}
.items .tq,.items th.tq{width:70px}.items .tu,.items th.tu{width:70px}
.items .tp,.items th.tp{width:110px}.items .trate,.items th.trate{width:80px}
.items .tr{width:78px}
.items .r,.items .tq,.items .tp{text-align:right}
.xrow{border:none;background:none;color:var(--err);font-size:18px;line-height:1;cursor:pointer;padding:4px 8px;border-radius:6px}
.xrow:hover{background:#fbecea}

table.view td,table.view th{padding:9px 10px}
table.view tfoot td{border-bottom:none;padding:5px 10px;color:var(--ink)}
table.view tfoot .grand td{border-top:2px solid var(--ink);font-weight:800;font-size:16px;padding-top:10px}

table.clickable tbody tr{cursor:pointer}
table.clickable tbody tr:hover{background:var(--soft)}

/* --- Belege / Upload --- */
.drop{display:flex;flex-direction:column;align-items:center;gap:8px;border:2px dashed var(--line);border-radius:14px;padding:30px 18px;cursor:pointer;text-align:center;background:#fafbfc;margin-bottom:14px}
.drop:hover{border-color:var(--accent);background:var(--soft)}
.drop input[type=file]{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}
.drop-in{font-weight:600;font-size:15px;color:var(--accent)}
.drop .fn{font-size:13px}

/* --- Mobile: breite Tabellen als Karten --- */
@media(max-width:640px){
  .top{gap:12px;padding:0 14px}
  .top nav{gap:2px}
  .top nav a{padding:7px 9px;font-size:13px}
  .wrap{padding:0 12px;margin:16px auto}
  .pagehead{flex-direction:column;gap:10px}
  .pagehead .btn{width:100%;text-align:center}
  .card{padding:14px}

  /* Klickbare Datentabellen -> Kartenliste */
  table.clickable thead{display:none}
  table.clickable, table.clickable tbody, table.clickable tr, table.clickable td{display:block;width:100%}
  table.clickable tr{border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:10px;background:#fff;position:relative}
  table.clickable td{border:none;padding:2px 0;text-align:left!important}
  table.clickable td.r{text-align:left!important}
  /* Label vor jeder Zelle via data-label */
  table.clickable td::before{content:attr(data-label);display:inline-block;min-width:92px;font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:var(--mut);font-weight:600}
  table.clickable td:first-child{font-size:16px;font-weight:700;margin-bottom:4px}
  table.clickable td:first-child::before{content:none}

  .stats{grid-template-columns:1fr 1fr!important}
  .split{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .actions{flex-direction:column;align-items:stretch}
  .actions .btn{width:100%;text-align:center}
}

/* --- Spracheingabe (Mikro) --- */
.micbtn{position:absolute;right:4px;top:50%;transform:translateY(-50%);border:none;background:transparent;cursor:pointer;font-size:14px;line-height:1;padding:3px 4px;border-radius:6px;z-index:2}
.micbtn:hover{background:var(--soft)}
.micbtn.rec{color:#fff;background:var(--err);animation:micpulse 1s infinite}
.items .has-mic{padding-right:26px}
@keyframes micpulse{0%,100%{opacity:1}50%{opacity:.45}}

/* --- Mobile: Positions-Formular als gestapelte Zeilen --- */
@media(max-width:640px){
  .items thead{display:none}
  .items, .items tbody{display:block;width:100%}
  .items tr.irow{display:grid;grid-template-columns:1fr 1fr;gap:8px;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:12px;background:#fff;position:relative}
  .items tr.irow td{display:block;padding:0;border:none}
  .items tr.irow td:nth-child(1){grid-column:1 / -1}          /* Beschreibung volle Breite */
  .items tr.irow td:nth-child(6){position:absolute;top:6px;right:6px}
  .items .ti{width:100%}
  .items .tq,.items .tu,.items .tp,.items .tr{width:100%}
  /* Mini-Labels vor den Feldern */
  .items tr.irow td:nth-child(2)::before{content:"Menge";display:block;font-size:10px;color:var(--mut);text-transform:uppercase;margin-bottom:2px}
  .items tr.irow td:nth-child(3)::before{content:"Einheit";display:block;font-size:10px;color:var(--mut);text-transform:uppercase;margin-bottom:2px}
  .items tr.irow td:nth-child(4)::before{content:"Einzelpreis €";display:block;font-size:10px;color:var(--mut);text-transform:uppercase;margin-bottom:2px}
  .items tr.irow td.trate::before{content:"USt";display:block;font-size:10px;color:var(--mut);text-transform:uppercase;margin-bottom:2px}
  .items .xrow{font-size:20px;padding:2px 6px}
}

/* Mikro bei mehrzeiligen Feldern (Anmerkung) oben rechts */
.micbtn.mic-top{top:8px;transform:none}
.form textarea.has-mic,.form input.has-mic{padding-right:34px}
