/* ===== HV-Meldungen Manager — Mockup Styles ===== */
:root{
  --bg:        #eef0f3;
  --panel:     #ffffff;
  --panel-2:   #fafbfc;
  --sidebar:   #f4f5f7;
  --ink:       #1c2128;
  --ink-2:     #4a515b;
  --muted:     #818892;
  --line:      #e3e6ea;
  --line-2:    #eceef1;
  --accent:    #0F4D52;
  --accent-ink:#0a393d;
  --accent-bg: #e3eeef;
  --green:     #1f8a5b;
  --green-bg:  #e7f3ec;
  --amber:     #b07407;
  --amber-bg:  #fbf1dd;
  --red:       #c0392b;
  --red-bg:    #fbeae8;
  --radius:    9px;
  --mono: "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  --sans: "Public Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  font-size:14px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
#root{height:100vh}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:14px}
::selection{background:var(--accent-bg)}

/* ---- App shell ---- */
.app{display:flex;height:100vh;overflow:hidden}

/* ---- Sidebar ---- */
.sidebar{
  width:288px;flex:0 0 288px;
  background:var(--sidebar);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
}
.sidebar-head{
  padding:18px 18px 14px;
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  width:30px;height:30px;border-radius:8px;
  background:var(--accent);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:15px;
  flex:0 0 auto;
}
.brand-title{font-weight:700;font-size:15px;letter-spacing:-.01em;line-height:1.1}
.brand-sub{font-size:11.5px;color:var(--muted);line-height:1.1}
.brand-cog{
  margin-left:auto;width:34px;height:34px;border-radius:8px;
  border:1px solid var(--line);background:#fff;color:var(--ink-2);
  display:grid;place-items:center;
}
.brand-cog:hover{background:var(--panel-2);color:var(--accent);border-color:var(--accent-bg)}

.nav-overview{
  margin:10px 10px 4px;padding:9px 12px;border-radius:8px;
  display:flex;align-items:center;gap:10px;color:var(--ink-2);font-weight:600;
  border:1px solid transparent;
}
.nav-overview:hover{background:#eceef1}
.nav-overview.active{background:#fff;border-color:var(--line);color:var(--ink);box-shadow:0 1px 2px rgba(20,25,35,.04)}
.nav-overview .badge-count{margin-left:auto}

.list-label{
  padding:12px 18px 6px;font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--muted);display:flex;align-items:center;justify-content:space-between;
}
.list-label button{
  border:none;background:none;color:var(--muted);display:grid;place-items:center;
  width:22px;height:22px;border-radius:6px;
}
.list-label button:hover{background:#e4e6ea;color:var(--ink)}

.kunden{flex:1;overflow-y:auto;padding:2px 10px 10px}
.kunde-item{
  display:flex;align-items:center;gap:11px;
  padding:9px 11px;border-radius:8px;margin-bottom:2px;
  border:1px solid transparent;position:relative;
}
.kunde-item:hover{background:#eceef1}
.kunde-item.active{background:#fff;border-color:var(--line);box-shadow:0 1px 2px rgba(20,25,35,.05)}
.kunde-dot{width:10px;height:10px;border-radius:3px;flex:0 0 auto}
.kunde-meta{min-width:0;flex:1}
.kunde-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.kunde-ticker{font-family:var(--mono);font-size:11px;color:var(--muted);line-height:1.2}
.kunde-item .mini-pill{flex:0 0 auto}

.sidebar-foot{
  border-top:1px solid var(--line);padding:12px 16px;
  display:flex;flex-direction:column;gap:8px;background:var(--sidebar);
}
.auto-toggle{display:flex;align-items:flex-start;gap:10px;cursor:pointer;user-select:none}
.auto-toggle .chk{margin-top:1px}
.auto-toggle .lbl{font-size:12.5px;color:var(--ink-2);line-height:1.3}
.auto-toggle .lbl b{color:var(--ink);font-weight:600;display:block}
.foot-user{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--muted);padding-top:2px}
.foot-user span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.foot-logout{margin-left:auto;border:none;background:transparent;color:var(--accent);font-weight:700;font-size:11.5px;padding:3px 0}
.foot-logout:hover{text-decoration:underline}

/* ---- Login ---- */
.login-shell{min-height:100vh;display:grid;place-items:center;background:var(--bg);padding:24px}
.login-card{width:360px;max-width:100%;background:var(--panel);border:1px solid var(--line);border-radius:10px;
  box-shadow:0 18px 45px rgba(20,25,35,.12);padding:28px}
.login-card h1{font-size:22px;margin:13px 0 2px;letter-spacing:-.02em}
.login-error{display:flex;align-items:center;gap:7px;margin-bottom:15px;padding:9px 11px;border:1px solid var(--red-bg);
  border-radius:8px;background:#fff7f6;color:var(--red);font-size:12.5px;font-weight:600}
.form-error{display:flex;align-items:center;gap:7px;margin-bottom:15px;padding:9px 11px;border:1px solid var(--red-bg);
  border-radius:8px;background:#fff7f6;color:var(--red);font-size:12.5px;font-weight:600}
.form-success{display:flex;align-items:center;gap:7px;margin-bottom:15px;padding:9px 11px;border:1px solid var(--green-bg);
  border-radius:8px;background:#f4fbf7;color:var(--green);font-size:12.5px;font-weight:600}

/* checkbox */
.chk{
  width:17px;height:17px;border-radius:5px;border:1.5px solid #b9bec6;background:#fff;
  display:grid;place-items:center;flex:0 0 auto;transition:.12s;
}
.chk.on{background:var(--accent);border-color:var(--accent)}
.chk svg{opacity:0;transition:.12s}
.chk.on svg{opacity:1}

/* ---- Main ---- */
.main{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg)}
.api-error{
  display:flex;align-items:center;gap:8px;margin:12px 18px 0;padding:9px 11px;
  border:1px solid var(--red-bg);border-radius:8px;background:#fff7f6;
  color:var(--red);font-size:13px;font-weight:600;
}
.main-scroll{flex:1;overflow-y:auto}

/* content header */
.chead{
  background:var(--panel);border-bottom:1px solid var(--line);
  padding:18px 30px 0;
}
.chead-top{display:flex;align-items:flex-start;gap:14px}
.chead-dot{width:13px;height:13px;border-radius:4px;margin-top:7px;flex:0 0 auto}
.chead h1{font-size:21px;font-weight:700;letter-spacing:-.02em;margin:0;line-height:1.15}
.chead-ticker{font-family:var(--mono);font-size:12.5px;color:var(--muted);margin-top:3px}
.chead-actions{margin-left:auto;display:flex;gap:8px;align-items:center}

/* meldung reiter / tabs */
.reiter{display:flex;gap:2px;margin-top:18px;align-items:flex-end;flex-wrap:wrap}
.reiter-tab{
  padding:9px 15px 10px;border-radius:8px 8px 0 0;border:1px solid transparent;border-bottom:none;
  display:flex;align-items:center;gap:9px;color:var(--ink-2);font-weight:600;position:relative;top:1px;
  background:transparent;font-size:13px;white-space:nowrap;
}
.reiter-tab:hover{background:var(--panel-2)}
.reiter-tab.active{background:var(--bg);border-color:var(--line);color:var(--ink)}
.reiter-tab .typ-dot{width:7px;height:7px;border-radius:50%}
.reiter-tab .rt-date{font-family:var(--mono);font-size:11.5px;color:var(--muted)}
.reiter-tab.active .rt-date{color:var(--ink-2)}
.reiter-add{
  width:30px;height:30px;border-radius:7px;border:1px dashed var(--line);background:none;
  color:var(--muted);display:grid;place-items:center;margin-left:4px;margin-bottom:1px;
}
.reiter-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}

/* globale Einstellungen */
.settings-page{display:flex;flex-direction:column;min-height:0;flex:1}
.settings-tabs{
  display:flex;align-items:center;gap:8px;
  padding:12px 36px 0;background:var(--panel);
  border-bottom:1px solid var(--line);
}
.settings-tab{
  height:36px;padding:0 13px;border:1px solid transparent;border-bottom:none;
  border-radius:8px 8px 0 0;background:transparent;color:var(--ink-2);
  display:flex;align-items:center;gap:7px;font-weight:600;
}
.settings-tab:hover{background:var(--panel-2);color:var(--ink)}
.settings-tab.active{background:var(--bg);border-color:var(--line);color:var(--ink)}

/* content body */
.cbody{padding:26px 30px 60px;max-width:920px}

/* cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 1px 2px rgba(20,25,35,.03)}
.card-pad{padding:20px 22px}
.card-head{padding:15px 22px;border-bottom:1px solid var(--line-2);display:flex;align-items:center;gap:10px}
.card-head h3{margin:0;font-size:14px;font-weight:700}
.card-head .sub{font-size:12px;color:var(--muted);font-weight:500}

/* dropzone */
.dropzone{
  border:2px dashed #cdd2da;border-radius:11px;background:var(--panel-2);
  padding:30px;text-align:center;transition:.15s;cursor:pointer;
}
.dropzone:hover{border-color:var(--accent);background:var(--accent-bg)}
.dropzone.drag{border-color:var(--accent);background:var(--accent-bg);transform:scale(1.005)}
.dz-icon{width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid var(--line);
  display:grid;place-items:center;margin:0 auto 12px;color:var(--accent)}
.dz-title{font-weight:600;font-size:15px}
.dz-sub{color:var(--muted);font-size:12.5px;margin-top:3px}

/* file slots */
.slot{
  display:flex;align-items:center;gap:14px;padding:14px 16px;border-bottom:1px solid var(--line-2);
}
.slot:last-child{border-bottom:none}
.slot-ico{
  width:38px;height:44px;border-radius:7px;flex:0 0 auto;display:grid;place-items:center;
  font-family:var(--mono);font-size:10px;font-weight:700;color:#fff;position:relative;
}
.slot-ico.pdf{background:#c64b3f}
.slot-ico.xlsx{background:#207245}
.slot-ico.empty{background:#eceef1;border:1px dashed #c7ccd4;color:var(--muted)}
.slot-main{min-width:0;flex:1}
.slot-label{font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.slot-rename{font-family:var(--mono);font-size:12px;color:var(--ink-2);margin-top:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.slot-orig{font-size:11.5px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:6px}
.slot-orig s{color:#a8aeb6}
.slot-right{flex:0 0 auto;display:flex;align-items:center;gap:10px}

/* small pills / badges */
.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:100px;font-size:11.5px;font-weight:600;line-height:1.4}
.pill.green{background:var(--green-bg);color:var(--green)}
.pill.amber{background:var(--amber-bg);color:var(--amber)}
.pill.red{background:var(--red-bg);color:var(--red)}
.pill.gray{background:#eef0f3;color:var(--muted)}
.pill.accent{background:var(--accent-bg);color:var(--accent-ink)}
.mini-pill{font-family:var(--mono);font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:6px;background:#eef0f3;color:var(--ink-2)}
.demo-pill{display:inline-flex;align-items:center;gap:7px;padding:7px 10px;border-radius:9px;background:#fff1ef;border:1px solid #f3c6bf;color:var(--red);font-weight:800;font-size:12px;letter-spacing:.04em}
.demo-banner{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:18px;padding:12px 16px;border:2px solid #ef6d74;background:#fff1ef;color:#b2332f;border-radius:9px;font-weight:900;letter-spacing:.03em;text-transform:uppercase;box-shadow:0 8px 24px rgba(197,57,53,.12)}
.badge-count{min-width:20px;height:20px;padding:0 6px;border-radius:100px;background:#dfe2e7;color:var(--ink-2);
  font-size:11px;font-weight:700;display:inline-grid;place-items:center}
.badge-count.hot{background:var(--amber);color:#fff}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:8px;
  border:1px solid var(--line);background:#fff;color:var(--ink);font-weight:600;font-size:13px;
  transition:.12s;white-space:nowrap;
}
.btn:hover{background:var(--panel-2);border-color:#d2d6dc}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-ink)}
.btn.primary:disabled{background:#b6cbcd;border-color:#b6cbcd;cursor:not-allowed}
.btn:disabled,.icon-btn:disabled{opacity:.45;cursor:not-allowed}
.btn:disabled:hover,.icon-btn:disabled:hover{background:#fff;color:var(--ink-2);border-color:var(--line)}
.btn.ghost{border-color:transparent;background:none}
.btn.ghost:hover{background:#eceef1}
.btn.green{background:var(--green);border-color:var(--green);color:#fff}
.btn.green:hover{filter:brightness(.95)}
.btn.sm{padding:6px 11px;font-size:12.5px}
.btn.lg{padding:12px 22px;font-size:14.5px}
.icon-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:#fff;
  display:grid;place-items:center;color:var(--ink-2)}
.icon-btn:hover{background:var(--panel-2);color:var(--ink)}

/* progress / status strip */
.statusbar{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:10px;
  border:1px solid var(--line);background:var(--panel)}
.spez-hit-box{border-radius:11px;border:1px solid var(--line);padding:14px 16px;margin-bottom:18px;background:var(--panel);box-shadow:var(--shadow)}
.spez-hit-box.danger{background:#fff1ef;border-color:#f3b5ad;color:#9f2f27}
.spez-hit-box.notice{background:var(--accent-bg);border-color:#b9d9dd;color:var(--accent-ink)}
.spez-hit-head{display:flex;align-items:center;gap:9px;margin-bottom:10px}
.spez-hit-list{display:flex;flex-direction:column;gap:7px}
.spez-hit-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:var(--ink)}
.spez-hit-row>span:first-child{font-weight:800}
.spez-hit-row.ignored{opacity:.55}
.spez-hit-row.ignored>span:first-child{text-decoration:line-through}
.spez-ignore-btn{margin-left:auto}
.spez-copy-box{background:#f4fbf9;border-color:#bfe4d1}
.mono{font-family:var(--mono)}
.progress{height:7px;border-radius:100px;background:#e7eaee;overflow:hidden;flex:1}
.progress > span{display:block;height:100%;background:var(--accent);border-radius:100px;transition:width .4s ease}
.progress > span.done{background:var(--green)}

/* excel convert rows */
.conv-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-2);font-size:13px}
.conv-row:last-child{border-bottom:none}
.conv-row .fn{font-family:var(--mono);font-size:12px}
.conv-arrow{color:var(--muted)}

/* zip package — ein Archiv */
.zip-pack{border:1px solid var(--line);border-radius:11px;overflow:hidden;background:#fff}
.zip-pack-head{display:flex;align-items:center;gap:14px;padding:15px 17px;background:var(--panel-2);border-bottom:1px solid var(--line-2)}
.zip-ico{width:42px;height:48px;border-radius:8px;display:grid;place-items:center;color:#fff;flex:0 0 auto}
.zip-ico.pending{background:#aab0b9}
.zip-ico.ready{background:var(--green)}
.zip-name{font-family:var(--mono);font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.zip-contents{padding:12px 17px 14px}
.zip-file{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;color:var(--ink-2);
  padding:3px 0 3px 16px;position:relative}
.zip-file::before{content:"";position:absolute;left:3px;top:-4px;bottom:50%;width:9px;
  border-left:1.5px solid #dbdee3;border-bottom:1.5px solid #dbdee3;border-radius:0 0 0 4px}

/* ---- Vorlagen / Spalten-Editor ---- */
.vorlage-title{font-size:14px;font-weight:700;border:1px solid transparent;border-radius:6px;padding:2px 6px;margin:-2px -6px 1px;
  background:transparent;color:var(--ink);width:100%;max-width:420px;outline:none}
.vorlage-title:hover{border-color:var(--line)}
.vorlage-title:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg);background:#fff}
.vorlage-row{display:flex;align-items:center;gap:14px;padding:13px 15px;border:1px solid var(--line);
  border-radius:10px;background:var(--panel-2)}

/* Dateiname-Builder */
.name-builder{display:flex;align-items:center;gap:4px;flex-wrap:wrap;padding:10px 12px;border:1px solid var(--line);
  border-radius:9px;background:var(--panel-2)}
.name-builder .tok{font-family:var(--mono);font-size:12px;font-weight:600;padding:5px 9px;border-radius:6px}
.name-builder .tok-fix{background:#e7e9ee;color:var(--ink-2)}
.name-builder .tok-sep{font-family:var(--mono);font-size:13px;color:var(--muted)}
.name-builder .tok-input{font-family:var(--mono);font-size:12px;padding:5px 9px;border:1px dashed var(--accent);
  border-radius:6px;background:var(--accent-bg);color:var(--accent-ink);outline:none;width:170px}
.name-builder .tok-input:focus{border-style:solid;box-shadow:0 0 0 3px var(--accent-bg)}

.col-chips{display:flex;flex-wrap:wrap;gap:8px}
.col-chip{display:inline-flex;align-items:center;border-radius:8px;border:1px solid var(--line);background:#fff;
  font-size:13px;font-weight:500;transition:.12s;overflow:hidden;cursor:pointer;font-family:inherit;color:inherit}
.col-chip .cc-toggle{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border:none;background:none;font:inherit;color:inherit}
.col-chip .cc-box{width:18px;height:18px;border-radius:5px;display:grid;place-items:center;flex:0 0 auto;color:#fff}
.col-chip.keep{border-color:#bfe3cf;background:var(--green-bg);color:#16623f}
.col-chip.keep .cc-box{background:var(--green)}
.col-chip.drop{border-color:var(--line);background:#f5f6f8;color:var(--muted)}
.col-chip.drop .cc-box{background:#b6bcc4}
.col-chip.drop .cc-name{text-decoration:line-through;text-decoration-color:#c2c7ce}
.col-chip:hover{box-shadow:0 2px 6px rgba(20,25,35,.07)}

/* Sortier-Liste */
.sort-list{display:flex;flex-direction:column;gap:7px}
.sort-row{display:flex;align-items:center;gap:12px;padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:#fff}
.sort-row.on{border-color:#aecdcf;background:var(--accent-bg)}
.sort-prio{width:20px;height:20px;border-radius:6px;flex:0 0 auto;display:grid;place-items:center;
  font-size:11px;font-weight:700;background:var(--accent);color:#fff}
.sort-row:not(.on) .sort-prio{background:transparent;color:transparent}
.sort-name{font-weight:600;flex:1;min-width:0}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff}
.seg button{border:none;background:none;padding:6px 12px;font:inherit;font-size:12.5px;font-weight:600;color:var(--ink-2);border-left:1px solid var(--line)}
.seg button:first-child{border-left:none}
.seg button:hover{background:var(--panel-2)}
.seg button.on{background:var(--accent);color:#fff}
.reorder{display:inline-flex;flex-direction:column;border:1px solid var(--line);border-radius:7px;overflow:hidden}
.reorder button{border:none;background:#fff;color:var(--ink-2);width:26px;height:15px;display:grid;place-items:center;padding:0}
.reorder button:first-child{border-bottom:1px solid var(--line)}
.reorder button:hover:not(:disabled){background:var(--panel-2);color:var(--ink)}
.reorder button:disabled{color:#cfd3d9;cursor:not-allowed}

/* dashboard */
.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.stat-num{font-size:30px;font-weight:800;letter-spacing:-.02em;line-height:1}
.stat-lbl{color:var(--muted);font-size:12.5px;margin-top:6px;font-weight:500}
.stat-num.amber{color:var(--amber)}
.stat-num.red{color:var(--red)}
.stat-num.green{color:var(--green)}

.dtable{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.dtable th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
  font-weight:700;padding:11px 16px;border-bottom:1px solid var(--line);background:var(--panel-2)}
.dtable td{padding:13px 16px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.dtable tr:last-child td{border-bottom:none}
.dtable tbody tr{cursor:pointer}
.dtable tbody tr:hover{background:var(--panel-2)}
.dt-kunde{display:flex;align-items:center;gap:10px;font-weight:600}
.dt-progress{display:flex;align-items:center;gap:8px;min-width:120px}
.dt-progress .progress{width:70px;flex:0 0 70px}

/* modal */
.scrim{position:fixed;inset:0;background:rgba(22,26,33,.42);display:grid;place-items:center;z-index:50;
  backdrop-filter:blur(2px);animation:fade .15s ease}
.modal{background:#fff;border-radius:14px;width:520px;max-width:calc(100vw - 40px);box-shadow:0 24px 60px rgba(15,20,30,.3);
  animation:pop .16s ease;max-height:calc(100vh - 60px);overflow-y:auto}
.modal-head{padding:20px 24px 0;display:flex;align-items:center;gap:12px}
.modal-head h2{margin:0;font-size:18px;font-weight:700;letter-spacing:-.01em}
.modal-body{padding:18px 24px}
.modal-foot{padding:14px 24px 20px;display:flex;gap:10px;justify-content:flex-end}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.98)}}

/* form */
.field{margin-bottom:16px}
.field > label{display:block;font-weight:600;font-size:12.5px;margin-bottom:6px;color:var(--ink-2)}
.field .hint{font-size:11.5px;color:var(--muted);margin-top:5px;font-family:var(--mono)}
.input{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;outline:none;transition:.12s}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.form-grid{display:grid;gap:14px}
.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.inline-form{display:flex;gap:10px;align-items:flex-start}
.inline-form .input{flex:1}
.input.mono{font-family:var(--mono)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.swatches{display:flex;gap:8px;flex-wrap:wrap}
.swatch{width:26px;height:26px;border-radius:7px;border:2px solid transparent;cursor:pointer}
.swatch.sel{border-color:var(--ink);box-shadow:0 0 0 2px #fff inset}

/* settings list */
.req-list{display:flex;flex-direction:column;gap:8px}
.req-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--line);border-radius:9px;background:var(--panel-2)}
.req-row .fn{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);margin-top:2px}

/* misc */
.section-title{font-size:13px;font-weight:700;color:var(--ink);margin:0 0 12px;display:flex;align-items:center;gap:9px}
.muted{color:var(--muted)}
.spacer{height:22px}
.empty-state{text-align:center;padding:70px 20px;color:var(--muted)}
.empty-state .es-ico{width:60px;height:60px;border-radius:16px;background:var(--panel);border:1px solid var(--line);
  display:grid;place-items:center;margin:0 auto 16px;color:var(--muted)}
.divider{height:1px;background:var(--line-2);margin:22px 0}
.kbd{font-family:var(--mono);font-size:11px;background:#eef0f3;border:1px solid var(--line);border-radius:5px;padding:1px 5px}
a.link{color:var(--accent-ink);font-weight:600;text-decoration:none}
a.link:hover{text-decoration:underline}

/* ============ Damba — Posteingang ============ */
.damba{flex:1;min-height:0;display:flex}
.damba-list{width:380px;flex:0 1 380px;min-width:300px;border-right:1px solid var(--line);background:var(--panel);display:flex;flex-direction:column;min-height:0}
.damba-filter{padding:14px 16px;border-bottom:1px solid var(--line-2)}
.damba-filter .seg{width:100%}
.damba-filter .seg button{flex:1;justify-content:center;display:inline-flex;align-items:center;gap:6px;padding:7px 6px}
.seg-n{font-family:var(--mono);font-size:10.5px;font-weight:700;background:rgba(20,25,35,.08);border-radius:100px;padding:1px 6px;color:inherit}
.damba-filter .seg button.on .seg-n{background:rgba(255,255,255,.28)}
.mail-scroll{flex:1;overflow-y:auto}

.mail-row{display:flex;gap:11px;padding:13px 17px;border-bottom:1px solid var(--line-2);cursor:pointer;transition:.1s}
.mail-row:hover{background:var(--panel-2)}
.mail-row.active{background:var(--accent-bg)}
.mail-row.active{box-shadow:inset 3px 0 0 var(--accent)}
.mail-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:6px;flex:0 0 auto}
.mail-main{min-width:0;flex:1}
.mail-top{display:flex;align-items:baseline;gap:8px}
.mail-from{font-size:13.5px;color:var(--ink-2);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.mail-row.unread .mail-from{color:var(--ink)}
.mail-time{font-family:var(--mono);font-size:11px;color:var(--muted);flex:0 0 auto}
.mail-subj{font-size:13px;color:var(--ink);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mail-row.unread .mail-subj{font-weight:700}
.mail-snippet{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.45;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mail-tags{display:flex;align-items:center;gap:7px;margin-top:8px;flex-wrap:wrap}
.kunde-tag{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--ink-2);
  background:var(--panel-2);border:1px solid var(--line);border-radius:7px;padding:2px 8px}
.kunde-tag.none{color:var(--muted);border-style:dashed}
.kunde-tag .kt-ticker{font-family:var(--mono);font-size:10px;color:var(--muted)}
.mail-clip{display:inline-flex;align-items:center;gap:3px;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--muted)}
.mail-state-mini{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:6px;margin-left:auto}
.mail-state-mini.done{background:var(--green-bg);color:var(--green)}

/* Leseansicht */
.damba-reader{flex:1 1 0;min-width:0;display:flex;min-height:0;background:var(--bg)}
.reader-scroll{flex:1;overflow-y:auto;min-width:0}
.reader-inner{max-width:760px;padding:26px clamp(20px,3.4vw,34px) 60px}
.reader-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.reader-subj{font-size:20px;font-weight:700;letter-spacing:-.01em;line-height:1.25;flex:1;min-width:0;text-wrap:balance;overflow-wrap:anywhere}
.reader-meta{display:flex;align-items:center;gap:13px;flex-wrap:wrap;padding:14px 16px;background:var(--panel);border:1px solid var(--line);border-radius:11px}
.rm-avatar{width:40px;height:40px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;
  background:var(--accent);color:#fff;font-weight:700;font-size:16px}
.rm-row{font-size:13px;display:flex;align-items:baseline;gap:7px;line-height:1.7;flex-wrap:wrap}
.rm-key{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);width:26px;flex:0 0 auto}
.rm-val.strong{font-weight:600;color:var(--ink)}
.rm-addr{font-family:var(--mono);font-size:11.5px;color:var(--muted);word-break:break-all}
.rm-time{font-family:var(--mono);font-size:11.5px;color:var(--muted);align-self:flex-start;white-space:nowrap;flex:0 0 auto;margin-left:auto}

.reader-assign{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:14px}
.ra-left{display:flex;align-items:center;gap:9px;flex:1;min-width:240px}
.ra-label{font-size:12px;font-weight:600;color:var(--ink-2);white-space:nowrap}
.ra-dot{width:11px;height:11px;border-radius:4px;flex:0 0 auto}
.ra-select{padding:7px 10px;max-width:300px;font-size:13px}

.reader-body{font-size:14px;line-height:1.7;color:var(--ink-2);white-space:pre-wrap;text-wrap:pretty}

.reader-att{margin-top:30px}
.att-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:10px}
.att-card{display:flex;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--line);border-radius:10px;background:var(--panel)}
.att-main{min-width:0;flex:1}
.att-name{font-family:var(--mono);font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.att-ext{font-size:11px;color:var(--muted);margin-top:2px}

/* ============ Porto / Kosten ============ */
.porto-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,.7fr);gap:16px}
.porto-grid.single{grid-template-columns:1fr}
.porto-drop{display:flex;align-items:center;gap:14px;border:1px dashed #b8c8cc;background:var(--panel-2);border-radius:11px;padding:16px}
.porto-drop.drag{background:var(--accent-bg);border-color:var(--accent)}
.porto-upload-feedback{display:flex;align-items:flex-start;gap:10px;margin-top:12px;border:1px solid var(--line);border-radius:10px;padding:11px 12px;background:var(--panel-2);font-size:13px}
.porto-upload-feedback b{display:block;margin-bottom:3px}
.porto-upload-feedback div div{color:var(--muted);font-family:var(--mono);font-size:12px;overflow-wrap:anywhere}
.porto-upload-feedback.ok{background:var(--green-bg);border-color:#bfe4d1;color:var(--green)}
.porto-upload-feedback.warn{background:#fff8e8;border-color:#f0d59b;color:#9a6500}
.porto-upload-feedback.error{background:#fff1ef;border-color:#f3c6bf;color:var(--red)}
.porto-upload-feedback.loading{background:var(--accent-bg);border-color:#b9d9dd;color:var(--accent)}
.porto-import-list{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.porto-import-row{display:flex;align-items:center;gap:9px;border:1px solid var(--line-2);border-radius:8px;padding:8px 10px;background:#fff}
.porto-import-row .fn{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.porto-kpis,.porto-sum-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.porto-kpi{position:relative;border:1px solid var(--line);border-radius:9px;background:var(--panel-2);padding:11px 12px}
.porto-kpi span{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:6px}
.porto-kpi b{font-family:var(--mono);font-size:20px;color:var(--ink)}
.porto-kpi .mini-action{border:0;background:transparent;color:var(--accent);font-weight:700;display:inline-flex;align-items:center;gap:5px;cursor:pointer;padding:0}
.porto-kpi .mini-action.icon-only{position:absolute;top:10px;right:10px;width:28px;height:28px;border:1px solid var(--line);border-radius:7px;justify-content:center;background:#fff;color:var(--ink-2)}
.porto-kpi .mini-action.icon-only:hover{background:var(--accent-bg);color:var(--accent);border-color:#b9d9dd}
.porto-kpi.green{background:var(--green-bg);border-color:#c2e7d5}
.porto-kpi.amber{background:#fff8e8;border-color:#f0d59b}
.porto-kpi.red{background:#fff1ef;border-color:#f3c6bf}
.porto-month-grid{display:grid;grid-template-columns:260px minmax(0,1fr);gap:18px}
.porto-month-list{display:flex;flex-direction:column;gap:8px}
.porto-month{border:1px solid var(--line);border-radius:9px;background:#fff;text-align:left;padding:10px 12px;cursor:pointer;color:var(--ink)}
.porto-month:hover{background:var(--panel-2)}
.porto-month.active{background:var(--accent-bg);border-color:#a8d4d9;box-shadow:inset 3px 0 0 var(--accent)}
.porto-month span{display:block;font-weight:700;margin-bottom:4px}
.porto-month b{font-family:var(--mono);font-size:16px}
.porto-month small{display:block;color:var(--muted);margin-top:3px}
.porto-month-detail{min-width:0}
.porto-filterbar{display:grid;grid-template-columns:minmax(145px,.8fr) minmax(180px,1.2fr) minmax(220px,1.5fr) 92px;gap:10px;align-items:end;margin-bottom:12px}
.porto-filterbar .field{margin:0}
.porto-filterbar .input{height:39px}
.porto-table{width:100%;margin-top:16px}
.porto-table .center,.porto-table th.center{text-align:center}
.porto-table .num,.porto-table th.num{text-align:right;font-family:var(--mono);white-space:nowrap}
.porto-table td .kunde-dot{display:inline-block;vertical-align:middle;margin-right:8px}
.porto-position-table{table-layout:auto}
.porto-position-table .date-col{width:1%;white-space:nowrap}
.porto-position-table .doc-col{width:1%;white-space:nowrap}
.porto-position-table .amount-col{width:1%;white-space:nowrap}
.porto-position-table .porto-file-col{width:auto}
.porto-hv-swatch{display:inline-block;width:14px;height:14px;border-radius:4px;border:1px solid rgba(0,0,0,.08);vertical-align:middle}
.porto-hv-name{display:inline-flex;align-items:center;gap:9px;white-space:nowrap}
.q-tooltip{position:relative;display:inline-flex;align-items:center;max-width:100%}
.q-tooltip:after{content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + 9px);transform:translateX(-50%);background:#111820;color:#fff;border-radius:7px;padding:7px 9px;font-size:12px;font-weight:600;line-height:1.35;white-space:nowrap;box-shadow:0 10px 24px rgba(15,22,30,.22);opacity:0;pointer-events:none;transition:opacity .12s ease, transform .12s ease;z-index:30}
.q-tooltip:before{content:"";position:absolute;left:50%;bottom:calc(100% + 4px);transform:translateX(-50%);border:5px solid transparent;border-top-color:#111820;opacity:0;pointer-events:none;transition:opacity .12s ease;z-index:31}
.q-tooltip:hover:after{opacity:1;transform:translateX(-50%) translateY(-2px)}
.q-tooltip:hover:before{opacity:1}
.porto-pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;flex-wrap:wrap}
.pager-actions{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.porto-hv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:12px}
.porto-hv-card{border:1px solid var(--line);border-radius:10px;background:var(--panel-2);padding:13px;display:flex;flex-direction:column;gap:10px}
.porto-hv-card .kunde-dot{display:inline-block;vertical-align:middle;margin-right:8px}
.porto-hv-total{font-family:var(--mono);font-size:24px;font-weight:700;color:var(--ink)}
.porto-bar{height:8px;background:#e4eaec;border-radius:999px;overflow:hidden}
.porto-bar span{display:block;height:100%;background:var(--accent);border-radius:999px}
.porto-rule{display:grid;grid-template-columns:22px 180px minmax(0,1fr) auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:9px;background:var(--panel-2);padding:11px 12px;margin-bottom:8px}
.spin{display:inline-flex;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

@media (max-width: 900px){
  .porto-grid,.porto-month-grid{grid-template-columns:1fr}
  .porto-filterbar{grid-template-columns:1fr}
  .porto-kpis,.porto-sum-row{grid-template-columns:1fr}
  .porto-rule{grid-template-columns:22px 1fr}
  .porto-rule .pill{justify-self:start}
}
