:root{color-scheme:light;font-family:Segoe UI,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color:#17324f;background:radial-gradient(circle at top left,rgba(255,255,255,.95),transparent 32%),linear-gradient(180deg,#dceefe,#edf7ff);--shell-bg: #edf7ff;--panel-main-bg: rgba(214, 236, 250, .86);--panel-main-border: rgba(73, 119, 164, .18);--panel-modal-bg: #c8dff4;--panel-history-bg: rgba(222, 241, 223, .95);--text-primary: #17324f;--text-secondary: #4d6780;--accent: #2d6f9f;--accent-strong: #1e5f8c;--border-soft: rgba(35, 76, 115, .14);--shadow-soft: 0 18px 40px rgba(32, 69, 104, .12);--success: #2d8f62;--danger: #c95050}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}button,input{font:inherit}button{border:0}.app-shell{min-height:100vh;padding:24px}.app-layout{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.app-header{display:grid;gap:14px}.app-header-top,.app-header-main{display:flex;justify-content:space-between;gap:20px}.app-header-top{align-items:baseline}.app-header-main{align-items:flex-start}.eyebrow{margin:0;font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-secondary)}.app-header h1,.panel-heading h2,.modal-header h3{margin:0}.app-header h1{font-size:clamp(1.8rem,3vw,2.8rem)}.tab-bar{display:inline-flex;flex-wrap:wrap;gap:10px;padding:8px;border-radius:999px;background:#ffffffb3;box-shadow:inset 0 0 0 1px #2d6f9f1a}.tab-btn{padding:12px 18px;border-radius:999px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color .15s ease,color .15s ease,transform .15s ease}.tab-btn:hover,.tab-btn:focus-visible{background:#2d6f9f1f;color:var(--text-primary);outline:none}.tab-btn--active{background:var(--accent);color:#fff;box-shadow:0 10px 20px #2d6f9f38}.panel{border-radius:28px;padding:24px;border:1px solid var(--panel-main-border);box-shadow:var(--shadow-soft)}.panel--main{background:var(--panel-main-bg)}.panel--history{background:var(--panel-history-bg)}.panel-heading{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:24px}.panel-heading p,.panel-copy,.panel-note,.helper-text,.empty-state,.error-text,.banner-text,.camera-meta,.mini-table td{margin:0;color:var(--text-secondary)}.summary-card{min-width:min(100%,260px);padding:20px 22px;border-radius:22px;background:#ffffffa3;border:1px solid rgba(255,255,255,.85)}.summary-label{margin:0 0 6px;font-weight:600;color:var(--text-secondary)}.summary-total{margin:0;font-size:clamp(2rem,4vw,3.2rem);line-height:1}.summary-date{margin-top:8px;font-size:.95rem}.actions-row,.history-toolbar,.modal-actions,.banner-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.refresh-btn,.primary-btn,.secondary-btn,.video-trigger,.icon-btn{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease}.refresh-btn,.primary-btn{padding:14px 20px;border-radius:16px;color:#fff;background:linear-gradient(135deg,#2d6f9f,#5694be);box-shadow:0 12px 24px #2d6f9f33}.refresh-btn:hover,.primary-btn:hover,.secondary-btn:hover,.video-trigger:hover,.icon-btn:hover{transform:translateY(-1px)}.secondary-btn{padding:12px 18px;border-radius:16px;background:#ffffffb8;color:var(--text-primary);border:1px solid rgba(23,50,79,.12)}.refresh-btn:disabled,.primary-btn:disabled,.secondary-btn:disabled{cursor:wait;opacity:.7;transform:none}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;font-size:.92rem;font-weight:600}.status-pill:before{content:"";width:10px;height:10px;border-radius:50%;display:inline-block}.status-pill--online{background:#2d8f621f;color:#1f754d}.status-pill--online:before{background:var(--success)}.status-pill--offline{background:#c950501f;color:#9a3131}.status-pill--offline:before{background:var(--danger)}.table-shell{overflow-x:auto;border-radius:22px;background:#ffffff8f;border:1px solid rgba(255,255,255,.8)}.data-table{width:100%;border-collapse:collapse;min-width:680px}.data-table th,.data-table td{padding:16px 18px;border-bottom:1px solid var(--border-soft);text-align:left}.data-table thead th{font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.data-table tbody tr:hover{background:#ffffff85}.data-table tbody tr:last-child td,.data-table tfoot tr:last-child td{border-bottom:0}.clickable-row{cursor:pointer}.count-cell{font-weight:700;color:var(--text-primary)}.location-cell strong{display:block}.location-cell span,.muted{color:var(--text-secondary)}.last-message-cell{display:inline-flex;flex-direction:column;gap:2px}.history-toolbar{margin-bottom:20px;justify-content:space-between}.date-picker{padding:12px 14px;border-radius:14px;border:1px solid rgba(23,50,79,.14);background:#ffffffb8;color:var(--text-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#1122367a;display:flex;align-items:center;justify-content:center;padding:20px}.modal-card{width:min(100%,980px);max-height:calc(100vh - 40px);overflow:auto;background:var(--panel-modal-bg);color:var(--text-primary);border-radius:28px;padding:24px;box-shadow:0 24px 60px #1122363d}.modal-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.icon-btn{min-width:42px;min-height:42px;border-radius:50%;background:#fffc;color:var(--text-primary)}.modal-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(260px,.95fr);gap:18px;margin-top:20px}.modal-section,.info-card,.video-stage,.banner{background:#fff9;border:1px solid rgba(255,255,255,.9);border-radius:22px}.modal-section,.video-stage,.info-card,.banner{padding:18px}.video-stage{min-height:340px;display:flex;align-items:center;justify-content:center}.video-stage video{width:100%;border-radius:16px;background:#0e2135}.video-placeholder{width:100%;display:grid;gap:16px;justify-items:center;text-align:center}.video-trigger{width:min(100%,260px);min-height:180px;border-radius:24px;background:linear-gradient(180deg,#ffffffe0,#d8e9f5eb);border:1px solid rgba(45,111,159,.18);color:var(--accent-strong)}.video-trigger__icon{display:block;font-size:3rem;line-height:1;margin-bottom:10px}.banner{display:grid;gap:14px;margin-bottom:16px;background:#fffadae6;border-color:#bc951d3d}.banner-title{margin:0;font-size:1rem}.mini-table{width:100%;border-collapse:collapse;margin-top:10px}.mini-table th,.mini-table td{padding:12px 10px;border-bottom:1px solid var(--border-soft);text-align:center}.mini-table tr:last-child td,.mini-table tr:last-child th{border-bottom:0}.mini-table th{width:120px;text-align:left}.error-text{color:#9a3131}.empty-state{padding:24px 0 8px}@media (max-width: 920px){.app-shell{padding:16px}.app-header-top,.app-header-main,.panel-heading,.history-toolbar,.modal-header,.modal-grid{grid-template-columns:1fr;display:grid;align-items:stretch}.tab-bar{width:100%;justify-content:stretch}.tab-btn{flex:1;text-align:center}.summary-card{min-width:100%}}@media (max-width: 640px){.panel,.modal-card{padding:18px;border-radius:22px}.data-table{min-width:560px}.video-stage{min-height:260px}}.login-container{max-width:360px;margin:80px auto;padding:2rem;text-align:center}.login-form{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.form-group{display:flex;flex-direction:column;text-align:left}.form-group label{margin-bottom:.25rem;font-weight:600}.form-group input{padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.login-error{color:#c00;font-size:.9rem}.login-btn{padding:.6rem;background:#2563eb;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.login-btn:disabled{opacity:.6;cursor:not-allowed}.app-header{margin-bottom:1rem}.user-info{display:flex;align-items:center;gap:.75rem;font-size:.95rem;justify-content:flex-end;flex-wrap:wrap}.logout-btn{padding:.45rem .9rem;background:linear-gradient(135deg,#c73d3d,#dc2626);color:#fff;border-radius:999px;cursor:pointer;font-size:.85rem;box-shadow:0 10px 18px #c73d3d2e}.admin-panel{margin-top:1rem}.admin-table{width:100%;border-collapse:collapse;margin-bottom:1.5rem}.admin-table th,.admin-table td{border:1px solid #ddd;padding:.5rem;text-align:left}.admin-table th{background:#f5f5f5}.delete-btn{padding:.25rem .5rem;background:#dc2626;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem}.admin-form{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.admin-form input,.admin-form select{padding:.4rem;border:1px solid #ccc;border-radius:4px}.admin-form button{padding:.4rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:4px;cursor:pointer}
