@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Sora:wght@500;600;700;800&display=swap";
:root{--font-display:"Sora","Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#3b82f6;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--primary-900:#1e3a8a;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--success:#10b981;--success-light:#d1fae5;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--danger-light:#fee2e2;--info:#06b6d4;--info-light:#cffafe;--purple:#8b5cf6;--purple-light:#ede9fe;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--shadow-2xl:0 25px 50px -12px #00000040;--shadow-blue:0 4px 14px 0 #2563eb63;--shadow-card:0 1px 3px #00000014,0 1px 2px #0000000f;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-base:.25s cubic-bezier(.4,0,.2,1);--transition-slow:.35s cubic-bezier(.4,0,.2,1);--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--z-toast:1080;--page-buffer:2rem}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{color:var(--gray-800);background:var(--gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;outline:none;font-family:inherit}input,textarea{border:none;outline:none;font-family:inherit}select{border:1px solid var(--primary-200);cursor:pointer;outline:none;font-family:inherit;background-color:var(--primary-50)!important;color:var(--primary-800)!important;border-radius:20px!important;padding:.6rem 1rem!important}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.text-center{text-align:center}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-primary{color:var(--primary-600)}.text-gray{color:var(--gray-500)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.w-full{width:100%}.h-full{height:100%}.card{box-shadow:var(--shadow-card);border:1.5px solid var(--gray-100);transition:box-shadow var(--transition-base),transform var(--transition-base);background:#fff;border-radius:20px;padding:2rem}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-title{color:var(--gray-800);font-size:1rem;font-weight:600}.btn{border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;cursor:pointer;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-700));color:#fff;box-shadow:var(--shadow-blue)}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-600),var(--primary-800));transform:translateY(-1px);box-shadow:0 6px 20px #2563eb73}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-200)}.btn-outline{border:1.5px solid var(--primary-500);color:var(--primary-600);background:0 0}.btn-outline:hover{background:var(--primary-50)}.btn-danger{background:linear-gradient(135deg,var(--danger),#dc2626);color:#fff}.btn-success{background:linear-gradient(135deg,var(--success),#059669);color:#fff}.btn-sm{padding:.4rem .75rem;font-size:.8rem}.btn-lg{padding:.875rem 2rem;font-size:1rem}.btn-icon{border-radius:var(--radius-md);width:2.5rem;height:2.5rem;padding:0}.input-group{flex-direction:column;gap:.375rem;display:flex}.input-group label{color:var(--gray-700);font-size:.875rem;font-weight:500}.input-field{background:var(--gray-50);border:1.5px solid var(--gray-200);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.input-field:focus-within{border-color:var(--primary-400);background:#fff;box-shadow:0 0 0 3px #3b82f61a}.input-field input{color:var(--gray-800);background:0 0;flex:1;font-size:.9375rem}.input-field input::placeholder{color:var(--gray-400)}.input-field .input-icon{color:var(--gray-400);flex-shrink:0;font-size:1.125rem}.badge{border-radius:var(--radius-full);align-items:center;gap:.25rem;padding:.2rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-success{background:var(--success-light);color:#065f46}.badge-warning{background:var(--warning-light);color:#92400e}.badge-danger{background:var(--danger-light);color:#991b1b}.badge-purple{background:var(--purple-light);color:#5b21b6}.table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--gray-200);overflow-x:auto}table{border-collapse:collapse;width:100%}table thead{background:var(--gray-50)}table th{text-align:left;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--gray-200);padding:.75rem 1rem;font-size:.8rem;font-weight:600}table td{color:var(--gray-700);border-bottom:1px solid var(--gray-100);padding:.875rem 1rem;font-size:.875rem}table tbody tr{transition:background var(--transition-fast)}table tbody tr:hover{background:var(--gray-50)}table tbody tr:last-child td{border-bottom:none}.avatar{border-radius:var(--radius-full);object-fit:cover;border:2px solid var(--gray-100);width:2.5rem;height:2.5rem}.avatar-sm{width:2rem;height:2rem}.avatar-lg{width:3.5rem;height:3.5rem}.avatar-xl{width:5rem;height:5rem}.avatar-initials{color:#fff;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));justify-content:center;align-items:center;font-weight:700;display:flex}.sidebar{border-right:1px solid var(--gray-100);width:260px;height:100vh;z-index:var(--z-fixed);transition:transform var(--transition-base);background:linear-gradient(#fff 0%,#f8fbff 100%);flex-direction:column;display:flex;position:fixed;top:0;left:0;box-shadow:0 20px 40px -36px #0f172a8c}.sidebar-header{border-bottom:1px solid var(--gray-100);background:linear-gradient(#eff6ffa6,#fff0);align-items:center;gap:.75rem;padding:1.5rem;display:flex}.sidebar-logo{background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex}.sidebar-brand{color:var(--gray-900);letter-spacing:-.02em;font-size:1.25rem;font-weight:800}.sidebar-brand span{color:var(--primary-600)}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:1rem .75rem;display:flex;overflow-y:auto}.sidebar-section{text-transform:uppercase;letter-spacing:.08em;color:var(--gray-400);margin-top:1rem;margin-bottom:.5rem;padding:0 .75rem;font-size:.7rem;font-weight:600}.nav-item{border-radius:var(--radius-md);color:var(--gray-600);transition:all var(--transition-fast);align-items:center;gap:.75rem;padding:.65rem .75rem;font-size:.875rem;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--gray-50);color:var(--gray-900)}.nav-item.active{background:var(--primary-50);color:var(--primary-700);font-weight:600;box-shadow:inset 0 0 0 1px #3b82f633}.nav-item.active:before{content:"";background:linear-gradient(180deg,var(--primary-500),var(--primary-700));border-radius:999px;width:3px;position:absolute;top:.45rem;bottom:.45rem;left:.35rem}.nav-item.active .nav-icon{color:var(--primary-600)}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:1.5rem;font-size:1.2rem;display:flex}.nav-badge{background:var(--danger);color:#fff;border-radius:var(--radius-full);justify-content:center;align-items:center;min-width:1.25rem;height:1.25rem;margin-left:auto;padding:0 .35rem;font-size:.65rem;font-weight:700;display:flex}.sidebar-footer{border-top:1px solid var(--gray-100);padding:1rem .75rem}.sidebar-mobile-toggle{z-index:1040;border-radius:var(--radius-md);border:1px solid var(--gray-200);cursor:pointer;width:40px;height:40px;box-shadow:var(--shadow-sm);color:var(--gray-700);background:#fff;justify-content:center;align-items:center;display:none;position:fixed;top:14px;left:12px}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1029;background:#0006;display:none;position:fixed;inset:0}.main-content{background:radial-gradient(circle at top right,#eef4ff 0%,var(--gray-50)40%);min-height:100vh;margin-left:260px}.top-header{border-bottom:1px solid var(--gray-100);height:64px;z-index:var(--z-sticky);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffdb;justify-content:space-between;align-items:center;padding:0 2rem;display:flex;position:sticky;top:0}.header-search{background:var(--gray-50);border-radius:var(--radius-full);border:1px solid var(--gray-200);width:min(420px,48vw);transition:all var(--transition-fast);align-items:center;gap:.5rem;padding:.5rem 1rem;display:flex}.header-search:focus-within{border-color:var(--primary-300);background:#fff;box-shadow:0 0 0 3px #3b82f614}.header-search input{background:0 0;flex:1;font-size:.875rem}.header-search .search-icon{color:var(--gray-400)}.header-search-btn{width:24px;height:24px;color:var(--gray-400);transition:all var(--transition-fast);border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.header-search-btn:hover{background:var(--gray-100);color:var(--gray-700)}.header-actions{align-items:center;gap:.5rem;display:flex}.header-icon-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--gray-500);transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:1.25rem;display:flex;position:relative}.header-icon-btn:hover{background:var(--gray-100);color:var(--gray-700);transform:translateY(-1px)}.admin-shell-loading{background:radial-gradient(circle at top right,#eef4ff 0%,var(--gray-50)40%);min-height:100vh;display:flex}.admin-shell-loading-side{border-right:1px solid var(--gray-100);background:linear-gradient(#fff 0%,#f8fbff 100%);flex-direction:column;gap:1rem;width:260px;padding:1.2rem .9rem;display:flex}.admin-shell-loading-brand{border-radius:14px;height:52px}.teacher-page-wrapper{max-width:1280px;padding:var(--page-buffer);margin:0 auto}@media (max-width:1024px){.teacher-page-wrapper{padding:1.25rem}}@media (max-width:640px){.teacher-page-wrapper{padding:.75rem}}.students-main-layout{align-items:flex-start;gap:1rem;display:flex}.students-list-card{flex:640px;min-width:0;padding:0}.students-list-card .table-wrapper{border-radius:14px;padding:0;overflow:hidden}.students-list-card table th,.students-list-card table td{padding:.9rem 1rem}.students-back-button{display:none}@media (max-width:960px){.students-main-layout{flex-direction:column}.students-list-card{order:1}.students-back-button{display:inline-flex}.students-stats-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){.students-stats-grid{grid-template-columns:1fr}.students-list-card table th{padding:.65rem .85rem;font-size:.72rem}.students-list-card table td{padding:.6rem .85rem;font-size:.82rem}}.admin-shell-loading-nav{gap:.45rem;display:grid}.admin-shell-loading-item{border-radius:10px;height:36px}.admin-shell-loading-footer{border-radius:10px;height:42px;margin-top:auto}.admin-shell-loading-main{flex:1;min-width:0}.admin-shell-loading-head{border-bottom:1px solid var(--gray-100);background:#ffffffdb;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex}.admin-shell-loading-search{border-radius:999px;width:min(420px,48vw);height:40px}.admin-shell-loading-actions{align-items:center;gap:.6rem;display:flex}.admin-shell-loading-chip{border-radius:999px;width:110px;height:30px}.admin-shell-loading-icon{border-radius:10px;width:36px;height:36px}.admin-shell-loading-user{border-radius:999px;width:150px;height:36px}.admin-shell-loading-content{padding:2rem}.admin-shell-loading-hero{border-radius:18px;height:112px;margin-bottom:1rem}.admin-shell-loading-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.admin-shell-loading-card{border-radius:14px;height:120px}.admin-loading-shimmer{background:#e2e8f0;position:relative;overflow:hidden}.admin-loading-shimmer:after{content:"";background:linear-gradient(100deg,#fff0 20%,#fff9 50%,#fff0 80%);animation:1.25s infinite shimmerMove;position:absolute;inset:0;transform:translate(-100%)}.header-icon-btn .notification-dot{background:var(--danger);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.header-user{border-radius:var(--radius-full);transition:background var(--transition-fast);cursor:pointer;align-items:center;gap:.75rem;padding:.375rem .75rem .375rem .375rem;display:flex}.header-user:hover{background:var(--gray-50)}.header-user-info{text-align:right;flex-direction:column;gap:1px;display:flex}.header-user-name{color:var(--gray-800);font-size:.875rem;font-weight:600}.header-user-role{color:var(--gray-500);font-size:.7rem}.page-wrapper{max-width:1280px;padding:var(--page-buffer);margin:0 auto}.chat-page-wrapper{max-width:100%;padding:var(--page-buffer);margin:0}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.page-title{color:var(--gray-900);letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--gray-500);margin-top:.25rem;font-size:.875rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{border-radius:var(--radius-lg);border:1px solid var(--gray-100);box-shadow:var(--shadow-card);transition:all var(--transition-base);background:#fff;align-items:flex-start;gap:1rem;padding:1.25rem;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;display:flex}.stat-icon.blue{background:var(--primary-100);color:var(--primary-600)}.stat-icon.green{background:var(--success-light);color:var(--success)}.stat-icon.orange{background:var(--warning-light);color:var(--warning)}.stat-icon.red{background:var(--danger-light);color:var(--danger)}.stat-icon.purple{background:var(--purple-light);color:var(--purple)}.stat-icon.teal{background:var(--info-light);color:var(--info)}.stat-info{flex:1}.stat-label{color:var(--gray-500);font-size:.8rem;font-weight:500}.stat-value{color:var(--gray-900);margin-top:.125rem;font-size:1.5rem;font-weight:800;line-height:1.2}.stat-change{align-items:center;gap:.2rem;margin-top:.25rem;font-size:.75rem;font-weight:600;display:inline-flex}.stat-change.positive{color:var(--success)}.stat-change.negative{color:var(--danger)}.admin-dash-hero{border-radius:var(--radius-xl);background:radial-gradient(circle at 0 0,#dbeafe 0,#e0e7ff 30%,#f8fafc 78%);border:1px solid #c7d2fe;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.35rem 1.4rem;display:flex}.admin-dash-kicker{letter-spacing:.08em;text-transform:uppercase;color:#334155;align-items:center;gap:.45rem;font-size:.75rem;font-weight:700;display:inline-flex}.admin-dash-title{font-family:var(--font-display);letter-spacing:-.03em;color:#0f172a;margin-top:.5rem;font-size:2rem;line-height:1.1}.admin-dash-subtitle{color:#475569;margin-top:.45rem;font-size:.9rem}.admin-dash-pill{border-radius:var(--radius-full);color:#0f172a;white-space:nowrap;background:#ffffffb3;border:1px solid #94a3b880;align-items:center;gap:.4rem;padding:.45rem .8rem;font-size:.78rem;font-weight:600;display:inline-flex}.admin-dash-stats-grid{margin-top:1.25rem}.admin-dash-stat-card{border-color:#e2e8f0;padding:1rem;box-shadow:0 8px 20px -14px #0206178c}.admin-dash-stat-icon{border-radius:14px}.admin-dash-stat-label{color:#475569;line-height:1.3}.admin-dash-stat-note{color:#64748b;margin-top:.3rem;font-size:.75rem}.admin-dash-bottom-grid{align-items:start}.admin-dash-bottom-card{border:1.5px solid var(--gray-100);border-radius:20px;padding:2rem;box-shadow:0 12px 24px -18px #0f172a80}.admin-dash-bottom-head{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.admin-dash-bottom-title{font-family:var(--font-display);color:#0f172a;font-size:1.05rem}.admin-dash-chip{border-radius:var(--radius-full);color:#334155;white-space:nowrap;background:#f1f5f9;align-items:center;gap:.35rem;padding:.35rem .65rem;font-size:.75rem;font-weight:600;display:inline-flex}.admin-dash-metric-list{gap:.6rem;display:grid}.admin-dash-metric-item{border-radius:var(--radius-md);color:#334155;background:#fafcff;border:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:.75rem;padding:.7rem .75rem;font-size:.88rem;display:flex}.admin-dash-metric-item strong{color:#0f172a;font-family:var(--font-display)}.admin-dash-feedback-list{gap:.85rem;margin:0;padding:0;list-style:none;display:grid}.admin-dash-feedback-item{border-radius:var(--radius-md);background:#fff;border:1px solid #e2e8f0;padding:.65rem .7rem}.admin-dash-feedback-row{color:#334155;justify-content:space-between;align-items:center;margin-bottom:.45rem;display:flex}.admin-dash-feedback-row strong{text-transform:capitalize;font-size:.85rem}.admin-dash-feedback-row span{font-family:var(--font-display);color:#0f172a;font-size:.95rem}.school-setup-hero{border-radius:var(--radius-xl);background:linear-gradient(140deg,#f8fafc 0%,#e0ecff 45%,#ecfeff 100%);border:1px solid #cbd5e1;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:1.35rem 1.4rem;display:flex}.school-setup-kicker{letter-spacing:.08em;text-transform:uppercase;color:#0f766e;align-items:center;gap:.45rem;font-size:.75rem;font-weight:700;display:inline-flex}.school-setup-title{font-family:var(--font-display);letter-spacing:-.03em;color:#0f172a;margin-top:.48rem;font-size:1.95rem;line-height:1.1}.school-setup-subtitle{color:#475569;margin-top:.45rem;font-size:.9rem}.school-setup-summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.25rem;display:grid}.school-setup-summary-card{border:1px solid #e2e8f0;padding:1rem;box-shadow:0 10px 20px -16px #020617a6}.school-setup-summary-icon{border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:.55rem;display:inline-flex}.school-setup-summary-icon.blue{background:var(--primary-100);color:var(--primary-700)}.school-setup-summary-icon.teal{color:#0f766e;background:#ccfbf1}.school-setup-summary-icon.orange{color:#c2410c;background:#ffedd5}.school-setup-summary-icon.purple{color:#6d28d9;background:#ede9fe}.school-setup-summary-label{color:#475569;font-size:.8rem}.school-setup-summary-value{font-family:var(--font-display);color:#0f172a;margin-top:.18rem;font-size:1.6rem;line-height:1.1}.school-setup-summary-note{color:#64748b;margin-top:.3rem;font-size:.75rem}.school-setup-card{border:1.5px solid var(--gray-100);border-radius:20px;padding:2rem;box-shadow:0 10px 24px -18px #0f172a8c}.school-setup-section-title{font-family:var(--font-display);align-items:center;gap:.45rem;display:inline-flex}.classes-hero{border-radius:var(--radius-xl);background:linear-gradient(140deg,#f8fafc 0%,#dbeafe 45%,#f0f9ff 100%);border:1px solid #cbd5e1;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:1.3rem 1.4rem;display:flex}.classes-kicker{letter-spacing:.08em;text-transform:uppercase;color:#0369a1;align-items:center;gap:.45rem;font-size:.75rem;font-weight:700;display:inline-flex}.classes-title{font-family:var(--font-display);letter-spacing:-.03em;color:#0f172a;margin-top:.48rem;font-size:1.95rem;line-height:1.1}.classes-subtitle{color:#475569;margin-top:.45rem;font-size:.9rem}.classes-summary-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1rem;display:grid}.classes-summary-card{border:1px solid #e2e8f0;padding:1rem;box-shadow:0 10px 22px -18px #020617a6}.classes-summary-icon{border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:.55rem;display:inline-flex}.classes-summary-icon.blue{background:var(--primary-100);color:var(--primary-700)}.classes-summary-icon.teal{color:#0f766e;background:#ccfbf1}.classes-summary-icon.orange{color:#c2410c;background:#ffedd5}.classes-summary-icon.purple{color:#6d28d9;background:#ede9fe}.classes-summary-label{color:#475569;font-size:.8rem}.classes-summary-value{font-family:var(--font-display);color:#0f172a;margin-top:.2rem;font-size:1.55rem;line-height:1.1}.classes-summary-value.classes-summary-small{font-size:1.05rem}.classes-summary-note{color:#64748b;margin-top:.3rem;font-size:.75rem}.classes-panel{border:1.5px solid var(--gray-100);border-radius:20px;padding:2rem;box-shadow:0 10px 24px -19px #0f172a80}.classes-table-head{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.8rem;display:flex}.classes-section-title{font-family:var(--font-display)}.attendance-hero{border-radius:var(--radius-xl);background:linear-gradient(140deg,#f8fafc 0%,#ecfeff 45%,#eef2ff 100%);border:1px solid #cbd5e1;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:1.3rem 1.4rem;display:flex}.attendance-kicker{letter-spacing:.08em;text-transform:uppercase;color:#0f766e;align-items:center;gap:.45rem;font-size:.75rem;font-weight:700;display:inline-flex}.attendance-title{font-family:var(--font-display);letter-spacing:-.03em;color:#0f172a;margin-top:.48rem;font-size:1.95rem;line-height:1.1}.attendance-subtitle{color:#475569;margin-top:.45rem;font-size:.9rem}.attendance-summary-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1rem;display:grid}.attendance-summary-card{border:1px solid #e2e8f0;padding:1rem;box-shadow:0 10px 22px -18px #020617a6}.attendance-summary-icon{border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:.55rem;display:inline-flex}.attendance-summary-icon.blue{background:var(--primary-100);color:var(--primary-700)}.attendance-summary-icon.teal{color:#0f766e;background:#ccfbf1}.attendance-summary-icon.orange{color:#c2410c;background:#ffedd5}.attendance-summary-icon.purple{color:#6d28d9;background:#ede9fe}.attendance-summary-label{color:#475569;font-size:.8rem}.attendance-summary-value{font-family:var(--font-display);color:#0f172a;margin-top:.2rem;font-size:1.55rem;line-height:1.1}.attendance-summary-value.attendance-summary-small{font-size:1.03rem}.attendance-summary-note{color:#64748b;margin-top:.3rem;font-size:.75rem}.attendance-panel{border:1.5px solid var(--gray-100);border-radius:20px;padding:2rem;box-shadow:0 10px 24px -19px #0f172a80}.attendance-panel-head{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.attendance-section-title{font-family:var(--font-display)}.registration-hero{border-radius:var(--radius-xl);background:linear-gradient(140deg,#f8fafc 0%,#e0e7ff 40%,#ecfeff 100%);border:1px solid #cbd5e1;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:1.3rem 1.4rem;display:flex}.registration-kicker{letter-spacing:.08em;text-transform:uppercase;color:#4338ca;align-items:center;gap:.45rem;font-size:.75rem;font-weight:700;display:inline-flex}.registration-title{font-family:var(--font-display);letter-spacing:-.03em;color:#0f172a;margin-top:.48rem;font-size:1.95rem;line-height:1.1}.registration-subtitle{color:#475569;margin-top:.45rem;font-size:.9rem}.registration-role-tabs{flex-wrap:wrap;gap:.55rem;margin-bottom:1.5rem;display:flex}.registration-role-tab{color:#334155;transition:all var(--transition-fast);background:#fff;border:1px solid #dbe2ea;border-radius:999px;align-items:center;gap:.4rem;padding:.52rem .85rem;font-size:.84rem;font-weight:600;display:inline-flex}.registration-role-tab.active{background:linear-gradient(135deg,var(--primary-600),var(--primary-700));color:#fff;box-shadow:var(--shadow-blue);border-color:#0000}.registration-form-card{border:1px solid #e2e8f0;box-shadow:0 10px 24px -19px #0f172a80}.registration-form-title{font-family:var(--font-display);align-items:center;gap:.45rem;display:inline-flex}.announcements-hero,.students-hero,.teachers-hero,.parents-hero{border-radius:var(--radius-xl);background:linear-gradient(140deg,#f8fafc 0%,#e2e8f0 38%,#ecfeff 100%);border:1px solid #cbd5e1;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:1.3rem 1.4rem;display:flex}.announcements-kicker,.students-kicker,.teachers-kicker,.parents-kicker{letter-spacing:.08em;text-transform:uppercase;color:#0f766e;align-items:center;gap:.45rem;font-size:.75rem;font-weight:700;display:inline-flex}.announcements-title,.students-title,.teachers-title,.parents-title{font-family:var(--font-display);letter-spacing:-.03em;color:#0f172a;margin-top:.48rem;font-size:1.95rem;line-height:1.1}.announcements-subtitle,.students-subtitle,.teachers-subtitle,.parents-subtitle{color:#475569;margin-top:.45rem;font-size:.9rem}.announcements-summary-grid,.students-summary-grid,.teachers-summary-grid,.parents-summary-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1rem;display:grid}.announcements-summary-card,.students-summary-card,.teachers-summary-card,.parents-summary-card,.announcements-panel,.students-panel,.teachers-panel,.parents-panel{border:1.5px solid var(--gray-100);border-radius:20px;padding:2rem;box-shadow:0 10px 24px -19px #0f172a80}.announcements-summary-icon,.students-summary-icon,.teachers-summary-icon,.parents-summary-icon{border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:.55rem;display:inline-flex}.announcements-summary-icon.blue,.students-summary-icon.blue,.teachers-summary-icon.blue,.parents-summary-icon.blue{background:var(--primary-100);color:var(--primary-700)}.announcements-summary-icon.teal,.students-summary-icon.teal,.teachers-summary-icon.teal,.parents-summary-icon.teal{color:#0f766e;background:#ccfbf1}.announcements-summary-icon.orange,.students-summary-icon.orange,.teachers-summary-icon.orange,.parents-summary-icon.orange{color:#c2410c;background:#ffedd5}.announcements-summary-label,.students-summary-label,.teachers-summary-label,.parents-summary-label{color:#475569;font-size:.8rem}.announcements-summary-value,.students-summary-value,.teachers-summary-value,.parents-summary-value{font-family:var(--font-display);color:#0f172a;margin-top:.2rem;font-size:1.55rem;line-height:1.1}.school-setup-summary-value,.classes-summary-value,.attendance-summary-value,.announcements-summary-value,.students-summary-value,.teachers-summary-value,.parents-summary-value{font-weight:800}.announcements-section-title,.parents-section-title{font-family:var(--font-display);align-items:center;gap:.45rem;display:inline-flex}.chat-hero{border-radius:var(--radius-xl);background:linear-gradient(140deg,#f8fafc 0%,#e0e7ff 40%,#ecfeff 100%);border:1px solid #cbd5e1;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:1.3rem 1.4rem;display:flex}.chat-kicker{letter-spacing:.08em;text-transform:uppercase;color:#4338ca;align-items:center;gap:.45rem;font-size:.75rem;font-weight:700;display:inline-flex}.chat-title{font-family:var(--font-display);letter-spacing:-.03em;color:#0f172a;margin-top:.48rem;font-size:1.95rem;line-height:1.1}.chat-subtitle{color:#475569;margin-top:.45rem;font-size:.9rem}.chat-me-pill{border-radius:var(--radius-full);color:#0f172a;background:#ffffffb3;border:1px solid #cbd5e1;align-items:center;gap:.4rem;padding:.42rem .78rem;font-size:.8rem;font-weight:600;display:inline-flex}.chat-hero-right{flex-wrap:wrap;align-items:center;gap:.5rem;display:inline-flex}.chat-rt-pill{border-radius:999px;align-items:center;gap:.35rem;padding:.36rem .65rem;font-size:.75rem;font-weight:700;display:inline-flex}.chat-rt-pill.online{color:#166534;background:#dcfce7;border:1px solid #86efac}.chat-rt-pill.offline{color:#92400e;background:#fef3c7;border:1px solid #fcd34d}.chat-layout{grid-template-columns:clamp(230px,21vw,280px) minmax(0,1fr) clamp(210px,18vw,250px);gap:1rem;width:100%;height:calc(100vh - 140px);min-height:560px;max-height:900px;display:grid}.chat-list-card,.chat-main-card,.chat-side-card{border:1px solid #e2e8f0;box-shadow:0 10px 24px -19px #0f172a80}.chat-list-card{flex-direction:column;padding:.9rem;display:flex}.chat-list-head{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.chat-tools-row{gap:.5rem;margin-bottom:.8rem;display:grid}.chat-search-wrap{color:#64748b;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:.35rem;padding:.45rem .55rem;display:flex}.chat-search-wrap input{background:0 0;border:none;width:100%;font-size:.84rem}.chat-filter-wrap{color:#64748b;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:.35rem;padding:.45rem .55rem;display:flex}.chat-filter-wrap select{background:0 0;border:none;width:100%;font-size:.84rem}.chat-conv-list{gap:.45rem;max-height:470px;display:grid;overflow-y:auto}.chat-conv-item{text-align:left;width:100%;transition:all var(--transition-fast);background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:.55rem .6rem}.chat-conv-item.active{background:#eff6ff;border-color:#93c5fd}.chat-conv-top,.chat-conv-bottom{justify-content:space-between;align-items:center;gap:.45rem;display:flex}.chat-conv-title{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;font-size:.83rem;font-weight:600;overflow:hidden}.chat-conv-title-wrap{align-items:center;gap:.55rem;min-width:0;display:flex}.chat-conv-avatar{flex-shrink:0;width:32px;height:32px;position:relative}.chat-avatar-text{color:#1d4ed8;background:#dbeafe;border-radius:999px;justify-content:center;align-items:center;width:100%;height:100%;font-size:.68rem;font-weight:700;display:inline-flex}.chat-conv-avatar-stack{justify-content:center;align-items:center;display:inline-flex;position:absolute;inset:0}.chat-conv-avatar-stack-item{color:#1d4ed8;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #fff;border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-size:.5rem;font-weight:700;display:inline-flex}.chat-avatar-wrap{flex-shrink:0;position:relative}.chat-avatar-wrap.private .chat-avatar,.chat-avatar-group{position:relative}.chat-avatar-group{background:linear-gradient(135deg,#dbeafe,#e0e7ff)}.chat-avatar-group-stack{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.chat-avatar-group-chip{color:#1d4ed8;background:#bfdbfe;border:1px solid #fff;border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-size:.5rem;font-weight:700;display:inline-flex}.chat-avatar-status{border:2px solid #fff;border-radius:999px;width:9px;height:9px;position:absolute;bottom:-1px;right:-1px}.chat-avatar-status.online{background:#22c55e}.chat-avatar-status.offline{background:#94a3b8}.chat-conv-time{color:#64748b;white-space:nowrap;font-size:.72rem}.chat-conv-time-wrap{align-items:center;gap:.28rem;display:inline-flex}.chat-unread-dot{background:#0ea5e9;border-radius:999px;width:7px;height:7px}.chat-unread-badge{color:#fff;background:#2563eb;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 .3rem;font-size:.65rem;font-weight:700;display:inline-flex}.chat-last-preview{color:#64748b;text-overflow:ellipsis;white-space:nowrap;max-width:145px;font-size:.72rem;overflow:hidden}.chat-type-pill{letter-spacing:.02em;white-space:nowrap;border-radius:999px;align-items:center;padding:.16rem .48rem;font-size:.67rem;font-weight:700;display:inline-flex}.chat-type-pill.group{color:#5b21b6;background:#ede9fe}.chat-type-pill.private{color:#1d4ed8;background:#dbeafe}.chat-main-card{flex-direction:column;min-width:0;padding:.9rem;display:flex}.chat-inspector-card{border:1px solid #e2e8f0;padding:.85rem;box-shadow:0 10px 24px -19px #0f172a80}.chat-inspector-head{align-items:center;gap:.55rem;margin-bottom:.7rem;display:flex}.chat-inspector-avatar{color:#1d4ed8;background:#dbeafe;border-radius:999px;justify-content:center;align-items:center;width:40px;height:40px;font-weight:700;display:inline-flex}.chat-inspector-title{color:#0f172a;font-size:.88rem;font-weight:700}.chat-inspector-sub{color:#64748b;font-size:.73rem}.chat-inspector-section{margin-bottom:.7rem}.chat-inspector-section-title{font-family:var(--font-display);color:#334155;margin-bottom:.4rem;font-size:.8rem}.chat-inspector-empty{color:#64748b;font-size:.78rem}.chat-inspector-member-list{gap:.35rem;display:grid}.chat-inspector-member{text-align:left;background:#fff;border:1px solid #e2e8f0;border-radius:10px;grid-template-columns:9px 1fr auto;align-items:center;gap:.35rem;width:100%;padding:.4rem .5rem;font-size:.75rem;display:grid}.chat-inspector-member em{color:#64748b;text-transform:capitalize;font-size:.65rem}.chat-main-head{margin-bottom:.7rem}.chat-main-title{font-family:var(--font-display);color:#0f172a;font-size:1.05rem}.chat-main-meta{align-items:center;gap:.4rem;margin-top:.3rem;display:inline-flex}.chat-parent-visible-pill{color:#9a3412;background:#ffedd5;border-radius:999px;align-items:center;gap:.2rem;padding:.16rem .48rem;font-size:.67rem;font-weight:700;display:inline-flex}.chat-messages-area{background:radial-gradient(circle at top,#f8fbff 0%,#fff 55%);border:1px solid #e2e8f0;border-radius:12px;flex:1;max-height:420px;padding:.85rem;overflow-y:auto}.chat-empty-small{color:#64748b;padding:.75rem .5rem;font-size:.84rem}.chat-empty-large{color:#64748b;flex-direction:column;justify-content:center;align-items:center;gap:.35rem;height:100%;min-height:140px;font-size:.9rem;display:flex}.chat-bubble-wrap{gap:.45rem;margin-bottom:.55rem;display:flex}.chat-bubble-wrap.compact{margin-top:-.2rem}.chat-bubble{border-radius:12px;max-width:80%;padding:.52rem .72rem;font-size:.86rem;box-shadow:0 8px 18px -16px #0f172a8c}.chat-bubble.mine{color:#0f172a;background:#dbeafe}.chat-bubble.other{color:#0f172a;background:#edf2f7}.chat-bubble-avatar-slot{align-items:flex-end;width:30px;display:flex}.chat-bubble-avatar{border:1px solid #dbeafe;width:28px;height:28px;box-shadow:0 4px 10px -8px #0f172a73}.chat-bubble-avatar-placeholder{width:28px;height:28px}.chat-bubble-meta-top{color:#475569;justify-content:flex-start;align-items:center;gap:.35rem;margin-bottom:.2rem;font-size:.66rem;display:flex}.chat-bubble-meta-bottom{color:#64748b;align-items:center;gap:.28rem;margin-top:.25rem;font-size:.66rem;display:inline-flex}.chat-name-btn{color:inherit;font-size:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-weight:700}.chat-name-btn:hover{text-decoration:underline}.chat-read-row{color:#64748b;align-items:center;gap:.25rem;margin-top:.2rem;font-size:.64rem;display:inline-flex}.chat-typing-line{color:#0369a1;align-items:center;gap:.35rem;margin-top:.35rem;font-size:.75rem;display:inline-flex}.chat-typing-dot{background:#0ea5e9;border-radius:999px;width:6px;height:6px;animation:1s ease-in-out infinite pulseTyping}@keyframes pulseTyping{0%,to{opacity:.4;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}}.chat-compose-row{align-items:flex-end;gap:.5rem;margin-top:.7rem;display:flex}.chat-jump-latest{z-index:4;color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;align-items:center;gap:.32rem;padding:.38rem .66rem;font-size:.72rem;font-weight:700;display:inline-flex;position:absolute;bottom:4.4rem;left:50%;transform:translate(-50%);box-shadow:0 10px 22px -16px #1d4ed8b3}.chat-jump-latest:hover{background:#dbeafe}.chat-compose-row textarea{resize:none;border:1px solid #e2e8f0;border-radius:10px;flex:1;padding:.55rem .65rem;font-size:.86rem}.chat-side-card{padding:.9rem}.chat-side-title{font-family:var(--font-display);margin-bottom:.55rem;font-size:.96rem}.chat-profile-card{border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:.6rem;margin-bottom:.75rem;padding:.7rem;display:flex}.chat-avatar{color:#1d4ed8;background:#dbeafe;border-radius:999px;justify-content:center;align-items:center;width:38px;height:38px;font-size:.85rem;font-weight:700;display:inline-flex}.chat-profile-name{color:#0f172a;font-size:.84rem;font-weight:700}.chat-profile-role{color:#64748b;text-transform:capitalize;font-size:.72rem}.chat-side-meta{gap:.45rem;margin-bottom:.8rem;display:grid}.chat-side-meta div{border:1px solid #e2e8f0;border-radius:10px;justify-content:space-between;align-items:center;gap:.45rem;padding:.45rem .55rem;display:flex}.chat-side-meta span{color:#64748b;font-size:.72rem}.chat-side-meta strong{color:#0f172a;font-size:.73rem}.chat-side-members h4{margin-bottom:.45rem;font-size:.78rem}.chat-side-members p{color:#64748b;font-size:.8rem}.chat-participant-row{grid-template-columns:auto 1fr auto;align-items:center;gap:.4rem;margin-bottom:.35rem;font-size:.78rem;display:grid}.chat-participant-avatar{color:#1d4ed8;background:#eff6ff;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.56rem;font-weight:700;display:inline-flex;position:relative}.chat-participant-row em{color:#64748b;text-transform:capitalize;font-size:.68rem}.chat-side-note{color:#9a3412;background:#fff7ed;border:1px solid #fed7aa;border-radius:10px;align-items:center;gap:.35rem;margin-top:.85rem;padding:.5rem .6rem;font-size:.74rem;display:inline-flex}.chat-profile-pop-head{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.7rem;display:flex}.chat-profile-pop-card{border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:.6rem;padding:.7rem;display:flex}.chat-profile-pop-avatar{width:48px;height:48px}.chat-profile-pop-grid{grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.8rem;display:grid}.chat-profile-pop-grid div{border:1px solid #e2e8f0;border-radius:10px;padding:.45rem .55rem}.chat-profile-pop-grid span{color:#64748b;font-size:.7rem;display:block}.chat-profile-pop-grid strong{color:#0f172a;word-break:break-word;align-items:center;gap:.25rem;margin-top:.2rem;font-size:.78rem;display:inline-flex}.chat-online-txt{color:#166534!important}.chat-offline-txt{color:#64748b!important}.chat-compose-type-btn{color:#334155;background:#fff;border:1px solid #dbe2ea;border-radius:999px;padding:.45rem .7rem;font-size:.8rem;font-weight:600}.chat-compose-input{border:1px solid #e2e8f0;border-radius:10px;width:100%;margin-bottom:.75rem;padding:.55rem .65rem}.chat-member-option{grid-template-columns:auto 1fr auto;align-items:center;gap:.5rem;margin-bottom:.35rem;font-size:.82rem;display:grid}.chat-member-option em{color:#64748b;text-transform:capitalize;font-size:.68rem}.chat-parent-visible-toggle{color:#334155;align-items:center;gap:.45rem;margin-top:.75rem;font-size:.82rem;display:inline-flex}.chat-shell{background:#f0f2f5;border-radius:16px;height:calc(100vh - 140px);min-height:calc(100vh - 140px);display:grid;overflow:hidden;box-shadow:0 4px 24px #00000014}.chat-shell.show-info-panel{grid-template-columns:300px minmax(0,1fr) 280px}.chat-shell.hide-info-panel{grid-template-columns:300px minmax(0,1fr)}.chat-rail{color:#5f6368;background:#fff;border-right:1px solid #e8eaed;flex-direction:column;justify-content:space-between;align-items:center;gap:0;padding:16px 0;display:flex}.chat-rail-brand{border-bottom:1px solid #e8eaed;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:100%;padding-bottom:16px;display:flex}.chat-rail-logo,.chat-rail-user-avatar{letter-spacing:.02em;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:.75rem;font-weight:900;display:flex}.chat-rail-logo{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff}.chat-rail-brand-text{display:none}.chat-rail-nav{flex-direction:column;flex:1;align-items:center;gap:4px;width:100%;padding:12px 0;display:flex}.chat-rail-item{color:#9aa0a6;cursor:pointer;background:0 0;border:none;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;transition:background .15s,color .15s;display:flex;position:relative}.chat-rail-item em,.chat-rail-item span{display:none}.chat-rail-item:hover,.chat-rail-item.active{background:var(--primary-50);color:var(--primary-600)}.chat-rail-item.primary{background:var(--primary-600);color:#fff;border-radius:12px}.chat-rail-footer{border-top:1px solid #e8eaed;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;padding-top:12px;display:flex}.chat-rail-icon-btn{color:#9aa0a6;cursor:pointer;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:inline-flex}.chat-rail-icon-btn:hover{background:var(--primary-50);color:var(--primary-600)}.chat-rail-user-avatar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#f97316)}.chat-inbox{background:#fff;border-right:1px solid #e8eaed;flex-direction:column;min-width:0;min-height:0;display:flex;overflow:hidden}.chat-inbox-head{justify-content:space-between;align-items:center;gap:8px;padding:16px 16px 8px;display:flex}.chat-inbox-eyebrow{display:none}.chat-inbox-title{color:#1a1a2e;font-size:1.1rem;font-weight:700;line-height:1.2}.chat-inbox-subtitle{display:none}.chat-search-row{padding:0 12px 8px}.chat-search-pill{color:#9aa0a6;background:#f5f5f5;border:1px solid #e8eaed;border-radius:24px;align-items:center;gap:8px;padding:8px 14px;display:flex}.chat-search-pill input{color:#3c4043;background:0 0;border:none;outline:none;width:100%;font-size:.85rem}.chat-search-pill input::placeholder{color:#9aa0a6}.chat-search-pill-modal{margin-bottom:12px}.chat-recent-strip{border-bottom:1px solid #f0f0f0;padding:0 12px 12px}.chat-recent-strip-label{color:#3c4043;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.78rem;font-weight:700;display:flex}.chat-recent-strip-label button{color:#9aa0a6;cursor:pointer;background:0 0;border:none;align-items:center;display:flex}.chat-recent-avatars{gap:12px;padding-bottom:2px;display:flex;overflow-x:auto}.chat-recent-avatar-item{cursor:pointer;flex-direction:column;flex:none;align-items:center;gap:4px;display:flex}.chat-recent-avatar-ring{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:.8rem;font-weight:800;display:flex;position:relative}.chat-recent-avatar-ring.active-ring{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--primary-600)}.chat-recent-avatar-name{color:#5f6368;text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:48px;font-size:.68rem;overflow:hidden}.chat-all-chats-label{color:#3c4043;justify-content:space-between;align-items:center;padding:10px 16px 6px;font-size:.78rem;font-weight:700;display:flex}.chat-all-chats-label button{color:#9aa0a6;cursor:pointer;background:0 0;border:none;align-items:center;display:flex}.chat-filter-row{gap:6px;padding:0 12px 8px;display:flex;overflow-x:auto}.chat-filter-chip{color:#5f6368;white-space:nowrap;cursor:pointer;background:#fff;border:1px solid #e8eaed;border-radius:999px;padding:4px 12px;font-size:.75rem;font-weight:600;transition:background .15s,color .15s,border-color .15s}.chat-filter-chip.active{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.chat-alert{color:#9a3412;background:#fff7ed;border:1px solid #fdba74;border-radius:10px;margin:0 12px 8px;padding:8px 12px;font-size:.8rem}.chat-conv-scroll{flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-conv-skeleton{background:linear-gradient(90deg,#f1f5f9,#e2e8f0,#f1f5f9) 0 0/200% 100%;border-radius:10px;height:64px;margin:2px 12px}.chat-conv-card{text-align:left;cursor:pointer;background:0 0;border:none;border-radius:0;align-items:center;gap:12px;width:100%;padding:10px 16px;transition:background .12s;display:flex}.chat-conv-card:hover{background:#f5f5f5}.chat-conv-card.active{background:var(--primary-50)}.chat-conv-card-top{display:contents}.chat-conv-avatar-shell{flex:none;width:46px;height:46px;position:relative}.chat-conv-avatar-large{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:.85rem;font-weight:800;display:flex}.chat-conv-avatar-large.group{background:linear-gradient(135deg,#f59e0b,#ef4444)}.chat-conv-avatar-large.direct{background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.chat-avatar-dot{border:2px solid #fff;border-radius:50%;width:10px;height:10px;position:absolute;bottom:1px;right:1px}.chat-avatar-dot.online{background:#22c55e}.chat-avatar-dot.offline{background:#d1d5db}.chat-conv-copy{flex:1;min-width:0}.chat-conv-card-title{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:700;overflow:hidden}.chat-conv-card-sub{color:var(--chat-sidebar-text);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.78rem;overflow:hidden}.chat-conv-card-sub.typing{color:#60a5fa;font-style:italic}.chat-conv-meta{flex-direction:column;flex:none;align-items:flex-end;gap:4px;display:flex}.chat-conv-meta span{color:#9aa0a6;font-size:.75rem}.chat-conv-meta strong{background:var(--primary-600);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 5px;font-size:.68rem;display:inline-flex}.chat-conv-card-bottom{display:none}.chat-pill{text-transform:capitalize;border-radius:999px;align-items:center;padding:2px 8px;font-size:.68rem;font-weight:700;display:inline-flex}.chat-pill.direct{color:#1d4ed8;background:#dbeafe}.chat-pill.group{background:var(--primary-50);color:var(--primary-750)}.chat-pill.soft{color:#4b5563;background:#f3f4f6}.chat-muted{color:#94a3b8;font-size:.72rem}.chat-empty-state{text-align:center;color:#9aa0a6;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:32px 20px;display:flex}.chat-stage-empty{flex:1}.chat-stage-empty-mark{background:linear-gradient(135deg,var(--primary-50),var(--primary-100));width:64px;height:64px;color:var(--primary-600);border-radius:20px;justify-content:center;align-items:center;margin-bottom:8px;font-size:1.1rem;font-weight:900;display:flex}.chat-stage{background:#fff;border-right:1px solid #e8eaed;flex-direction:column;min-width:0;min-height:0;display:flex;overflow:hidden}.chat-stage-head{background:#fff;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.chat-stage-contact{align-items:center;gap:10px;display:flex}.chat-stage-contact-avatar{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;border-radius:50%;flex:none;justify-content:center;align-items:center;width:40px;height:40px;font-size:.8rem;font-weight:800;display:flex}.chat-stage-title{color:#1a1a2e;font-size:.95rem;font-weight:700;line-height:1.2}.chat-stage-subtitle{color:#94a3b8;align-items:center;gap:5px;margin-top:1px;font-size:.75rem;font-weight:500;display:flex}.chat-stage-subtitle.online{color:#22c55e}.chat-stage-subtitle.offline{color:#94a3b8}.chat-stage-subtitle.online:before,.chat-stage-subtitle.offline:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px;display:inline-block}.chat-stage-subtitle.typing{color:#60a5fa;font-style:italic}.chat-stage-subtitle.connecting{color:#f59e0b}.chat-stage-actions{align-items:center;gap:4px;display:flex}.chat-stage-icon-btn{color:#5f6368;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s;display:inline-flex}.chat-stage-icon-btn:hover{background:#f5f5f5}.chat-stage-badges,.chat-status-pill,.chat-stage-subtle{display:none}.chat-message-stack{background:#fff;flex-direction:column;flex:1;gap:0;padding:16px 16px 8px;display:flex;overflow-y:auto}.chat-day-divider{color:#fff;letter-spacing:.02em;background:#1a1a2e;border-radius:999px;width:fit-content;margin:12px auto;padding:4px 16px;font-size:.72rem;font-weight:600}.chat-bubble-wrap{align-items:flex-end;gap:8px;margin-bottom:4px;display:flex}.chat-bubble-wrap.mine{justify-content:flex-end}.chat-bubble-wrap.other{justify-content:flex-start}.chat-bubble-avatar-slot{flex:none;align-items:flex-end;width:32px;display:flex}.chat-participant-avatar{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.62rem;font-weight:800;display:inline-flex}.chat-bubble{border-radius:18px;max-width:min(65%,480px);padding:10px 14px;font-size:.88rem;line-height:1.5;box-shadow:0 1px 2px #0000000f}.chat-bubble.mine{background:var(--primary-600);color:#fff;border-bottom-right-radius:4px}.chat-bubble.other{color:#1a1a2e;background:#f5f5f5;border-bottom-left-radius:4px}.chat-bubble-meta-top{opacity:.75;align-items:center;gap:6px;margin-bottom:4px;font-size:.72rem;display:flex}.chat-bubble-meta-top strong{font-weight:700}.chat-bubble-meta-bottom{opacity:.65;justify-content:flex-end;align-items:center;gap:4px;margin-top:4px;font-size:.68rem;display:flex}.chat-bubble-sender-name{margin-bottom:3px;font-size:.72rem;font-weight:700}.chat-bubble.mine .chat-bubble-sender-name{color:#ffffffd9}.chat-bubble.other .chat-bubble-sender-name{color:var(--primary-600)}.chat-bubble-text{white-space:pre-wrap;word-break:break-word;font-size:.88rem;line-height:1.5}.chat-bubble-footer{justify-content:flex-end;align-items:center;gap:3px;margin-top:4px;display:flex}.chat-bubble-time{font-size:.65rem}.chat-bubble.mine .chat-bubble-time{color:#ffffffbf}.chat-bubble.other .chat-bubble-time{color:#9aa0a6}.chat-msg-status{color:#ffffffbf;flex:none;align-items:center;line-height:1;display:inline-flex}.chat-bubble.pending{opacity:.65}.chat-compose-bar{background:#fff;border-top:1px solid #f0f0f0;align-items:center;gap:8px;padding:10px 16px 12px;display:flex}.chat-compose-bar textarea{resize:none;color:#1a1a2e;background:#f5f5f5;border:1px solid #e8eaed;border-radius:24px;outline:none;flex:1;min-height:20px;max-height:100px;padding:9px 16px;font-size:.88rem;line-height:1.4}.chat-compose-bar textarea::placeholder{color:#9aa0a6}.chat-compose-icon-btn{color:#5f6368;cursor:pointer;background:0 0;border:none;border-radius:50%;flex:none;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s;display:inline-flex}.chat-compose-icon-btn:hover{background:#f5f5f5}.chat-send-btn{background:var(--primary-600);color:#fff;cursor:pointer;border:none;border-radius:50%;flex:none;justify-content:center;align-items:center;gap:0;width:36px;height:36px;padding:0;transition:background .15s;display:inline-flex}.chat-send-btn:hover{background:var(--primary-700)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-info{background:#fff;flex-direction:column;min-width:0;min-height:0;display:flex}.chat-info-body{flex-direction:column;flex:1;gap:20px;min-height:0;padding:16px;display:flex;overflow-y:auto}.chat-info-body::-webkit-scrollbar{width:4px}.chat-info-body::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:4px}.chat-info-action-row{gap:8px;width:100%;display:flex}.chat-info-action-row .block-btn{background:0 0;border-radius:10px;width:100%;padding:8px 16px;font-weight:600;transition:all .2s;border-color:var(--danger)!important;color:var(--danger)!important}.chat-info-action-row .block-btn:hover{box-shadow:0 2px 8px #ef444414;background:#ef44440d!important}.chat-info-notif-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:.82rem;font-weight:600;display:flex}.chat-info-notif-row .notif-label{color:#475569;align-items:center;gap:8px;display:flex}.chat-info-notif-row button{border-radius:8px!important;padding:4px 10px!important;font-size:.75rem!important;font-weight:600!important}.chat-info-photos-grid{grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px;display:grid}.chat-info-photos-grid a{aspect-ratio:1;border:1px solid #e2e8f0;border-radius:8px;transition:transform .2s,box-shadow .2s;display:block;overflow:hidden}.chat-info-photos-grid a:hover{transform:scale(1.04);box-shadow:0 4px 12px #00000014}.chat-info-photos-grid img{object-fit:cover;width:100%;height:100%;display:block}.chat-info-file-grid{grid-template-columns:repeat(3,1fr);gap:8px;width:100%;display:grid}.chat-info-file-grid .chat-file-card{background:#fafafa;border:1px solid #e8eaed;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:8px;transition:border-color .2s,background .2s;display:flex}.chat-info-file-grid .chat-file-card:hover{border-color:var(--primary-200);background:var(--primary-25)}.chat-info-file-grid .chat-file-card span{color:var(--gray-500);font-size:.7rem;font-weight:500}.chat-info-file-grid .chat-file-card strong{color:var(--gray-800);font-size:1rem;font-weight:700}.chat-info-section{flex-direction:column;width:100%;display:flex}.chat-info-section .chat-info-section-title{color:#9aa0a6;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:700;padding:0 0 6px!important}.chat-info-head{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;gap:8px;padding:14px 16px 10px;display:flex}.chat-info-title{color:#1a1a2e;font-size:.95rem;font-weight:700}.chat-info-subtitle{color:#9aa0a6;text-transform:capitalize;margin-top:1px;font-size:.75rem}.chat-info-card{padding:0}.chat-info-card-hero{text-align:center;border-bottom:1px solid #f0f0f0;flex-direction:column;align-items:center;gap:6px;padding:20px 16px 12px;display:flex}.chat-info-avatar{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.1rem;font-weight:900;display:flex}.chat-info-name{color:#1a1a2e;font-size:.95rem;font-weight:700}.chat-info-role{color:#9aa0a6;text-transform:capitalize;font-size:.78rem}.chat-info-section-title{color:#9aa0a6;text-transform:uppercase;letter-spacing:.08em;padding:10px 16px 4px;font-size:.72rem;font-weight:700}.chat-file-grid{grid-template-columns:repeat(2,1fr);gap:8px;padding:0 12px 12px;display:grid}.chat-file-card{background:#fafafa;border:1px solid #e8eaed;border-radius:10px;flex-direction:column;gap:2px;padding:10px;display:flex}.chat-file-card span{color:#9aa0a6;font-size:.68rem}.chat-file-card strong{color:#1a1a2e;font-size:1rem;font-weight:700}.chat-member-list{flex-direction:column;gap:2px;padding:0 8px 12px;display:flex}.chat-member-item{background:0 0;border:none;border-radius:10px;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;padding:8px;transition:background .12s;display:grid}.chat-member-item:hover{background:#f5f5f5}.chat-member-avatar{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.65rem;font-weight:800;display:flex}.chat-member-copy{min-width:0}.chat-member-name{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.chat-member-role{color:#9aa0a6;text-transform:capitalize;font-size:.7rem}.chat-member-state{text-transform:uppercase;letter-spacing:.04em;font-size:.62rem;font-weight:700}.chat-member-state.online{color:#22c55e}.chat-member-state.offline{color:#d1d5db}.chat-info-stats{flex-direction:column;gap:0;padding:0 8px 12px;display:flex}.chat-info-stats div{background:0 0;border:none;border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:8px;display:flex}.chat-info-stats span{color:#9aa0a6;font-size:.75rem}.chat-info-stats strong{color:#1a1a2e;font-size:.78rem;font-weight:600}.chat-info-note{background:var(--primary-50);border:1px solid var(--primary-100);color:var(--primary-700);border-radius:10px;margin:0 12px 12px;padding:10px 12px;font-size:.75rem;line-height:1.45}.chat-empty-note{color:#9aa0a6;text-align:center;padding:16px;font-size:.8rem}.chat-compose-overlay{z-index:2200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a80;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.chat-compose-modal{background:#fff;border-radius:20px;width:min(900px,100%);max-height:86vh;padding:20px;overflow:auto;box-shadow:0 20px 60px #0003}.chat-compose-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.chat-compose-title{color:#1a1a2e;font-size:1.1rem;font-weight:700}.chat-compose-grid{grid-template-columns:1.15fr .85fr;gap:16px;margin-top:16px;display:grid}.chat-member-option-row{cursor:pointer;background:#fff;border:1px solid #e8eaed;border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;width:100%;margin-bottom:6px;padding:10px 12px;transition:background .12s;display:grid}.chat-member-option-row:hover{background:#f5f5f5}.chat-member-option-row.selected{background:var(--primary-50);border-color:var(--primary-200)}.chat-member-action{color:var(--primary-600);font-size:.72rem;font-weight:700}.chat-selected-list{flex-wrap:wrap;gap:8px;min-height:48px;display:flex}.chat-selected-chip{background:var(--primary-50);color:var(--primary-700);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.chat-selected-chip button{width:18px;height:18px;color:inherit;cursor:pointer;background:#ffffffb3;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.chat-compose-actions{justify-content:flex-end;align-items:center;gap:10px;margin-top:16px;display:flex}.chat-compose-type-row{gap:8px;margin-bottom:12px;display:flex}.chat-compose-type-btn{color:#5f6368;cursor:pointer;background:#fff;border:1px solid #e8eaed;border-radius:999px;padding:6px 16px;font-size:.82rem;font-weight:600;transition:background .15s,color .15s}.chat-compose-type-btn.active{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.chat-compose-input{border:1px solid #e8eaed;border-radius:10px;outline:none;width:100%;margin-bottom:10px;padding:8px 12px;font-size:.88rem}.chat-member-picker{border:1px solid #e8eaed;border-radius:12px;max-height:220px;padding:6px;overflow-y:auto}.chat-parent-visible-toggle{color:#3c4043;cursor:pointer;align-items:center;gap:8px;margin:8px 0;font-size:.82rem;display:inline-flex}.admin-dash-skeleton-block{pointer-events:none}.admin-skeleton{background:#e2e8f0}.shimmer{position:relative;overflow:hidden}.shimmer:after{content:"";background:linear-gradient(100deg,#fff0 20%,#ffffffa6 50%,#fff0 80%);animation:1.25s infinite shimmerMove;position:absolute;inset:0;transform:translate(-100%)}@keyframes shimmerMove{to{transform:translate(100%)}}.content-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.content-grid-3{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.content-full{grid-column:1/-1}.tabs{border-bottom:2px solid var(--gray-100);gap:0;margin-bottom:1.5rem;display:flex}.tab{color:var(--gray-500);transition:all var(--transition-fast);cursor:pointer;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.75rem 1.25rem;font-size:.875rem;font-weight:500}.tab:hover{color:var(--gray-700)}.tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600);font-weight:600}.modal-overlay{z-index:var(--z-modal-backdrop);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn var(--transition-fast);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);width:90%;max-width:560px;max-height:85vh;animation:slideUp var(--transition-base);z-index:var(--z-modal);background:#fff;padding:1.75rem;overflow:auto}.modal-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-title{font-size:1.125rem;font-weight:700}.modal-close{border-radius:var(--radius-md);width:2rem;height:2rem;color:var(--gray-400);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--gray-100);color:var(--gray-700)}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid var(--gray-100);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.toast-container{z-index:var(--z-toast);flex-direction:column;gap:.5rem;display:flex;position:fixed;top:1.5rem;right:1.5rem}.toast{border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border-left:4px solid var(--primary-500);animation:slideInRight var(--transition-base);background:#fff;align-items:center;gap:.75rem;min-width:300px;padding:1rem 1.25rem;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.login-page{background:linear-gradient(135deg,#f0f7ff 0%,#e8f0fe 50%,#f8fafc 100%);min-height:100vh;display:flex}.login-left{flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.login-card{border-radius:var(--radius-2xl);width:100%;max-width:420px;box-shadow:var(--shadow-xl);background:#fff;border:1px solid #3b82f61a;padding:2.5rem}.login-logo-wrapper{justify-content:center;margin-bottom:1.5rem;display:flex}.login-logo{background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-radius:var(--radius-xl);width:72px;height:72px;box-shadow:var(--shadow-blue);justify-content:center;align-items:center;display:flex}.login-logo svg{color:#fff;width:40px;height:40px}.login-heading{text-align:center;margin-bottom:2rem}.login-heading h1{color:var(--gray-900);margin-bottom:.375rem;font-size:1.5rem;font-weight:800}.login-heading p{color:var(--gray-500);font-size:.9rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.login-forgot{text-align:right;margin-top:-.5rem}.login-forgot a{color:var(--primary-500);font-size:.8rem;font-weight:500}.login-forgot a:hover{color:var(--primary-700)}.login-btn{background:linear-gradient(135deg,var(--primary-500),var(--primary-700));color:#fff;border-radius:var(--radius-md);width:100%;box-shadow:var(--shadow-blue);transition:all var(--transition-fast);letter-spacing:.02em;padding:.875rem;font-size:1rem;font-weight:700}.login-btn:hover{background:linear-gradient(135deg,var(--primary-600),var(--primary-800));transform:translateY(-1px);box-shadow:0 6px 20px #2563eb73}.login-offline{text-align:center;margin-top:1.5rem}.login-offline a{color:var(--gray-500);align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;display:inline-flex}.login-offline a:hover{color:var(--gray-700)}.login-right{background:linear-gradient(135deg,var(--primary-600),var(--primary-800));flex:1;justify-content:center;align-items:center;padding:3rem;display:flex;position:relative;overflow:hidden}.login-right:before{content:"";background:#ffffff0d;border-radius:50%;width:500px;height:500px;position:absolute;top:-100px;right:-100px}.login-right:after{content:"";background:#ffffff08;border-radius:50%;width:300px;height:300px;position:absolute;bottom:-50px;left:-50px}.login-right-content{text-align:center;color:#fff;z-index:1;position:relative}.login-right-content h2{margin-bottom:1rem;font-size:2rem;font-weight:800}.login-right-content p{opacity:.85;max-width:400px;font-size:1.05rem;line-height:1.7}.ai-float-btn{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-500),var(--purple));color:#fff;width:56px;height:56px;z-index:var(--z-fixed);transition:all var(--transition-base);justify-content:center;align-items:center;font-size:1.5rem;animation:2s ease-in-out infinite pulse;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 8px 25px #3b82f666}.ai-float-btn:hover{animation:none;transform:scale(1.1);box-shadow:0 12px 35px #3b82f680}.ai-popup-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-fast);background:#0009;position:fixed;inset:0}.ai-popup{border-radius:var(--radius-2xl);z-index:var(--z-modal);animation:slideUp var(--transition-base);background:#fff;flex-direction:column;display:flex;position:fixed;inset:1.5rem;overflow:hidden}.ai-popup-header{border-bottom:1px solid var(--gray-100);background:linear-gradient(135deg,var(--primary-50),#fff);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.ai-popup-close{border-radius:var(--radius-full);width:2.5rem;height:2.5rem;color:var(--gray-500);transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:1.25rem;display:flex}.ai-popup-close:hover{background:var(--gray-100);color:var(--gray-800)}.ai-popup-body{flex:1;padding:1.5rem;overflow-y:auto}.legacy-chat-layout{height:calc(100vh - 64px);display:flex}.chat-sidebar{border-right:1px solid var(--gray-100);background:#fff;flex-direction:column;width:320px;display:flex}.chat-list{flex:1;overflow-y:auto}.chat-list-item{transition:background var(--transition-fast);cursor:pointer;border-bottom:1px solid var(--gray-50);align-items:center;gap:.75rem;padding:.875rem 1.25rem;display:flex}.chat-list-item:hover,.chat-list-item.active{background:var(--gray-50)}.chat-main{flex-direction:column;flex:1;display:flex}.chat-messages{flex-direction:column;flex:1;gap:1rem;padding:1.5rem;display:flex;overflow-y:auto}.chat-input-area{border-top:1px solid var(--gray-100);background:#fff;align-items:center;gap:.75rem;padding:1rem 1.5rem;display:flex}.chat-input{border:1.5px solid var(--gray-200);border-radius:var(--radius-full);background:var(--gray-50);flex:1;padding:.75rem 1rem;font-size:.9rem}.chat-input:focus{background:#fff;border-color:#2563eb;outline:none}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.calendar-day-header{text-align:center;color:var(--gray-500);text-transform:uppercase;padding:.5rem;font-size:.75rem;font-weight:600}.calendar-day{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);flex-direction:column;align-items:center;padding:.5rem;font-size:.875rem;display:flex}.calendar-day:hover{background:var(--gray-100)}.calendar-day.today{background:var(--primary-500);color:#fff;font-weight:700}.calendar-day.has-event:after{content:"";background:var(--primary-500);border-radius:50%;width:5px;height:5px;margin-top:auto}.leaderboard-item{border-bottom:1px solid var(--gray-50);align-items:center;gap:1rem;padding:.875rem 0;display:flex}.leaderboard-rank{text-align:center;width:2rem;font-size:1rem;font-weight:800}.leaderboard-rank.gold{color:#f59e0b}.leaderboard-rank.silver{color:#94a3b8}.leaderboard-rank.bronze{color:#d97706}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:3rem;display:flex}.empty-state-icon{border-radius:var(--radius-full);background:var(--gray-100);width:80px;height:80px;color:var(--gray-400);justify-content:center;align-items:center;margin-bottom:1rem;font-size:2rem;display:flex}.progress-bar{background:var(--gray-100);border-radius:var(--radius-full);width:100%;height:8px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:linear-gradient(90deg,var(--primary-500),var(--primary-400));height:100%;transition:width var(--transition-slow)}@media (max-width:1024px){.content-grid{grid-template-columns:1fr}.login-right{display:none}}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.stats-grid{grid-template-columns:1fr 1fr}.page-wrapper{padding:1rem}.admin-dash-hero{flex-direction:column}.admin-dash-title{font-size:1.7rem}.admin-dash-bottom-head{flex-direction:column;align-items:flex-start}.school-setup-hero{flex-direction:column}.school-setup-title{font-size:1.65rem}.school-setup-summary-grid{grid-template-columns:1fr 1fr}.classes-hero,.attendance-hero,.registration-hero,.announcements-hero,.students-hero,.teachers-hero,.parents-hero,.chat-hero{flex-direction:column}.classes-title,.attendance-title,.registration-title,.announcements-title,.students-title,.teachers-title,.parents-title,.chat-title{font-size:1.65rem}.classes-summary-grid,.attendance-summary-grid,.announcements-summary-grid,.students-summary-grid,.teachers-summary-grid,.parents-summary-grid{grid-template-columns:1fr 1fr}.chat-layout{grid-template-columns:1fr}.chat-list-card,.chat-side-card{min-height:auto}}@media (max-width:560px){.school-setup-summary-grid,.classes-summary-grid,.attendance-summary-grid,.announcements-summary-grid,.students-summary-grid,.teachers-summary-grid,.parents-summary-grid,.chat-profile-pop-grid{grid-template-columns:1fr}}.student-mobile-bottom-nav{display:none}.student-header{border-bottom:1px solid var(--gray-100);z-index:100;background:#fff;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;position:sticky;top:0}.student-header-brand{align-items:center;gap:.75rem;display:flex}.student-header-user{align-items:center;gap:1rem;display:flex}.student-header-user-info{align-items:center;gap:.5rem;display:flex}.student-header-user-details{display:block}.student-main{max-width:960px;margin:0 auto;padding:2rem 1.5rem}.exam-stats-grid{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}.student-dashboard-layout{grid-template-columns:1fr 360px;align-items:start;gap:2.5rem;display:grid}.exam-filter-tabs{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.exam-card-meta{color:var(--gray-500);flex-wrap:wrap;align-items:center;gap:1.5rem;margin-bottom:1rem;font-size:.8rem;display:flex}.exam-topbar{border-bottom:1px solid var(--gray-100);z-index:100;background:#fff;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.exam-topbar-info{min-width:0}.exam-topbar-title{color:var(--gray-900);white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:700;overflow:hidden}.exam-topbar-subtitle{color:var(--gray-500);font-size:.8rem}.exam-main-layout{flex:1;display:flex;overflow:hidden}.exam-question-panel{flex:1;padding:2rem;overflow-y:auto}.exam-navigator-sidebar{border-left:1px solid var(--gray-100);background:#fff;flex-shrink:0;width:240px;padding:1.5rem;overflow-y:auto}.exam-question-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.exam-nav-buttons{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.result-overview{background:linear-gradient(135deg,#fff 0%,var(--gray-50)100%);border:1px solid var(--gray-100);border-radius:20px;align-items:center;gap:2rem;margin-bottom:1.5rem;padding:2rem;display:flex}.result-stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.result-answer-row{gap:1rem;font-size:.85rem;display:flex}.submitted-card{text-align:center;background:#fff;border-radius:24px;width:100%;max-width:480px;padding:3rem;box-shadow:0 20px 60px #00000014}.submitted-scores{flex-wrap:wrap;justify-content:center;gap:2rem;margin-bottom:2rem;display:flex}.submitted-meta{flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:1.5rem;font-size:.85rem;display:flex}@media (max-width:1024px){.exam-navigator-sidebar{width:200px;padding:1rem}.exam-question-panel{padding:1.5rem}}@media (max-width:768px){.sidebar-mobile-toggle{display:flex}.sidebar-overlay{display:block}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.top-header{padding:0 1rem 0 3.5rem}.header-search{display:none!important}.header-user-info{display:none}.stats-grid{grid-template-columns:1fr 1fr}.page-wrapper{padding:1rem}.content-grid-3{grid-template-columns:1fr}.student-header{height:56px;padding:0 1rem}.student-header-user-details{display:none}.student-desktop-link{display:none!important}.student-logout-btn .logout-text{display:none}.student-logout-btn{border-radius:8px;padding:.4rem!important}.student-main{padding:1.25rem 1rem 80px!important}.student-mobile-bottom-nav{-webkit-backdrop-filter:blur(20px);z-index:1000;background:#ffffffe6;border-top:1px solid #e2e8f0cc;justify-content:space-around;align-items:center;height:60px;padding:0 .5rem;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000a}.student-mobile-nav-item{color:var(--gray-500);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;height:100%;font-size:.65rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.student-mobile-nav-item.active{color:var(--primary-600)}.student-mobile-nav-item svg{width:20px;height:20px;transition:transform .2s}.student-mobile-nav-item:active svg{transform:scale(.9)}.exam-stats-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)!important}.student-dashboard-layout{gap:2rem;grid-template-columns:1fr!important}.exam-card-meta{gap:.75rem;font-size:.75rem}.exam-topbar{flex-wrap:wrap;gap:.5rem;padding:.5rem .75rem}.exam-main-layout{flex-direction:column}.exam-question-panel{order:1;padding:1rem}.exam-navigator-sidebar{border-left:none;border-top:1px solid var(--gray-100);order:2;width:100%;max-height:none;padding:1rem}.exam-navigator-sidebar .nav-grid{grid-template-columns:repeat(10,1fr)}.exam-question-header{flex-direction:column;align-items:flex-start}.exam-nav-buttons span{display:none}.result-overview{text-align:center;flex-direction:column;gap:1.5rem;padding:1.5rem}.result-answer-row{flex-direction:column;gap:.5rem}.submitted-card{border-radius:16px;padding:2rem 1.5rem}.submitted-scores{gap:1.25rem}.submitted-meta{flex-direction:column;gap:.5rem}}@media (max-width:480px){.student-main{padding:1rem .75rem}.exam-stats-grid{gap:.5rem}.exam-filter-tabs{gap:.35rem}.exam-filter-tabs button{padding:.4rem .75rem!important;font-size:.75rem!important}.exam-topbar{padding:.5rem}.exam-question-panel{padding:.75rem}.exam-navigator-sidebar .nav-grid{grid-template-columns:repeat(5,1fr)}.result-stats-grid{grid-template-columns:1fr 1fr;gap:.5rem}}@media (max-width:640px){.top-header{gap:.4rem!important;padding:.5rem .75rem!important}.header-search{display:none!important}:root{--user-info-display:none;--year-display:none}}@media (min-width:641px){:root{--user-info-display:flex;--year-display:flex}}@media (max-width:768px){.admin-dash-hero{flex-direction:column!important;gap:1rem!important;padding:1.25rem!important}.admin-dash-title{font-size:1.5rem!important}.admin-dash-stats-grid{grid-template-columns:1fr 1fr!important;gap:.75rem!important}.stat-card{border-radius:16px!important;padding:1rem!important}.page-wrapper{padding:1rem!important}}@media (max-width:480px){.admin-dash-stats-grid{grid-template-columns:1fr!important}}@media (max-width:1024px){.admin-dash-stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:.9rem!important;display:grid!important}.admin-dash-bottom-grid{grid-template-columns:1fr!important;gap:1rem!important;display:grid!important}.admin-dash-bottom-card{padding:1.25rem!important}.admin-dash-stat-card{padding:.9rem!important}.admin-dash-bottom-head{gap:.5rem!important}}@media (max-width:640px){.admin-dash-stats-grid{grid-template-columns:1fr!important;gap:.6rem!important}.admin-dash-bottom-card{padding:.9rem!important}.admin-dash-chip{padding:.25rem .6rem!important;font-size:.75rem!important}}@media (max-width:768px){.card{border-radius:12px!important}.card-header{flex-wrap:wrap!important;gap:.5rem!important}.table-wrapper{overflow-x:auto!important}.tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;overflow-x:auto!important}.tab{white-space:nowrap!important;flex-shrink:0!important}.main-content{margin-left:0!important}.chat-shell{height:calc(100vh - 100px)!important;min-height:calc(100vh - 100px)!important}}@media (min-width:769px) and (max-width:1024px){.chat-shell.show-info-panel{grid-template-columns:260px minmax(0,1fr) 240px!important}.chat-shell.hide-info-panel{grid-template-columns:280px minmax(0,1fr)!important}}@media (max-width:768px){.chat-mobile-back-btn{color:#5f6368;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;margin-right:8px;transition:background .15s;display:inline-flex!important}.chat-mobile-back-btn:hover{background:#f5f5f5}.chat-shell.no-active-conv{grid-template-columns:1fr!important}.chat-shell.no-active-conv .chat-inbox{width:100%!important;max-width:100%!important;display:flex!important}.chat-shell.no-active-conv .chat-stage,.chat-shell.no-active-conv .chat-info{display:none!important}.chat-shell.has-active-conv{grid-template-columns:1fr!important}.chat-shell.has-active-conv .chat-inbox{display:none!important}.chat-shell.has-active-conv.hide-info-panel .chat-stage{width:100%!important;display:flex!important}.chat-shell.has-active-conv.hide-info-panel .chat-info,.chat-shell.has-active-conv.show-info-panel .chat-stage{display:none!important}.chat-shell.has-active-conv.show-info-panel .chat-info{width:100%!important;max-width:100%!important;display:flex!important}}@media (min-width:769px){.chat-mobile-back-btn{display:none!important}}.chat-bubble{position:relative;max-width:min(72%,620px)!important}.chat-bubble-row .chat-bubble-actions{opacity:0!important;pointer-events:none!important}.chat-bubble-row:hover .chat-bubble-actions{opacity:1!important;pointer-events:auto!important}.chat-bubble-actions button:hover{background:#f1f5f9!important}.chat-conv-card:hover .chat-conv-pin-btn{opacity:1!important}@keyframes chatPulse{0%,to{opacity:1}50%{opacity:.4}}.chat-bubble-text{word-break:break-word}.chat-back-row{margin-bottom:1rem}.chat-back-btn{border:1.5px solid var(--gray-150);color:var(--gray-800);cursor:pointer;background:#fff;border-radius:12px;align-items:center;gap:.5rem;padding:.55rem 1.15rem;font-size:.85rem;font-weight:700;transition:all .2s ease-in-out;display:inline-flex;box-shadow:0 2px 8px #0000000a}.chat-back-btn:hover{border-color:var(--primary-300);transform:translateY(-1px);box-shadow:0 4px 16px #2563eb14}.chat-back-btn svg{color:var(--primary-600)}.mobile-search-toggle-btn{display:none!important}@media (max-width:768px){.mobile-search-toggle-btn{display:inline-flex!important}}@media (min-width:769px){.sidebar{transition:width .2s cubic-bezier(.4,0,.2,1),transform var(--transition-base)!important}.main-content{transition:margin-left .2s cubic-bezier(.4,0,.2,1)!important}body.sidebar-collapsed .sidebar{width:70px!important}body.sidebar-collapsed .main-content{margin-left:70px!important}body.sidebar-collapsed .sidebar-header{justify-content:center!important;padding:1rem .75rem!important}body.sidebar-collapsed .sidebar-brand-wrapper{display:none!important}body.sidebar-collapsed .sidebar-nav{padding:1rem .5rem!important}body.sidebar-collapsed .nav-item{border-radius:12px!important;justify-content:center!important;width:100%!important;padding:.75rem 0!important}body.sidebar-collapsed .nav-label{display:none!important}body.sidebar-collapsed .nav-icon{margin-right:0!important}body.sidebar-collapsed .sidebar-section{display:none!important}body.sidebar-collapsed .nav-badge{padding:2px 5px!important;font-size:.65rem!important;position:absolute!important;top:4px!important;right:4px!important}body.sidebar-collapsed .sidebar-footer{padding:1rem .5rem!important}}.sidebar-desktop-collapse-btn{border:1px solid var(--gray-200);width:24px;height:24px;color:var(--gray-500);cursor:pointer;z-index:100;background:#fff;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:24px;right:-12px;box-shadow:0 4px 10px #0f172a14}.sidebar-desktop-collapse-btn:hover{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-600);transform:scale(1.08)}@media (max-width:768px){.sidebar-desktop-collapse-btn{display:none!important}}.settings-grid-layout{grid-template-columns:minmax(0,1.2fr) minmax(250px,.8fr);align-items:start;gap:1.5rem;display:grid}.settings-info-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (max-width:992px){.settings-grid-layout{gap:1.25rem;grid-template-columns:1fr!important}}@media (max-width:480px){.settings-info-grid{gap:.75rem;grid-template-columns:1fr!important}}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(360px,1fr));align-items:start;gap:1.5rem;margin-top:1.5rem;display:grid}.settings-input{width:100%;margin-top:6px;display:block;border:1.5px solid var(--gray-300)!important;color:var(--gray-900)!important;background-color:#f8fafc!important;border-radius:10px!important;outline:none!important;padding:.65rem .85rem!important;font-size:.9rem!important;font-weight:500!important;transition:all .2s!important;box-shadow:inset 0 1px 2px #0f172a08!important}.settings-input:hover{border-color:var(--gray-400)!important;background-color:#f1f5f9!important}.settings-input:focus{border-color:var(--primary-500)!important;background-color:#fff!important;box-shadow:0 0 0 3px #2563eb1f,0 1px 2px #0f172a0a!important}.settings-label{color:var(--gray-700);cursor:pointer;margin-bottom:.8rem;font-size:.88rem;font-weight:600;display:block}.calendar-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.calendar-main-layout{grid-template-columns:minmax(0,1fr) 340px;align-items:start;gap:16px;display:grid}.calendar-day-cell{min-height:110px}.calendar-day-events-container{flex-direction:column;gap:6px;display:flex}.calendar-more-badge{color:var(--gray-500);padding-left:2px;font-size:.72rem}@media (max-width:992px){.calendar-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.calendar-main-layout{grid-template-columns:1fr!important}}@media (max-width:768px){.calendar-day-cell{min-height:64px!important;padding:6px!important}.calendar-empty-cell{min-height:64px!important}.calendar-day-events-container{flex-flow:wrap!important;justify-content:center!important;gap:4px!important}.calendar-more-badge{color:var(--primary-600)!important;padding-left:0!important;font-size:.6rem!important;font-weight:700!important}.day-chip-label{display:none!important}.day-chip-button{background:0 0!important;border:none!important;border-radius:50%!important;width:auto!important;padding:4px!important;display:inline-flex!important}}@media (max-width:480px){.calendar-stats-grid{grid-template-columns:1fr!important}}.exams-main-layout{grid-template-columns:minmax(0,1fr) 300px;align-items:start;gap:1.25rem;display:grid}.exams-details-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (max-width:992px){.exams-main-layout{grid-template-columns:1fr!important}}@media (max-width:576px){.exams-details-grid{grid-template-columns:1fr!important}}.students-main-layout{grid-template-columns:1fr;gap:1.25rem;display:grid}.students-main-layout.has-selected{grid-template-columns:minmax(0,1fr) minmax(0,1.5fr)}.students-stats-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (max-width:992px){.students-main-layout.has-selected{grid-template-columns:1fr!important}.students-main-layout.has-selected .students-list-card{display:none!important}.students-back-button{margin-bottom:.5rem;display:inline-flex!important}}@media (max-width:768px){.students-list-card table{min-width:500px!important}}@media (max-width:576px){.students-main-layout table{min-width:400px}}@media (max-width:480px){.students-stats-grid{grid-template-columns:1fr!important}}.registration-grid{grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.25rem;display:grid}.info-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}.registration-success-body{padding:24px 28px}.registration-form-card{padding:2rem}.registration-fallback{text-align:center;color:var(--gray-500);padding:2rem}@media (max-width:768px){.registration-grid,.info-grid{grid-template-columns:1fr!important}.registration-form-card,.registration-success-body,.registration-fallback{padding:1rem!important}}@media (max-width:480px){.registration-form-card,.registration-success-body{padding:.75rem!important}}
