@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";:root{--bg-main:#f5f5f7;--bg-sidebar:#fff;--bg-surface:#fff;--bg-accent:#f4f4f5;--text-main:#1a1a2e;--text-secondary:#4b5563;--text-muted:#9ca3af;--primary:#1a1a2e;--primary-hover:#2d2d48;--primary-soft:#1a1a2e0d;--border-subtle:#e8e8ed;--border-bold:#d1d5db;--status-green:#22c55e;--status-amber:#f59e0b;--status-red:#ef4444;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--shadow-subtle:0 1px 2px #00000008;--shadow-md:0 4px 12px #0000000d;--shadow-hover:0 10px 25px #00000014;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--text-xs:.75rem;--text-sm:.875rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-main);color:var(--text-main);-webkit-font-smoothing:antialiased;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13.5px;line-height:1.5}img{max-width:100%;height:auto;display:block}button{font-family:inherit}h1,h2,h3,h4,.font-display{color:var(--text-main);font-family:Plus Jakarta Sans,sans-serif;line-height:1.2}h1{letter-spacing:-.02em;font-size:1.5rem;font-weight:800}h2{font-size:1.125rem;font-weight:700}h3{font-size:.938rem;font-weight:600}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-md{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes cardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.animated-fade-up{animation:.8s forwards fadeUp}.animated-slide{animation:.8s forwards slideRight}.delay-1{animation-delay:.2s}.bg-indigo-soft,.bg-emerald-soft,.bg-blue-soft,.bg-amber-soft,.bg-slate-soft{color:var(--text-main);background:#f8fafc}.text-amber{color:#d97706}.text-red{color:#ef4444}.text-white{color:#fff!important}.text-muted{color:var(--text-muted)}.text-primary{color:var(--primary)}.border-amber{border-color:#f59e0b!important}.border-red{border-color:#ef4444!important}.border-primary{border-color:var(--primary)!important}.border-top,.border-t{border-top:1px solid var(--border-subtle)}.border-slate-50{border-color:#f8fafc}.border-slate-100{border-color:#f1f5f9}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.flex-center{justify-content:center;align-items:center;display:flex}.flex-shrink-0{flex-shrink:0}.gap-1{gap:.25rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}@media (width>=768px){.md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}}.m-0{margin:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-8{margin-top:2rem}.mt-10{margin-top:2.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.ml-auto{margin-left:auto}.p-4{padding:1rem}.p-8{padding:2rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.px-10{padding-left:2.5rem;padding-right:2.5rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.w-full{width:100%}.w-3{width:.75rem}.w-10{width:2.5rem}.h-3{height:.75rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.text-right{text-align:right}.text-center{text-align:center}.font-mono{font-family:SF Mono,Fira Code,monospace}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.leading-relaxed{line-height:1.625}.hidden{display:none!important}.cursor-pointer{cursor:pointer}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.75rem}.rounded-2xl{border-radius:1rem}.overflow-hidden{overflow:hidden}.opacity-20{opacity:.2}.opacity-50{opacity:.5}.transition-all{transition:all .2s}.transition-colors{transition:color .2s}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.dot-status,.dot-green,.dot-amber,.dot-red,.status-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.dot-green,.status-dot.emerald{background:var(--status-green);box-shadow:0 0 8px #22c55e66}.dot-amber,.status-dot.amber{background:var(--status-amber);box-shadow:0 0 8px #f59e0b66}.dot-red,.status-dot.red{background:var(--status-red);box-shadow:0 0 8px #ef444466}.status-dot.indigo{background-color:#4f46e5}.status-dot.slate{background-color:#64748b}.status-dot.pulsing{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.skeleton{background:linear-gradient(90deg,#f0f0f2 25%,#f7f7f8 50%,#f0f0f2 75%) 0 0/200% 100%;border-radius:4px;animation:1.5s infinite shimmer}.bg-emerald-500{background-color:#10b981}.bg-amber-500{background-color:#f59e0b}.bg-slate-50\/80{background-color:#f8fafccc}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.text-slate-300{color:#cbd5e1}.text-slate-400{color:#94a3b8}.text-slate-500{color:#64748b}.text-slate-600{color:#475569}.text-red-400{color:#f87171}.hover\:text-red-600:hover{color:#dc2626}.hover\:bg-red-50:hover{background-color:#fef2f2}.app-shell{background-color:var(--bg-main);min-height:100vh;display:flex!important}.main-view{background:var(--bg-main);flex-direction:column!important;flex:1!important;display:flex!important}.content-container{width:100%;max-width:1400px;margin:0 auto;padding:1.5rem 2rem!important}.layout-header{border-bottom:1px solid var(--border-subtle);z-index:100;background:#fff;padding:1rem 0;position:sticky;top:0}.header-container{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:0 2rem;display:flex}.header-title{color:var(--text-main);letter-spacing:-.02em;font-size:1.25rem;font-weight:800}.header-actions{flex-flow:row!important;align-items:center!important;gap:.75rem!important;display:flex!important}.header-subtitle{display:none}.sidebar{z-index:50;background:var(--bg-sidebar)!important;border-right:1px solid var(--border-subtle)!important;flex-direction:column!important;width:240px!important;height:100vh!important;padding:1.5rem 1rem!important;display:flex!important;position:sticky!important;top:0!important}.sidebar-brand-box{align-items:center;gap:12px;padding:.5rem .5rem 2.5rem;display:flex}.sidebar-logo-mark{border:1px solid var(--border-subtle);background:#f4f4f5;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sidebar-logo-mark img{object-fit:contain;width:24px;height:24px}.sidebar-brand-text{flex-direction:column;display:flex}.brand-name{color:#0f172a;letter-spacing:-.02em;font-size:1.125rem;font-weight:800;line-height:1}.brand-tag{color:#64748b;letter-spacing:.2em;text-transform:uppercase;margin-top:1px;font-size:.563rem;font-weight:700}.nav-link{color:#64748b;cursor:pointer;border-radius:10px;align-items:center;gap:12px;margin-bottom:4px;padding:.625rem .875rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-link:hover{color:var(--text-main);background:#f1f5f9}.nav-link.active{color:var(--text-main);background:#f1f5f9;box-shadow:inset 0 0 0 1px #0000000d}.nav-link svg{opacity:.7;transition:opacity .2s}.nav-link:hover svg,.nav-link.active svg{opacity:1;color:var(--text-main)}.sidebar-footer{border-top:1px solid #e2e8f0;margin-top:auto;padding-top:1rem}.btn-premium,.btn-ghost,.btn-danger,.btn-filter,.btn-signout,.btn-add-field{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:.5rem 1rem;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn-premium{background:var(--primary);color:#fff}.btn-premium:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #1a1a2e26}.btn-ghost{color:var(--text-secondary);border-color:var(--border-subtle);background:0 0}.btn-ghost:hover{background:var(--bg-accent);border-color:var(--border-bold)}.btn-danger{color:#e11d48;background-color:#fff1f2;border:1px solid #fecdd3;font-weight:700}.btn-danger:hover{color:#fff;background-color:#fb7185;border-color:#fb7185;transform:translateY(-1px);box-shadow:0 4px 12px #e11d4833}.action-btn-danger{color:#94a3b8;cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.action-btn-danger:hover{color:#e11d48;background:#fff1f2;border-color:#fecdd3;transform:scale(1.05)}.btn-signout{color:#ef4444;background:0 0;border:none;width:100%}.btn-signout:hover{background-color:#fef2f2}.btn-icon{color:#cbd5e1;cursor:pointer;background:0 0;border:none;padding:.5rem;transition:color .2s}.btn-icon-danger,.btn-icon-subtle{cursor:pointer;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex}.btn-icon-danger{color:#ef4444;background:#fef2f2;border:1px solid #fee2e2}.btn-icon-subtle{color:var(--text-secondary);background:#f1f5f9;border:1px solid #e2e8f0}.btn-success-small{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:4px;padding:6px;font-size:.75rem;font-weight:600;display:flex}.btn-ghost-danger-small{color:#ef4444;cursor:pointer;background:0 0;border:1px solid #fee2e2;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:4px;padding:6px;font-size:.75rem;font-weight:600;display:flex}.btn-ghost-small{color:var(--text-secondary);border:1px solid var(--border-subtle);cursor:pointer;background:0 0;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:4px;padding:6px;font-size:.75rem;font-weight:600;display:flex}.btn-cloud-console{color:#0f172a;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:8px;height:44px;padding:0 24px;font-size:.875rem;font-weight:700;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 1px 2px #0000000d}.btn-cloud-console:hover{background:#f8fafc;border-color:#0f172a;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.btn-cloud-console svg{color:#64748b;transition:color .2s}.btn-cloud-console:hover svg{color:#0f172a}.card-overview,.detail-card,.feature-card,.status-card,.stat-card,.info-card,.action-card,.request-card,.feature-pill-card,.global-config-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all .2s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.card-overview:hover,.stat-card:hover,.feature-card:hover,.action-card:hover{border-color:var(--border-bold);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-overview{cursor:pointer;padding:1.25rem}.detail-card{background-color:#f8fafc;padding:2rem}.detail-card.plain{background-color:#fff}.stat-card{flex-direction:column;gap:.5rem;padding:1.25rem;display:flex;box-shadow:0 1px 2px #00000005}.stat-header{align-items:center;gap:.75rem;margin-bottom:.25rem;display:flex}.stat-icon{width:36px;height:36px;color:var(--text-secondary);background:#f1f5f9;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.688rem;font-weight:700}.stat-value{color:var(--text-main);letter-spacing:-.02em;font-size:1.5rem;font-weight:800}.stat-footer{color:var(--text-muted);margin-top:.25rem;font-size:.75rem;font-weight:600}.action-card{box-shadow:var(--shadow-subtle);background:#fff;padding:1.5rem}.action-card.border-emerald{border-left:3px solid var(--status-green)}.action-card.border-amber{border-left:3px solid var(--status-amber)}.action-card.border-indigo{border-left:3px solid var(--primary)}.action-card.border-red{border-left:3px solid var(--status-red)}.info-card{background:var(--bg-surface);padding:1.5rem}.request-card{flex-direction:column;gap:.875rem;padding:1.25rem;display:flex}.request-card.pending{border-left:3px solid var(--status-amber)}.request-card.resolved{border-left:3px solid var(--status-green);opacity:.75}.request-card.ignored{border-left:3px solid var(--text-muted);opacity:.6}.request-header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.request-body{flex-direction:column;gap:.75rem;display:flex}.request-meta{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.75rem;display:flex}.request-actions{border-top:1px solid var(--border-subtle);gap:.5rem;padding-top:.75rem;display:flex}.feature-pill-card{background:var(--bg-surface);border-radius:12px;align-items:center;gap:1rem;padding:1rem;display:flex}.card-icon-box{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:1rem;display:flex}.card-icon-box.emerald{color:#10b981;background:#10b9811a}.card-icon-box.amber{color:#f59e0b;background:#f59e0b1a}.card-icon-box.indigo{color:#6366f1;background:#6366f11a}.card-icon-box.red{color:#ef4444;background:#ef44441a}.switch{width:48px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#cbd5e1;border-radius:34px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:#4f46e5}input:checked+.slider:before{transform:translate(24px)}.ios-switch{width:40px;height:22px;display:inline-block;position:relative}.ios-switch input{opacity:0;width:0;height:0}.ios-slider{cursor:pointer;background-color:#e2e8f0;border-radius:34px;transition:all .3s;position:absolute;inset:0}.ios-slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;bottom:2px;left:2px;box-shadow:0 1px 3px #0000001a}input:checked+.ios-slider{background-color:#10b981}input:checked+.ios-slider:before{transform:translate(18px)}.input-premium,.input-field-modern,.input-field-hex{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;outline:none;width:100%;height:44px;padding:.75rem 1rem;font-size:.875rem;transition:all .2s}.input-premium:focus,.input-field-modern:focus,.input-field-hex:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #1a1a2e0d}.form-group-premium,.form-group-modern{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.form-group-premium label,.form-group-modern label{text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-size:.75rem;font-weight:700;display:block}.select-premium{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:1.25rem;padding-right:2.5rem}.search-input{background-color:#fff;border:1px solid #e2e8f0;border-radius:.5rem;outline:none;width:100%;padding:.5rem 1rem .5rem 2.25rem;font-size:.75rem;transition:all .2s}.search-icon,.filter-icon{color:var(--text-muted);pointer-events:none;z-index:10;position:absolute;left:.875rem}.search-group,.filter-group{align-items:center;display:flex;position:relative}.search-group input,.filter-group select{height:38px;color:var(--text-main);background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;outline:none;padding:0 1rem 0 2.5rem;font-size:.813rem;transition:all .2s}.search-group input{width:320px}.search-group input:focus,.filter-group select:focus{border-color:var(--text-main);background:#fff;box-shadow:0 0 0 3px #1a1a2e0d}.table-container{background-color:#fff;border:1px solid #f1f5f9;border-radius:1rem;overflow:hidden;box-shadow:0 1px 2px #0000000d}.table-base{text-align:left;border-collapse:collapse;width:100%}.table-base th{color:#94a3b8;text-transform:uppercase;letter-spacing:.1em;background-color:#f8fafc;border-bottom:1px solid #f1f5f9;padding:1rem 1.5rem;font-size:.6875rem;font-weight:700}.table-base td{border-bottom:1px solid #f8fafc;padding:1rem 1.5rem}.table-base tr:hover td{background-color:#f8fafc}.node-table-container{width:100%}.node-table{border-collapse:collapse;width:100%}.node-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border-subtle);background:#fcfcfd;padding:.875rem 1.5rem;font-size:.75rem;font-weight:700}.node-table td{border-bottom:1px solid var(--border-subtle);color:#4b5563;padding:1.25rem 1.5rem;font-size:.813rem;font-weight:500}.status-badge.online{color:#10b981;background:#10b98114}.status-badge.offline{color:#94a3b8;background:#94a3b814}.status-badge.pending{color:#f59e0b;background:#f59e0b14}.status-badge.resolved{color:#10b981;background:#10b98114}.status-badge.ignored{color:#94a3b8;background:#94a3b814}.status-indicator{text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:8px;font-size:.75rem;font-weight:700;display:inline-flex}.status-indicator .dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.status-indicator.online{color:#10b981}.status-indicator.online .dot{background:#10b981;box-shadow:0 0 6px #10b98166}.status-indicator.offline{color:#94a3b8}.status-indicator.offline .dot{background:#d1d5db}.status-dot-small{border-radius:50%;width:6px;height:6px}.status-badge.online .status-dot-small{background:#10b981;box-shadow:0 0 6px #10b98166}.status-badge.offline .status-dot-small{background:#d1d5db}.node-info{align-items:center;gap:12px;display:flex}.node-details{flex-direction:column;display:flex}.node-name{color:#0f172a;font-size:.938rem;font-weight:700}.node-code{text-transform:uppercase;color:#475569;background:#f1f5f9;border-radius:6px;padding:2px 8px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.75rem;font-weight:700}.node-avatar,.list-item-logo{background:#f1f1f4;border:1px solid #e8e8ed;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;overflow:hidden}.node-avatar img,.list-item-logo img{object-fit:contain;width:100%;height:100%;padding:4px}.namespace-pill{color:#475569;text-transform:uppercase;background:#f1f5f9;border-radius:6px;padding:2px 8px;font-size:.75rem;font-weight:700}.clickable-row{cursor:pointer;transition:background .2s}.clickable-row:hover{background:#fafafb}.empty-row{text-align:center;color:var(--text-muted);padding:3rem 1rem;font-size:.875rem}.modern-list-container{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden}.list-header{border-bottom:1px solid var(--border-subtle);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;background:#f8fafc;grid-template-columns:2fr 1.5fr 1fr 60px;padding:.75rem 1.5rem;font-size:.688rem;font-weight:700;display:grid}.list-row{border-bottom:1px solid var(--border-subtle);grid-template-columns:2fr 1.5fr 1fr 60px;align-items:center;padding:1rem 1.5rem;transition:background .2s;display:grid}.list-row:last-child{border-bottom:none}.list-row:hover{background:#fcfcfd}.list-empty{text-align:center;color:var(--text-muted);padding:2.5rem 1.5rem;font-size:.875rem}.user-info-block{align-items:center;gap:.75rem;display:flex}.user-avatar-circle{background:var(--primary-soft);width:36px;height:36px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.813rem;font-weight:700;display:flex}.user-details{flex-direction:column;gap:2px;min-width:0;display:flex}.user-name-primary{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:700;overflow:hidden}.user-id-sub{color:var(--text-muted);font-size:.688rem;font-weight:500}.contact-chip{color:var(--text-secondary);align-items:center;gap:6px;font-size:.813rem;font-weight:500;display:inline-flex}.role-badge{text-transform:uppercase;letter-spacing:.05em;color:#475569;background:#f1f5f9;border-radius:6px;align-items:center;padding:3px 10px;font-size:.688rem;font-weight:800;display:inline-flex}.role-badge.admin{color:#6366f1;background:#6366f114}.role-badge.clerk{color:#10b981;background:#10b98114}.role-badge.teacher{color:#d97706;background:#f59e0b14}.school-tag{color:var(--text-secondary);align-items:center;gap:6px;font-size:.75rem;font-weight:600;display:inline-flex}.user-info{align-items:center;gap:.75rem;display:flex}.user-avatar-small{background:var(--primary-soft);width:32px;height:32px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.user-name-label{color:var(--text-main);font-size:.875rem;font-weight:700}.user-contact-label{color:var(--text-muted);align-items:center;gap:4px;margin-top:2px;font-size:.75rem;display:flex}.btn-icon-sm{border:1px solid var(--border-subtle);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-icon-sm:hover{color:var(--text-main);border-color:var(--border-bold);background:#f8fafc}.tab-container{border-bottom:1px solid var(--border-subtle);gap:2rem;margin-bottom:2.5rem;display:flex}.tab-item{color:var(--text-secondary);cursor:pointer;padding:.75rem .25rem;font-weight:500;transition:color .2s;position:relative}.tab-item:hover{color:var(--text-main)}.tab-item.active{color:var(--primary);font-weight:600}.tab-item.active:after{content:"";background:var(--primary);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-1px;left:0;right:0}.modern-tabs-wrapper{border-bottom:1px solid var(--border-subtle);gap:.5rem;margin-bottom:2rem;padding-bottom:2px;display:flex}.modern-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.modern-tab:hover{color:var(--text-main);background:#f8fafc;border-radius:6px 6px 0 0}.modern-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.modal-overlay-premium{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;padding:1.5rem;animation:.3s ease-out modalFadeIn;display:flex;position:fixed;inset:0}.modal-container-premium{background:#fff;border:1px solid #fffc;border-radius:24px;flex-direction:column;width:100%;max-width:440px;max-height:calc(100vh - 3rem);animation:.4s cubic-bezier(.16,1,.3,1) modalSlideUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000026}.modal-container-premium.modal-wide{max-width:580px}.modal-header-premium{border-bottom:1px solid #f1f5f9;padding:2rem 2rem 1.25rem}.modal-header-premium h3{color:#0f172a;letter-spacing:-.02em;font-size:1.25rem;font-weight:800}.modal-header-premium p{color:#64748b;margin-top:4px;font-size:.875rem;line-height:1.5}.modal-body-premium{scrollbar-width:thin;scrollbar-color:var(--border-subtle) transparent;flex:1;padding:2rem;overflow-y:auto}.modal-body-premium::-webkit-scrollbar{width:6px}.modal-body-premium::-webkit-scrollbar-track{background:0 0}.modal-body-premium::-webkit-scrollbar-thumb{background-color:var(--border-subtle);border-radius:10px}.form-group-premium{margin-bottom:1.5rem}.form-group-premium label{text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:.5rem;font-size:.75rem;font-weight:700;display:block}.modal-footer-premium{gap:1rem;padding:1.25rem 2rem 2rem;display:flex}.modal-footer-premium button{flex:1}.modal-container-premium form{flex-direction:column;flex:1;display:flex;overflow:hidden}.auth-page{color:#1a1a2e;background:#f5f5f7;min-height:100vh;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;display:flex;position:relative}.auth-bg{z-index:0;pointer-events:none;position:fixed;inset:0}.auth-orb{display:none}.auth-noise{opacity:0;position:absolute;inset:0}.auth-brand-panel{z-index:1;background:#fff;border-right:1px solid #e8e8ed;flex-direction:column;justify-content:center;align-items:center;width:45%;padding:3rem;display:none;position:relative}@media (width>=1024px){.auth-brand-panel{display:flex}}.auth-brand-panel:before{content:"";opacity:.4;background-image:radial-gradient(circle,#d1d5db .8px,#0000 .8px);background-size:24px 24px;position:absolute;inset:0}.auth-brand-content{text-align:center;z-index:1;position:relative}.auth-logo-mark{background:#f0f0f5;border:1px solid #e8e8ed;border-radius:18px;justify-content:center;align-items:center;width:68px;height:68px;margin:0 auto 1.5rem;display:flex}.auth-logo-img{object-fit:contain;width:40px;height:40px}.auth-brand-name{letter-spacing:.3em;color:#1a1a2e;margin:0 0 .5rem;font-family:Plus Jakarta Sans,sans-serif;font-size:1.75rem;font-weight:300}.auth-brand-tagline{color:#9ca3af;letter-spacing:.12em;text-transform:uppercase;margin:0;font-size:.78rem;font-weight:500}.auth-brand-footer{color:#9ca3af;text-transform:uppercase;letter-spacing:.08em;z-index:1;align-items:center;gap:.5rem;font-size:.7rem;font-weight:600;display:flex;position:absolute;bottom:2.5rem}.auth-form-panel{z-index:1;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex;position:relative}@media (width>=1024px){.auth-form-panel{flex:none;width:55%}}.auth-card{background:#fff;border:1px solid #e8e8ed;border-radius:20px;width:100%;max-width:400px;padding:2.5rem;animation:.5s cubic-bezier(.16,1,.3,1) cardIn;box-shadow:0 1px 3px #0000000a,0 6px 24px #0000000f}.auth-card-header{margin-bottom:2rem}.auth-header-icon{color:#1a1a2e;opacity:.7;margin-bottom:1rem}.auth-card-header h2{color:#1a1a2e;letter-spacing:-.02em;margin:0 0 .375rem;font-size:1.5rem;font-weight:700}.auth-card-header p{color:#9ca3af;margin:0;font-size:.85rem;line-height:1.5}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.auth-field label{color:#4b5563;letter-spacing:.01em;margin-bottom:.5rem;font-size:.8rem;font-weight:600;display:block}.auth-input-wrap{align-items:center;display:flex;position:relative}.auth-input-icon{color:#9ca3af;pointer-events:none;z-index:10;transition:color .2s;position:absolute;left:14px}.auth-input-wrap input{color:#1a1a2e;background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;outline:none;width:100%;padding:.8rem 1rem .8rem 2.75rem;font-family:Plus Jakarta Sans,sans-serif;font-size:.875rem;transition:all .2s}.auth-input-wrap input:focus{background:#fff;border-color:#1a1a2e;box-shadow:0 0 0 3px #1a1a2e0f}.auth-input-wrap:focus-within .auth-input-icon{color:#1a1a2e}.auth-toggle-pw{color:#9ca3af;cursor:pointer;z-index:10;background:0 0;border:none;padding:4px;display:flex;position:absolute;right:12px}.auth-otp-input{text-align:center!important;letter-spacing:.5em!important;padding-left:1rem!important;font-size:1.5rem!important;font-weight:600!important}.auth-submit{color:#fff;cursor:pointer;background:#1a1a2e;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.5rem;padding:.85rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.auth-submit:hover:not(:disabled){background:#2d2d48;box-shadow:0 4px 12px #1a1a2e26}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-spinner{border:2px solid #ffffff40;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.auth-qr-area{text-align:center;margin-bottom:.5rem}.auth-qr-box{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px;display:inline-block}.auth-qr-box img{width:160px;height:160px;display:block}.auth-status-dot{background:var(--status-green);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse;box-shadow:0 0 8px #22c55e66}.auth-footer-link{border-top:1px solid #f0f0f5;justify-content:center;align-items:center;gap:.4rem;margin-top:1.75rem;padding-top:1.25rem;font-size:.8rem;display:flex}.auth-footer-link span{color:#9ca3af}.auth-footer-link a{color:#1a1a2e;font-weight:600;text-decoration:none}.auth-qr-hint{color:var(--text-muted);margin-top:.5rem;font-size:.75rem}.auth-back-btn{text-align:center;width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-top:1.25rem;padding:.5rem;font-size:.813rem;font-weight:500;transition:color .2s;display:block}.auth-back-btn:hover{color:var(--text-main)}.dashboard-grid-layout{grid-template-columns:1fr 320px;align-items:start;gap:1.5rem;display:grid}@media (width<=1200px){.dashboard-grid-layout{grid-template-columns:1fr}}.dashboard-metrics{grid-template-columns:repeat(1,minmax(0,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}@media (width>=768px){.dashboard-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}}.metrics-grid{grid-template-columns:repeat(1,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}@media (width>=1024px){.metrics-grid{grid-template-columns:repeat(4,1fr)}}.dashboard-content{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:#fff;overflow:hidden;box-shadow:0 1px 3px #00000005}.content-toolbar{border-bottom:1px solid var(--border-subtle);background:#fff;justify-content:space-between;align-items:center;gap:.75rem;padding:1rem 1.5rem;display:flex}.toolbar-left,.toolbar-right{align-items:center;gap:.75rem;display:flex}.btn-icon-ghost{border:1px solid var(--border-subtle);width:38px;height:38px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-icon-ghost:hover{color:var(--text-main);border-color:var(--border-bold);background:#f8fafc}.dashboard-activity-sidebar{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);flex-direction:column;height:calc(100vh - 180px);padding:1.25rem 0;display:flex;position:sticky;top:100px}.sidebar-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:0 1.5rem 1rem;display:flex}.activity-list{flex-direction:column;flex:1;gap:1.25rem;padding:1.25rem 1.5rem;display:flex;overflow-y:auto}.activity-empty{text-align:center;color:var(--text-muted);padding:2rem 0;font-size:.813rem}.activity-item{margin-bottom:0;padding-left:1.25rem;position:relative}.activity-item:last-child .activity-line{display:none}.activity-point{z-index:1;background:#1a1a2e;border-radius:50%;width:4px;height:4px;position:absolute;top:8px;left:1px}.activity-line{background:#f1f5f9;width:1px;position:absolute;top:12px;bottom:-20px;left:2.5px}.activity-time{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-size:.625rem;font-weight:700;display:block}.activity-desc{color:var(--text-secondary);font-size:.813rem;line-height:1.5}.activity-school{color:var(--text-secondary);background:0 0;align-items:center;gap:4px;margin-top:4px;padding:0;font-size:.75rem;font-weight:600;display:flex}.alert-strip{border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:.875rem 1.25rem;font-size:.813rem;transition:all .2s;display:flex}.alert-strip.amber{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.alert-strip.amber:hover{background:#fef3c7;box-shadow:0 2px 8px #f59e0b1a}.system-section{flex-direction:column;gap:2rem;display:flex}.system-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=768px){.system-grid{grid-template-columns:repeat(3,1fr)}}.infrastructure-layout{flex-direction:column;gap:1.5rem;display:flex}.section-intro{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.intro-text h2{margin:0 0 .25rem;font-size:1.125rem}.intro-text p{color:var(--text-muted);margin:0;font-size:.813rem}.service-map-container{border-radius:var(--radius-xl);background-color:#f8fafc;border:1px solid #f1f5f9;padding:2rem}.service-item{background-color:#fff;border:1px solid #f1f5f9;border-radius:.75rem;justify-content:space-between;align-items:center;padding:1rem;display:flex}.audit-list-container{background-color:#fff;border:1px solid #f1f5f9;border-radius:1rem;overflow:hidden}.audit-item{border-bottom:1px solid #f8fafc;justify-content:space-between;align-items:center;padding:1rem;transition:background-color .2s;display:flex}.audit-item:hover{background-color:#f8fafc}.audit-icon{border-radius:.5rem;padding:.5rem}.audit-icon.critical{color:#dc2626;background-color:#fef2f2}.audit-icon.normal{color:#94a3b8;background-color:#f8fafc}.settings-stack{flex-direction:column;gap:1.5rem;display:flex}.settings-group{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.5rem}.group-header{color:var(--text-main);border-bottom:1px solid var(--border-subtle);align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;font-size:.938rem;font-weight:700;display:flex}.config-list-modern{flex-direction:column;gap:0;display:flex}.modern-config-item{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:1.5rem;padding:1rem 0;display:flex}.modern-config-item:last-child{border-bottom:none}.modern-config-item.mt-4{margin-top:0}.config-info{flex-direction:column;flex:1;gap:3px;display:flex}.config-label{color:var(--text-main);font-size:.875rem;font-weight:700}.config-hint{color:var(--text-muted);font-size:.75rem;line-height:1.4}.security-audit-content,.global-settings-content{flex-direction:column;display:flex}.tab-content-area{padding-top:1.5rem}.status-card{padding:var(--space-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);background:#fff;border:1px solid #eef2f6;flex-direction:column;display:flex}.status-card h4{color:#1e293b;margin-bottom:var(--space-md);align-items:center;gap:8px;font-size:1rem;font-weight:800;display:flex}.infra-tab-content .status-card h4{justify-content:center;margin-top:-.25rem}.status-list{flex-direction:column;gap:0;display:flex}.status-item{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:.75rem 0;font-size:.813rem;display:flex}.status-item:last-child{border-bottom:none}.status-item span{color:var(--text-muted);font-weight:500}.status-item b{color:var(--text-main);font-weight:700}.overview-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.admin-header{margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:flex-end;display:flex}.admin-header h2{margin:0}.logo-config-card{gap:var(--space-xl);padding:var(--space-xl);border-radius:var(--radius-xl);margin-bottom:var(--space-xl);background:#f8fafc;border:1px dashed #cbd5e1;grid-template-columns:280px 1fr;align-items:center;display:grid}@media (width<=768px){.logo-config-card{grid-template-columns:1fr}}.logo-preview-wrapper{background:#fff;border-radius:16px;justify-content:center;align-items:center;min-height:140px;padding:1.5rem;display:flex;box-shadow:0 10px 15px -3px #0000001a}.logo-preview-wrapper img{object-fit:contain;max-width:160px;max-height:160px}.logo-upload-info{flex-direction:column;gap:.25rem;display:flex}.logo-upload-info h4{color:var(--text-main);margin:0 0 .5rem;font-size:1rem;font-weight:800}.logo-upload-info p{color:var(--text-muted);margin:0;font-size:.813rem;line-height:1.5}.theme-config-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.color-picker-item{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.color-picker-item label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.625rem;font-weight:800;display:block}.color-input-wrapper{align-items:center;gap:.75rem;display:flex}.color-input-wrapper input[type=color]{cursor:pointer;border:none;border-radius:8px;flex-shrink:0;width:36px;height:36px;padding:0}.color-value-text{color:var(--text-secondary);font-family:SF Mono,Fira Code,monospace;font-size:.813rem;font-weight:700}.module-card{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);background:#fff;border:1px solid #eef2f6;justify-content:space-between;align-items:center;display:flex}.module-info{align-items:center;gap:1rem;display:flex}.module-icon{color:#64748b;background:#f1f5f9;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.module-text h5{color:#1e293b;margin:0 0 2px;font-size:.875rem;font-weight:700}.module-text p{color:#94a3b8;margin:0;font-size:.75rem}.module-list{flex-direction:column;gap:1.5rem;display:flex}.danger-section{margin-top:var(--space-xl);padding:var(--space-xl);border-radius:var(--radius-lg);background:#fff1f2;border:1px solid #fecdd3}.danger-header{color:#e11d48;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.danger-header h4{color:#e11d48;margin:0;font-size:1rem;font-weight:800}.danger-section p{color:#9f1239;margin-bottom:1rem;font-size:.813rem;line-height:1.5}.resource-bar-container{background:#f1f5f9;border-radius:10px;height:6px;margin-top:6px;overflow:hidden}.resource-bar-fill{border-radius:10px;height:100%;transition:width 1s ease-in-out}.resource-bar-fill.primary{background:var(--primary);box-shadow:0 0 8px #6366f14d}.resource-bar-fill.emerald{background:#10b981;box-shadow:0 0 8px #10b9814d}.resource-item{margin-bottom:1rem}.resource-item:last-child{margin-bottom:0}.btn-manage-subtle{color:#475569;cursor:pointer;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem 1rem;font-size:.75rem;font-weight:700;transition:all .2s}.btn-manage-subtle:hover{color:var(--text-main);background:#e2e8f0}.btn-add-field-action{color:#64748b;cursor:pointer;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px;align-items:center;gap:8px;padding:.625rem 1rem;font-size:.75rem;font-weight:700;transition:all .2s;display:flex}.btn-add-field-action:hover{border-color:var(--text-muted);background:#f1f5f9}.school-detail-container{flex-direction:column;display:flex}.branding-section{flex-direction:column;gap:0;display:flex}.input-hint-premium{color:var(--text-muted);margin-top:.5rem;font-size:.688rem;line-height:1.5}.section-container{flex-direction:column;gap:1.5rem;display:flex}.toolbar{justify-content:space-between;align-items:center;gap:1rem;display:flex}.search-bar{flex:1;align-items:center;max-width:400px;display:flex;position:relative}.search-bar .search-icon{color:var(--text-muted);pointer-events:none;z-index:1;position:absolute;left:.875rem}.search-bar .search-input{width:100%;padding-left:2.5rem}.loading-state{justify-content:center;align-items:center;padding:4rem 0;display:flex}.spinner{border:3px solid var(--border-subtle);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}.loading-spinner-premium{border:3px solid var(--border-subtle);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}.loading-spinner-small{border:2px solid #0000001a;border-top-color:currentColor;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.empty-state .empty-icon{color:var(--text-muted);opacity:.3;margin-bottom:.5rem}.empty-state h3{color:var(--text-main);margin:0;font-size:1.125rem;font-weight:700}.empty-state p{color:var(--text-muted);max-width:360px;margin:0;font-size:.875rem}.requests-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem;display:grid}.performance-container{flex-direction:column;gap:2rem;padding-bottom:2rem;display:flex}.metrics-overview-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;display:grid}.metric-card-premium{background:#fff;border:1px solid #f1f5f9;border-radius:1.25rem;flex-direction:column;gap:1rem;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -2px #0000000d}.metric-card-premium:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.metric-header{justify-content:space-between;align-items:center;display:flex}.metric-icon-box{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.metric-icon-box.cpu{color:#2563eb;background:#eff6ff}.metric-icon-box.ram{color:#7c3aed;background:#f5f3ff}.metric-icon-box.db{color:#059669;background:#ecfdf5}.metric-icon-box.rps{color:#ea580c;background:#fff7ed}.metric-label{color:#64748b;font-size:.875rem;font-weight:600}.metric-value-container{align-items:baseline;gap:.5rem;display:flex}.metric-value-large{color:#1e293b;letter-spacing:-.025em;font-size:1.875rem;font-weight:800}.metric-unit{color:#94a3b8;font-size:.875rem;font-weight:500}.usage-bar-container{background:#f1f5f9;border-radius:4px;width:100%;height:8px;margin-top:.5rem;overflow:hidden}.usage-bar-fill{border-radius:4px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.usage-bar-fill.blue{background:linear-gradient(90deg,#3b82f6,#2563eb)}.usage-bar-fill.purple{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.usage-bar-fill.green{background:linear-gradient(90deg,#10b981,#059669)}.health-monitor-section{background:#fff;border:1px solid #f1f5f9;border-radius:1.5rem;padding:2rem}.section-title-premium{color:#1e293b;align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:1.125rem;font-weight:700;display:flex}.subsystem-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.subsystem-card{background:#f8fafc;border:1px solid #f1f5f9;border-radius:1rem;align-items:center;gap:1rem;padding:1.25rem;transition:background .2s;display:flex}.subsystem-card:hover{background:#f1f5f9}.status-dot{border-radius:50%;width:10px;height:10px;position:relative}.status-dot.active{background:#10b981;box-shadow:0 0 10px #10b98180}.status-dot.degraded{background:#f59e0b;box-shadow:0 0 10px #f59e0b80}.status-dot.missing{background:#94a3b8}.subsystem-info{flex:1}.subsystem-name{color:#1e293b;margin-bottom:2px;font-size:.938rem;font-weight:700}.subsystem-meta{color:#64748b;gap:.75rem;font-size:.75rem;display:flex}.status-badge-premium{text-transform:uppercase;letter-spacing:.025em;border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-weight:700}.status-badge-premium.healthy{color:#166534;background:#dcfce7}.status-badge-premium.warning{color:#92400e;background:#fef3c7}@keyframes pulse-glow{0%{box-shadow:0 0 #10b98166}70%{box-shadow:0 0 0 10px #10b98100}to{box-shadow:0 0 #10b98100}}.pulse-active{animation:2s infinite pulse-glow}.flex-between-center{justify-content:space-between;align-items:center;display:flex}.flex-center-spinner{flex-direction:column;justify-content:center;align-items:center;padding:80px 20px;display:flex}.text-loading{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:12px;font-size:11px;font-weight:700}.empty-panel-card{text-align:center;background:var(--bg-surface);border:1px dashed var(--border-bold);border-radius:var(--radius-lg);padding:60px 40px}.empty-panel-card h3{color:var(--text-main);margin:12px 0 6px;font-size:14px;font-weight:700}.empty-panel-card p{color:var(--text-secondary);max-width:320px;margin:0 auto;font-size:12px}.text-muted-icon{color:var(--text-muted);margin:0 auto}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1.5rem;display:grid}.template-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-subtle);flex-direction:column;justify-content:space-between;padding:1.5rem;transition:all .2s cubic-bezier(.16,1,.3,1);display:flex}.template-card:hover{border-color:var(--border-bold);box-shadow:var(--shadow-md);transform:translateY(-2px)}.badge-row{gap:6px;margin-bottom:12px;display:flex}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:4px 10px;font-size:9px;font-weight:800}.badge.rule{background:var(--primary-soft);color:var(--text-main);border:1px solid var(--border-subtle)}.badge.role{color:var(--text-secondary);background:#f1f5f9}.badge.custom{color:var(--status-amber);background:#f59e0b1a}.template-name{color:var(--text-main);margin:0 0 12px;font-size:15px;font-weight:700;line-height:1.4}.template-preview-box{background:var(--bg-accent);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:12px;padding:12px}.preview-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px;font-size:9px;font-weight:700}.preview-title{color:var(--text-main);margin-bottom:12px;font-size:12px;font-weight:700}.preview-body{color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;font-family:SF Mono,Fira Code,monospace;font-size:11px;line-height:1.5}.template-actions{border-top:1px solid var(--border-subtle);gap:8px;margin-top:1.25rem;padding-top:1rem;display:flex}.btn-push{background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:11px;font-weight:700;transition:background .15s;display:inline-flex}.btn-push:hover{background:var(--primary-hover)}.btn-push:disabled{opacity:.6;cursor:not-allowed}.btn-delete-icon{border:1px solid var(--border-subtle);width:38px;height:38px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-delete-icon:hover{color:var(--status-red);background:#ef44440d;border-color:#ef444433}.broadcast-layout{grid-template-columns:1.2fr 1fr;align-items:start;gap:2rem;display:grid}@media (width<=1024px){.broadcast-layout{grid-template-columns:1fr}}.broadcast-form-panel,.broadcast-schools-panel{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-subtle);padding:1.75rem}.form-card-header,.schools-panel-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;display:flex}.form-card-header h4,.schools-panel-header h4{text-transform:uppercase;letter-spacing:.05em;color:var(--text-main);margin:0;font-size:14px;font-weight:800}.btn-link-action{color:var(--text-main);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border:none;font-size:11px;font-weight:700}.btn-link-action:hover{color:var(--primary-hover);text-decoration:underline}.alert-badge-tip{background:var(--primary-soft);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);align-items:center;margin-top:1rem;padding:10px 14px;font-size:11px;line-height:1.4;display:flex}.spinner-loader{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin-notif}.schools-select-list{flex-direction:column;gap:8px;max-height:480px;padding-right:4px;display:flex;overflow-y:auto}.school-select-item{background:var(--bg-accent);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;justify-content:space-between;align-items:center;padding:12px 16px;transition:all .2s;display:flex}.school-select-item:hover{border-color:var(--border-bold);background:#f1f5f9}.school-select-item.selected{background:var(--primary-soft);border-color:var(--primary)}.school-details{flex-direction:column;gap:2px;display:flex}.school-name{color:var(--text-main);font-size:12.5px;font-weight:700}.school-code{color:var(--text-muted);font-family:SF Mono,Fira Code,monospace;font-size:9px;font-weight:600}.checkbox-box{color:var(--text-muted);transition:color .15s}.checkbox-box.checked{color:var(--primary)}.form-grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=640px){.form-grid-2{grid-template-columns:1fr}}.variables-overlay-banner{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:#f8fafc;margin-bottom:1.5rem;padding:12px 16px}.variables-title{text-transform:uppercase;color:var(--text-secondary);letter-spacing:.05em;margin-bottom:6px;font-size:10px;font-weight:800}.variables-list{flex-wrap:wrap;gap:6px;display:flex}.variable-chip{border:1px solid var(--border-subtle);color:var(--text-main);cursor:copy;background:#fff;border-radius:4px;padding:2px 8px;font-family:monospace;font-size:10px}.variable-chip:hover{background:var(--bg-main)}@keyframes spin-notif{to{transform:rotate(360deg)}}.school-templates-list{flex-direction:column;gap:1.5rem;display:flex}.school-template-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.5rem;transition:all .2s}.school-template-card.inactive{opacity:.65;background:var(--bg-accent)}.school-template-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;padding-bottom:1rem;display:flex}.school-template-info{flex-direction:column;gap:6px;display:flex}.school-template-title-bar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.school-template-title-bar h3{color:var(--text-main);margin:0;font-size:1.125rem;font-weight:700}.status-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:12px;align-items:center;gap:4px;padding:3px 8px;font-size:9px;font-weight:800;display:inline-flex}.status-badge.active{color:var(--status-green);background:#22c55e1a}.status-badge.inactive{color:var(--status-red);background:#ef44441a}.status-badge.custom{color:var(--status-amber);background:#f59e0b1a}.school-template-meta{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;gap:1rem;font-size:10px;font-weight:700;display:flex}.school-template-content-grid{grid-template-columns:2fr 1fr;gap:1.5rem;display:grid}@media (width<=768px){.school-template-content-grid{grid-template-columns:1fr}}.school-template-preview-panel{flex-direction:column;gap:1rem;display:flex}.preview-field-box{background:var(--bg-accent);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px 16px}.preview-field-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.preview-field-header span{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-size:9px;font-weight:800}.preview-field-header b{text-transform:uppercase;color:var(--text-secondary);border:1px solid var(--border-subtle);background:#fff;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:800}.preview-field-val{color:var(--text-main);font-size:13px;font-weight:700}.preview-field-body-val{color:var(--text-secondary);font-family:SF Mono,Fira Code,monospace;font-size:12px;line-height:1.5}.school-template-schedule-panel{background:var(--bg-accent);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-direction:column;justify-content:space-between;min-height:140px;padding:1rem;display:flex}.schedule-header{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-size:9px;font-weight:800}.schedule-time-display{align-items:center;gap:8px;margin-top:10px;display:flex}.schedule-time-val{color:var(--text-main);font-size:20px;font-weight:800}.schedule-time-freq{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;font-size:10px;font-weight:700}.school-template-edit-form{border-top:1px solid var(--border-subtle);flex-direction:column;gap:1.25rem;margin-top:1rem;padding-top:1.25rem;display:flex}.form-actions-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:1rem;display:flex}.actions-left-group{gap:8px;display:flex}.pgbouncer-alert-banner{color:#92400e;background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%);border:1px solid #fde68a;border-radius:1rem;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;animation:.4s cubic-bezier(.16,1,.3,1) slideInDown;display:flex;box-shadow:0 4px 6px -1px #fbbf240d}.alert-icon-wrapper{color:#d97706;flex-shrink:0;justify-content:center;align-items:center;padding-top:2px;display:flex}.alert-content-wrapper{flex-direction:column;gap:.25rem;display:flex}.alert-title{margin:0;font-size:.938rem;font-weight:700}.alert-description{opacity:.9;margin:0;font-size:.813rem;line-height:1.4}.pooling-mode-toggle-group{background:#f1f5f9;border-radius:.75rem;gap:4px;max-width:fit-content;margin-top:1rem;padding:4px;display:flex}.pooling-toggle-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:.5rem;padding:.5rem 1.25rem;font-size:.813rem;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1)}.pooling-toggle-btn:hover{color:#334155;background:#ffffff80}.pooling-toggle-btn.active{color:#0f172a;background:#fff;box-shadow:0 2px 4px #0000000d,0 1px 2px #0000000d}.pooling-mode-description{transition:opacity .25s ease-out}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.risk-badge{text-transform:uppercase;border-radius:9999px;align-items:center;gap:.375rem;padding:.25rem .75rem;font-size:.75rem;font-weight:700;display:inline-flex}.risk-badge.green{color:#16a34a;background-color:#22c55e1a;border:1px solid #22c55e33}.risk-badge.yellow{color:#d97706;background-color:#f59e0b1a;border:1px solid #f59e0b33}.risk-badge.red{color:#dc2626;background-color:#ef44441a;border:1px solid #ef444433}.status-badge{border-radius:.375rem;align-items:center;gap:.25rem;padding:.125rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-badge.success{color:#16a34a;background-color:#22c55e14}.status-badge.pending{color:#d97706;background-color:#f59e0b14}.status-badge.failed{color:#dc2626;background-color:#ef444414}.status-badge.untested{color:#6b7280;background-color:#6b728014}.dr-alert-strip{border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:var(--text-sm);border:1px solid;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;line-height:1.5;display:flex}.dr-alert-strip.red{color:#991b1b;background:linear-gradient(135deg,#fff5f5 0%,#fee2e2 100%);border-color:#fca5a5}.dr-alert-strip.amber{color:#92400e;background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%);border-color:#fde68a}.dr-alert-strip.info{color:#166534;background:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%);border-color:#bbf7d0}.dr-alert-strip-icon{flex-shrink:0;margin-top:2px}.progress-spinner{border:3px solid #1a1a2e1a;border-left-color:var(--primary);vertical-align:middle;border-radius:50%;width:24px;height:24px;margin-right:.5rem;animation:1s linear infinite spin;display:inline-block}.flex-align-center{align-items:center;display:flex}.gap-2{gap:.5rem}.mb-4{margin-bottom:1rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.text-emerald{color:#10b981}.text-red-500{color:#ef4444}.history-logs-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.history-logs-header{color:#64748b;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:1px solid #edf2f7;grid-template-columns:2.8fr 1fr 1.3fr 1.2fr 1.1fr;padding:1.25rem 1.5rem;font-size:.72rem;font-weight:700;display:grid}.history-logs-row{border-bottom:1px solid #edf2f7;grid-template-columns:2.8fr 1fr 1.3fr 1.2fr 1.1fr;align-items:center;padding:1.25rem 1.5rem;transition:background-color .2s;display:grid}.history-logs-row:last-child{border-bottom:none}.history-logs-row:hover{background-color:#f8fafc}.history-meta-pill{color:#475569;background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;align-items:center;padding:.125rem .375rem;font-size:.7rem;font-weight:600;display:inline-flex}.history-meta-pill.success{color:#166534;background-color:#f0fdf4;border-color:#dcfce7}.history-meta-pill.danger{color:#991b1b;background-color:#fef2f2;border-color:#fee2e2}.btn-copy-id:hover svg{color:var(--primary)!important}
