:root{--color-brand-maroon:#8b1c1c;--color-brand-maroon-dark:#661010;--color-brand-orange:#e67e22;--color-brand-orange-soft:#fdf3e7;--color-bg:#f5f7fa;--color-bg-grid:#e2e8f0;--color-surface:#fff;--color-header:var(--color-brand-maroon);--color-header-2:var(--color-brand-maroon-dark);--color-ink:#1e293b;--color-ink-soft:#64748b;--color-ink-faint:#94a3b8;--color-accent:#e67e22;--color-accent-ink:#b25300;--color-accent-soft:#fdf3e7;--color-success:#16a34a;--color-success-soft:#f0fdf4;--color-warning:#d97706;--color-warning-soft:#fef9c3;--color-danger:#dc2626;--color-danger-soft:#fef2f2;--color-border:#e2e8f0;--font-display:"Outfit", "Segoe UI", system-ui, -apple-system, sans-serif;--font-body:"Inter", "Segoe UI", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "IBM Plex Mono", Consolas, monospace;--radius-lg:16px;--radius-md:12px;--radius-sm:8px;--shadow-card:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-card-hover:0 20px 25px -5px #8b1c1c14, 0 10px 10px -5px #0000000a}*{box-sizing:border-box}.dashboard-container{background:radial-gradient(circle at 1px 1px, var(--color-bg-grid) 1px, transparent 1px) 0 0 / 32px 32px, var(--color-bg);min-height:100vh;font-family:var(--font-body);color:var(--color-ink);padding:30px 40px}.dashboard-header{background:linear-gradient(135deg, var(--color-header) 0%, var(--color-header-2) 100%);border-radius:var(--radius-lg);border-bottom:4px solid var(--color-brand-orange);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;padding:24px 32px;display:flex;box-shadow:0 10px 15px -3px #8b1c1c33}.icon-main{flex-shrink:0;width:32px;height:32px;color:var(--color-brand-orange)!important}.dashboard-header h1{font-family:var(--font-display);letter-spacing:-.01em;margin:0;font-size:1.65rem;font-weight:700;color:#fff!important}.subtitle{letter-spacing:.01em;margin:4px 0 0 46px;font-size:.92rem;font-weight:500;color:#fca5a5!important}.timer-badge{background:#0003;border:1px solid #ffffff26;border-radius:999px;align-items:center;gap:16px;padding:10px 20px 10px 16px;display:flex}.pulse-indicator{background:var(--color-brand-orange);border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:2s infinite pulse;box-shadow:0 0 #e67e2299}@keyframes pulse{0%{box-shadow:0 0 #e67e228c}70%{box-shadow:0 0 0 9px #e67e2200}to{box-shadow:0 0 #e67e2200}}.timer-text{flex-direction:column;gap:2px;font-size:.82rem;display:flex;color:#f3f4f6!important}.timer-text strong{font-family:var(--font-mono);font-weight:600;color:#fff!important}.icon-inline{vertical-align:-2px;width:14px;height:14px;margin-right:4px;display:inline-block;color:var(--color-brand-orange)!important}.icon-spin{animation:3s linear infinite spin}@keyframes spin{to{transform:rotate(-360deg)}}.btn-refresh{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;transition:all .2s;display:flex}.btn-refresh:hover{color:var(--color-brand-orange);background:#fff3}.btn-refresh svg{width:18px;height:18px}.btn-refresh.is-loading svg{animation:1s linear infinite spin}.summary-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px;margin-bottom:25px;display:grid}.summary-tile{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);flex-direction:column;gap:4px;padding:18px 20px;display:flex}.summary-tile .summary-label{color:var(--color-ink-soft);text-transform:uppercase;letter-spacing:.05em;font-size:.76rem;font-weight:600}.summary-tile .summary-value{font-family:var(--font-mono);color:var(--color-ink);font-size:2.2rem;font-weight:700;line-height:1}.summary-tile .summary-value .unit{font-family:var(--font-body);color:var(--color-ink-faint);margin-left:4px;font-size:.9rem;font-weight:500}.summary-tile.accent-success{border-top:3px solid var(--color-success)}.summary-tile.accent-success .summary-value{color:var(--color-success)}.summary-tile.accent-danger{border-top:3px solid var(--color-danger)}.summary-tile.accent-danger .summary-value{color:var(--color-danger)}.summary-tile.accent-accent{border-top:3px solid var(--color-brand-maroon)}.summary-tile.accent-accent .summary-value{color:var(--color-brand-maroon)}.beds-grid{flex-direction:column;gap:35px;width:100%;display:flex}.kelas-section-block{flex-direction:column;gap:16px;width:100%;display:flex}.kelas-block-title{color:var(--color-brand-maroon);margin: ;border-bottom:3px solid var(--color-brand-maroon);text-transform:uppercase;letter-spacing:.5px;padding-bottom:6px;font-size:1.4rem;font-weight:700}.kelas-section-block .bed-grid{flex-flow:wrap;gap:20px;width:100%;display:flex}.kelas-section-block .bed-card{background:var(--color-surface);border-radius:var(--radius-md);min-width:280px;box-shadow:var(--shadow-sm);border:1px solid var(--color-bg-grid);flex-direction:column;flex:0 calc(25% - 20px);display:flex;overflow:hidden}.bed-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);border-top:5px solid var(--color-border);box-shadow:var(--shadow-card);padding:20px;transition:all .2s}.bed-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-3px)}.bed-card.card-success{border-top-color:var(--color-success)}.bed-card.card-warning{border-top-color:var(--color-warning)}.bed-card.card-danger{border-top-color:var(--color-danger)}.card-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:10px;padding-bottom:12px;display:flex}.room-title-wrapper{align-items:center;gap:10px;min-width:0;display:flex}.icon-bed{width:20px;height:20px;color:var(--color-brand-maroon);flex-shrink:0}.bed-card h3{font-family:var(--font-display);color:var(--color-ink);margin:0;font-size:1.1rem;font-weight:700}.badge-status{text-transform:uppercase;border-radius:999px;padding:4px 10px;font-size:.72rem;font-weight:700}.badge-success{background:var(--color-success-soft);color:var(--color-success)}.badge-warning{background:var(--color-warning-soft);color:var(--color-warning)}.badge-danger{background:var(--color-danger-soft);color:var(--color-danger)}.card-body{margin-top:14px}.progress-container{flex-direction:column;gap:6px;display:flex}.progress-bar-bg{background:var(--color-bg-grid);border-radius:999px;width:100%;height:8px;overflow:hidden}.progress-bar-fill{border-radius:999px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.bar-success{background:var(--color-success)}.bar-warning{background:var(--color-warning)}.bar-danger{background:var(--color-danger)}.percentage-text{color:var(--color-ink-soft);font-size:.78rem;font-weight:500}.stats-row{grid-template-columns:1fr 1fr;gap:12px;margin-top:16px;display:grid}.stat-box{border-radius:var(--radius-sm);border:1px solid #0000;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.stat-icon-wrapper{align-items:center;gap:8px;display:flex}.icon-stat-bed{flex-shrink:0;width:16px;height:16px}.stat-label{font-size:.8rem;font-weight:600;line-height:1}.stat-value{font-family:var(--font-mono);font-size:1.3rem;font-weight:700;line-height:1}.stat-box.kosong{background:var(--color-success-soft);border-color:#16a34a1f}.stat-box.kosong .icon-stat-bed{color:var(--color-success)}.stat-box.kosong .stat-label{color:#15803d}.stat-box.kosong .stat-value{color:var(--color-success)}.stat-box.terisi{background:var(--color-danger-soft);border-color:#dc26261f}.stat-box.terisi .icon-stat-bed{color:var(--color-danger)}.stat-box.terisi .stat-label{color:#b91c1c}.stat-box.terisi .stat-value{color:var(--color-danger)}.card-footer{border-top:1px dashed var(--color-border);justify-content:space-between;align-items:center;margin-top:16px;padding-top:12px;font-size:.8rem;display:flex}.total-label{color:var(--color-ink-soft);font-weight:500}.total-value{font-family:var(--font-mono);color:var(--color-ink);font-weight:700}.loader-container{color:var(--color-ink-soft);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 20px;display:flex}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-brand-maroon);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.alert-error{background:var(--color-danger-soft);color:#8f1d1d;border-radius:var(--radius-md);border:1px solid #dc262640;align-items:center;gap:14px;margin-top:20px;padding:16px 20px;display:flex}.icon-error{flex-shrink:0;width:24px;height:24px}.alert-error p{flex:1;margin:0;font-size:.92rem}.btn-retry{background:var(--color-brand-maroon);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:8px 16px;font-size:.85rem;font-weight:600}@media (width<=900px){.dashboard-container{padding:20px}.summary-grid{grid-template-columns:repeat(2,1fr)}.dashboard-header{flex-direction:column;align-items:flex-start;padding:20px}.subtitle{margin-left:46px}}@media (width<=768px){.beds-grid{gap:24px;padding:10px}.kelas-block-title{border-bottom-width:2px;padding-bottom:4px;font-size:1.15rem}.kelas-section-block .bed-grid{flex-direction:column;gap:12px;width:100%}.kelas-section-block .bed-card{flex:100%;width:100%;min-width:0;box-shadow:0 1px 3px #0000000d}.kelas-section-block .card-header{padding:10px 14px}.kelas-section-block .card-header h3{font-size:1rem}.kelas-section-block .card-body{padding:12px}.kelas-section-block .stats-row{gap:8px}.kelas-section-block .stat-box{padding:10px}.kelas-section-block .stat-value{font-size:1.4rem}.kelas-section-block .stat-label{font-size:.75rem}.kelas-section-block .stat-icon{font-size:.85rem}}.title-with-icon{align-items:center;gap:14px;display:flex}.logo-main-png{object-fit:contain;filter:drop-shadow(0 2px 4px #00000026);flex-shrink:0;width:42px;height:42px}.kiosk-footer-copyright{border-top:1px solid var(--color-border);text-align:center;flex-direction:column;gap:4px;margin-top:40px;padding-top:20px;display:flex}.kiosk-footer-copyright p{color:var(--color-ink-soft);margin:0;font-size:.82rem;font-weight:500}.kiosk-footer-copyright .tech-stack{color:var(--color-ink-faint);letter-spacing:.03em;font-size:.76rem}body[data-v-5f1557b4]{background-color:#f4f6f9;margin:0}
