:root {
    --bg: #f4f6f8;
    --panel: #ffffff;
    --text: #15202b;
    --muted: #5d6b78;
    --line: #dbe2ea;
    --accent: #1f6feb;
    --accent-soft: #dbe7f8;
    --ok: #18794e;
    --bad: #b42318;
    --warn: #9a6700;
    --shadow: rgba(0,0,0,0.05);
    --topbar: #101820;
    --topbar-text: #ffffff;
}

:root[data-theme="dark"] {
    --bg: #0d1117;
    --panel: #161b22;
    --text: #e6edf3;
    --muted: #9da7b3;
    --line: #30363d;
    --accent: #2f81f7;
    --accent-soft: #1f2a3a;
    --ok: #3fb950;
    --bad: #f85149;
    --warn: #d29922;
    --shadow: rgba(0,0,0,0.22);
    --topbar: #06090f;
    --topbar-text: #e6edf3;
}

* { box-sizing: border-box; }
body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    line-height: 1.5;
}

.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 22px;
    background: var(--topbar);
    color: var(--topbar-text);
}
.topbar span { color: var(--muted); margin-left: 12px; }
.top-actions { display: flex; gap: 10px; align-items: center; }
.top-actions form { margin: 0; }
.page { max-width: 1280px; margin: 0 auto; padding: 24px; }

.login-card, .card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 20px;
    box-shadow: 0 8px 24px var(--shadow);
}
.login-card { max-width: 460px; margin: 60px auto; }
.card-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.count { min-width: 32px; text-align: center; border-radius: 999px; background: var(--accent-soft); color: var(--text); padding: 4px 9px; font-weight: 800; }

.tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 18px;
}
.tab-button, button {
    border: 0;
    border-radius: 10px;
    padding: 10px 14px;
    background: var(--accent);
    color: #fff;
    cursor: pointer;
    font-weight: 650;
}
.tab-button { background: var(--accent-soft); color: var(--text); }
.tab-button.active { background: var(--accent); color: #fff; }
button.small { padding: 7px 10px; font-size: 0.9rem; }
button.danger { background: var(--bad); }
button.primary { background: var(--ok); }
button.secondary { background: var(--accent-soft); color: var(--text); }

.tab-panel { display: none; }
.tab-panel.active { display: block; }
.grid { display: grid; gap: 18px; margin-bottom: 18px; }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.stack-list { display: grid; grid-template-columns: 1fr; gap: 18px; margin-bottom: 18px; }
.wide { margin-top: 18px; }
.wide-table { overflow-x: auto; }

h1 { margin: 0 0 16px; }
h2 { margin-top: 0; }
h3 { margin-bottom: 10px; }
label { display: block; font-weight: 650; margin-bottom: 14px; }
input, select {
    width: 100%;
    display: block;
    margin-top: 6px;
    padding: 11px;
    border: 1px solid var(--line);
    border-radius: 10px;
    font: inherit;
    background: var(--panel);
    color: var(--text);
}
small { display: block; color: var(--muted); font-weight: 400; margin-top: 4px; }
.checkbox input { width: auto; display: inline-block; margin-right: 8px; }

.message {
    border-radius: 12px;
    padding: 14px;
    margin-bottom: 18px;
    border: 1px solid var(--line);
    background: var(--panel);
}
.message pre { white-space: pre-wrap; margin: 0 0 10px; }
.message.success { border-color: #58a878; background: rgba(24, 121, 78, 0.12); }
.message.error { border-color: #c5524a; background: rgba(180, 35, 24, 0.10); }
.inline-actions { display: inline-block; margin-right: 8px; }

.help { color: var(--text); }
.compact-help p { margin: 8px 0; }
dl { margin: 0; }
dt { font-weight: 700; margin-top: 10px; }
dd { margin: 2px 0 0; color: var(--muted); word-break: break-word; }

table { width: 100%; border-collapse: collapse; min-width: 760px; }
th, td { text-align: left; border-bottom: 1px solid var(--line); padding: 10px; vertical-align: top; }
th { color: var(--muted); font-size: 0.92rem; }
.path { color: var(--muted); font-size: 0.92rem; word-break: break-all; }
.badge { border-radius: 999px; padding: 4px 9px; font-size: 0.85rem; font-weight: 700; white-space: nowrap; }
.badge.on { background: rgba(24,121,78,0.16); color: var(--ok); }
.badge.off { background: rgba(154,103,0,0.16); color: var(--warn); }
.compact-form { margin: 0; display: inline-block; }
.button-cell { min-width: 180px; white-space: nowrap; }
.button-cell .compact-form { margin-right: 6px; margin-bottom: 6px; }
.button-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.button-grid form, .button-grid button { width: 100%; }
.stacked { margin-top: 20px; }
code { background: var(--accent-soft); color: var(--text); padding: 2px 5px; border-radius: 5px; }

.advanced {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 10px 12px;
    margin: 14px 0;
}
.advanced summary { cursor: pointer; font-weight: 800; }
.advanced[open] summary { margin-bottom: 12px; }
.mini-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.button-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px; }
.button-row button { width: auto; }
.hint { color: var(--muted); font-size: 0.95rem; }
ol { padding-left: 22px; }
em { color: var(--warn); font-style: normal; font-weight: 700; }

@media (max-width: 900px) {
    .grid.two, .mini-grid { grid-template-columns: 1fr; }
    .page { padding: 14px; }
    .topbar { align-items: flex-start; gap: 10px; }
    .top-actions { flex-wrap: wrap; justify-content: flex-end; }
}


.pending-banner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    border: 1px solid rgba(210,153,34,0.75);
    background: rgba(210,153,34,0.18);
    color: var(--text);
    border-radius: 14px;
    padding: 14px;
    margin-bottom: 18px;
}
.pending-banner span { display: block; color: var(--muted); margin-top: 3px; }
.pending-actions, .head-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.dot { display: inline-block; width: 0.75rem; height: 0.75rem; border-radius: 50%; margin-right: 6px; vertical-align: -1px; }
.dot.green { background: var(--ok); box-shadow: 0 0 0 3px rgba(24,121,78,0.16); }
.dot.red { background: var(--bad); box-shadow: 0 0 0 3px rgba(180,35,24,0.14); }
.dot.orange { background: var(--warn); box-shadow: 0 0 0 3px rgba(217,119,6,0.16); }
.busy-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 1000;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.busy-overlay.active { display: flex; }
.busy-overlay > div {
    background: var(--panel);
    color: var(--text);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 24px 28px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.35);
    font-weight: 800;
}
@media (max-width: 700px) {
    .pending-banner, .card-head { align-items: flex-start; flex-direction: column; }
    .pending-actions { width: 100%; }
    .pending-actions form, .pending-actions button { width: 100%; }
}

button.pending {
    background: rgba(210,153,34,0.22);
    color: var(--text);
    border: 1px solid rgba(210,153,34,0.75);
}
button.danger-outline {
    background: transparent;
    color: var(--bad);
    border: 1px solid var(--bad);
}
.pending-row {
    background: rgba(210,153,34,0.10);
}
.button-link {
    display: inline-block;
    border-radius: 10px;
    padding: 10px 14px;
    background: var(--accent);
    color: #fff;
    text-decoration: none;
    font-weight: 650;
}
.button-link.secondary {
    background: var(--accent-soft);
    color: var(--text);
}

/* v0.1.11 Bedien-Feinschliff */
.theme-switch {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    border: 1px solid var(--line);
    background: var(--panel);
    color: var(--text);
    padding: 6px 9px;
    border-radius: 999px;
    box-shadow: 0 4px 14px var(--shadow);
}
.switch-label { font-size: 0.82rem; font-weight: 800; color: var(--muted); }
.switch-track {
    position: relative;
    width: 42px;
    height: 22px;
    border-radius: 999px;
    background: var(--accent-soft);
    border: 1px solid var(--line);
}
.switch-thumb {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--accent);
    transition: transform 0.18s ease;
}
:root[data-theme="dark"] .switch-thumb { transform: translateX(20px); }
:root[data-theme="dark"] .switch-dark,
:root:not([data-theme="dark"]) .switch-light { color: var(--text); }

tbody tr { transition: background 0.12s ease, box-shadow 0.12s ease; }
tbody tr:hover {
    background: rgba(47,129,247,0.12);
    box-shadow: inset 3px 0 0 var(--accent);
}
.pending-row:hover { background: rgba(210,153,34,0.20); }
.message.fade-out {
    opacity: 0;
    transform: translateY(-6px);
    transition: opacity 0.35s ease, transform 0.35s ease;
}
.compact-form + .compact-form { margin-left: 3px; }

/* v0.1.12 Diagnose-/Bedien-Feinschliff */
.console-panel {
    border-radius: 14px;
    margin-bottom: 18px;
    border: 1px solid var(--line);
    background: var(--panel);
    box-shadow: 0 8px 24px var(--shadow);
    overflow: hidden;
}
.console-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    font-weight: 800;
}
.console-head span { color: var(--muted); font-size: 0.9rem; }
.console-panel pre {
    margin: 0;
    padding: 14px;
    max-height: 260px;
    overflow: auto;
    white-space: pre-wrap;
    font-size: 0.92rem;
    border-top: 1px solid var(--line);
    background: rgba(0,0,0,0.12);
}
.console-ok { border-color: var(--ok); }
.console-ok .console-head { background: rgba(24,121,78,0.16); }
.console-error { border-color: var(--bad); }
.console-error .console-head { background: rgba(180,35,24,0.16); }
.console-warn { border-color: var(--warn); }
.console-warn .console-head { background: rgba(210,153,34,0.18); }
.console-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 10px 14px 14px;
    border-top: 1px solid var(--line);
}
.console-actions form { margin: 0; }
.table-action {
    max-width: 140px;
    white-space: normal;
    line-height: 1.15;
    padding: 7px 8px !important;
    font-size: 0.82rem !important;
}
td .compact-form { vertical-align: middle; }
td .compact-form button.small { margin-top: 3px; }
.pending-badge {
    display: inline-block;
    margin-top: 5px;
    background: rgba(210,153,34,0.20);
    color: var(--warn);
}
.wide-table td { max-width: 340px; }
@media (max-width: 900px) {
    .console-panel pre { max-height: 210px; }
    .table-action { max-width: 120px; }
}

/* v0.1.13 Abschluss-Feinschliff: kompakte Tabellen, Aktionsmenü, Branding */
.brand-block {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}
.brand-ascii {
    margin: 0;
    padding: 6px 9px;
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: 10px;
    color: #7dd3fc;
    background: rgba(47,129,247,0.12);
    font-weight: 900;
    line-height: 1.05;
    letter-spacing: 0.04em;
    font-size: 0.78rem;
}
.footer-brand {
    max-width: 1280px;
    margin: 0 auto;
    padding: 10px 24px 24px;
    color: var(--muted);
    font-size: 0.88rem;
    text-align: center;
}
.compact-card { padding: 16px; }
.compact-table {
    min-width: 620px;
    table-layout: fixed;
}
.compact-table th,
.compact-table td {
    padding: 8px 9px;
    font-size: 0.92rem;
}
.compact-table th:last-child,
.compact-table td:last-child {
    width: 62px;
    text-align: right;
}
.compact-table th:nth-child(1), .compact-table td:nth-child(1) { width: 22%; }
.compact-table th:nth-child(2), .compact-table td:nth-child(2) { width: 88px; }
.compact-table th:nth-child(3), .compact-table td:nth-child(3) { width: 95px; }
.compact-table th:nth-child(5), .compact-table td:nth-child(5) { width: 78px; }
.short-path {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 240px;
}
.cert-cell { white-space: nowrap; }
.tiny-note {
    color: var(--muted);
    font-size: 0.78rem;
    margin-left: 2px;
}
.action-cell { position: relative; overflow: visible; }
.action-menu {
    position: relative;
    display: inline-block;
    text-align: left;
}
.action-menu > summary {
    list-style: none;
    cursor: pointer;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 34px;
    height: 30px;
    border-radius: 9px;
    background: var(--accent-soft);
    color: var(--text);
    font-size: 1.45rem;
    font-weight: 900;
    line-height: 1;
    border: 1px solid var(--line);
}
.action-menu > summary::-webkit-details-marker { display: none; }
.action-menu[open] > summary {
    background: var(--accent);
    color: #fff;
}
.action-menu-list {
    position: absolute;
    right: 0;
    top: 34px;
    z-index: 50;
    min-width: 190px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--panel);
    box-shadow: 0 12px 30px rgba(0,0,0,0.28);
}
.action-menu-list .compact-form {
    display: block;
    margin: 0 0 6px 0 !important;
}
.action-menu-list .compact-form:last-child { margin-bottom: 0 !important; }
.menu-btn {
    width: 100%;
    display: block;
    text-align: left;
    padding: 8px 9px;
    border-radius: 9px;
    font-size: 0.88rem;
    white-space: normal;
}
.action-menu-list .danger { background: var(--bad); color: #fff; }
.action-menu-list .primary { background: var(--ok); color: #fff; }
.action-menu-list .secondary { background: var(--accent-soft); color: var(--text); }
.single-labels label { margin-bottom: 10px; }
@media (max-width: 760px) {
    .brand-ascii { display: none; }
    .compact-table { min-width: 560px; }
    .compact-table th, .compact-table td { font-size: 0.86rem; padding: 7px; }
    .action-menu-list { right: -8px; }
}


/* v0.1.14 letzter UI-Schliff */
.brand-block { min-width: 180px; }
.brand-ribbon {
    width: 210px;
    height: 32px;
    border-radius: 12px;
    background: linear-gradient(90deg, rgba(47,129,247,0.95), rgba(125,211,252,0.60));
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.18), 0 8px 22px rgba(47,129,247,0.24);
}
.brand-ascii { display: none !important; }
.topbar span { margin-left: 0; }
.wide-table { overflow-x: auto; overflow-y: visible; }
.card.wide-table, .compact-card { overflow: visible; }
.action-menu-list { z-index: 5000; }
.action-menu.menu-fixed .action-menu-list {
    position: fixed;
    right: auto;
    top: auto;
    max-width: min(260px, calc(100vw - 16px));
}
.cert-table { min-width: 680px; }
.cert-table th:last-child, .cert-table td:last-child { width: 62px; }
.cert-table th:nth-child(1), .cert-table td:nth-child(1) { width: 18%; }
.cert-table th:nth-child(3), .cert-table td:nth-child(3) { width: 150px; }
.cert-table th:nth-child(4), .cert-table td:nth-child(4) { width: 105px; }
@media (max-width: 760px) {
    .brand-block { min-width: 130px; }
    .brand-ribbon { width: 150px; height: 28px; }
}


/* v0.1.15 Abschluss: Konsolenlogo und deaktivierte Zeilen */
.brand-block, .brand-ribbon { display: none !important; }
.brand-console {
    min-width: 168px;
    color: var(--topbar-text);
    border: 1px solid rgba(125,211,252,0.35);
    border-radius: 12px;
    padding: 7px 10px;
    background: rgba(47,129,247,0.12);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.06);
}
.brand-console pre {
    margin: 0;
    font: 700 0.78rem/1.05 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    letter-spacing: 0.02em;
    white-space: pre;
}
tr.is-disabled td { opacity: 0.72; }
tr.is-disabled td:first-child::before { content: "⏸ "; color: var(--warn); }
@media (max-width: 760px) {
    .brand-console { min-width: 116px; padding: 6px 8px; }
    .brand-console pre { font-size: 0.68rem; }
}

/* v0.1.19 Domain-/Zertifikats-Feinschliff */
button:disabled,
button[disabled] {
    opacity: 0.55;
    cursor: not-allowed;
    filter: grayscale(0.3);
}
.badge.pending-badge {
    border: 1px solid rgba(210,153,34,0.55);
}
tr.pending-row td:nth-child(2) .badge.pending-badge {
    background: rgba(210,153,34,0.28);
    color: var(--warn);
}
.cert-cell[title*="Doppelter server_name"] .dot.orange {
    animation: certWarnPulse 1.6s ease-in-out infinite;
}
@keyframes certWarnPulse {
    0%, 100% { box-shadow: 0 0 0 3px rgba(217,119,6,0.16); }
    50% { box-shadow: 0 0 0 6px rgba(217,119,6,0.08); }
}

/* v0.1.21: Zertifikatszellen kompakter, damit Text nicht in die Ziel-Spalte läuft. */
.cert-cell { min-width: 5.2rem; white-space: normal; line-height: 1.15; }
.cert-cell .tiny-note { display: block; max-width: 6.5rem; overflow-wrap: anywhere; font-size: 0.72rem; opacity: .9; margin-top: .25rem; }
.compact-table td { vertical-align: middle; }
.compact-table td.path { max-width: 20rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }


/* v0.1.21 Diagnose-Konsole und Proxy-Tabellenkorrekturen */
.diagnostic-card { overflow: visible; }
.diagnostic-console {
    width: 100%;
    min-height: 460px;
    margin-top: 14px;
    padding: 14px;
    resize: vertical;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: rgba(0,0,0,0.18);
    color: var(--text);
    font: 0.88rem/1.45 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    white-space: pre;
    overflow: auto;
}
.compact-table .cert-cell { max-width: 8rem; overflow-wrap: anywhere; }
.compact-table .path.short-path { max-width: 18rem; }
tr.pending-row td { background-clip: padding-box; }
@media (max-width: 800px) {
    .diagnostic-console { min-height: 340px; font-size: 0.8rem; }
    .head-actions { align-items: stretch; }
    .head-actions form, .head-actions a, .head-actions button { width: 100%; text-align: center; }
}

.warning-text{color:#fbbf24;font-weight:700;}


/* v0.1.24 UI-Politur: ruhiger Header, klare Felder, gleiche Diagnose-Buttons, Alias-Spalten */
:root {
    --field-bg: #ffffff;
    --field-border: #c7d0dc;
    --field-focus: rgba(31,111,235,0.22);
    --tab-bg: rgba(219,231,248,0.92);
    --button-shadow: 0 6px 16px rgba(31,111,235,0.14);
}
:root[data-theme="dark"] {
    --bg: #090d14;
    --panel: #151b25;
    --field-bg: #202938;
    --field-border: #465569;
    --field-focus: rgba(47,129,247,0.34);
    --tab-bg: rgba(46,58,77,0.92);
    --button-shadow: 0 8px 20px rgba(0,0,0,0.25);
}
body {
    background:
        radial-gradient(circle at 18% 0%, rgba(47,129,247,0.18), transparent 32rem),
        linear-gradient(180deg, var(--topbar) 0, var(--bg) 155px, var(--bg) 100%);
    font-family: "Trebuchet MS", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}
.topbar {
    max-width: 1280px;
    margin: 0 auto;
    padding: 16px 24px 8px;
    background: transparent;
}
.brand-console {
    background: rgba(32,41,56,0.72);
    border-color: rgba(125,211,252,0.38);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.04), 0 12px 26px rgba(0,0,0,0.18);
}
.page { padding-top: 12px; }
.tabs {
    position: relative;
    padding: 10px;
    margin: 0 0 22px;
    border: 1px solid rgba(125,211,252,0.12);
    border-radius: 18px;
    background: rgba(13,17,23,0.20);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.025);
}
.tab-button {
    border-radius: 999px;
    background: var(--tab-bg);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 5px 12px rgba(0,0,0,0.10);
}
.tab-button.active {
    background: linear-gradient(135deg, var(--accent), #22d3ee);
    color: #fff;
    box-shadow: 0 8px 22px rgba(34,211,238,0.22);
}
h1 { font-weight: 900; letter-spacing: -0.025em; }
h2 { font-weight: 850; letter-spacing: -0.015em; }
input, select, textarea {
    background: var(--field-bg);
    border-color: var(--field-border);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
input:focus, select:focus, textarea:focus {
    outline: 3px solid var(--field-focus);
    border-color: var(--accent);
}
select { cursor: pointer; }
button, .button-link {
    border-radius: 999px;
    box-shadow: var(--button-shadow);
    letter-spacing: -0.01em;
}
button.small { border-radius: 999px; }
.badge, .count, .tiny-note.warning-text {
    border-radius: 999px;
}
.badge {
    display: inline-flex;
    align-items: center;
    min-height: 1.55rem;
}
.button-row button, .button-row .button-link, .head-actions button, .head-actions .button-link {
    min-height: 2.5rem;
}
.compact-table {
    min-width: 760px;
}
.compact-table th:nth-child(1), .compact-table td:nth-child(1) { width: 18%; }
.compact-table th:nth-child(2), .compact-table td:nth-child(2) { width: 17%; }
.compact-table th:nth-child(3), .compact-table td:nth-child(3) { width: 92px; }
.compact-table th:nth-child(4), .compact-table td:nth-child(4) { width: 96px; }
.compact-table th:last-child, .compact-table td:last-child { width: 58px; }
.domain-cell code { white-space: nowrap; }
.alias-cell {
    color: var(--muted);
    font-size: 0.86rem;
    line-height: 1.25;
}
.alias-list {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
    max-width: 15rem;
}
.muted-dash { color: var(--muted); opacity: 0.65; }
.path.short-path { max-width: 16rem; }
.cert-cell .tiny-note {
    display: inline-flex;
    margin-left: .25rem;
    padding: 0.12rem 0.45rem;
    border-radius: 999px;
    background: rgba(125,211,252,0.10);
}
.action-menu > summary {
    border-radius: 999px;
    width: 32px;
    height: 30px;
    font-size: 1.25rem;
}
.action-menu-list { border-radius: 16px; }
.menu-btn { border-radius: 999px; }
.diagnostic-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    min-width: min(100%, 680px);
}
.diagnostic-actions form { margin: 0; }
.diagnostic-actions button,
.diagnostic-actions .button-link {
    width: 100%;
    min-height: 44px;
    padding: 10px 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 0.92rem;
    line-height: 1.15;
}
.diagnostic-card .card-head {
    align-items: end;
}
.card {
    border-color: rgba(148,163,184,0.26);
}
tbody tr:hover {
    background: rgba(34,211,238,0.10);
}
.pending-row:hover { background: rgba(210,153,34,0.22); }
@media (max-width: 900px) {
    .diagnostic-actions { grid-template-columns: 1fr; min-width: 100%; }
    .diagnostic-actions button, .diagnostic-actions .button-link { min-height: 42px; }
    .tabs { padding: 8px; }
}


/* v0.1.25 Tabellen-/ACME-Feinschliff */
.wide-table {
    overflow-x: auto;
    overflow-y: visible;
    max-width: 100%;
}
.compact-table {
    width: 100%;
    min-width: 0;
    table-layout: fixed;
}
.compact-table th,
.compact-table td {
    padding: 10px 12px;
    vertical-align: middle;
    overflow: hidden;
    text-overflow: ellipsis;
}
.compact-table th {
    white-space: nowrap;
    line-height: 1.15;
}
.compact-table .domain-cell,
.compact-table .alias-cell,
.compact-table .cert-cell,
.compact-table .action-cell {
    overflow: visible;
}
.compact-table .path.short-path,
.compact-table td.path,
.compact-table .target-cell {
    display: table-cell;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: normal;
}
.vhost-table .col-domain { width: 17%; }
.vhost-table .col-alias { width: 15%; }
.vhost-table .col-status { width: 104px; }
.vhost-table .col-cert { width: 86px; }
.vhost-table .col-path { width: auto; }
.vhost-table .col-size { width: 82px; }
.vhost-table .col-action { width: 58px; }
.proxy-table .col-domain { width: 20%; }
.proxy-table .col-alias { width: 18%; }
.proxy-table .col-status { width: 104px; }
.proxy-table .col-cert { width: 86px; }
.proxy-table .col-target { width: auto; }
.proxy-table .col-action { width: 58px; }
.alias-list {
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: normal;
}
.cert-cell {
    white-space: nowrap;
}
.cert-cell .tiny-note {
    max-width: 4.6rem;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: middle;
}
.action-cell {
    text-align: right;
}
.action-menu-list {
    z-index: 999;
}
@media (max-width: 900px) {
    .compact-table { min-width: 780px; }
    .vhost-table .col-path { width: 190px; }
    .proxy-table .col-target { width: 210px; }
}

/* v0.1.26 UI-/Funktionsausbau: Technik-Hintergrund, softer Light Mode, Loader, Folder-Picker, Ping, Editor */
:root {
    --bg: #e8eef6;
    --panel: #f7f9fc;
    --text: #152033;
    --muted: #5b687a;
    --line: #cbd5e1;
    --accent: #1976d2;
    --accent-soft: #d9e9fb;
    --topbar: #dfeaf6;
    --topbar-text: #142033;
    --field-bg: #eef4fb;
    --field-border: #b7c6d8;
}
:root[data-theme="dark"] {
    --bg: #07111d;
    --panel: #121c2a;
    --text: #edf7ff;
    --muted: #a9b8c8;
    --line: #334155;
    --accent: #22c7e8;
    --accent-soft: #263247;
    --topbar: #07111d;
    --topbar-text: #edf7ff;
    --field-bg: #1d2938;
    --field-border: #53677d;
}
body {
    background-color: var(--bg);
    background-image:
        radial-gradient(circle at 18% 0%, rgba(34,211,238,0.18), transparent 30rem),
        linear-gradient(rgba(34,211,238,0.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(34,211,238,0.055) 1px, transparent 1px),
        linear-gradient(180deg, rgba(7,17,29,0.38), transparent 190px);
    background-size: auto, 34px 34px, 34px 34px, auto;
    background-attachment: fixed;
}
:root:not([data-theme="dark"]) body {
    background-image:
        radial-gradient(circle at 15% 0%, rgba(25,118,210,0.16), transparent 30rem),
        linear-gradient(rgba(25,118,210,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(25,118,210,0.06) 1px, transparent 1px),
        linear-gradient(180deg, rgba(210,224,240,0.95), transparent 190px);
}
body::before {
    content: "";
    pointer-events: none;
    position: fixed;
    inset: 0;
    background: linear-gradient(90deg, transparent 0 8%, rgba(34,211,238,.08) 8.5%, transparent 9%, transparent 26%, rgba(34,211,238,.06) 26.4%, transparent 27%);
    opacity: .45;
    mix-blend-mode: screen;
}
.topbar { padding-bottom: 6px; }
.tabs { align-items: center; backdrop-filter: blur(10px); }
.card, .login-card { backdrop-filter: blur(8px); }
input, select, textarea {
    background: var(--field-bg) !important;
    border-color: var(--field-border) !important;
}
button, .button-link, .badge, .count, .tiny-note, .tab-button {
    border-radius: 999px !important;
}
.badge.muted { background: rgba(148,163,184,0.18); color: var(--muted); }
.ping-cell small { display: block; margin-top: .18rem; font-size: .72rem; white-space: nowrap; }
.proxy-table .col-ping { width: 96px; }
.proxy-table .col-target { width: auto; }
.loader-icon {
    display: inline-block;
    width: 1.45rem;
    height: 1.45rem;
    margin-right: .7rem;
    border: 3px solid rgba(34,211,238,.28);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: loaderSpin .8s linear infinite;
    vertical-align: middle;
}
.busy-overlay > div { display: inline-flex; align-items: center; gap: .25rem; }
@keyframes loaderSpin { to { transform: rotate(360deg); } }
.folder-picker-row {
    display: grid;
    grid-template-columns: minmax(0,1fr) auto;
    gap: 8px;
    align-items: end;
}
.folder-picker-row button { margin-top: 6px; white-space: nowrap; }
.modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 7000;
    background: rgba(0,0,0,.55);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
}
.modal-backdrop.active { display: flex; }
.modal-box {
    width: min(760px, 96vw);
    max-height: 82vh;
    overflow: auto;
    background: var(--panel);
    color: var(--text);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 18px;
    box-shadow: 0 28px 90px rgba(0,0,0,.45);
}
.modal-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.folder-browser-modal { width: min(880px, 96vw); }
.folder-browser-toolbar {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
    margin: 12px 0;
}
.folder-current {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    color: var(--accent);
    background: rgba(15, 23, 42, .44);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 10px 12px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.folder-tree {
    margin-top: 12px;
    display: grid;
    gap: 7px;
    max-height: 46vh;
    overflow: auto;
    padding-right: 4px;
}
.folder-tree-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
    background: rgba(148,163,184,.08);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 7px;
}
.folder-tree-row:hover { background: rgba(34,211,238,.12); border-color: rgba(34,211,238,.36); }
.folder-open {
    text-align: left;
    background: transparent;
    color: var(--text);
    border: 0;
    box-shadow: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding: 8px 10px;
}
.folder-use { white-space: nowrap; padding: 8px 12px; }
.folder-loading, .error-text { padding: 14px; }
.code-picker {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 12px;
    margin: 12px 0 16px;
}
.code-picker legend { font-weight: 800; color: var(--muted); }
.inline-check { display: inline-flex; align-items: center; gap: 6px; margin: 4px 10px 4px 0; }
.inline-check input { width: auto; margin: 0; }
.config-editor-text {
    width: 100%;
    min-height: 560px;
    font: .9rem/1.45 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    resize: vertical;
    white-space: pre;
    overflow: auto;
}
.config-picker-form { margin-bottom: 12px; }
.config-editor-actions { align-items: center; }
.disabled-link { opacity: .55; pointer-events: none; filter: grayscale(.3); }
@media (max-width: 900px) {
    .folder-picker-row { grid-template-columns: 1fr; }
    .proxy-table .col-ping { width: 88px; }
}

/* v0.1.27 Feinschliff: stabiles Aktionsmenü, Editor-Kontrast, Default-Server UI */
.action-menu-list {
    z-index: 99999 !important;
    background: var(--panel) !important;
    color: var(--text) !important;
    border: 1px solid var(--line) !important;
}
.action-menu.menu-fixed .action-menu-list { position: fixed !important; }
.config-editor-text,
textarea.config-editor-text {
    background: #0b1524 !important;
    color: #eaf6ff !important;
    border-color: #496176 !important;
    caret-color: #22d3ee;
    text-shadow: none !important;
}
:root:not([data-theme="dark"]) .config-editor-text,
:root:not([data-theme="dark"]) textarea.config-editor-text {
    background: #f8fbff !important;
    color: #122033 !important;
    border-color: #9fb0c6 !important;
}
.config-editor-text::selection { background: rgba(34,211,238,.35); color: #fff; }
:root:not([data-theme="dark"]) .config-editor-text::selection { background: rgba(25,118,210,.22); color: #0f172a; }

.vhost-table, .proxy-table { min-width: 980px; }
.vhost-table .col-domain { width: 18%; }
.vhost-table .col-alias { width: 16%; }
.vhost-table .col-status { width: 112px; }
.vhost-table .col-cert { width: 94px; }
.vhost-table .col-path { width: auto; }
.vhost-table .col-size { width: 90px; }
.vhost-table .col-action { width: 64px; }
.proxy-table .col-domain { width: 18%; }
.proxy-table .col-alias { width: 16%; }
.proxy-table .col-status { width: 112px; }
.proxy-table .col-cert { width: 94px; }
.proxy-table .col-target { width: auto; }
.proxy-table .col-ping { width: 106px; }
.proxy-table .col-action { width: 64px; }
.compact-table th, .compact-table td { overflow: hidden; }
.compact-table .action-cell, .compact-table .domain-cell, .compact-table .alias-cell, .compact-table .cert-cell { overflow: visible; }
.compact-table .path.short-path, .compact-table .target-cell { max-width: 100%; }
.alias-list { max-width: 100%; }

form[action="/settings/default-server"] {
    grid-column: 1 / -1;
}
form[action="/settings/default-server"] .mini-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 1000px) {
    form[action="/settings/default-server"] .mini-grid { grid-template-columns: 1fr; }
    .vhost-table, .proxy-table { min-width: 900px; }
}

/* v0.1.28: sicherer Ordnerbaum-Browser */
.browse-button { min-width: 148px; }
:root:not([data-theme="dark"]) .folder-current { background: rgba(226,232,240,.72); }
@media (max-width: 720px) { .folder-tree-row { grid-template-columns: 1fr; } .folder-use { width: 100%; } }


/* v0.1.29 Jobliste und Ausführungsdialog */
.pending-banner.pending-jobs {
    display: block;
    border-color: rgba(210,153,34,0.75);
    background: linear-gradient(135deg, rgba(210,153,34,0.20), rgba(210,153,34,0.10));
}
.pending-headline {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    margin-bottom: 12px;
}
.pending-table-wrap { overflow-x: auto; }
.pending-table {
    width: 100%;
    min-width: 760px;
    border-collapse: collapse;
    background: rgba(0,0,0,0.10);
    border-radius: 12px;
    overflow: hidden;
}
.pending-table th,
.pending-table td {
    padding: 8px 10px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    vertical-align: middle;
}
.pending-table tr:last-child td { border-bottom: 0; }
.pending-table th { color: var(--muted); font-size: .82rem; text-transform: uppercase; letter-spacing: .03em; }
.badge.job-area { background: rgba(47,129,247,0.16); color: var(--text); border: 1px solid rgba(47,129,247,0.28); }

.busy-overlay {
    background: rgba(0,0,0,0.62);
    backdrop-filter: blur(3px);
}
.busy-overlay .busy-card {
    display: block;
    min-width: min(640px, 92vw);
    max-width: 760px;
    padding: 24px 28px;
}
.busy-title {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 1.08rem;
    margin-bottom: 8px;
}
.busy-card p {
    margin: 0 0 12px;
    color: var(--muted);
    font-weight: 600;
}
.busy-job-list {
    margin: 0;
    padding-left: 22px;
    display: grid;
    gap: 8px;
    font-weight: 650;
}
.busy-job-list li {
    color: var(--muted);
    padding: 6px 8px;
    border-radius: 10px;
    background: rgba(255,255,255,0.04);
}
.busy-job-list li.running {
    color: var(--text);
    background: rgba(47,129,247,0.18);
    border: 1px solid rgba(47,129,247,0.35);
}
.busy-job-list li.running::after {
    content: "  läuft …";
    color: var(--accent);
    font-weight: 800;
}
.busy-job-list li.done {
    color: var(--ok);
}
.busy-job-list li.done::after {
    content: "  vorbereitet";
    color: var(--ok);
    font-weight: 800;
}
@media (max-width: 700px) {
    .pending-headline { flex-direction: column; align-items: flex-start; }
    .pending-actions, .pending-actions form, .pending-actions button { width: 100%; }
}

.busy-title, .busy-card p { background: transparent; border: 0; box-shadow: none; padding: 0; }

/* v0.1.30 Erweiterungen: deaktivierte Tabellen und Benutzerverwaltung */
.disabled-section {
    border-style: dashed;
    opacity: 0.96;
}
.badge.auth-badge {
    display: inline-block;
    margin-top: 5px;
    background: rgba(47,129,247,0.16);
    color: var(--accent);
}
.auth-table td form { margin: 0; }
.auth-table .path { max-width: 360px; }
