@import "https://fonts.googleapis.com/css2?family=Tajawal:wght@300;400;500;700;800&family=Inter:wght@400;500;600;700&display=swap";:root{--bg:#f5f5f7;--surface:#fff;--surface-2:#fafafa;--border:#00000012;--divider:#00000017;--pink:#b8738a;--pink-soft:#e8cdd6;--pink-bg:#fdf0f4;--teal:#5faf94;--teal-soft:#c4e8de;--teal-bg:#f0faf7;--lav:#9580b8;--lav-soft:#ddd6f0;--lav-bg:#f5f2fc;--amber:#c98040;--amber-bg:#fdf5ee;--text-1:#1d1d1f;--text-2:#6e6e73;--text-3:#aeaeb2;--green:#2da44e;--green-bg:#edf9f1;--red:#cf3333;--red-bg:#fef0f0;--sidebar-w:252px;--s-xs:0 1px 2px #0000000a;--s-sm:0 1px 4px #0000000f, 0 2px 8px #00000008;--s-md:0 4px 14px #00000014, 0 1px 4px #0000000a;--s-lg:0 10px 32px #0000001a, 0 2px 8px #0000000a;--s-xl:0 22px 64px #00000024, 0 4px 18px #0000000f;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-2xl:24px;--ease:cubic-bezier(.25, .46, .45, .94);--dur:.2s;--brand-text:#3a1f2e;--brand-soft:#967080;--brand-softer:#c49aaa;--brand-surface:#fdf7f9;--brand-border:#f2e8ec;--brand-bg2:#fdf0f5}html.dark{--brand-text:#f0f0f2;--brand-soft:#a0a0a8;--brand-softer:#707078;--brand-surface:#1c1c1e;--brand-border:#ffffff14;--brand-bg2:#2a1520;--bg:#0f0f11;--surface:#1c1c1e;--surface-2:#2c2c2e;--border:#ffffff14;--divider:#ffffff1a;--pink:#d4899f;--pink-soft:#5a2e3d;--pink-bg:#2a1520;--teal:#6fbfa4;--teal-soft:#1e4a3d;--teal-bg:#0d2820;--lav:#b09ed8;--lav-soft:#3d2f60;--lav-bg:#1e1530;--amber:#d49060;--amber-bg:#2a1e0d;--text-1:#f0f0f2;--text-2:#a0a0a8;--text-3:#5a5a62;--green:#40c464;--green-bg:#0d2a18;--red:#e05555;--red-bg:#2a0d0d;--s-xs:0 1px 2px #0000004d;--s-sm:0 1px 4px #0006, 0 2px 8px #0003;--s-md:0 4px 14px #00000080, 0 1px 4px #0000004d;--s-lg:0 10px 32px #0009, 0 2px 8px #0000004d;--s-xl:0 22px 64px #000000b3, 0 4px 18px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;overflow-x:hidden}body{background:var(--bg);color:var(--text-1);direction:rtl;width:100%;max-width:100%;min-height:100vh;font-family:Tajawal,Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.6;overflow-x:hidden}#root{width:100%;max-width:100%;overflow-x:hidden}.app-shell,.main-content,.page-inner,.page-wrapper,.page,section,main{min-width:0;max-width:100%}.app-shell{min-height:100vh;display:flex}.page-inner{box-sizing:border-box;width:100%}.landing-page{background:var(--bg);min-height:100vh;color:var(--brand-text);direction:rtl}.landing-page-compact{flex-direction:column;align-items:center;gap:26px;padding:84px 16px 54px;display:flex;position:relative}.landing-nav{justify-content:space-between;align-items:center;gap:16px;width:min(1120px,100% - 32px);margin:0 auto;padding:20px 0;display:flex}.landing-brand{align-items:center;gap:12px;display:flex}.landing-brand img{object-fit:contain;width:54px;height:54px}.landing-brand strong{font-size:17px;font-weight:900;display:block}.landing-brand span{color:var(--brand-soft);margin-top:2px;font-size:12px;display:block}.landing-nav button,.landing-actions button,.landing-footer button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#a05878,#c47a94);border:none;border-radius:12px;font-family:Tajawal,sans-serif;font-weight:800;box-shadow:0 10px 28px #a058783d}.landing-nav button{padding:10px 18px;font-size:13px}.landing-hero{text-align:center;flex-direction:column;align-items:center;gap:14px;width:min(820px,100%);margin:0 auto;padding:0;display:flex}.landing-logo-main{object-fit:contain;width:clamp(132px,17vw,210px);height:auto;margin-bottom:2px}.landing-kicker{color:#a05878;background:#fdf0f4;border-radius:999px;margin-bottom:18px;padding:6px 12px;font-size:13px;font-weight:800;display:inline-flex}.landing-hero h1{max-width:820px;margin-bottom:12px;font-size:clamp(30px,4.8vw,48px);font-weight:900;line-height:1.35}.landing-hero-copy>p:not(.landing-kicker){color:var(--brand-soft);max-width:760px;font-size:17px;line-height:1.9}.landing-actions{flex-wrap:wrap;align-items:center;gap:14px;margin-top:28px;display:flex}.landing-actions button{padding:13px 28px;font-size:15px}.landing-actions a{color:#2f8f83;padding:12px 6px;font-weight:800;text-decoration:none}.landing-hero-panel{background:#ffffffb8;border:1px solid #a058781f;border-radius:28px;flex-direction:column;justify-content:center;gap:18px;min-height:440px;padding:28px;display:flex;box-shadow:0 26px 70px #3a1f2e1f}.landing-program-card{color:#fff;background:linear-gradient(135deg,#a05878,#8f4568);border-radius:20px;padding:24px;box-shadow:0 18px 38px #a0587847}.landing-program-card span{opacity:.84;margin-bottom:10px;font-weight:700;display:block}.landing-program-card strong{font-size:42px;font-weight:900;display:block}.landing-mini-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.landing-mini-grid span{border:1px solid var(--brand-border);text-align:center;min-height:86px;color:var(--brand-soft);background:#fff;border-radius:16px;place-items:center;padding:12px;font-weight:800;display:grid}.landing-section{width:min(1120px,100% - 32px);margin:0 auto;padding:74px 0}.landing-section-head{text-align:center;margin-bottom:28px}.landing-section-head p{color:#2f8f83;margin-bottom:8px;font-size:13px;font-weight:900}.landing-section-head h2{font-size:clamp(25px,4vw,38px);line-height:1.35}.landing-features{grid-template-columns:repeat(5,1fr);gap:12px;display:grid}.landing-feature-card{border:1px solid var(--brand-border);background:#fff;border-radius:16px;min-height:178px;padding:18px;box-shadow:0 10px 28px #a0587812}.landing-feature-card span{color:#a05878;background:#fdf0f4;border-radius:50%;place-items:center;width:34px;height:34px;margin-bottom:14px;font-weight:900;display:grid}.landing-feature-card p{color:var(--brand-text);font-size:14px;font-weight:700;line-height:1.8}.landing-demo-wrap{flex-direction:column;align-items:center;gap:18px;width:100%;display:flex}.landing-demo-section{width:min(760px,100%);padding:0}.landing-parent-ui{background:linear-gradient(135deg,#fbedf4 0%,#f6f4fc 55%,#eef8f6 100%);border:1px solid #a058781f;border-radius:24px;width:min(560px,100%);padding:0;position:relative;overflow:hidden;box-shadow:0 24px 72px #3a1f2e24}.landing-parent-top{color:#fff;background:#944f6e;justify-content:space-between;align-items:center;gap:12px;height:118px;padding:20px 28px 34px;display:flex}.landing-parent-top span{color:#ffffff94;text-align:left;font-size:13px;font-weight:700;display:block}.landing-parent-top strong{font-size:24px;font-weight:900;display:block}.landing-parent-top button{color:#fff;background:#ffffff2b;border:1px solid #ffffff80;border-radius:999px;padding:8px 22px;font-family:Tajawal,sans-serif;font-size:17px;font-weight:800}.landing-parent-tabs{z-index:2;justify-content:center;gap:10px;margin:-28px auto 6px;padding:0 18px;display:flex;position:relative}.landing-parent-tabs button{color:#9a6f80;min-width:156px;transition:all .3s var(--ease);background:#fff;border:2px solid #e8cbd6;border-radius:999px;padding:9px 18px;font-family:Tajawal,sans-serif;font-size:18px;font-weight:900}.landing-parent-tabs button.active{color:#fff;background:#a85a7e;border-color:#a85a7e;box-shadow:0 9px 20px #944f6e33}.landing-parent-scroll{height:auto;animation:landingCardIn .42s var(--ease);padding:0 28px 28px;overflow:hidden}.landing-parent-card{background:#fff;border-radius:20px;margin-top:18px;padding:22px;box-shadow:0 8px 28px #a058780a}.landing-parent-card h3{color:#3a1f2e;margin-bottom:16px;font-size:20px;font-weight:900}.landing-identity-card{grid-template-columns:auto 1fr auto;align-items:center;gap:18px;min-height:120px;display:grid}.landing-identity-card h3{margin-bottom:4px;font-size:25px}.landing-identity-card span{color:#9a6f80;font-size:15px;font-weight:700}.landing-parent-avatar{color:#fff;background:#bc7896;border-radius:50%;place-items:center;width:70px;height:70px;font-size:35px;font-weight:900;display:grid}.landing-parent-points{text-align:center;color:#a85a7e}.landing-parent-points strong{font-size:34px;font-weight:900;line-height:1;display:block}.landing-parent-points span{color:#9a6f80;margin-top:10px;font-size:14px;display:block}.landing-attendance-card h3{text-align:right}.landing-attendance-body{grid-template-columns:110px 1fr;align-items:center;gap:22px;display:grid}.landing-attendance-body>strong{color:#3e816c;font-size:40px;font-weight:900}.landing-attendance-bar{background:#f0e4ea;border-radius:999px;height:13px;overflow:hidden}.landing-attendance-bar span{height:100%;transition:width .52s var(--ease);background:#3e816c;border-radius:999px;display:block}.landing-attendance-body p{color:#9a6f80;margin-top:10px;font-weight:700}.landing-attendance-body span{color:#9a6f80;font-size:14px}.landing-point-list{gap:16px;display:grid}.landing-point-row{grid-template-columns:130px 1fr 26px;align-items:center;gap:14px;display:grid}.landing-point-label{color:#9a6f80;font-size:15px;font-weight:700}.landing-point-track{background:#f0e4ea;border-radius:999px;height:10px;overflow:hidden}.landing-point-track span{height:100%;transition:width .52s var(--ease);border-radius:999px;display:block}.landing-point-row strong{font-size:15px;font-weight:900}.landing-note-card div{border-right:4px solid #a85a7e;padding-right:14px}.landing-note-card p{color:#3a1f2e;margin-bottom:8px;font-size:17px;font-weight:600;line-height:1.8}.landing-note-card span{color:#9a6f80;font-size:13px;font-weight:700}.landing-password-card{justify-content:space-between;align-items:center;gap:18px;min-height:128px;display:flex}.landing-password-card h3{margin:0}.landing-password-card button{color:#a85a7e;background:#fff9fb;border:2px solid #e8cbd6;border-radius:16px;padding:12px 24px;font-family:Tajawal,sans-serif;font-size:16px;font-weight:900}.landing-password-card button.is-pulsing{animation:.9s ease-in-out infinite alternate landingPulse}.landing-cursor{opacity:0;pointer-events:none;width:34px;height:42px;transition:opacity .2s;position:absolute;top:135px;right:64%}.landing-cursor span{filter:drop-shadow(0 8px 10px #3a1f2e33);background-image:url("data:image/svg+xml,%3Csvg width='34' height='42' viewBox='0 0 34 42' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 3L4.8 32.5L12.5 24.9L18.5 39L24.8 36.3L18.8 22.2H29.8L4 3Z' fill='white' stroke='%233A1F2E' stroke-width='2.4' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:contain;width:34px;height:42px;display:block}.landing-demo-wrap.is-running .landing-cursor{opacity:1}.landing-demo-wrap.is-running .landing-cursor.step-0{animation:2.2s ease-in-out both cursorToFirst}.landing-demo-wrap.is-running .landing-cursor.step-1{animation:2.2s ease-in-out both cursorToSecond}.landing-demo-wrap.is-running .landing-cursor.step-2{animation:2.2s ease-in-out both cursorToPassword}.landing-demo-wrap.is-running .landing-cursor.step-3{animation:2.2s ease-in-out both cursorToAttendance}.landing-footer{border-top:1px solid var(--brand-border);justify-content:space-between;align-items:center;gap:14px;width:min(1120px,100% - 32px);margin:0 auto;padding:34px 0 46px;display:flex}.landing-footer span{color:var(--brand-soft);font-weight:900}.landing-footer button{padding:11px 18px}.landing-main-login{color:#fff;cursor:pointer;z-index:4;background:linear-gradient(135deg,#a05878,#c47a94);border:none;border-radius:18px;min-width:0;padding:12px 22px;font-family:Tajawal,sans-serif;font-size:15px;font-weight:900;position:absolute;top:24px;left:24px;box-shadow:0 14px 30px #a058783d}@keyframes landingPulse{0%{transform:translateY(0);box-shadow:0 0 #a0587800}to{transform:translateY(-2px);box-shadow:0 0 0 6px #a0587814}}@keyframes landingCardIn{0%{opacity:.55;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes cursorToFirst{0%{top:142px;right:62%;transform:scale(1)}56%{top:142px;right:64%;transform:scale(1)}72%{top:142px;right:64%;transform:scale(.82)}to{top:142px;right:64%;transform:scale(1)}}@keyframes cursorToPassword{0%{top:142px;right:26%;transform:scale(1)}54%{top:815px;right:42%;transform:scale(1)}72%{top:815px;right:42%;transform:scale(.82)}to{top:815px;right:42%;transform:scale(1)}}@keyframes cursorToSecond{0%{top:142px;right:64%;transform:scale(1)}56%{top:142px;right:26%;transform:scale(1)}72%{top:142px;right:26%;transform:scale(.82)}to{top:142px;right:26%;transform:scale(1)}}@keyframes cursorToAttendance{0%{top:815px;right:42%;transform:scale(1)}56%{top:335px;right:25%;transform:scale(1)}72%{top:335px;right:25%;transform:scale(.82)}to{top:335px;right:25%;transform:scale(1)}}@media (width<=980px){.landing-hero{grid-template-columns:1fr;min-height:auto;padding-top:18px}.landing-hero-panel{min-height:300px}.landing-features{grid-template-columns:1fr 1fr}}@media (width<=620px){.landing-page-compact{padding-top:78px}.landing-nav{align-items:flex-start}.landing-nav button{padding:9px 12px}.landing-brand img{width:46px;height:46px}.landing-hero h1{font-size:34px}.landing-hero-copy>p:not(.landing-kicker){font-size:16px}.landing-mini-grid,.landing-features,.landing-metrics{grid-template-columns:1fr}.landing-parent-tabs{flex-direction:column;margin-top:-20px}.landing-parent-top{flex-direction:column-reverse;align-items:flex-start;height:auto;padding-bottom:34px}.landing-identity-card,.landing-attendance-body,.landing-point-row{grid-template-columns:1fr}.landing-password-card{flex-direction:column;align-items:flex-start}.landing-cursor{display:none}.landing-footer{flex-direction:column;align-items:stretch}.landing-main-login{border-radius:14px;padding:10px 16px;font-size:13px;top:18px;left:18px}}.main-content{margin-right:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-wrapper{flex:1;padding:32px 36px}.sidebar{width:var(--sidebar-w);background:var(--surface);border-left:1px solid var(--border);z-index:100;height:100dvh;padding:18px 12px max(18px, env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:16px;padding:4px 6px 18px;display:flex}.sidebar-brand img{object-fit:cover;border-radius:50%;width:42px;height:42px}.sidebar-brand-name{color:var(--text-1);letter-spacing:-.2px;font-size:15px;font-weight:800}.sidebar-brand-sub{color:var(--text-2);margin-top:1px;font-size:11px}.sidebar-user{background:var(--bg);border-radius:var(--r-lg);align-items:center;gap:10px;margin-bottom:18px;padding:10px 12px;display:flex}.sidebar-avatar{background:linear-gradient(135deg,var(--pink),var(--lav));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:800;display:flex}.sidebar-user-name{color:var(--text-1);font-size:13px;font-weight:700}.sidebar-role-pill{color:var(--pink);background:var(--pink-bg);border-radius:20px;margin-top:2px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.nav-item{border-radius:var(--r-md);color:var(--text-2);transition:background var(--dur),color var(--dur);cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:9px 12px;font-family:inherit;font-size:13.5px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--bg);color:var(--text-1)}.nav-item.active{background:var(--pink-bg);color:var(--pink);font-weight:700}.sidebar-footer{border-top:1px solid var(--border);margin-top:8px;padding-top:12px}.logout-btn{border-radius:var(--r-md);width:100%;color:var(--text-3);cursor:pointer;transition:all var(--dur);background:0 0;border:none;justify-content:space-between;align-items:center;padding:8px 12px;font-family:inherit;font-size:13px;display:flex}.logout-btn:hover{background:var(--red-bg);color:var(--red)}.sidebar-sync-btn{color:var(--pink);background:var(--pink-bg);font-weight:700}.sidebar-sync-btn:hover{background:var(--pink-bg);color:var(--pink)}.sidebar-sync-btn:disabled{opacity:.65;cursor:default}.mobile-bar{z-index:50;background:linear-gradient(135deg,#a05878,#7a3a58);justify-content:space-between;align-items:center;padding:13px 18px;display:none;position:sticky;top:0}.hamburger{cursor:pointer;color:#ffffffe6;background:0 0;border:none;font-size:22px}.mobile-title{color:#fff;font-size:15px;font-weight:800}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:28px;display:flex}.page-title{color:var(--text-1);letter-spacing:-.4px;font-size:26px;font-weight:800}.page-sub{color:var(--text-2);margin-top:3px;font-size:13px}.card{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--s-sm);border:1px solid var(--border);transition:box-shadow var(--dur);padding:22px}.card:hover{box-shadow:var(--s-md)}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{align-items:center;gap:7px;font-size:15px;font-weight:700;display:flex}.stat-row{flex-wrap:wrap;gap:14px;margin-bottom:22px;display:flex}.stat-card{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--s-sm);border:1px solid var(--border);flex:1;min-width:130px;padding:20px 22px}.stat-val{font-size:28px;font-weight:800;line-height:1.1}.stat-label{color:var(--text-2);margin-top:4px;font-size:12px;font-weight:500}.btn{border-radius:var(--r-md);cursor:pointer;transition:all var(--dur) var(--ease);white-space:nowrap;border:none;align-items:center;gap:6px;padding:9px 18px;font-family:inherit;font-size:13.5px;font-weight:700;display:inline-flex}.btn-primary{background:var(--pink);color:#fff;box-shadow:0 2px 8px #b8738a4d}.btn-primary:hover{background:#a35e7a;box-shadow:0 4px 14px #b8738a66}.btn-teal{background:var(--teal);color:#fff;box-shadow:0 2px 8px #5faf944d}.btn-teal:hover{background:#4d9e84}.btn-ghost{background:var(--bg);color:var(--text-2);border:1.5px solid var(--border)}.btn-ghost:hover{color:var(--text-1);background:#ebebed}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#b82b2b}.btn-sm{border-radius:9px;padding:6px 13px;font-size:12.5px}.btn-lg{border-radius:var(--r-lg);padding:12px 24px;font-size:15px}.btn-icon{background:var(--bg);border:1px solid var(--border);cursor:pointer;width:32px;height:32px;transition:all var(--dur);border-radius:9px;justify-content:center;align-items:center;padding:0;font-size:14px;display:inline-flex}.btn-icon:hover{background:var(--surface-2)}html.dark .btn-icon{color:var(--text-1)}.btn-icon.danger:hover{background:var(--red-bg);border-color:var(--red)}.form-group{margin-bottom:14px}.form-label{color:var(--text-2);margin-bottom:6px;font-size:12.5px;font-weight:700;display:block}.form-input,.form-select,.form-textarea{border:1.5px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--text-1);background:var(--surface);transition:border-color var(--dur),box-shadow var(--dur);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--pink);box-shadow:0 0 0 3px #b8738a1f}.form-textarea{resize:vertical;min-height:90px}.table-wrap{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--s-sm);border:1px solid var(--border);overflow:hidden}.table-scroll{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13.5px}thead tr{background:var(--bg)}th{text-align:right;color:var(--text-2);border-bottom:1px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;padding:11px 16px;font-size:11.5px;font-weight:700}td{border-bottom:1px solid var(--border);color:var(--text-1);vertical-align:middle;padding:12px 16px}tr:last-child td{border-bottom:none}tbody tr{transition:background var(--dur)}tbody tr:hover{background:var(--surface-2)}.badge{white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:11.5px;font-weight:700;display:inline-flex}.badge-pink{background:var(--pink-bg);color:var(--pink)}.badge-teal{background:var(--teal-bg);color:var(--teal)}.badge-lav{background:var(--lav-bg);color:var(--lav)}.badge-amber{background:var(--amber-bg);color:var(--amber)}.badge-green{background:var(--green-bg);color:var(--green)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-neutral{background:var(--bg);color:var(--text-2)}.tab-bar{background:var(--bg);border-radius:var(--r-lg);gap:3px;width:fit-content;margin-bottom:24px;padding:4px;display:flex}.tab-btn{border-radius:var(--r-md);cursor:pointer;color:var(--text-2);transition:all var(--dur) var(--ease);background:0 0;border:none;padding:7px 18px;font-family:inherit;font-size:13.5px;font-weight:500}.tab-btn.active{background:var(--surface);color:var(--text-1);box-shadow:var(--s-xs);font-weight:700}.overlay{-webkit-backdrop-filter:blur(6px);z-index:500;animation:fadeIn .2s var(--ease);background:#00000052;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-sm{background:var(--surface);border-radius:var(--r-2xl);box-shadow:var(--s-xl);text-align:center;width:100%;max-width:420px;animation:scaleIn .2s var(--ease);padding:36px 32px}.modal-icon{margin-bottom:16px;font-size:48px}.modal-title{margin-bottom:8px;font-size:20px;font-weight:800}.modal-msg{color:var(--text-2);margin-bottom:28px;font-size:14px;line-height:1.7}.modal-actions{justify-content:center;gap:10px;display:flex}.modal-lg{background:var(--surface);border-radius:var(--r-2xl);box-shadow:var(--s-xl);width:100%;max-width:640px;max-height:88vh;animation:scaleIn .2s var(--ease);flex-direction:column;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-body{flex:1;padding:20px 24px;overflow-y:auto}.ai-bar{background:var(--surface);border-radius:var(--r-xl);border:1.5px solid var(--border);box-shadow:var(--s-sm);transition:border-color var(--dur),box-shadow var(--dur);align-items:center;gap:12px;margin-bottom:24px;padding:12px 18px;display:flex}.ai-bar:focus-within{border-color:var(--lav);box-shadow:0 0 0 3px #9580b81f,var(--s-md)}.ai-bar input{color:var(--text-1);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:14.5px}.ai-bar input::placeholder{color:var(--text-3)}.ai-response{background:var(--lav-bg);border:1px solid var(--lav-soft);border-radius:var(--r-lg);margin-bottom:20px;padding:18px 20px;font-size:14px;line-height:1.8}.ai-link{background:var(--lav);color:#fff;cursor:pointer;transition:background var(--dur);border:none;border-radius:20px;align-items:center;gap:4px;padding:2px 10px;font-family:inherit;font-size:13px;font-weight:700;display:inline-flex}.ai-link:hover{background:#7d6aa0}.drop-zone{border:2px dashed var(--border);border-radius:var(--r-xl);text-align:center;cursor:pointer;transition:all var(--dur) var(--ease);background:var(--surface-2);padding:44px 24px}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--pink);background:var(--pink-bg);box-shadow:0 0 0 3px #b8738a1a}.drop-zone-icon{margin-bottom:12px;font-size:42px}.drop-zone-title{font-size:15px;font-weight:700}.drop-zone-sub{color:var(--text-2);margin-top:4px;font-size:13px}.search-bar{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);align-items:center;gap:9px;min-width:200px;padding:8px 14px;display:flex}.search-bar:focus-within{border-color:var(--pink)}.search-bar input{color:var(--text-1);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13.5px}.login-page{background:linear-gradient(135deg,#fdf0f4 0%,#f5f2fc 50%,#f0faf7 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--surface);border-radius:var(--r-2xl);box-shadow:var(--s-xl);text-align:center;width:100%;max-width:420px;animation:scaleIn .25s var(--ease);padding:44px 40px}.login-logo{object-fit:cover;border-radius:50%;width:86px;height:86px;margin:0 auto 14px}.login-title{margin-bottom:4px;font-size:24px;font-weight:800}.login-sub{color:var(--text-2);margin-bottom:32px;font-size:13px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.98)}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(4px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.modal-closing .modal-sm,.modal-closing .modal-lg{animation:scaleOut .2s var(--ease) forwards}.modal-closing.overlay{animation:fadeOut .2s var(--ease) forwards}.toast-exit{animation:slideOut .15s var(--ease) forwards}@media (prefers-reduced-motion:reduce){.overlay,.modal-sm,.modal-lg,.toast,.modal-closing .modal-sm,.modal-closing .modal-lg,.modal-closing.overlay,.toast-exit{transition:none!important;animation:none!important}}.spinner{animation:.9s linear infinite spin;display:inline-block}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.toast{background:var(--text-1);color:#fff;border-radius:var(--r-lg);box-shadow:var(--s-lg);min-width:220px;max-width:360px;animation:slideUp .18s var(--ease);align-items:center;gap:10px;padding:12px 18px;font-size:13.5px;font-weight:500;display:flex}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-sm{color:var(--text-2);font-size:13px}.text-xs{color:var(--text-3);font-size:11.5px}.font-bold{font-weight:800}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}@media (width<=768px){.sidebar{box-shadow:var(--s-xl);transition:transform var(--dur) var(--ease);padding-bottom:calc(96px + env(safe-area-inset-bottom));transform:translate(100%)}.sidebar.open{transform:translate(0)}.main-content{margin-right:0}.mobile-bar{display:flex}.page-wrapper{padding:14px 12px}.page-title{font-size:20px}.table-scroll{-webkit-overflow-scrolling:touch;max-width:100%;overflow-x:auto}table{min-width:0;font-size:12px}th{padding:8px;font-size:10.5px}td{padding:9px 8px}.mobile-hide{display:none!important}.card{padding:14px!important}.card-title{font-size:14px!important}.stat-grid{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}.modal-sm,.modal-lg{max-width:calc(100vw - 24px)!important;margin:12px!important}.overlay{align-items:flex-end!important;padding:12px!important}.form-input,.form-select{padding:12px 14px!important;font-size:16px!important}.btn{font-size:14px!important}.page-header{flex-direction:column;align-items:flex-start!important;gap:10px!important}.page-header .btn{justify-content:center;width:100%}.stats-flex{flex-wrap:unset!important;grid-template-columns:repeat(2,1fr)!important;gap:10px!important;display:grid!important}.stats-flex>*{flex:unset!important;width:auto!important}.stats-flex>:last-child{grid-column:1/-1!important}.points-layout{grid-template-columns:1fr!important}.page-inner{max-width:100%!important}.grid-3col{grid-template-columns:1fr!important;gap:12px!important}.grid-3col>*{grid-column:auto!important}.grid-4col{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}.app-shell,.main-content,.page-inner,.page-wrapper,main{min-width:0;max-width:100%}.students-mobile-list{display:none}.students-desktop-table{display:block}@media (width<=768px){.students-mobile-list{flex-direction:column;gap:10px;width:100%;max-width:100%;display:flex!important}.students-desktop-table{display:none!important}}.program-form-overlay{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;overflow-y:auto;justify-content:center!important;align-items:center!important}.program-form-overlay .modal-sm,.program-scroll-modal{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;max-height:min(85vh,720px);overflow-y:auto}.program-card-track{grid-template-columns:repeat(2,minmax(140px,1fr));gap:14px;display:grid}.program-card{border-radius:20px;min-height:220px}.program-card:hover{transform:translateY(-2px);box-shadow:0 20px 52px #7a3a5880!important}@media (width<=400px){.program-card-track{grid-template-columns:repeat(2,1fr);gap:10px}.program-card{min-height:190px}}@media (width<=768px){div,section,article,aside,main,header,footer,nav{min-width:0;max-width:100%}.page-inner{padding-inline:12px!important;overflow-x:hidden!important}.card,.panel,.section-card{box-sizing:border-box!important;border-radius:18px!important;width:100%!important;min-width:0!important;max-width:100%!important;padding:14px!important}.actions-row{flex-wrap:wrap!important;gap:10px!important;width:100%!important;display:flex!important}.actions-row>button,.actions-row>a{flex:140px!important;min-width:0!important}.stats-grid,.cards-grid,.dashboard-grid,.report-stats{grid-template-columns:1fr 1fr!important;gap:12px!important;width:100%!important;max-width:100%!important;display:grid!important}.schedule-grid{min-width:600px}}@media (width<=480px){.page-inner{padding-inline:10px!important}}
