:root{
  --accent:#1a56ff;--accent-dark:#1242c8;--accent-soft:#eaf0ff;
  --ink:#0f1729;--ink-soft:#475069;--line:#e3e8f2;--bg:#f6f8fc;--card:#fff;--surface:#fff;
  --hover:#f8faff;--code-bg:#f1f4fa;--placeholder:#9aa3b2;--field-hover-border:#c7cede;
  --ok:#16a34a;--ok-bg:#e7f7ee;--ok-ink:#15803d;--ok-border:#bbf7d0;
  --err-bg:#fdeeee;--err-ink:#b91c1c;--err-border:#fecaca;
  --danger-bg:#fdeeee;--danger-ink:#b91c1c;--danger-border:#f6c9c9;--danger-hover:#fbdcdc;
  --badge-on-bg:#e7f7ee;--badge-off-bg:#fdeeee;--badge-off-ink:#c0392b;
  --radius:14px;--shadow:0 1px 2px rgba(16,23,41,.04),0 8px 24px rgba(16,23,41,.06);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
/* Dunkles Theme: automatisch nach Geräteeinstellung ... */
@media (prefers-color-scheme: dark){
  :root{
    --accent:#5b82ff;--accent-dark:#3b6cff;--accent-soft:rgba(91,130,255,.16);
    --ink:#e7ebf5;--ink-soft:#9aa6bd;--line:#293247;--bg:#0d121e;--card:#151c2c;--surface:#1b2334;
    --hover:#1b2434;--code-bg:#1e2738;--placeholder:#6b7689;--field-hover-border:#3a445c;
    --ok:#34d399;--ok-bg:rgba(52,211,153,.14);--ok-ink:#6ee7b7;--ok-border:rgba(52,211,153,.32);
    --err-bg:rgba(248,113,113,.14);--err-ink:#fca5a5;--err-border:rgba(248,113,113,.32);
    --danger-bg:rgba(248,113,113,.14);--danger-ink:#fca5a5;--danger-border:rgba(248,113,113,.32);--danger-hover:rgba(248,113,113,.22);
    --badge-on-bg:rgba(52,211,153,.16);--badge-off-bg:rgba(248,113,113,.16);--badge-off-ink:#fca5a5;
    --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.45);
  }
}
/* Manuelle Wahl 'hell' überschreibt die Geräteeinstellung */
:root[data-theme="light"]{
  --accent:#1a56ff;--accent-dark:#1242c8;--accent-soft:#eaf0ff;
  --ink:#0f1729;--ink-soft:#475069;--line:#e3e8f2;--bg:#f6f8fc;--card:#fff;--surface:#fff;
  --hover:#f8faff;--code-bg:#f1f4fa;--placeholder:#9aa3b2;--field-hover-border:#c7cede;
  --ok:#16a34a;--ok-bg:#e7f7ee;--ok-ink:#15803d;--ok-border:#bbf7d0;
  --err-bg:#fdeeee;--err-ink:#b91c1c;--err-border:#fecaca;
  --danger-bg:#fdeeee;--danger-ink:#b91c1c;--danger-border:#f6c9c9;--danger-hover:#fbdcdc;
  --badge-on-bg:#e7f7ee;--badge-off-bg:#fdeeee;--badge-off-ink:#c0392b;
  --shadow:0 1px 2px rgba(16,23,41,.04),0 8px 24px rgba(16,23,41,.06);
}
/* Manuelle Wahl 'dunkel' überschreibt die Geräteeinstellung */
:root[data-theme="dark"]{
  --accent:#5b82ff;--accent-dark:#3b6cff;--accent-soft:rgba(91,130,255,.16);
  --ink:#e7ebf5;--ink-soft:#9aa6bd;--line:#293247;--bg:#0d121e;--card:#151c2c;--surface:#1b2334;
  --hover:#1b2434;--code-bg:#1e2738;--placeholder:#6b7689;--field-hover-border:#3a445c;
  --ok:#34d399;--ok-bg:rgba(52,211,153,.14);--ok-ink:#6ee7b7;--ok-border:rgba(52,211,153,.32);
  --err-bg:rgba(248,113,113,.14);--err-ink:#fca5a5;--err-border:rgba(248,113,113,.32);
  --danger-bg:rgba(248,113,113,.14);--danger-ink:#fca5a5;--danger-border:rgba(248,113,113,.32);--danger-hover:rgba(248,113,113,.22);
  --badge-on-bg:rgba(52,211,153,.16);--badge-off-bg:rgba(248,113,113,.16);--badge-off-ink:#fca5a5;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.45);
}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
.topbar{background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.topbar__inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:14px 24px}
.brand{display:flex;align-items:center;gap:10px;color:var(--ink);font-size:19px}.brand:hover{text-decoration:none}
.brand__mark{width:22px;height:22px;border-radius:6px;background:linear-gradient(135deg,var(--accent),#4f7bff);box-shadow:0 2px 6px rgba(26,86,255,.4)}
.brand__name strong{color:var(--accent)}.topnav{display:flex;align-items:center;gap:16px}
.pill{display:inline-flex;align-items:center;font-size:12px;font-weight:600;letter-spacing:.02em;background:var(--accent-soft);color:var(--accent-dark);padding:4px 10px;border-radius:999px}
.badge{font-size:12px;font-weight:600;padding:2px 9px;border-radius:999px}
.badge--on{background:var(--badge-on-bg);color:var(--ok)}.badge--off{background:var(--badge-off-bg);color:var(--badge-off-ink)}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;padding:10px 18px;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:.15s}
.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-dark);text-decoration:none}
.btn--ghost{background:transparent;border-color:var(--line);color:var(--ink-soft)}.btn--ghost:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.content{max-width:1100px;margin:32px auto;padding:0 24px}
.eyebrow{color:var(--accent);font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase}
h1{font-size:30px;margin:6px 0 4px;letter-spacing:-.02em}.lead{color:var(--ink-soft);margin:0 0 28px}
.grid{display:grid;gap:18px}.grid--stats{grid-template-columns:repeat(3,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.stat__label{color:var(--ink-soft);font-size:13px;font-weight:600}
.stat__value{font-size:36px;font-weight:700;letter-spacing:-.03em;margin-top:4px}.stat__value span{color:var(--accent)}
.section-title{margin:34px 0 14px;font-size:16px;font-weight:700}
table{width:100%;border-collapse:collapse;font-size:14px}
th{text-align:left;color:var(--ink-soft);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em;padding:10px 14px}
td{padding:12px 14px;border-top:1px solid var(--line)}tbody tr:hover{background:var(--hover)}
.login-wrap{min-height:70vh;display:grid;place-items:center}.login-card{width:100%;max-width:380px}.login-card h1{font-size:22px}
.field{margin-bottom:14px}.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.field input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:15px;font-family:var(--font)}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.error{background:var(--err-bg);color:var(--err-ink);padding:10px 13px;border-radius:10px;font-size:14px;margin-bottom:14px}
.footer{max-width:1100px;margin:40px auto;padding:0 24px;color:var(--ink-soft);font-size:13px}
@media(max-width:720px){.grid--stats{grid-template-columns:1fr}}
/* --- Erweiterungen: Banner, Formulare, Rollen --- */
.banner{padding:11px 14px;border-radius:10px;font-size:14px;margin-bottom:18px;font-weight:500}
.banner--ok{background:var(--ok-bg);color:var(--ok-ink);border:1px solid var(--ok-border)}
.banner--err{background:var(--err-bg);color:var(--err-ink);border:1px solid var(--err-border)}
.row{display:flex;gap:10px;align-items:center}
.row input,.row select{padding:10px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;font-family:var(--font)}
.row input:focus,.row select:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field select{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:15px;font-family:var(--font);background:var(--surface)}
.hint{color:var(--ink-soft);font-size:13px;margin:10px 0 0}
.check{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink);margin-top:6px}
.check input{width:16px;height:16px}
code{background:var(--code-bg);padding:2px 6px;border-radius:6px;font-size:13px}
/* --- Domain-Detail: Reiter + DNS-Tabelle --- */
.tabs{display:flex;gap:4px;border-bottom:2px solid var(--line);margin:18px 0 20px}
.tab{padding:10px 16px;font-size:14px;font-weight:600;color:var(--ink-soft);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-2px}
.tab:hover{color:var(--accent)}
.tab--on{color:var(--accent);border-bottom-color:var(--accent)}
table.dns td{vertical-align:top}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;word-break:break-all}
table.dns td.val{max-width:520px}
.rec-note{color:var(--ink-soft);font-size:11.5px;margin-top:3px;font-family:var(--font)}
.copy{padding:6px 10px;font-size:12.5px;white-space:nowrap}
/* --- Modernere Formularelemente + neue Komponenten --- */
input[type=text],input[type=password],input[type=number],input:not([type]),textarea,.row input,.field input,.field textarea,
.row select,.field select,select{
  appearance:none;-webkit-appearance:none;
  padding:11px 13px;border:1px solid var(--line);border-radius:11px;font-size:14.5px;
  font-family:var(--font);background:var(--surface);color:var(--ink);
  box-shadow:0 1px 2px rgba(16,24,40,.04);transition:border-color .15s,box-shadow .15s}
input::placeholder{color:var(--placeholder)}
input:hover,select:hover{border-color:var(--field-hover-border)}
input:focus,select:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 4px var(--accent-soft)}
select,.row select,.field select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231a56ff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:38px;cursor:pointer}
.field input,.field select{width:100%}
.ident{display:flex;align-items:center;gap:8px;padding-left:6px}
.ident__name{font-size:13.5px;color:var(--ink);font-weight:600;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cta{background:linear-gradient(180deg,var(--card), var(--accent-soft));border-color:var(--line)}
.mbx{padding:14px 16px}
.mbx + .mbx{margin-top:10px}
.mbx__actions input{padding:8px 10px;font-size:13px}
.mbx__actions .btn{padding:8px 12px;font-size:13px}
.btn--danger{background:var(--danger-bg);color:var(--danger-ink);border:1px solid var(--danger-border)}
.btn--danger:hover{background:var(--danger-hover)}
/* --- Webmail --- */
.wm{display:grid;grid-template-columns:200px 1fr;gap:14px;margin-top:14px}
.wm__side{padding:10px;align-self:start}
.wm__folder{display:block;padding:9px 12px;border-radius:9px;color:var(--ink);font-size:14px;font-weight:500;text-decoration:none}
.wm__folder:hover{background:var(--accent-soft);text-decoration:none}
.wm__folder--on{background:var(--accent);color:#fff}
.wm__folder--on:hover{background:var(--accent-dark)}
.wm__head{padding:13px 16px;border-bottom:1px solid var(--line);font-weight:600;color:var(--ink-soft);font-size:13px}
table.wm__list{width:100%;border-collapse:collapse}
table.wm__list td{padding:11px 14px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}
table.wm__list tr:last-child td{border-bottom:none}
table.wm__list tr:hover{background:var(--hover)}
.wm__from{width:230px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:230px}
.wm__subj a{color:var(--ink);text-decoration:none}
.wm__subj a:hover{color:var(--accent)}
.wm__date{width:140px;color:var(--ink-soft);text-align:right;white-space:nowrap}
.wm__unread .wm__from,.wm__unread .wm__subj a{font-weight:700;color:var(--ink)}
.wm__unread .wm__subj a::before{content:"●";color:var(--accent);font-size:10px;margin-right:7px;vertical-align:middle}
.wm__body{width:100%;min-height:420px;border:none;background:#fff;border-radius:8px}
.wm__text{white-space:pre-wrap;word-wrap:break-word;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13.5px;margin:0;color:var(--ink)}
textarea{width:100%;resize:vertical;min-height:160px;line-height:1.5}
@media(max-width:760px){.wm{grid-template-columns:1fr}.wm__from{display:none}}

/* --- Theme-Umschalter --- */
.theme-toggle{padding:8px 12px;font-size:13px;gap:6px}
.theme-toggle svg{width:16px;height:16px}
/* --- Webmail: Ordnerzaehler + Zeilenaktionen --- */
.wm__folder{display:flex;align-items:center;justify-content:space-between}
.wm__count{background:var(--accent-soft);color:var(--accent-dark);font-size:11px;font-weight:700;border-radius:999px;padding:1px 8px;margin-left:8px}
.wm__folder--on .wm__count{background:rgba(255,255,255,.25);color:#fff}
.wm__row-actions{white-space:nowrap;text-align:right}
.wm__row-actions form{display:inline}
.linkbtn{background:none;border:none;color:var(--ink-soft);font-size:12.5px;cursor:pointer;padding:2px 6px;font-family:var(--font)}
.linkbtn:hover{color:var(--accent);text-decoration:underline}
.linkbtn--danger:hover{color:var(--danger-ink)}
/* --- Webmail 3-Spalten + Vorschau --- */
.wm--3{grid-template-columns:185px minmax(260px,1fr) minmax(320px,1.5fr)}
@media(max-width:1100px){.wm--3{grid-template-columns:170px 1fr}.wm__preview{display:none}}
@media(max-width:760px){.wm--3{grid-template-columns:1fr}.wm__side{display:flex;flex-wrap:wrap;gap:6px}}
.wm__main{align-self:start}
table.wm__list tr[data-uid]{cursor:pointer}
table.wm__list tr.is-active{background:var(--accent-soft)}
table.wm__list tr.is-active .wm__subj{color:var(--accent-dark)}
.wm__cell{display:block}
.wm__line1{display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.wm__line1 .wm__from{font-weight:600;color:var(--ink)}
.wm__line1 .wm__date{color:var(--ink-soft);font-size:12px;white-space:nowrap}
.wm__subj{color:var(--ink-soft);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:46ch}
.wm__unread .wm__from,.wm__unread .wm__subj{font-weight:700;color:var(--ink)}
.wm__unread .wm__line1 .wm__from::before{content:"●";color:var(--accent);font-size:10px;margin-right:6px;vertical-align:middle}
.wm__preview{align-self:start;min-height:420px;padding:0;overflow:hidden}
.wm__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:420px;color:var(--ink-soft);text-align:center;padding:24px}
.wm__empty-ic{font-size:34px;opacity:.5}
.wm__msg{display:flex;flex-direction:column;height:100%}
.wm__msg-head{padding:18px 20px 6px}
.wm__msg-head h2{margin:0 0 4px;font-size:19px}
.wm__msg-meta{margin:0;color:var(--ink-soft);font-size:13px}
.wm__msg-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding:10px 20px;border-bottom:1px solid var(--line)}
.wm__msg-actions form{display:inline}
.wm__msg-body{padding:16px 20px;overflow:auto}
.btn--sm{padding:6px 10px;font-size:13px}
/* --- Migrations-Banner --- */
.mig{border-radius:var(--radius);padding:14px 16px;margin:14px 0;border:1px solid var(--line);background:var(--card)}
.mig--running{border-color:var(--accent);background:var(--accent-soft)}
.mig--done{border-color:var(--ok-border);background:var(--ok-bg);color:var(--ok-ink)}
.mig--err{border-color:var(--err-border);background:var(--err-bg);color:var(--err-ink)}
.mig__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.mig__pct{font-weight:700;color:var(--accent-dark)}
.mig__bar{height:8px;border-radius:99px;background:rgba(0,0,0,.12);overflow:hidden}
.mig__bar>span{display:block;height:100%;background:var(--accent);border-radius:99px;transition:width .6s ease}
.mig .hint{margin:8px 0 0}
.mig-mini{display:flex;align-items:center;gap:8px;margin-top:6px}
.mig-mini__bar{display:inline-block;width:120px;height:6px;border-radius:99px;background:rgba(0,0,0,.12);overflow:hidden}
.mig-mini__bar>span{display:block;height:100%;background:var(--accent)}
.mig-mini__txt{font-size:12.5px;color:var(--ink-soft)}
.mig-mini--done{font-size:12.5px;color:var(--ok-ink);margin-top:6px}
.mig-mini--err{font-size:12.5px;color:var(--err-ink);margin-top:6px}
.check{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink)}
.check input{width:auto}
/* --- Webmail Redesign: Symbolleiste + klarere 3-Spalten --- */
.wm-toolbar{display:flex;align-items:center;gap:12px;margin:6px 0 12px;flex-wrap:wrap}
.wm-search{flex:1;min-width:220px;max-width:520px;display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:8px 14px;color:var(--ink-soft)}
.wm-search input{flex:1;background:none;border:none;outline:none;color:var(--ink);font:inherit;min-width:0}
.wm-search__clear{color:var(--ink-soft);text-decoration:none;font-size:18px;line-height:1;padding:0 4px}
.wm-search__clear:hover{color:var(--accent)}
.wm-toolbar__actions{display:flex;gap:8px}
.wm--3{grid-template-columns:200px 340px 1fr}
@media(max-width:1100px){.wm--3{grid-template-columns:180px 1fr}.wm__preview{display:none}}
@media(max-width:760px){.wm--3{grid-template-columns:1fr}.wm__side{display:flex;flex-wrap:wrap;gap:6px}}
.wm__side-head{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);padding:4px 12px 8px}
.wm__main{align-self:start;padding:0;overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 220px)}
.wm__head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--line);font-weight:600;color:var(--ink);font-size:14px}
.wm__head-cnt{font-size:12px;font-weight:700;color:var(--accent-dark);background:var(--accent-soft);border-radius:999px;padding:1px 9px}
.wm__list{overflow:auto}
.wm__item{display:flex;gap:8px;justify-content:space-between;align-items:flex-start;padding:11px 14px;border-bottom:1px solid var(--line);cursor:pointer}
.wm__item:last-child{border-bottom:none}
.wm__item:hover{background:var(--hover)}
.wm__item.is-active{background:var(--accent-soft)}
.wm__item.is-active .wm__subj{color:var(--accent-dark)}
.wm__item-main{min-width:0;flex:1}
.wm__line1{display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.wm__line1 .wm__from{font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wm__line1 .wm__date{color:var(--ink-soft);font-size:12px;white-space:nowrap;flex-shrink:0}
.wm__subj{color:var(--ink-soft);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wm__unread .wm__from,.wm__unread .wm__subj{font-weight:700;color:var(--ink)}
.wm__unread .wm__from::before{content:"●";color:var(--accent);font-size:9px;margin-right:6px;vertical-align:middle}
.wm__none{padding:18px 14px;color:var(--ink-soft)}
.wm__row-actions{display:flex;flex-direction:column;gap:2px;align-items:flex-end;opacity:0;transition:opacity .12s}
.wm__item:hover .wm__row-actions,.wm__item.is-active .wm__row-actions{opacity:1}
.wm__row-actions form{display:inline}
.wm__preview{align-self:start;min-height:420px;max-height:calc(100vh - 220px);padding:0;overflow:hidden}
/* --- Passkey-Liste --- */
.pk-list{display:flex;flex-direction:column;gap:8px;margin:10px 0}
.pk-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--surface)}
.pk-item__meta{font-size:12.5px;color:var(--ink-soft)}
/* --- Webmail: Aufteilung angelehnt an webmail.php (mailcore-Design) --- */
.wm--3{grid-template-columns:236px 360px 1fr}
@media(max-width:1100px){.wm--3{grid-template-columns:200px 1fr}.wm__preview{display:none}}
@media(max-width:760px){.wm--3{grid-template-columns:1fr}.wm__side{display:flex;flex-wrap:wrap;gap:6px}}
.wm__head{position:sticky;top:0;z-index:2;background:var(--card)}
.wm__head-ttl{font-weight:800}
.wm__item{position:relative}
.wm__unread .wm__from::before{content:none}
.wm__item.wm__unread{box-shadow:inset 3px 0 0 var(--accent)}
/* Lesebereich im read-wrap-Stil */
.wm__preview .read-wrap{padding:18px 22px;max-width:860px}
.read-subj{font-size:20px;font-weight:800;line-height:1.25;margin:0 0 10px}
.read-meta{display:flex;flex-direction:column;gap:3px;font-size:13px;color:var(--ink-soft);border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:14px}
.read-meta b{color:var(--ink)}
.read-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:14px}
.read-actions form{display:inline}
.read-body{width:100%;min-height:440px;border:0;background:#fff;border-radius:10px}
.read-body--text{min-height:0;background:var(--code-bg);color:var(--ink);white-space:pre-wrap;word-break:break-word;padding:14px;border-radius:10px;font-size:14px}
/* ===== Vollbild-Webmail (Aufteilung wie webmail.php, mailcore-Design) ===== */
.wm-body{margin:0;height:100vh;height:100dvh;overflow:hidden;background:var(--bg)}
.wm-app{display:flex;flex-direction:column;height:100vh;height:100dvh}
.wm-top{display:flex;align-items:center;gap:12px;padding:9px 16px;background:var(--surface);border-bottom:1px solid var(--line);flex-shrink:0}
.wm-top .brand{flex-shrink:0}
.wm-spacer{flex:1}
.wm-search{flex:1;max-width:460px;display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:7px 14px;color:var(--ink-soft)}
.wm-search input{flex:1;background:none;border:none;outline:none;color:var(--ink);font:inherit;min-width:0}
.wm-search__clear{color:var(--ink-soft);text-decoration:none;font-size:18px;line-height:1;padding:0 4px}
.wm-search__clear:hover{color:var(--accent)}
.wm-iconbtn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:10px;text-decoration:none;flex-shrink:0}
.wm-iconbtn:hover{border-color:var(--accent);color:var(--accent)}
.wm-iconbtn--danger:hover{border-color:var(--danger-ink);color:var(--danger-ink)}
.wm-menu{display:none}
.wm-migbar{padding:0 16px;flex-shrink:0}
.wm-migbar .mig{margin:8px 0}
.wm-main{flex:1;display:grid;grid-template-columns:248px 380px 1fr;min-height:0}
.wm-side,.wm-list,.wm-read{min-height:0;overflow:auto}
.wm-side{background:var(--surface);border-right:1px solid var(--line);padding:8px}
.wm-list{background:var(--bg);border-right:1px solid var(--line)}
.wm-read{background:var(--surface)}
.wm-side-head{font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);padding:6px 10px}
/* Ordnerbaum */
.wm-fold{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:9px;color:var(--ink);text-decoration:none;font-size:14px;user-select:none}
.wm-fold:hover{background:var(--hover);text-decoration:none}
.wm-fold--active{background:var(--accent-soft);color:var(--accent-dark);font-weight:700}
.wm-twist{display:grid;place-items:center;width:16px;height:16px;flex-shrink:0;border:0;background:none;color:var(--ink-soft);padding:0;cursor:pointer;transition:transform .15s}
.wm-twist.open{transform:rotate(90deg)}
.wm-twist--empty{cursor:default}
.wm-fold__ic{display:grid;place-items:center;width:18px;height:18px;color:var(--ink-soft);flex-shrink:0}
.wm-fold--active .wm-fold__ic{color:var(--accent)}
.wm-fold__lbl{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wm-fold__cnt{font-size:11.5px;font-weight:700;background:var(--accent);color:#fff;border-radius:999px;padding:1px 8px;flex-shrink:0}
/* Liste */
.wm-listhead{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--line);background:var(--bg)}
.wm-listhead__ttl{font-weight:800}
.wm-listhead__cnt{font-size:12.5px;color:var(--ink-soft)}
.wm-mrow{position:relative;display:flex;flex-direction:column;gap:2px;padding:11px 16px;border-bottom:1px solid var(--line);cursor:pointer}
.wm-mrow:hover{background:var(--hover)}
.wm-mrow.is-active{background:var(--accent-soft)}
.wm-mrow--unseen{box-shadow:inset 3px 0 0 var(--accent)}
.wm-mrow__l1{display:flex;align-items:center;gap:8px}
.wm-mrow__from{font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}
.wm-mrow__date{font-size:12px;color:var(--ink-soft);flex-shrink:0}
.wm-mrow__subj{font-size:13.5px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wm-mrow--unseen .wm-mrow__from,.wm-mrow--unseen .wm-mrow__subj{font-weight:800;color:var(--ink)}
.wm-mrow__act{display:none;gap:10px;margin-top:5px}
.wm-mrow:hover .wm-mrow__act,.wm-mrow.is-active .wm-mrow__act{display:flex}
.wm-mrow__act form{display:inline}
/* Lesebereich */
.wm-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;height:100%;min-height:300px;color:var(--ink-soft);text-align:center;padding:28px}
.wm-empty__ic{font-size:34px;opacity:.5}
.wm-read .read-wrap{padding:20px 26px;max-width:880px}
/* Responsive */
@media(max-width:1100px){
  .wm-main{grid-template-columns:230px 1fr}
  .wm-read{display:none}
  .wm-read.show{display:block;position:fixed;inset:120px 0 0 0;z-index:40;border-top:1px solid var(--line)}
}
@media(max-width:760px){
  .wm-menu{display:inline-flex}
  .wm-main{grid-template-columns:1fr}
  .wm-side{position:fixed;inset:56px 0 0 0;width:270px;z-index:50;transform:translateX(-100%);transition:transform .2s;box-shadow:var(--shadow)}
  .wm-side.show{transform:none}
  .wm-search{max-width:none}
}
/* --- Server-Auslastung (Dashboard) --- */
.gauge{height:8px;border-radius:99px;background:var(--code-bg);overflow:hidden;margin:8px 0 6px}
.gauge>span{display:block;height:100%;width:0;border-radius:99px;background:var(--accent);transition:width .6s ease}
.gauge>span.ok{background:var(--ok)}
.gauge>span.warn{background:#f59e0b}
.gauge>span.danger{background:var(--danger-ink)}
/* --- Lesebereich: volle Restbreite, Skalierung, externe Bilder --- */
.wm-read .read-wrap{max-width:none;width:100%;padding:18px clamp(16px,2vw,40px)}
.wm-read .read-body{width:100%;min-height:0;border:0;background:#fff;border-radius:10px;display:block}
.wm-read .read-body--text{min-height:0;font-size:clamp(14px,1.04vw,17px);line-height:1.55;background:var(--code-bg);color:var(--ink);white-space:pre-wrap;word-break:break-word;padding:16px clamp(14px,1.4vw,22px);border-radius:10px}
.read-subj{font-size:clamp(19px,1.5vw,26px)}
.read-imgbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;background:var(--code-bg);border:1px solid var(--line);border-radius:10px;padding:9px 13px;margin-bottom:12px;font-size:13px;color:var(--ink-soft)}
.read-imgbar--on{background:var(--accent-soft)}

/* Externe Migration je Postfach */
.mbx__mig{margin-top:10px;border-top:1px solid var(--line);padding-top:10px}
.mbx__mig summary{cursor:pointer;color:var(--accent);font-size:13px;font-weight:600;list-style:none}
.mbx__mig summary::-webkit-details-marker{display:none}
.mbx__mig summary::before{content:"▸ ";color:var(--ink-soft)}
.mbx__mig[open] summary::before{content:"▾ "}

/* Navigations-Dropdown (Einstellungen) */
.navdrop{position:relative;display:inline-flex}
.navdrop>details{position:relative}
.navdrop>details>summary{list-style:none;cursor:pointer;color:var(--ink-soft);font-weight:500}
.navdrop>details>summary::-webkit-details-marker{display:none}
.navdrop>details>summary::after{content:"▾";font-size:.75em;margin-left:5px;opacity:.7}
.navdrop>details[open]>summary{color:var(--ink)}
.navdrop>details>summary:hover{color:var(--ink)}
.navdrop__menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--card);border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);min-width:200px;padding:6px;z-index:120;display:flex;flex-direction:column;gap:2px}
.navdrop__menu a{padding:9px 12px;border-radius:8px;color:var(--ink);white-space:nowrap;font-weight:500}
.navdrop__menu a:hover{background:var(--hover)}

/* Webmail-Pager */
.wm-pager{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;border-top:1px solid var(--line)}
.wm-pager__info{font-size:13px;color:var(--ink-soft)}
.wm-pager .is-disabled{opacity:.4;pointer-events:none}

/* Server-Auslastung: klickbare Karten + Verlaufs-Modal */
.sys-card{cursor:pointer;position:relative}
.sys-card:hover{border-color:var(--accent)}
.sys-card__more{position:absolute;top:10px;right:12px;font-size:11px;color:var(--ink-soft);opacity:.75}
.sysmodal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}
.sysmodal[hidden]{display:none}
.sysmodal__box{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);max-width:980px;width:100%;padding:18px;max-height:92vh;overflow:auto}
.sysmodal__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.sysmodal__row{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.sysmodal__row label{font-size:13px;color:var(--ink-soft);display:flex;gap:6px;align-items:center}
.sysmodal__row input{padding:6px 8px;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--ink)}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{background:transparent;border:0;padding:7px 13px;color:var(--ink-soft);cursor:pointer;font:inherit}
.seg button + button{border-left:1px solid var(--line)}
.seg button.on{background:var(--accent);color:#fff}
.sysmodal canvas{width:100%;height:auto;border:1px solid var(--line);border-radius:12px}

/* Marke: Logo neben der Wortmarke */
.brand__logo{width:26px;height:26px;display:block;flex-shrink:0}
.wm-top .brand__logo{width:24px;height:24px}
/* Hinweis auf neue Nachrichten (Webmail) */
.wm-new{display:inline-flex;align-items:center;gap:7px;margin:0 0 8px;padding:7px 12px;border:0;border-radius:10px;background:var(--accent);color:#fff;font:inherit;font-weight:600;cursor:pointer;box-shadow:0 2px 8px rgba(26,86,255,.35)}

/* Eingabe mit fest angehängter Domain (Postfach anlegen) + Passwort-Generator */
.inp-affix{display:inline-flex;align-items:stretch;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--input,transparent)}
.inp-affix input{border:0;outline:none;background:transparent;color:var(--ink);padding:9px 10px;flex:1;min-width:0;font:inherit}
.inp-affix__suf{display:inline-flex;align-items:center;padding:0 11px;background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--ink-soft);font-weight:600;white-space:nowrap;border-left:1px solid var(--line)}
