@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--primary:#2563eb;--primary-light:#eff6ff;--primary-dark:#1d4ed8;--bg:#fff;--bg-secondary:#f5f7fa;--bg-tertiary:#eef2ff;--surface:#fff;--border:#e5e9f0;--text-primary:#0f172a;--text-secondary:#64748b;--text-muted:#94a3b8;--success:#22c55e;--success-light:#f0fdf4;--warning:#f59e0b;--warning-light:#fffbeb;--danger:#ef4444;--danger-light:#fef2f2;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 10px 30px #0000001a, 0 4px 8px #0000000a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--transition:all .2s cubic-bezier(.4, 0, .2, 1);--sidebar-width:240px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-secondary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;font-family:inherit}img{max-width:100%}.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-content{flex:1;padding:28px 32px}@media (width<=768px){.app-layout{flex-direction:column;min-height:100dvh}.sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;height:auto;box-shadow:var(--shadow-sm);position:sticky;top:0}.sidebar-logo{padding:12px 14px}.sidebar-nav{border-top:1px solid var(--border);scrollbar-width:none;gap:6px;padding:8px 10px;display:flex;overflow-x:auto}.sidebar-nav::-webkit-scrollbar{display:none}.nav-section-title{display:none}.nav-item{white-space:nowrap;flex:none;margin-bottom:0;padding:8px 10px;font-size:13px}.sidebar-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;padding:8px 10px;display:flex}.sidebar-footer .user-card{display:none}.sidebar-footer .nav-item{margin:0;padding:8px 10px}.main-content{min-height:calc(100dvh - 128px);margin-left:0}.topbar{height:58px;padding:0 14px}.page-title{font-size:16px}.page-subtitle{font-size:12px}.topbar-right{gap:8px}.page-content,.card-header,.card-body,.stat-card{padding:14px}.stat-value{font-size:24px}.table-wrap{overflow-x:auto}.table-wrap table,.data-table{min-width:720px}.modal{border-radius:16px;max-width:520px;max-height:calc(100dvh - 20px);padding:20px;overflow-y:auto;width:calc(100vw - 20px)!important}.btn{padding:9px 14px}}@media (width<=480px){.sidebar-logo .logo-text{font-size:14px}.sidebar-logo .logo-icon{width:30px;height:30px;font-size:13px}.nav-item{gap:7px;padding:7px 9px;font-size:12px}.topbar{padding:0 10px 0 50px}.topbar-avatar{width:32px;height:32px;font-size:12px}.page-content{padding:10px}.card-header,.card-body{padding:12px}.btn{gap:6px;font-size:12px}.form-control{padding:9px 11px;font-size:13px}.modal{border-radius:14px;max-height:calc(100dvh - 12px);padding:14px;width:calc(100vw - 12px)!important}}.sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);z-index:100;height:100vh;box-shadow:var(--shadow-sm);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px;display:flex}.sidebar-logo .logo-icon{background:var(--primary);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;font-weight:700;display:flex}.sidebar-logo .logo-text{color:var(--text-primary);font-size:16px;font-weight:700}.sidebar-logo .logo-text span{color:var(--primary)}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:12px 10px 6px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);transition:var(--transition);cursor:pointer;align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:500;display:flex}.nav-item:hover{background:var(--primary-light);color:var(--primary)}.nav-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}.nav-item .nav-icon{flex-shrink:0}.sidebar-footer{border-top:1px solid var(--border);padding:16px}.user-card{border-radius:var(--radius-sm);background:var(--bg-secondary);cursor:pointer;transition:var(--transition);align-items:center;gap:10px;padding:10px;display:flex}.user-card:hover{background:var(--primary-light)}.avatar{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.user-info .user-name{color:var(--text-primary);font-size:13px;font-weight:600}.user-info .user-role{color:var(--text-muted);font-size:11px}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:50;height:64px;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:12px;display:flex}.page-title{color:var(--text-primary);font-size:18px;font-weight:700}.page-subtitle{color:var(--text-muted);font-size:13px}.topbar-right{align-items:center;gap:12px;display:flex}.topbar-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-md)}.card-body{padding:20px}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-title{color:var(--text-primary);font-size:15px;font-weight:600}.modal-backdrop{z-index:1000;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;inset:0}.modal{background:var(--surface);z-index:1001;width:100%;animation:.3s cubic-bezier(.16,1,.3,1) forwards modalPop;position:relative}@keyframes modalPop{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition);padding:20px;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--primary);height:3px;position:absolute;top:0;left:0;right:0}.stat-card.success:before{background:var(--success)}.stat-card.warning:before{background:var(--warning)}.stat-card.danger:before{background:var(--danger)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-icon{border-radius:var(--radius-sm);background:var(--primary-light);width:44px;height:44px;color:var(--primary);justify-content:center;align-items:center;margin-bottom:14px;display:flex}.stat-icon.success{background:var(--success-light);color:var(--success)}.stat-icon.warning{background:var(--warning-light);color:var(--warning)}.stat-icon.danger{background:var(--danger-light);color:var(--danger)}.stat-value{color:var(--text-primary);font-size:28px;font-weight:800;line-height:1}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:12px;font-weight:500}.stat-change{margin-top:8px;font-size:12px;font-weight:500}.stat-change.up{color:var(--success)}.stat-change.down{color:var(--danger)}.badge{letter-spacing:.02em;border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-primary{background:var(--primary-light);color:var(--primary)}.badge-success{background:var(--success-light);color:#16a34a}.badge-warning{background:var(--warning-light);color:#d97706}.badge-danger{background:var(--danger-light);color:#dc2626}.badge-gray{background:var(--bg-secondary);color:var(--text-secondary)}.badge-dot:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px;display:inline-block}.btn{border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 4px #2563eb4d}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb66}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#16a34a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#d97706}.btn-sm{padding:6px 14px;font-size:12px}.btn-lg{border-radius:var(--radius-md);padding:14px 28px;font-size:16px}.btn-icon{border-radius:var(--radius-sm);background:var(--bg-secondary);padding:8px}.btn-icon:hover{background:var(--border)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-group{margin-bottom:18px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-control{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:var(--surface);transition:var(--transition);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.form-control::placeholder{color:var(--text-muted)}textarea.form-control{resize:vertical;min-height:100px}select.form-control{appearance:none;cursor:pointer}.input-icon-wrap{position:relative}.input-icon-wrap .icon{color:var(--text-muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.input-icon-wrap .form-control{padding-left:38px}.table-wrap{border-radius:var(--radius-md);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead th{background:var(--bg-secondary);text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:12px 16px;font-size:11px;font-weight:600}tbody td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:12px 16px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--primary-light)}.progress-ring{justify-content:center;align-items:center;display:inline-flex;position:relative}.progress-ring svg{transform:rotate(-90deg)}.progress-ring-value{color:var(--text-primary);font-size:22px;font-weight:800;position:absolute}.progress-ring-label{color:var(--text-muted);font-size:10px;font-weight:500;position:absolute;bottom:-4px}.grid{gap:20px;display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (width<=1200px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.grid-3,.grid-4{grid-template-columns:1fr}}@media (width<=640px){.grid-2{grid-template-columns:1fr}}.flex{display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.w-full{width:100%}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-muted{color:var(--text-muted)}.text-sm{font-size:13px}.text-xs{font-size:11px}.font-bold{font-weight:700}.font-semibold{font-weight:600}.rounded-full{border-radius:999px}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state svg{opacity:.35;margin-bottom:16px}.empty-state h3{color:var(--text-secondary);margin-bottom:6px;font-size:15px}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);color:#fff;white-space:nowrap;opacity:0;pointer-events:none;transition:var(--transition);background:#1e293b;border-radius:6px;padding:5px 10px;font-size:11px;font-weight:500;position:absolute;bottom:110%;left:50%;transform:translate(-50%)}[data-tooltip]:hover:after{opacity:1}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes ping{0%{opacity:1;transform:scale(1)}75%,to{opacity:0;transform:scale(1.6)}}@keyframes scanLine{0%,to{top:8px}50%{top:calc(100% - 8px)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.95)}80%{transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99999;background:#0f172a66;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border:1px solid #ffffff1a;border-radius:24px;padding:32px;position:relative;box-shadow:0 25px 50px -12px #00000040}.fade-in{animation:.3s forwards fadeIn}.slide-up{animation:.4s cubic-bezier(.16,1,.3,1) forwards slideUp}.pop-in{animation:.4s cubic-bezier(.16,1,.3,1) forwards popIn}.animate-spin{animation:1s linear infinite spin}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-ping{animation:1.2s ease-in-out infinite ping}.auth-layout{grid-template-columns:1fr 480px;min-height:100vh;display:grid}.auth-illustration{background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 50%,#4f8ef7 100%);flex-direction:column;justify-content:center;align-items:center;padding:60px;display:flex;position:relative;overflow:hidden}.auth-illustration:before{content:"";background:#ffffff0f;border-radius:50%;width:500px;height:500px;position:absolute;top:-100px;right:-100px}.auth-illustration:after{content:"";background:#ffffff0f;border-radius:50%;width:300px;height:300px;position:absolute;bottom:-80px;left:-80px}.auth-brand{z-index:1;align-items:center;gap:12px;margin-bottom:48px;display:flex}.auth-brand-icon{width:48px;height:48px;color:var(--primary);background:#fff;border-radius:12px;justify-content:center;align-items:center;font-size:22px;font-weight:900;display:flex}.auth-brand-name{color:#fff;font-size:22px;font-weight:800}.auth-headline{color:#fff;z-index:1;margin-bottom:16px;font-size:36px;font-weight:800;line-height:1.2}.auth-subtext{color:#ffffffbf;z-index:1;max-width:360px;font-size:15px}.auth-features{z-index:1;flex-direction:column;gap:14px;margin-top:48px;display:flex}.auth-feature{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;display:flex}.auth-feature-icon{color:#fff;background:#ffffff26;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.auth-feature-text{color:#ffffffe6;font-size:13px;font-weight:500}.auth-card-wrap{background:#fff;justify-content:center;align-items:center;padding:48px;display:flex;box-shadow:-20px 0 60px #00000014}.auth-card{width:100%;max-width:360px}.auth-title{color:var(--text-primary);margin-bottom:6px;font-size:26px;font-weight:800}.auth-desc{color:var(--text-muted);margin-bottom:32px;font-size:14px}.role-tabs{background:var(--bg-secondary);border-radius:var(--radius-sm);grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:24px;padding:4px;display:grid}.role-tab{text-align:center;color:var(--text-muted);cursor:pointer;transition:var(--transition);border-radius:6px;padding:8px;font-size:12px;font-weight:600}.role-tab.active{color:var(--primary);box-shadow:var(--shadow-sm);background:#fff}@media (width<=900px){.auth-layout{grid-template-columns:1fr}.auth-illustration{display:none}.auth-card-wrap{box-shadow:none}}.scanner-container{background:#0a0a0a;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex}.scanner-frame{border-radius:var(--radius-xl);width:300px;height:300px;position:relative;overflow:hidden}.scanner-frame video{object-fit:cover;width:100%;height:100%}.scanner-corners:before,.scanner-corners:after,.scanner-corners>span:before,.scanner-corners>span:after{content:"";z-index:2;border-style:solid;border-color:#2563eb;width:28px;height:28px;position:absolute}.scan-line{z-index:3;background:linear-gradient(90deg,#0000,#2563eb,#0000);height:2px;animation:2s ease-in-out infinite scanLine;position:absolute;left:10px;right:10px}.qr-display-page{background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.qr-display-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0f;border:1px solid #ffffff1f;border-radius:28px;flex-direction:column;align-items:center;gap:24px;padding:48px;display:flex}.qr-image-wrap{background:#fff;border-radius:20px;padding:20px;box-shadow:0 20px 60px #0006}.countdown-ring{position:relative}.countdown-value{color:#fff;justify-content:center;align-items:center;font-size:22px;font-weight:800;display:flex;position:absolute;inset:0}.spin{animation:1s linear infinite spin}@media (width<=1024px){.dashboard-toolbar{flex-wrap:wrap;gap:10px;align-items:stretch!important}.dashboard-toolbar-left,.dashboard-toolbar-right{flex-wrap:wrap;gap:8px;width:100%;display:flex}.dashboard-toolbar-search{max-width:100%;width:100%!important}.dashboard-toolbar-search .form-control{width:100%}}@media (width<=768px){.dashboard-toolbar{flex-direction:column;align-items:stretch!important}.dashboard-toolbar h3{font-size:18px}.dashboard-toolbar-left,.dashboard-toolbar-right{justify-content:flex-start;width:100%}.teacher-session-row{flex-wrap:wrap;align-items:flex-start!important;gap:10px!important;padding:14px 12px!important}.teacher-session-meta{flex:calc(100% - 56px);min-width:0}.teacher-session-status{margin-right:0!important}.teacher-session-actions{flex-wrap:wrap;width:100%}.teacher-session-actions .btn{flex:120px}.teacher-fraud-row{flex-wrap:wrap;align-items:flex-start!important}.teacher-fraud-meta{width:100%;text-align:left!important}}@media (width<=480px){.dashboard-toolbar-left .btn,.dashboard-toolbar-right .btn,.teacher-session-actions .btn{flex:100%}}@media (width<=1024px){.analytics-toolbar,.fraud-filter-bar,.students-toolbar,.live-attendance-toolbar{flex-wrap:wrap;gap:10px;align-items:stretch!important}.analytics-toolbar-actions,.students-toolbar-actions{flex-wrap:wrap;gap:8px;width:100%;display:flex}.students-toolbar-search,.analytics-toolbar-actions .btn,.students-toolbar-search .form-control{width:100%!important}.analytics-pie-layout{flex-wrap:wrap;gap:16px;justify-content:center!important}.student-detail-actions{flex-wrap:wrap}.student-detail-actions .btn{flex:calc(50% - 8px)}}@media (width<=768px){.analytics-toolbar,.fraud-filter-bar,.students-toolbar,.live-attendance-toolbar{flex-direction:column;align-items:stretch!important}.analytics-toolbar-actions,.students-toolbar-actions{margin-left:0!important}.notification-channels{flex-wrap:wrap}.notification-channels label{flex:100%!important}.notification-student-row,.notification-recent-row{flex-wrap:wrap;align-items:flex-start!important}.notification-recent-row .badge{margin-left:44px}.students-hero{flex-direction:column;gap:12px;align-items:flex-start!important;padding:18px!important}.live-session-row{flex-wrap:wrap;align-items:flex-start!important;gap:10px!important;padding:14px 12px!important}.live-session-meta{flex:calc(100% - 56px);min-width:0}.live-session-status{margin-right:0!important}.live-attendance-footer-actions,.live-attendance-footer-actions .btn{width:100%}.fraud-card-main{flex-direction:column}.fraud-card-left{width:100%}.fraud-card-right{width:100%;align-items:flex-start!important}.fraud-card-actions{flex-wrap:wrap;width:100%}.fraud-card-actions .btn{flex:120px}.student-detail-profile{flex-direction:column}.student-detail-channel-row{flex-direction:column;gap:10px!important}.student-detail-modal-actions{flex-direction:column}.student-edit-grid{grid-template-columns:1fr!important}.qr-display-card-shell{border-radius:20px;padding:18px!important}.qr-display-header,.qr-display-stats,.qr-display-actions{width:100%}.qr-display-actions{flex-wrap:wrap}.qr-display-actions .btn{flex:100%}}@media (width<=480px){.analytics-toolbar .btn,.analytics-toolbar-actions .btn,.fraud-filter-bar .btn,.students-toolbar-actions .btn,.live-attendance-toolbar .btn,.fraud-card-actions .btn,.student-detail-actions .btn{width:100%}.student-detail-actions .btn{flex:100%}.qr-display-card-shell{padding:14px!important}}.sidebar-mobile-toggle,.sidebar-floating-toggle,.sidebar-mobile-overlay{display:none}@media (width<=768px){.app-layout{flex-direction:row;min-height:100dvh}.sidebar{border-right:1px solid var(--border);z-index:140;width:min(280px,82vw);height:100dvh;box-shadow:var(--shadow-sm);border-bottom:none;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-102%)}.sidebar.mobile-open{transform:translate(0)}.sidebar-mobile-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:130;background:#02061773;display:block;position:fixed;inset:0}.sidebar-floating-toggle{background:var(--surface);border:1px solid var(--border);width:36px;height:36px;color:var(--text-primary);z-index:145;box-shadow:var(--shadow-sm);border-radius:10px;justify-content:center;align-items:center;display:inline-flex;position:fixed;top:12px;left:12px}.sidebar-logo{justify-content:space-between;padding:12px 14px}.sidebar-mobile-toggle{background:var(--bg-secondary);width:34px;height:34px;color:var(--text-primary);border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.sidebar-nav{border-top:1px solid var(--border);background:var(--surface);flex-direction:column;gap:4px;max-height:calc(100dvh - 120px);padding:10px;display:none;overflow-y:auto}.sidebar.mobile-open .sidebar-nav{display:flex}.nav-section-title{display:none}.nav-item{width:100%;margin-bottom:0;padding:10px 12px;font-size:13px}.sidebar-footer{border-top:1px solid var(--border);background:var(--surface);padding:10px;display:none}.sidebar.mobile-open .sidebar-footer{justify-content:flex-end;align-items:center;display:flex}.sidebar-footer .user-card{display:none}.main-content{width:100%;min-height:100dvh;margin-left:0}.topbar{height:56px;padding:0 12px 0 56px}.topbar-left{flex:1;min-width:0}.page-title,.page-subtitle{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.page-title{font-size:16px;line-height:1.2}.page-subtitle{max-width:190px;font-size:12px}.topbar-right{gap:8px}.page-content,.card-header,.card-body,.stat-card{padding:14px}.table-wrap,.data-table{overflow-x:auto}.table-wrap table,.data-table{min-width:720px}.modal{border-radius:16px;max-width:560px;max-height:calc(100dvh - 20px);padding:20px;overflow-y:auto;width:calc(100vw - 20px)!important}}@media (width<=480px){.sidebar-logo .logo-text{font-size:14px}.sidebar-logo .logo-icon{width:30px;height:30px;font-size:13px}.sidebar-mobile-toggle{width:32px;height:32px}.sidebar-floating-toggle{width:34px;height:34px;top:10px;left:10px}.topbar{padding:0 10px 0 50px}.topbar .btn-icon.btn,.topbar-avatar{width:32px;height:32px}.page-content{padding:10px}.card-header,.card-body,.stat-card{padding:12px}.btn{padding:8px 12px;font-size:12px}.form-control{padding:9px 11px;font-size:13px}.modal{border-radius:14px;max-height:calc(100dvh - 12px);padding:14px;width:calc(100vw - 12px)!important}}.admin-page{width:100%;min-width:0}.admin-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.admin-data-table{min-width:860px}.admin-row-actions{align-items:center;gap:6px;display:flex}.admin-modal-shell{max-height:calc(100dvh - 28px);overflow-y:auto;width:min(620px,100vw - 28px)!important}.admin-page .dashboard-toolbar{gap:12px}.admin-page .dashboard-toolbar-left,.admin-page .dashboard-toolbar-right{min-width:0}.admin-page .dashboard-toolbar-left h3{margin-right:4px}.admin-search{min-width:220px}.admin-overview-charts .card,.admin-overview-comms .card,.admin-toolbar-pills{min-width:0}.admin-toolbar-pills .btn{white-space:nowrap}.admin-channel-row{flex-wrap:wrap}.admin-modal-actions{gap:12px;display:flex}@media (width<=1024px){.admin-page .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-page .dashboard-toolbar-left,.admin-page .dashboard-toolbar-right{flex-wrap:wrap;width:100%}.admin-page .dashboard-toolbar-right{justify-content:flex-start}.admin-search{min-width:0;max-width:100%;width:100%!important}.admin-search .form-control{width:100%}.admin-page .card-body[style*="height: 260px"]{height:220px!important;padding:12px!important}}@media (width<=768px){.admin-page{padding:12px}.admin-page .grid-4,.admin-page .grid-3,.admin-page .grid-2{grid-template-columns:1fr}.admin-page .dashboard-toolbar{flex-direction:column;align-items:stretch!important}.admin-page .dashboard-toolbar-left,.admin-page .dashboard-toolbar-right{flex-wrap:wrap;gap:8px;width:100%;display:flex}.admin-page .dashboard-toolbar-left .btn,.admin-page .dashboard-toolbar-right .btn{flex:calc(50% - 8px);min-width:120px}.admin-page .dashboard-toolbar-left h3{width:100%;margin-bottom:2px}.admin-data-table{min-width:720px}.admin-row-actions{flex-wrap:wrap;justify-content:flex-start}.admin-modal-backdrop{padding:10px;overflow-y:auto;align-items:flex-start!important}.admin-modal-shell{max-height:none;margin:0;border-radius:16px!important;width:100%!important;max-width:none!important;padding:18px!important}.admin-overview-charts .card,.admin-overview-comms .card{overflow:hidden}.admin-overview-charts canvas{max-height:220px}.admin-toolbar-pills .btn{flex:calc(50% - 8px)}.admin-modal-actions{flex-direction:column;gap:8px}.admin-modal-actions .btn,.admin-channel-row label{width:100%}}@media (width<=480px){.admin-page{padding:10px}.admin-page .dashboard-toolbar-left .btn,.admin-page .dashboard-toolbar-right .btn{flex:100%}.admin-page .dashboard-toolbar-left,.admin-page .dashboard-toolbar-right{gap:6px}.admin-data-table{min-width:680px}.admin-modal-shell{border-radius:14px!important;padding:14px!important}.admin-toolbar-pills .btn{flex:100%}}
