:root {
    --bg: #f4efe7;
    --bg-soft: #fffaf2;
    --ink: #19222e;
    --muted: #5f6f80;
    --accent: #c24d2c;
    --accent-2: #0f766e;
    --danger: #b42318;
    --warning: #c77d00;
    --border: #d8ccbc;
    --card: #fffefb;
    --shadow: 0 12px 30px rgba(39, 28, 17, 0.12);
}

html[data-theme="dark"] {
    --bg: #1b2024;
    --bg-soft: #232a30;
    --ink: #f5f7f9;
    --muted: #9dafc0;
    --accent: #f97316;
    --accent-2: #14b8a6;
    --danger: #f87171;
    --warning: #f59e0b;
    --border: #334150;
    --card: #20272e;
    --shadow: 0 12px 30px rgba(0, 0, 0, 0.3);
}

* {
    box-sizing: border-box;
}

[hidden] {
    display: none !important;
}

body {
    margin: 0;
    color: var(--ink);
    font-family: "IBM Plex Sans", "Avenir Next", "Trebuchet MS", sans-serif;
    background:
        radial-gradient(1100px 500px at 5% -10%, rgba(194, 77, 44, 0.22), transparent 58%),
        radial-gradient(900px 540px at 95% 0%, rgba(15, 118, 110, 0.18), transparent 55%),
        var(--bg);
    min-height: 100vh;
}

.site-header {
    display: grid;
    grid-template-columns: 260px 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 18px 20px;
    position: sticky;
    top: 0;
    z-index: 10;
    background: color-mix(in srgb, var(--bg-soft) 90%, transparent);
    border-bottom: 1px solid var(--border);
    backdrop-filter: blur(9px);
}

.brand {
    display: grid;
    gap: 2px;
}

.brand-mark {
    font-size: 11px;
    letter-spacing: 1.7px;
    color: var(--accent);
    font-weight: 800;
}

.brand h1 {
    margin: 0;
    font-family: "IBM Plex Sans Condensed", "Impact", sans-serif;
    font-size: 21px;
    font-weight: 700;
}

.main-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
}

.main-nav a {
    text-decoration: none;
    color: var(--ink);
    padding: 8px 11px;
    border-radius: 999px;
    border: 1px solid transparent;
    transition: 120ms ease;
}

.main-nav a:hover {
    border-color: var(--border);
    background: rgba(255, 255, 255, 0.35);
}

.main-nav a.is-active {
    border-color: color-mix(in srgb, var(--accent) 55%, var(--border));
    color: var(--accent);
    background: color-mix(in srgb, var(--accent) 9%, transparent);
}

.header-actions {
    display: flex;
    gap: 10px;
    align-items: center;
}

#app-content {
    max-width: 1300px;
    margin: 20px auto 60px;
    padding: 0 16px;
    animation: fadeSlide 180ms ease;
}

@keyframes fadeSlide {
    from { opacity: 0; transform: translateY(3px); }
    to { opacity: 1; transform: translateY(0); }
}

.page-head h2 {
    margin: 0 0 4px;
    font-size: 28px;
}

.page-head p {
    margin: 0;
    color: var(--muted);
}

.page-head-subtle h2 {
    font-size: 24px;
    font-weight: 650;
}

.page-head-subtle p {
    font-size: 15px;
}

.panel {
    margin-top: 14px;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: var(--shadow);
    padding: 14px;
}

.stats-grid {
    margin-top: 14px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 11px;
}

.stats-grid-tight {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

.stats-grid-tight .stat-card strong {
    font-size: 18px;
}

.stat-card {
    background: color-mix(in srgb, var(--card) 84%, var(--bg-soft));
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 12px;
}

.stat-card h3,
.stat-card h4 {
    margin: 0 0 8px;
    color: var(--muted);
    font-size: 14px;
    font-weight: 600;
}

.stat-card strong {
    font-size: 24px;
}

.panel-boards {
    background: color-mix(in srgb, var(--card) 96%, transparent);
}

.board-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.board-card {
    background: color-mix(in srgb, var(--bg-soft) 45%, var(--card));
    border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
    border-radius: 16px;
    padding: 14px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
    display: grid;
    gap: 10px;
}

.board-card-link {
    text-decoration: none;
    color: inherit;
    transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.board-card-link:link,
.board-card-link:visited,
.board-card-link:hover,
.board-card-link:active {
    color: inherit;
    text-decoration: none;
}

.board-card-link * {
    color: inherit;
    text-decoration: none;
}

.board-card-link:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.18);
    border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
}

.board-card-cta {
    margin: 0;
    font-size: 13px;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.board-card-head {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    align-items: flex-start;
}

.board-card-head h3 {
    margin: 0;
    font-size: clamp(20px, 1.5vw, 24px);
    line-height: 1.05;
    font-family: "IBM Plex Sans Condensed", "Avenir Next Condensed", sans-serif;
}

.board-card-subtle .board-card-head h3 {
    font-size: clamp(18px, 1.3vw, 21px);
}

.board-status-pill {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    border-radius: 999px;
    padding: 4px 9px;
    border: 1px solid var(--border);
    white-space: nowrap;
}

.board-status-active { background: rgba(15, 118, 110, 0.18); border-color: rgba(15, 118, 110, 0.38); }
.board-status-paused { background: rgba(199, 125, 0, 0.15); border-color: rgba(199, 125, 0, 0.4); }
.board-status-runout { background: rgba(180, 35, 24, 0.16); border-color: rgba(180, 35, 24, 0.45); }
.board-status-stopped { background: rgba(130, 130, 130, 0.14); border-color: rgba(130, 130, 130, 0.3); }
.board-status-settled { background: rgba(99, 102, 241, 0.2); border-color: rgba(99, 102, 241, 0.4); }
.board-status-idle { background: rgba(22, 163, 74, 0.18); border-color: rgba(22, 163, 74, 0.4); }

.board-meta {
    margin: 0;
    color: var(--ink);
    font-size: 16px;
    line-height: 1.25;
}

.board-meta strong {
    color: var(--muted);
    font-size: 14px;
    letter-spacing: 0.2px;
}

.board-card-subtle .board-meta {
    font-size: 15px;
}

.board-live-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.board-live-grid div {
    border: 1px solid color-mix(in srgb, var(--border) 90%, transparent);
    border-radius: 12px;
    background: color-mix(in srgb, var(--bg-soft) 55%, transparent);
    padding: 9px 10px;
    display: grid;
    gap: 4px;
}

.board-live-grid span {
    color: var(--muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.35px;
}

.board-live-grid strong {
    font-size: 19px;
    line-height: 1;
}

.board-card-subtle .board-live-grid strong {
    font-size: 17px;
}

.board-actions {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.board-actions .btn {
    text-align: center;
}

.board-actions .board-btn-start,
.board-actions .btn:only-child {
    grid-column: 1 / -1;
}

.board-btn-start {
    width: 100%;
    padding: 11px 12px;
    font-size: 18px;
}

.board-detail-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.board-detail-head p {
    margin: 0;
    font-size: 18px;
}

.board-detail-actions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 9px;
    margin-bottom: 12px;
}

.board-empty-note {
    margin: 0 0 10px;
    color: var(--muted);
    font-style: italic;
}

.board-summary-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}

.board-summary-strip article {
    border: 1px solid color-mix(in srgb, var(--border) 85%, transparent);
    border-radius: 11px;
    padding: 8px 10px;
    background: color-mix(in srgb, var(--bg-soft) 55%, transparent);
    display: grid;
    gap: 4px;
}

.board-summary-strip span {
    color: var(--muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.board-summary-strip strong {
    font-size: 21px;
}

.board-customer-box {
    border: 1px dashed color-mix(in srgb, var(--border) 88%, transparent);
    border-radius: 12px;
    padding: 10px;
    margin-bottom: 12px;
    background: color-mix(in srgb, var(--bg-soft) 40%, transparent);
}

.board-customer-box p {
    margin: 0 0 4px;
}

.board-customer-box p:last-child {
    margin-bottom: 0;
}

.table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 8px;
}

.table th,
.table td {
    text-align: left;
    border-bottom: 1px solid var(--border);
    padding: 8px 7px;
    vertical-align: top;
}

.table th {
    font-size: 12px;
    color: var(--muted);
    letter-spacing: 0.3px;
    text-transform: uppercase;
}

.table.compact td,
.table.compact th {
    padding: 6px;
}

.btn {
    background: var(--accent);
    color: #fff;
    border: 1px solid color-mix(in srgb, var(--accent) 75%, #000);
    padding: 8px 12px;
    border-radius: 10px;
    font-weight: 700;
    cursor: pointer;
    text-decoration: none;
    display: inline-block;
}

.btn.subtle {
    background: color-mix(in srgb, var(--accent-2) 18%, var(--card));
    color: var(--ink);
    border-color: color-mix(in srgb, var(--accent-2) 44%, var(--border));
}

.btn.warning {
    background: var(--warning);
    border-color: color-mix(in srgb, var(--warning) 70%, #000);
}

.btn.danger {
    background: var(--danger);
    border-color: color-mix(in srgb, var(--danger) 70%, #000);
}

.btn.tiny {
    padding: 5px 8px;
    font-size: 12px;
}

.form-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.form-stack {
    display: grid;
    gap: 10px;
}

label {
    display: grid;
    gap: 6px;
    font-size: 13px;
    color: var(--muted);
}

.toggle-row {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 16px;
}

.toggle-row input[type="checkbox"] {
    width: 18px;
    height: 18px;
}

input,
select,
textarea {
    width: 100%;
    border: 1px solid var(--border);
    border-radius: 9px;
    padding: 8px 10px;
    background: var(--bg-soft);
    color: var(--ink);
}

.qty-input {
    width: 72px;
}

.total-line {
    margin: 12px 0;
    font-size: 18px;
}

.grid-two {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    gap: 12px;
}

.action-row {
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
}

.pill {
    display: inline-flex;
    border-radius: 999px;
    padding: 3px 8px;
    border: 1px solid var(--border);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.pill-active { background: rgba(15, 118, 110, 0.15); border-color: rgba(15, 118, 110, 0.4); }
.pill-paused { background: rgba(199, 125, 0, 0.15); border-color: rgba(199, 125, 0, 0.45); }
.pill-stopped { background: rgba(95, 111, 128, 0.12); }
.pill-runout { background: rgba(180, 35, 24, 0.14); border-color: rgba(180, 35, 24, 0.45); }
.pill-idle { background: rgba(127, 127, 127, 0.11); }
.pill-resumed { background: rgba(15, 118, 110, 0.14); }

.flash {
    margin-bottom: 10px;
    padding: 10px 12px;
    border-radius: 9px;
}

.flash-error {
    background: rgba(180, 35, 24, 0.1);
    border: 1px solid rgba(180, 35, 24, 0.32);
}

.flash-success {
    background: rgba(15, 118, 110, 0.1);
    border: 1px solid rgba(15, 118, 110, 0.35);
}

.toast-stack {
    position: fixed;
    right: 12px;
    bottom: 12px;
    z-index: 1200;
    display: grid;
    gap: 8px;
}

.toast {
    min-width: 220px;
    max-width: 360px;
    border: 1px solid var(--border);
    background: var(--card);
    border-radius: 10px;
    box-shadow: var(--shadow);
    padding: 10px 12px;
}

.toast.success { border-color: rgba(15, 118, 110, 0.5); }
.toast.error { border-color: rgba(180, 35, 24, 0.55); }
.toast.fade-out { opacity: 0; transition: opacity 200ms ease; }

.modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.46);
    display: grid;
    place-items: center;
    z-index: 1400;
    padding: 14px;
}

.modal-panel {
    width: min(760px, 100%);
    background: var(--card);
    border-radius: 14px;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    padding: 14px;
    position: relative;
}

.modal-close {
    position: absolute;
    right: 10px;
    top: 8px;
    font-size: 26px;
    border: 0;
    background: transparent;
    color: var(--muted);
    cursor: pointer;
}

.modal-flow h3 {
    margin: 0 0 4px;
    font-size: clamp(24px, 2.2vw, 38px);
    line-height: 1.03;
    font-family: "IBM Plex Sans Condensed", "Avenir Next Condensed", sans-serif;
}

.modal-flow p {
    margin: 0 0 8px;
    color: var(--muted);
}

.modal-flow-start .form-stack,
.modal-flow-move .form-stack {
    gap: 12px;
}

.modal-flow input,
.modal-flow select {
    font-size: 19px;
    padding: 11px 12px;
    border-radius: 10px;
}

.numpad-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.numpad-btn {
    border: 1px solid color-mix(in srgb, var(--accent) 50%, var(--border));
    background: color-mix(in srgb, var(--accent) 16%, var(--card));
    color: var(--ink);
    border-radius: 10px;
    padding: 11px 8px;
    font-size: 22px;
    cursor: pointer;
}

.numpad-btn:hover {
    filter: brightness(1.05);
}

.cookie-banner {
    position: fixed;
    left: 12px;
    right: 12px;
    bottom: 12px;
    z-index: 1500;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--card);
    box-shadow: var(--shadow);
    padding: 12px;
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: space-between;
}

.cookie-actions {
    display: flex;
    gap: 8px;
}

.login-body {
    display: grid;
    place-items: center;
}

.login-shell {
    width: min(460px, 95vw);
    margin: 10vh 0;
}

.login-card {
    border: 1px solid var(--border);
    background: var(--card);
    border-radius: 16px;
    box-shadow: var(--shadow);
    padding: 22px;
}

.login-card h1 {
    margin: 0 0 4px;
}

@media (max-width: 980px) {
    .site-header {
        grid-template-columns: 1fr;
    }
    .header-actions {
        justify-content: flex-start;
    }

    .board-live-grid {
        grid-template-columns: 1fr;
    }

    .modal-panel {
        width: min(620px, 100%);
    }
}

@media (max-width: 640px) {
    .board-actions {
        grid-template-columns: 1fr;
    }

    .board-actions .btn {
        grid-column: auto;
    }

    .numpad-btn {
        font-size: 19px;
    }

    .board-detail-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .board-detail-actions {
        grid-template-columns: 1fr;
    }
}
