:root {
    --danger: #f43f5e;
    --success: #22c55e;
    --warning: #f59e0b;
}

.dark-theme { --bg: #0f172a; --card-bg: #1e293b; --text: #f8fafc; --text-muted: #94a3b8; --primary: #38bdf8; --border: #334155; --input-bg: #0f172a; }
.light-theme { --bg: #f1f5f9; --card-bg: #ffffff; --text: #0f172a; --text-muted: #64748b; --primary: #0284c7; --border: #e2e8f0; --input-bg: #f8fafc; }

body { font-family: 'Inter', sans-serif; max-width: 1100px; margin: 0 auto; padding: 20px; background: var(--bg); color: var(--text); line-height: 1.5; }

/* HEADER */
.header-section { display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px; position: relative; }
.title-container h1 { font-size: 1.5rem; margin: 0; white-space: nowrap; }

.header-controls { display: flex; gap: 8px; }
.btn-text { display: none; }

.btn-icon, .btn-secondary, .btn-reset { 
    background: var(--card-bg); border: 1px solid var(--border); color: var(--text); 
    padding: 8px 12px; border-radius: 8px; cursor: pointer; display: flex; align-items: center; gap: 6px; font-size: 0.85rem;
}
.btn-reset { color: var(--danger); border-color: var(--danger); }

.menu-toggle { display: none; background: var(--card-bg); border: 1px solid var(--border); color: var(--text); padding: 8px; border-radius: 8px; cursor: pointer; }

/* CARDS */
.card { background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; padding: 24px; margin-bottom: 24px; }
.config-stack { display: flex; flex-direction: column; gap: 20px; align-items: flex-start; }
.input-row { display: flex; gap: 16px; align-items: flex-end; flex-wrap: wrap; justify-content: flex-start; width: 100%; }

.description-input { flex: 0 1 350px; }
.qty-input { width: 80px; }
.res-inputs { display: flex; align-items: center; gap: 8px; }
.res-divider { color: var(--text-muted); font-weight: bold; }
.select-group { flex: 0 1 130px; }

label { font-size: 0.7rem; font-weight: 700; text-transform: uppercase; color: var(--text-muted); margin-bottom: 8px; display: block; }
input, select { background: var(--input-bg); border: 1px solid var(--border); color: var(--text); padding: 10px; border-radius: 6px; width: 100%; box-sizing: border-box; font-size: 0.9rem; }

.btn-add { background: var(--primary); color: #000; border: none; padding: 12px 24px; border-radius: 8px; font-weight: 700; cursor: pointer; display: flex; align-items: center; gap: 8px; }

/* DASHBOARD HEADER - JETZT RECHTSBÜNDIGE BITRATE */
.dashboard-header { 
    display: flex; 
    align-items: baseline; 
    justify-content: space-between; /* Links: Titel, Rechts: Wert */
    margin-bottom: 20px; 
    border-bottom: 1px solid var(--border); 
    padding-bottom: 15px; 
}
.section-title { font-size: 1.6rem; margin: 0; font-weight: 800; }
.total-val-hero { font-size: 1.6rem; font-weight: 800; color: var(--primary); text-align: right; }

/* UTILIZATION GRID */
.utilization-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; }
.usage-card { background: var(--input-bg); padding: 16px; border-radius: 10px; border: 1px solid var(--border); }
.usage-label { display: flex; justify-content: space-between; font-size: 0.8rem; font-weight: 700; margin-bottom: 10px; }
.progress-bar { background: var(--border); height: 6px; border-radius: 10px; overflow: hidden; }
.progress-fill { height: 100%; width: 0; transition: width 0.5s ease; }

/* TABLE */
.table-container { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
th { text-align: left; font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; padding: 12px; border-bottom: 2px solid var(--border); }
td { padding: 14px 12px; border-bottom: 1px solid var(--border); font-size: 0.9rem; }

/* SUMMARY */
.centered-summary { display: flex; justify-content: center; text-align: center; }
.summary-content { max-width: 700px; display: flex; flex-direction: column; align-items: center; gap: 25px; }
.summary-box { width: 100%; }
.summary-box .val { font-size: 2.2rem; font-weight: 800; margin: 5px 0; }
.summary-desc { font-size: 0.75rem; color: var(--text-muted); max-width: 500px; margin: 0 auto; }
.summary-spacer { width: 80px; height: 1px; background: var(--border); }
.highlight .val { color: var(--primary); }

.hidden { display: none !important; }

/* MOBILE */
@media (max-width: 768px) {
    .title-container h1 { font-size: 1.1rem; }
    .menu-toggle { display: block; z-index: 1001; }
    .header-controls {
        display: none;
        position: absolute;
        top: 50px;
        right: 0;
        background: var(--card-bg);
        border: 1px solid var(--border);
        border-radius: 12px;
        flex-direction: column;
        padding: 10px;
        box-shadow: 0 10px 25px rgba(0,0,0,0.3);
        z-index: 1000;
        min-width: 150px;
    }
    .header-controls.active { display: flex; }
    .header-controls button { width: 100%; justify-content: flex-start; padding: 12px; }
    .btn-text { display: inline; }

    .dashboard-header { flex-direction: row; align-items: baseline; }
    .section-title { font-size: 1.2rem; }
    .total-val-hero { font-size: 1.2rem; }

    .input-row { flex-direction: column; align-items: stretch; }
    .description-input, .qty-input, .select-group { width: 100%; flex: none; }
    
    thead { display: none; }
    tr { display: block; padding: 15px 45px 15px 0; position: relative; border-bottom: 1px solid var(--border); }
    td { display: flex; justify-content: space-between; border: none; padding: 4px 0; text-align: right; }
    td:last-child { position: absolute; top: 15px; right: 0; padding: 0; }
    td::before { content: attr(data-label); font-weight: 700; color: var(--text-muted); font-size: 0.65rem; text-transform: uppercase; margin-right: 15px; text-align: left; }
}