:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background:#f6f7fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #f6f7fb;--surface: #ffffff;--text: #0f172a;--muted: #475569;--border: rgba(15, 23, 42, .12);--shadow: 0 16px 50px rgba(15, 23, 42, .12);--primary: #4f46e5;--primary-hover: #4338ca}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--text);background:var(--bg)}a{color:inherit;text-decoration:none}.btn{border:1px solid var(--border);background:#ffffffb3;color:var(--text);border-radius:10px;padding:10px 12px;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease}.btn:hover{background:#ffffffe6;transform:translateY(-1px)}.btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn.primary{background:var(--primary);color:#fff;border-color:#4f46e5cc}.btn.primary:hover{background:var(--primary-hover)}.btn.secondary{background:transparent}.btn.secondary:hover{background:#0f172a0a}#root{min-height:100vh}.particlesWrap{position:fixed;inset:0;z-index:0;pointer-events:none}.particlesWrap canvas{width:100%!important;height:100%!important}.authPage{min-height:100vh;position:relative;background:radial-gradient(1200px 600px at 10% 0%,rgba(79,70,229,.16) 0%,transparent 65%),radial-gradient(900px 500px at 90% 20%,rgba(14,165,233,.12) 0%,transparent 65%),var(--bg)}.authContent{position:relative;z-index:1;min-height:100vh;display:grid;place-items:center;padding:28px 18px}.authCard{width:100%;max-width:420px;background:#ffffffc7;border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.authBrand{font-weight:800;letter-spacing:.3px;color:var(--text)}.authTitle{margin:10px 0 6px;font-size:22px}.authSubtitle{margin:0 0 14px;color:var(--muted);font-size:13px}.loginForm{display:grid;gap:12px}.field{display:grid;gap:6px}.field span{font-size:12px;color:var(--muted)}.field input{width:100%;padding:11px 12px;border-radius:10px;border:1px solid var(--border);background:#ffffffe6;color:var(--text);outline:none}.field input:focus{border-color:#4f46e599;box-shadow:0 0 0 4px #4f46e524}.password-field .input-container{position:relative}.password-field input{padding-right:60px}.visibility-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:4px;border-radius:4px}.visibility-btn:hover{color:var(--text);background:#0000000d}.visibility-btn svg{width:18px;height:18px;display:block}.error{padding:10px 12px;border-radius:10px;border:1px solid rgba(220,38,38,.35);background:#dc262614;color:#991b1b}.authRow{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12px}.authRowRight{justify-content:flex-end}.authRowCenter{justify-content:center}.authMuted{color:var(--muted)}.authLink{color:var(--primary);font-weight:600}.authLink:hover{text-decoration:underline}.linkButton{background:none;border:none;padding:0;font:inherit;cursor:pointer}.linkButton:disabled{cursor:not-allowed;color:var(--muted);text-decoration:none}.authMessage{padding:10px 12px;border-radius:10px;border:1px solid rgba(15,23,42,.1);background:#0f172a0a;color:var(--text);font-size:12px}.authMessage.success{border-color:#22c55e66;background:#22c55e1a;color:#166534}.otpInputs{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.otpInput{width:100%;height:46px;border-radius:10px;border:1px solid var(--border);text-align:center;font-size:18px;font-weight:700;background:#ffffffe6;color:var(--text);outline:none}.otpInput:focus{border-color:#4f46e599;box-shadow:0 0 0 4px #4f46e524}.page{min-height:100vh;background:radial-gradient(1200px 600px at 10% 0%,rgba(79,70,229,.18) 0%,transparent 65%),radial-gradient(900px 500px at 90% 20%,rgba(14,165,233,.14) 0%,transparent 65%),var(--bg);color:var(--text)}.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border);background:#ffffff8c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.brandTitle{font-weight:700;letter-spacing:.2px}.brandSubtitle{color:var(--muted);font-size:12px;margin-top:2px}.userArea{display:flex;align-items:center;gap:14px}.userMeta{text-align:right;line-height:1.1}.userEmail{font-size:12px;color:var(--muted)}.userRole{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.content{max-width:900px;margin:0 auto;padding:84px 22px 60px}.pageTitle{margin:0 0 14px;font-size:22px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px;box-shadow:var(--shadow)}.codeBlock{margin:0;white-space:pre-wrap;padding:12px;border-radius:10px;border:1px solid var(--border);background:#f8fafc;color:#0f172a;overflow:auto}.profileDropdown{position:relative;display:flex;align-items:center}.profileDropdownTrigger{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center}.profileDropdownAvatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--primary);box-shadow:0 1px 3px #0000001a;transition:transform .2s ease}.profileDropdownTrigger:hover .profileDropdownAvatar{transform:scale(1.05)}.profileDropdownIcon{margin-left:8px;color:var(--primary);font-size:14px;transition:transform .2s ease}.profileDropdownTrigger:hover .profileDropdownIcon{transform:translateY(2px)}.profileDropdownMenu{position:absolute;right:0;top:100%;margin-top:8px;width:240px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;overflow:hidden;z-index:100;border:1px solid var(--border)}.profileDropdownHeader{padding:16px;background:#4f46e50d}.profileDropdownUserEmail{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profileDropdownUserRole{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.profileDropdownDivider{height:1px;background:var(--border);margin:8px 0}.profileDropdownItem{width:100%;background:none;border:none;padding:12px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;text-align:left;font-size:14px;color:var(--text);transition:background-color .2s ease}.profileDropdownItem:hover{background:#4f46e514}.profileDropdownItemIcon{font-size:18px}.profileDropdownItemText{flex:1}.sharedNavbar{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border);background:#f6f7fbf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 3px #0000001a}.sharedNavbarContent{width:100%;display:flex;justify-content:space-between;align-items:center}.sharedNavbarLeft{display:flex;align-items:center;gap:16px}.sharedNavbarLogo{display:flex;align-items:center;margin-right:12px}.sharedNavbarLogoImage{height:45px;width:auto;object-fit:contain;transition:transform .2s ease}.sharedNavbarLogoImage:hover{transform:scale(1.05)}.sharedNavbarTitle{font-weight:700;color:var(--text);font-size:18px}.sharedBackButton{background:#4f46e514;border:1px solid rgba(79,70,229,.2);color:var(--primary);font-size:14px;font-weight:600;cursor:pointer;padding:6px 12px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;gap:6px;box-shadow:0 1px 2px #0000000d}.sharedBackButton:hover{background:#4f46e526;border-color:#4f46e54d;transform:translate(-2px);box-shadow:0 2px 4px #0000001a}.sharedBackButton:active{transform:translate(0);background:#4f46e533}.sharedNavbarRight{display:flex;align-items:center;gap:12px}.sharedNavbarUserInfo{display:flex;flex-direction:column;align-items:flex-end;margin-right:8px}.sharedNavbarUserEmail{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap}.sharedNavbarUserRole{font-size:12px;font-weight:500;color:var(--text);white-space:nowrap;opacity:.9;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}.sharedDashboardLink{color:var(--primary);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;text-decoration:none}.sharedDashboardLink:hover{color:#4f46e5;transform:translateY(-1px)}@media(max-width:768px){.sharedNavbar{padding:12px 16px}.sharedNavbarTitle{font-size:16px}.sharedBackButton{font-size:13px}.sharedNavbarUserEmail{font-size:12px}.sharedNavbarLogoImage{height:32px}}.adminLayout{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.adminSidebar{position:sticky;top:56px;height:calc(100vh - 56px);padding:18px 14px;border-right:1px solid var(--border);background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.adminBrand{font-weight:900;letter-spacing:.2px;padding:10px 10px 14px}.adminNav{display:grid;gap:4px}.adminLink{padding:10px;border-radius:10px;color:var(--text);border:1px solid transparent}.adminLink:hover{background:#4f46e50f}.adminLink.active{background:#4f46e51f;border-color:#4f46e52e}.adminMain{min-width:0;height:calc(100vh - 56px)}.adminTopbar{position:sticky;top:0;z-index:5;display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border);background:#f6f7fbbf;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.adminTopbarTitle{font-weight:700}.adminUser{display:flex;align-items:center;gap:12px}.adminUserMeta{text-align:right;line-height:1.1}.adminUserEmail{font-size:12px;color:var(--muted)}.adminUserRole{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.adminContent{padding:84px 18px 60px}@media(max-width:900px){.adminLayout{grid-template-columns:1fr}.adminSidebar{position:relative;height:auto;border-right:none;border-bottom:1px solid var(--border)}.adminNav{grid-template-columns:repeat(3,minmax(0,1fr))}}.sectionTitle{margin:0 0 12px;font-size:18px}.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.gridCards{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.statCard{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow)}.statLabel{font-size:12px;color:var(--muted)}.statValue{margin-top:6px;font-size:22px;font-weight:800}.panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow)}.chartsGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.chartTitle{font-weight:900;margin-bottom:10px}.chartHint{font-size:12px;color:var(--muted);margin-top:-6px;margin-bottom:10px}@media(max-width:1100px){.chartsGrid{grid-template-columns:1fr}}.toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;margin-bottom:12px}.search{display:flex;gap:10px;align-items:center}.input{width:100%;max-width:360px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:#ffffffe6;color:var(--text);outline:none}.input:focus{border-color:#4f46e599;box-shadow:0 0 0 4px #4f46e51f}.actions{display:flex;gap:8px;align-items:center}.btn.small{padding:8px 10px;border-radius:10px;font-size:12px;border:1px solid var(--border)}.btn.danger{background:#dc26261f;border-color:#dc262633;color:#991b1b}.btn.danger:hover{background:#dc262629}.formGrid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.formRow{display:grid;gap:6px}.formRow label{font-size:12px;color:var(--muted)}.select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:#ffffffe6;color:var(--text)}.select.narrow{max-width:360px}.table{width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:12px;overflow:hidden}.table th,.table td{padding:10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;font-size:13px}.snCol{width:56px;text-align:right}.table th{background:#f8fafc;color:var(--muted);font-weight:700}.table tr:hover td{background:#4f46e508}.truncate{max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.muted{color:var(--muted)}.errorText{color:#991b1b}@media(max-width:1100px){.gridCards{grid-template-columns:repeat(2,minmax(0,1fr))}}.modalOverlay{position:fixed;inset:0;background:#0f172a59;display:grid;place-items:center;padding:18px;z-index:1050}.modal{width:100%;max-width:800px!important;max-height:99vh!important;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);display:flex;flex-direction:column}.modalHeader{padding:14px 14px 10px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.modalTitle{font-weight:900}.modalBody{padding:14px;overflow:auto}.psWrap{position:relative}.psButton{width:100%;display:flex;align-items:center;justify-content:flex-start;gap:10px;padding:10px 64px 10px 12px;border-radius:10px;border:1px solid var(--border);background:#ffffffe6;cursor:pointer;position:relative}.psButtonText{font-weight:800;font-size:13px;color:var(--text);flex:1;text-align:left}.psChevron{font-size:12px;color:var(--muted);position:absolute;right:12px;top:50%;transform:translateY(-50%)}.psClear{position:absolute;right:36px;top:50%;transform:translateY(-50%);width:22px;height:22px;display:grid;place-items:center;border:1px solid var(--border);background:#ffffffe6;border-radius:999px;cursor:pointer;color:var(--muted);z-index:2}.psClear:hover{background:#4f46e50f;color:var(--text)}.psDropdown{position:fixed;z-index:1060;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}.psSearch{padding:10px;border-bottom:1px solid var(--border);background:#f8fafc}.psSearchInput{max-width:100%}.psList{display:grid;overflow:auto}.psItem{text-align:left;border:none;background:transparent;padding:10px 12px;cursor:pointer}.psItem:hover{background:#4f46e50f}.psItem.active{background:#4f46e51f}.psItemTitle{font-weight:900;font-size:13px}.psEmpty{padding:10px 12px;font-size:12px;color:var(--muted)}.smsMulti{display:grid;gap:10px}.smsChips{display:flex;flex-wrap:wrap;gap:8px}.smsChip{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;border:1px solid var(--border);background:#4f46e514;color:var(--text);cursor:pointer}.smsChip:hover{background:#4f46e51f}.smsChipText{max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.smsChipX{opacity:.8;font-weight:900}.smsInputRow{display:flex;gap:10px;align-items:center}.smsLoading{font-size:12px;color:var(--muted);white-space:nowrap}.smsDropdown{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}.smsEmpty{padding:10px 12px;font-size:12px;color:var(--muted)}.smsList{display:grid}.smsItem{text-align:left;padding:10px 12px;border:none;background:transparent;cursor:pointer}.smsItem:hover{background:#4f46e50f}.smsItem.disabled{opacity:.6;cursor:not-allowed}.smsItemTitle{font-weight:800;font-size:13px}.smsItemMeta{margin-top:3px;display:flex;gap:8px;align-items:center;font-size:12px;color:var(--muted)}.tsWrap{position:relative}.tsButton{width:100%;display:flex;align-items:center;justify-content:flex-start;gap:10px;padding:10px 64px 10px 12px;border-radius:10px;border:1px solid var(--border);background:#ffffffe6;cursor:pointer;position:relative}.tsButtonText{font-weight:800;font-size:13px;color:var(--text);flex:1;text-align:left}.tsChevron{font-size:12px;color:var(--muted);position:absolute;right:12px;top:50%;transform:translateY(-50%)}.tsClear{position:absolute;right:36px;top:50%;transform:translateY(-50%);width:22px;height:22px;display:grid;place-items:center;border:1px solid var(--border);background:#ffffffe6;border-radius:999px;cursor:pointer;color:var(--muted);z-index:2}.tsClear:hover{background:#4f46e50f;color:var(--text)}.tsDropdown{position:fixed;z-index:1100;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}.tsSearchInput{max-width:100%}.tsSearch{padding:10px;border-bottom:1px solid var(--border);background:#f8fafc}.tsList{display:grid;max-height:260px;overflow:auto}.tsItem{text-align:left;border:none;background:transparent;padding:10px 12px;cursor:pointer}.tsItem:hover{background:#4f46e50f}.tsItem.active{background:#4f46e51f}.tsItemTitle{font-weight:900;font-size:13px}.tsItemMeta{margin-top:3px;font-size:12px}.tsEmpty{padding:10px 12px;font-size:12px;color:var(--muted)}.smsToastWrap{position:fixed;top:14px;right:14px;z-index:50;max-width:min(420px,calc(100vw - 28px))}.smsToast{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;border-radius:14px;border:1px solid var(--border);background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow);color:var(--text)}.smsToast.success{border-color:#22c55e59;background:#f0fdf4eb}.smsToast.error{border-color:#ef44444d;background:#fef2f2eb}.smsToastMessage{font-size:13px;font-weight:600}.smsToastClose{border:1px solid rgba(148,163,184,.35);background:#fffc;color:var(--muted);border-radius:10px;padding:6px 10px;cursor:pointer}.smsToastClose:hover{background:#0f172a0a}.profileSidebar{position:fixed;top:60px;left:0;height:calc(100vh - 60px);padding:18px 14px;border-right:1px solid var(--border);background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:260px;z-index:900;overflow-y:auto}.profileSidebarHeader{font-weight:900;letter-spacing:.2px;padding:10px 10px 14px;border-bottom:1px solid var(--border);margin-bottom:14px}.profileBackButton{background:none;border:none;color:var(--primary);font-size:14px;font-weight:600;cursor:pointer;padding:6px 0;margin-bottom:12px;display:flex;align-items:center;gap:6px;transition:all .2s ease}.profileBackButton:hover{color:var(--primary);transform:translate(-2px)}.profileBackButton:active{transform:translate(0)}.profileSidebarHeader h3{font-size:16px;color:var(--text);margin:0}.profileSidebarNav{display:grid;gap:4px}.profileSidebarItem{padding:10px;border-radius:10px;color:var(--text);border:1px solid transparent;background:none;cursor:pointer;text-align:left;font-size:14px;font-weight:500;display:flex;align-items:center;gap:10px;transition:all .2s ease}.profileSidebarItem:hover{background:#4f46e50f}.profileSidebarItem.active{background:#4f46e51f;border-color:#4f46e52e;font-weight:600}.profileSidebarIcon{font-size:16px}.profileSidebarText{flex:1}@media(max-width:900px){.profileSidebar{position:relative;height:auto;border-right:none;border-bottom:1px solid var(--border)}.profileSidebarNav{grid-template-columns:repeat(2,minmax(0,1fr))}}.adminProfilePageFull{min-height:100vh;height:100vh;overflow:hidden}.teacherProfilePageFull{min-height:100vh;height:100vh;overflow:hidden}.studentProfilePageFull{min-height:100vh;height:100vh;overflow:hidden}:root{--primary: #4361ee;--primary-light: #4895ef;--secondary: #3a0ca3;--success: #4cc9f0;--danger: #f72585;--warning: #f8961e;--light: #f8f9fa;--dark: #212529;--gray: #6c757d;--light-gray: #e9ecef;--border-radius: 12px;--box-shadow: 0 4px 6px rgba(0, 0, 0, .1);--transition: all .3s ease}.parentProfilePageFull{min-height:100vh;height:100vh;overflow:hidden}.profile-container{display:flex;padding-left:275px;padding-right:20px;padding-top:20px;gap:24px;margin-top:60px;height:calc(100vh - 60px);overflow:hidden}.profile-main{flex:1;background:#fff;border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:30px;overflow-y:auto;height:100%}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid var(--light-gray)}.profile-header h1{font-size:28px;font-weight:700;color:var(--dark);margin:0}.profile-card{display:grid;grid-template-columns:200px 1fr;gap:40px}.security-card{max-width:500px;margin:0 auto;border:2px solid var(--light-gray);border-radius:var(--border-radius);padding:24px;background:#fff;box-shadow:0 2px 8px #0000000d}.security-card h3{font-size:20px;margin-bottom:25px;color:var(--dark);border-bottom:2px solid var(--primary);padding-bottom:12px}.profile-avatar-section{text-align:center}.avatar-container{position:relative;width:160px;height:160px;margin:0 auto 20px;border-radius:50%;overflow:hidden;border:4px solid white;box-shadow:var(--box-shadow)}.avatar{width:100%;height:100%;object-fit:cover;transition:var(--transition)}.avatar-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition)}.avatar-container:hover .avatar-overlay{opacity:1}.avatar-input{display:none}.btn-avatar{background:var(--primary);color:#fff;width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;font-size:18px;transition:var(--transition)}.btn-avatar:hover{background:var(--secondary);transform:scale(1.1)}.camera-icon-button{background:var(--primary);color:#fff;width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;font-size:18px;transition:var(--transition)}.camera-icon-button:hover{background:var(--secondary);transform:scale(1.1)}.camera-icon-button svg{width:20px;height:20px}.btn-remove-image{background:transparent;color:var(--danger);border:1px solid var(--danger);padding:8px 16px;border-radius:20px;cursor:pointer;font-size:14px;transition:var(--transition)}.btn-remove-image:hover{background:var(--danger);color:#fff}.profile-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.info-field{background:var(--light);padding:16px;border-radius:8px;border-left:4px solid var(--primary)}.info-label{display:block;font-size:12px;color:var(--gray);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:600}.info-value{font-size:16px;color:var(--dark);font-weight:500}.info-value.multiline{white-space:pre-wrap;line-height:1.5}.btn-edit{background:var(--primary);color:#fff;border:none;padding:12px 24px;border-radius:25px;cursor:pointer;font-weight:600;display:flex;align-items:center;gap:8px;transition:var(--transition)}.btn-edit:hover{background:var(--secondary);transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.btn-primary{background:var(--primary);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;display:flex;align-items:center;gap:8px;transition:var(--transition)}.btn-primary:hover:not(:disabled){background:var(--secondary);transform:translateY(-2px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--dark);border:2px solid var(--light-gray);padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;display:flex;align-items:center;gap:8px;transition:var(--transition)}.btn-secondary:hover{border-color:var(--gray)}.password-form{display:flex;flex-direction:column;gap:20px;border:1px solid var(--light-gray);border-radius:8px;padding:20px;background:var(--light)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--dark)}.form-input{width:100%;padding:12px 16px;border:2px solid var(--light-gray);border-radius:8px;font-size:16px;transition:var(--transition)}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4361ee1a}.password-input-group{position:relative}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;font-size:18px;color:var(--gray)}.form-actions{display:flex;justify-content:flex-end;margin-top:20px}.alert{padding:16px;border-radius:8px;margin-bottom:24px;font-weight:500}.alert-error{background:#fee;color:#c33;border:1px solid #fcc}.alert-success{background:#efe;color:#090;border:1px solid #cfc}.modal-avatar-section{text-align:center;margin-bottom:24px}.modal-avatar-container{position:relative;width:120px;height:120px;margin:0 auto 16px;border-radius:50%;overflow:hidden;border:4px solid white;box-shadow:var(--box-shadow)}.modal-avatar{width:100%;height:100%;object-fit:cover;transition:var(--transition)}.modal-avatar-overlay{position:absolute;inset:0;background:transparent;display:flex;align-items:center;justify-content:center;opacity:1;transition:var(--transition)}.modal-avatar-clickable{position:relative;display:block;cursor:pointer;border-radius:50%;overflow:hidden}.camera-icon-overlay{position:absolute;bottom:8px;right:8px;background:#fff;color:var(--primary);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--primary);box-shadow:0 2px 6px #00000026;transition:var(--transition)}.camera-icon-overlay:hover{background:var(--primary);color:#fff;transform:scale(1.05)}.camera-icon-overlay svg{width:16px;height:16px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal{background:#fff;border-radius:var(--border-radius);box-shadow:0 20px 40px #0003;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--light-gray)}.modal-header h3{margin:0;font-size:20px}.btn-close{background:none;border:none;font-size:28px;cursor:pointer;color:var(--gray);transition:var(--transition)}.btn-close:hover{color:var(--dark)}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid var(--light-gray)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px}.spinner{width:50px;height:50px;border:4px solid var(--light-gray);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.profile-container{flex-direction:column}.profile-card{grid-template-columns:1fr;text-align:center}}@media(max-width:768px){.profile-container{padding:10px}.profile-main{padding:20px}.profile-header{flex-direction:column;gap:16px;text-align:center}.modal{width:95%;margin:10px}.profile-info-grid{grid-template-columns:1fr}}
