:root{--bg: #0f1117;--surface: #181c26;--surface2:#1e2433;--border: #2a3047;--accent: #4f7cff;--success: #34d399;--danger: #f87171;--warning: #fbbf24;--text: #e8ecf4;--muted: #6b7699;--radius: 10px}[data-theme=light]{--bg: #f0f4f8;--surface: #ffffff;--surface2:#f1f5f9;--border: #d1d9e6;--accent: #3b6fd4;--success: #059669;--danger: #dc2626;--warning: #d97706;--text: #1e2a3a;--muted: #64748b}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif;min-height:100vh;-webkit-tap-highlight-color:transparent}h1{font-size:1.6rem;font-weight:700}h2{font-size:1.2rem;font-weight:600}h3{font-size:1rem;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.2rem;border-radius:var(--radius);border:none;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;text-decoration:none;line-height:1}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn-sm{padding:.35rem .8rem;font-size:.85rem}.btn-lg{padding:.75rem 1.8rem;font-size:1.05rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.85rem;color:var(--muted);font-weight:500}input,select,textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1rem;padding:.55rem .85rem;width:100%;outline:none;transition:border-color .15s;font-family:inherit}input:focus,select:focus,textarea:focus{border-color:var(--accent)}input::placeholder{color:var(--muted)}.navbar{background:var(--surface);border-bottom:1px solid var(--border);padding:.75rem 1.25rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.navbar-brand{font-weight:700;font-size:1.1rem;color:var(--text);display:flex;align-items:center;gap:.5rem}.navbar-actions{display:flex;align-items:center;gap:.5rem}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-danger{background:color-mix(in srgb,var(--danger) 20%,transparent);color:var(--danger)}.badge-success{background:color-mix(in srgb,var(--success) 20%,transparent);color:var(--success)}.badge-accent{background:color-mix(in srgb,var(--accent) 20%,transparent);color:var(--accent)}.alarm-btn{width:200px;height:200px;border-radius:50%;border:none;font-size:1.3rem;font-weight:800;letter-spacing:.04em;cursor:pointer;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;line-height:1.2;background:var(--danger);color:#fff;box-shadow:0 0 color-mix(in srgb,var(--danger) 40%,transparent)}.alarm-btn:hover:not(:disabled){transform:scale(1.04);box-shadow:0 8px 30px color-mix(in srgb,var(--danger) 40%,transparent)}.alarm-btn:active:not(:disabled){transform:scale(.97)}.alarm-btn.active{background:var(--success);animation:pulse 2s ease-in-out infinite}.alarm-btn.active:hover:not(:disabled){box-shadow:0 8px 30px color-mix(in srgb,var(--success) 40%,transparent)}@keyframes alarm-flash{0%,to{opacity:1;transform:scale(1)}50%{opacity:.75;transform:scale(1.01)}}@keyframes pulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--success) 40%,transparent)}50%{box-shadow:0 0 0 18px color-mix(in srgb,var(--success) 0%,transparent)}}.alarm-card{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--danger);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem;animation:slideIn .25s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.alarm-card .teacher-name{font-size:1.15rem;font-weight:700}.alarm-card .room-info{color:var(--muted);font-size:.9rem}.alarm-card .time-info{color:var(--muted);font-size:.85rem}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{padding:.65rem 1rem;text-align:left;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:600;font-size:.8rem;text-transform:uppercase}tr:hover td{background:var(--surface2)}.text-muted{color:var(--muted)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-sm{font-size:.85rem}.gap-1{gap:.5rem}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-4{margin-top:2rem}.mb-2{margin-bottom:1rem}.w-full{width:100%}.theme-toggle{background:var(--surface2);border:1px solid var(--border);border-radius:999px;padding:.3rem .7rem;color:var(--muted);cursor:pointer;font-size:.85rem}.theme-toggle:hover{border-color:var(--accent);color:var(--text)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) * 1.5);padding:2rem;width:100%;max-width:380px;display:flex;flex-direction:column;gap:1.5rem}.login-logo{text-align:center;font-size:2.5rem}.login-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--surface2);border-radius:var(--radius);padding:.2rem;gap:.2rem}.login-tab{padding:.5rem;border:none;border-radius:calc(var(--radius) - 2px);background:transparent;color:var(--muted);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.login-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px #0003}.pin-display{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem;font-size:2rem;text-align:center;letter-spacing:.5em;font-family:monospace;min-height:3.5rem;color:var(--text)}.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.numpad button{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1.3rem;font-weight:600;padding:.85rem;cursor:pointer;transition:background .1s}.numpad button:hover{background:var(--border)}.numpad button:active{transform:scale(.95)}.numpad .del-btn{color:var(--danger)}.alarm-page{display:flex;flex-direction:column;min-height:100vh}.alarm-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;padding:2rem 1.5rem}.alarm-greeting{text-align:center;display:flex;flex-direction:column;gap:.3rem}.alarm-status{text-align:center;font-size:.95rem;min-height:1.5em;color:var(--muted)}.alarm-status.active{color:var(--success);font-weight:600}.dashboard-page{display:flex;flex-direction:column;min-height:100vh}.dashboard-main{flex:1;padding:1.5rem;max-width:1100px;margin:0 auto;width:100%}.alarms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem}.no-alarms{text-align:center;padding:3rem;color:var(--muted);border:2px dashed var(--border);border-radius:var(--radius)}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--success);display:inline-block;margin-right:.4rem;animation:blink 2s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.alert{padding:.75rem 1rem;border-radius:var(--radius);font-size:.9rem;border:1px solid transparent}.alert-error{background:color-mix(in srgb,var(--danger) 12%,transparent);border-color:color-mix(in srgb,var(--danger) 30%,transparent);color:var(--danger)}.alert-success{background:color-mix(in srgb,var(--success) 12%,transparent);border-color:color-mix(in srgb,var(--success) 30%,transparent);color:var(--success)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) * 1.5);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006;animation:modalIn .18s ease}@keyframes modalIn{0%{opacity:0;transform:translateY(-12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:1.25rem 1.5rem 1rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.modal-close{background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;padding:.25rem .6rem;border-radius:var(--radius);line-height:1}.modal-close:hover{color:var(--text);background:var(--surface2)}.modal-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.9rem;flex:1}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.75rem;position:sticky;bottom:0;background:var(--surface)}.modal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.modal-section{border-top:1px solid var(--border);padding-top:.75rem;margin-top:.25rem}.modal-section-label{font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.checkbox-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem;cursor:pointer}.checkbox-row input[type=checkbox]{width:1rem;height:1rem;min-height:unset;cursor:pointer}@media(max-width:768px){.navbar{padding:.6rem 1rem;gap:.4rem}.navbar-actions{gap:.35rem;flex-wrap:wrap;justify-content:flex-end}.navbar-actions .btn{font-size:.8rem;padding:.35rem .7rem}.navbar-brand{font-size:1rem}.dashboard-main{padding:1.25rem}.alarms-grid{grid-template-columns:1fr}.admin-tabs{overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:.25rem}.admin-tabs::-webkit-scrollbar{display:none}.admin-tabs .btn{white-space:nowrap;flex-shrink:0}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}th,td{white-space:nowrap}.login-card{padding:1.5rem}}@media(max-width:480px){h1{font-size:1.25rem}h2{font-size:1.05rem}.navbar{padding:.5rem .75rem}.navbar-brand{font-size:.95rem}.navbar-actions .btn-ghost{font-size:.78rem;padding:.3rem .6rem}.alarm-btn{width:160px;height:160px;font-size:1rem}.alarm-main{gap:1.5rem;padding:1.5rem 1rem}.alarm-greeting h1{font-size:1.2rem}.dashboard-main{padding:.85rem}.alarm-card{padding:.85rem 1rem}.no-alarms{padding:2rem 1rem}.table-wrap table{min-width:520px}.form-group label{font-size:.8rem}input,select{font-size:.95rem;padding:.5rem .75rem}.login-page{padding:2rem 1rem 1rem;align-items:flex-start}.login-card{padding:1.25rem;border-radius:var(--radius)}.pin-display{font-size:1.6rem}.numpad button{padding:.75rem;font-size:1.15rem}.card{padding:1rem}}@media(max-width:360px){.alarm-btn{width:140px;height:140px;font-size:.9rem}.numpad button{padding:.6rem;font-size:1rem}}@supports (padding: max(0px)){.navbar{padding-left:max(1.25rem,env(safe-area-inset-left));padding-right:max(1.25rem,env(safe-area-inset-right))}.alarm-main{padding-bottom:max(2rem,env(safe-area-inset-bottom))}}@media(pointer:coarse){.btn{min-height:44px}.numpad button{min-height:56px}input,select{min-height:44px}.login-tab{min-height:40px}th,td{padding:.75rem 1rem}}
