@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.underline{text-decoration-line:underline}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--green:#1a5c38;--green-dark:#134429;--green-light:#e8f2ec;--gold:#c9a84c;--bg:#f4f5f7;--card:#fff;--border:#e5e7eb;--text:#111827;--muted:#6b7280;--sidebar-w:clamp(250px, 18vw, 300px);--header-h:56px;--radius:.75rem;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #0000001a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{background:var(--bg);height:100%;color:var(--text);font-family:var(--font-geist-sans), "Inter", system-ui, -apple-system, sans-serif;-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}.auth-wrap{background:linear-gradient(150deg,#1a5c38 0%,#0d2e1c 100%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.auth-card{background:var(--card);border-radius:1.25rem;width:100%;max-width:420px;padding:2.5rem 2rem;box-shadow:0 24px 64px #00000047}.auth-logo{text-align:center;margin-bottom:2rem}.auth-logo .logo-icon{background:var(--green);border-radius:1rem;justify-content:center;align-items:center;width:60px;height:60px;margin-bottom:.875rem;display:inline-flex}.auth-logo h1{color:var(--green);font-size:1.375rem;font-weight:700}.auth-logo p{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem;font-size:.75rem}.form-stack{flex-direction:column;gap:1rem;display:flex}.field{flex-direction:column;gap:.375rem;display:flex}.field label{color:#374151;font-size:.8rem;font-weight:600}.field input,.field select,.field textarea{border:1.5px solid var(--border);color:var(--text);background:#fff;border-radius:.625rem;outline:none;width:100%;padding:.625rem .875rem;font-family:inherit;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px #1a5c381a}.btn-primary{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:.625rem;width:100%;padding:.75rem 1rem;font-size:.875rem;font-weight:600;transition:background .15s,transform .1s}.btn-primary:hover:not(:disabled){background:var(--green-dark);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.error-msg{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:.5rem .75rem;font-size:.8rem}.success-msg{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:.5rem;padding:.5rem .75rem;font-size:.8rem}.auth-footer{text-align:center;color:var(--muted);margin-top:1.25rem;font-size:.8rem}.auth-footer a{color:var(--green);font-weight:600}.admin-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--green);z-index:100;flex-direction:column;padding:1.25rem .875rem;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #ffffff1f;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.25rem .5rem 1.25rem;display:flex}.brand-icon{background:var(--gold);border-radius:.625rem;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.sidebar-brand h2{color:#fff;font-size:.9rem;font-weight:700;line-height:1.2}.sidebar-brand span{color:#ffffff80;font-size:.68rem;display:block}.sidebar-section-badge{color:var(--gold);text-transform:uppercase;letter-spacing:.07em;text-align:center;background:#ffffff14;border:1px solid #ffffff26;border-radius:.5rem;margin-bottom:1.25rem;padding:.3rem .75rem;font-size:.7rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:.35rem;display:flex}.nav-item{color:#ffffffa6;text-align:left;background:0 0;border:none;border-radius:.5rem;align-items:center;gap:.625rem;width:100%;padding:.6rem .75rem;font-size:.825rem;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-item svg{opacity:.8;flex-shrink:0}.nav-item:hover{color:#fff;background:#ffffff1a}.nav-item:hover svg{opacity:1}.nav-item.active{color:#fff;background:#ffffff29;font-weight:600}.nav-item.active svg{opacity:1}.nav-group{margin-bottom:.15rem}.nav-group-title{text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;padding:.75rem .75rem .25rem;font-size:.65rem;font-weight:700}.nav-group-toggle{color:#ffffffc7;background:#ffffff0f;border:none;border-radius:.55rem;justify-content:space-between;align-items:center;gap:.75rem;width:100%;padding:.65rem .75rem;font-size:.78rem;font-weight:700;display:flex}.nav-group-toggle:hover,.nav-group-toggle.active{color:#fff;background:#ffffff1f}.nav-group-toggle-left{align-items:center;gap:.625rem;display:inline-flex}.nav-group-chevron{opacity:.8;transition:transform .18s}.nav-group-chevron.open{transform:rotate(180deg)}.nav-group-children{flex-direction:column;gap:.18rem;padding:.35rem 0 .15rem .55rem;display:flex}.nav-child-item{color:#ffffff94;padding:.52rem .75rem;font-size:.77rem}.nav-child-item svg{width:14px;height:14px}.sidebar-footer{border-top:1px solid #ffffff1f;margin-top:.5rem;padding-top:1rem}.sidebar-email{color:#fff6;text-overflow:ellipsis;white-space:nowrap;padding:0 .75rem .625rem;font-size:.7rem;overflow:hidden}.nav-item-logout{color:#ffffff80}.nav-item-logout:hover{color:#fca5a5;background:#ef44441f}.admin-body{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-width:0;display:flex}.admin-main{flex:1;width:100%;max-width:min(100%,1800px);padding:clamp(1.25rem,2vw,2.25rem)}.mobile-header{height:var(--header-h);background:var(--green);z-index:50;align-items:center;gap:1rem;padding:0 1.25rem;display:none;position:sticky;top:0}.mobile-menu-btn{color:#fff;background:0 0;border:none;align-items:center;padding:.25rem;display:flex}.mobile-brand{color:#fff;font-size:.95rem;font-weight:700}.sidebar-overlay{z-index:99;background:#00000073;display:none;position:fixed;inset:0}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.75rem;display:flex}.page-header h1{color:var(--text);font-size:1.375rem;font-weight:700}.page-header p{color:var(--muted);margin-top:.2rem;font-size:.825rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));gap:1rem;margin-bottom:1.75rem;display:grid}.stat-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);align-items:center;gap:1rem;padding:1.25rem;display:flex}.stat-icon{width:44px;height:44px;color:var(--green);background:var(--green-light);border-radius:.625rem;flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-card h3{font-size:1.625rem;font-weight:700;line-height:1}.stat-card p{color:var(--muted);margin-top:.2rem;font-size:.75rem}.content-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);width:100%;overflow:hidden}.content-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.125rem 1.5rem;display:flex}.content-card-header h2{font-size:.95rem;font-weight:600}.content-card-header span{color:var(--muted);font-size:.75rem}.reg-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;transition:background .1s;display:flex}.reg-item:last-child{border-bottom:none}.reg-item:hover{background:#fafafa}.reg-item-left{align-items:center;gap:.875rem;min-width:0;display:flex}.reg-item-actions{flex-shrink:0;gap:.5rem;display:flex}.avatar{background:var(--green-light);width:38px;height:38px;color:var(--green);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.875rem;font-weight:700;display:flex}.reg-email{text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;overflow:hidden}.reg-meta{align-items:center;gap:.5rem;margin-top:.2rem;display:flex}.reg-date{color:#9ca3af;font-size:.7rem}.badge{text-transform:capitalize;white-space:nowrap;border-radius:999px;align-items:center;padding:.15rem .55rem;font-size:.68rem;font-weight:600;display:inline-flex}.badge-pending{color:#92400e;background:#fef3c7}.badge-approved{color:#065f46;background:#d1fae5}.badge-rejected{color:#991b1b;background:#fee2e2}.badge-sent{color:#065f46;background:#d1fae5}.badge-partial{color:#a16207;background:#fff1c2}.badge-failed{color:#991b1b;background:#fee2e2}.badge-brothers{background:var(--green-light);color:var(--green)}.badge-sisters{color:#5b21b6;background:#ede9fe}.badge-reading{color:#1e40af;background:#dbeafe}.badge-completed{color:#065f46;background:#d1fae5}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-box{background:var(--card);border-radius:var(--radius);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.modal-header h2{font-size:1rem;font-weight:700}.modal-close{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:.375rem;padding:.2rem .4rem;font-size:1.4rem;line-height:1}.modal-close:hover{background:var(--border)}.modal-body{padding:1.25rem 1.5rem}.btn-approve{color:#065f46;white-space:nowrap;background:#d1fae5;border:none;border-radius:.5rem;padding:.375rem .875rem;font-size:.775rem;font-weight:600;transition:background .15s}.btn-approve:hover{background:#a7f3d0}.btn-reject{color:#991b1b;white-space:nowrap;background:#fee2e2;border:none;border-radius:.5rem;padding:.375rem .875rem;font-size:.775rem;font-weight:600;transition:background .15s}.btn-reject:hover{background:#fecaca}.empty-state{text-align:center;color:var(--muted);padding:3.5rem 2rem}.empty-state svg{opacity:.3;margin:0 auto .875rem}.empty-state p{font-size:.875rem;font-weight:500}.student-topbar{height:var(--header-h);background:var(--card);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;padding:0 1.5rem;display:flex;position:sticky;top:0}.topbar-actions{align-items:center;gap:.25rem;display:flex}.topbar-icon-btn{color:var(--muted);border-radius:.5rem;align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.8rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex;position:relative}.topbar-icon-btn:hover,.topbar-icon-btn.active{background:var(--green-light);color:var(--green)}.topbar-label{display:inline}.notif-dot{background:#ef4444;border:1.5px solid #fff;border-radius:50%;width:7px;height:7px;position:absolute;top:6px;right:8px}.student-topbar .mobile-menu-btn{display:none}@media (max-width:768px){.student-topbar .mobile-menu-btn{display:flex}.topbar-label{display:none}.student-topbar{padding:0 1rem}}.student-topnav{background:var(--green);z-index:50;justify-content:space-between;align-items:center;height:60px;padding:0 2rem;display:flex;position:sticky;top:0}.student-brand{color:#fff;align-items:center;gap:.625rem;font-size:.95rem;font-weight:700;display:flex}.student-nav-right{align-items:center;gap:1rem;display:flex}.user-pill{color:#fff;text-overflow:ellipsis;white-space:nowrap;background:#ffffff1f;border-radius:999px;max-width:200px;padding:.3rem .875rem;font-size:.775rem;overflow:hidden}.btn-logout-text{color:#ffffffa6;background:0 0;border:none;font-size:.775rem;transition:color .15s}.btn-logout-text:hover{color:#fff}.student-main{max-width:760px;margin:2rem auto;padding:0 1.5rem}.profile-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.profile-card-header{background:linear-gradient(135deg, var(--green), var(--green-dark));color:#fff;padding:1.5rem 2rem}.profile-card-header h2{font-size:1.1rem;font-weight:700}.profile-card-header p{opacity:.7;margin-top:.2rem;font-size:.8rem}.profile-card-body{padding:1.75rem 2rem}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.pending-wrap{background:linear-gradient(150deg,#1a5c38 0%,#0d2e1c 100%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.pending-card{text-align:center;background:#fff;border-radius:1.25rem;width:100%;max-width:420px;padding:3rem 2.5rem;box-shadow:0 24px 64px #00000047}.pending-icon-wrap{color:#92400e;background:#fef3c7;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1.25rem;display:flex}.pending-card h2{margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.pending-card p{color:var(--muted);margin-bottom:1.75rem;font-size:.875rem;line-height:1.6}.btn-back{background:var(--green);color:#fff;border-radius:.625rem;padding:.625rem 1.75rem;font-size:.875rem;font-weight:600;transition:background .15s;display:inline-block}.btn-back:hover{background:var(--green-dark)}.section-shell{flex-direction:column;gap:1rem;width:100%;display:flex}.section-outline{background:#fcfefd;border:1px solid #c8dfd0;border-radius:.75rem;width:100%}.section-outline-header{border-bottom:1px solid #d7e8dd;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.section-outline-header h2{color:#1d3a29;font-size:.96rem;font-weight:700}.section-outline-header p{color:#7b9384;margin-top:.15rem;font-size:.74rem}.toolbar-chip{color:#9c6b00;background:#fff7db;border:1px solid #f3d58b;border-radius:.5rem;align-items:center;gap:.35rem;padding:.35rem .6rem;font-size:.68rem;font-weight:700;display:inline-flex}.toolbar-chip strong{font-weight:800}.soft-toolbar{background:#fffaf0;border:1px solid #f2d488;border-radius:.6rem;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:.8rem 1rem;display:flex}.toolbar-actions{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.toolbar-select{color:#7e6a32;align-items:center;gap:.45rem;font-size:.76rem;font-weight:600;display:inline-flex}.toolbar-select input{accent-color:var(--green)}.btn-soft-approve,.btn-soft-reject,.btn-soft-neutral{background:#fff;border:1px solid;border-radius:.45rem;padding:.42rem .9rem;font-size:.74rem;font-weight:700}.btn-soft-approve{color:#2f8550;border-color:#55b880}.btn-soft-reject{color:#d94841;border-color:#ff8077}.btn-soft-neutral{color:#607365;border-color:#bfd6c5}.panel-table-wrap{width:100%;padding:0 1rem 1rem;overflow-x:auto}.panel-table{border-collapse:separate;border-spacing:0 .55rem;width:100%}.panel-table th{text-align:left;letter-spacing:.06em;text-transform:uppercase;color:#82a08d;padding:0 .55rem;font-size:.62rem;font-weight:800}.panel-table td{vertical-align:middle;color:#1f3529;background:#fff;border-top:1px solid #d8e8de;border-bottom:1px solid #d8e8de;padding:.9rem .55rem;font-size:.78rem}.panel-table td:first-child{border-left:1px solid #d8e8de;border-top-left-radius:.55rem;border-bottom-left-radius:.55rem}.panel-table td:last-child{border-right:1px solid #d8e8de;border-top-right-radius:.55rem;border-bottom-right-radius:.55rem}.pending-student-cell{align-items:center;gap:.75rem;min-width:180px;display:flex}.pending-student-avatar{color:#3467c7;background:#edf4ff;border-radius:.45rem;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.62rem;font-weight:800;display:flex}.pending-student-meta strong{color:#274132;font-size:.77rem;display:block}.pending-student-meta span{color:#7f9488;font-size:.69rem;display:block}.table-muted{color:#7f9488;font-size:.72rem}.table-actions{flex-wrap:wrap;justify-content:flex-end;gap:.45rem;display:flex}.mini-action{background:#fff;border:1px solid;border-radius:.4rem;padding:.38rem .75rem;font-size:.68rem;font-weight:700}.mini-action.approve{color:#22764b;border-color:#53b57d}.mini-action.reject{color:#d53a34;border-color:#ff8b84}.legend-row{flex-wrap:wrap;gap:.65rem;padding:0 1rem 1rem;display:flex}.legend-pill{text-align:center;background:#fff;border:1px solid;border-radius:.45rem;min-width:86px;padding:.38rem .7rem;font-size:.68rem;font-weight:700}.legend-available{color:#2c8a53;border-color:#6fc18d}.legend-full{color:#dd3d37;border-color:#ff8e88}.legend-partial{color:#d98a00;border-color:#ffc14d}.legend-empty{color:#7d8f83;border-color:#c7d9cd}.block-shell{background:#fff;border:1px solid #d7e8dd;border-radius:.75rem;margin:0 1rem 1rem;overflow:hidden}.block-title{color:#47614f;text-transform:uppercase;border-bottom:1px solid #d7e8dd;padding:.7rem .9rem;font-size:.72rem;font-weight:800}.room-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.8rem;padding:1rem;display:grid}.room-card{background:#fdfefe;border:1px solid #d8e8de;border-radius:.7rem;min-height:170px;overflow:hidden}.room-card-header{color:#fff;text-align:center;padding:.55rem .7rem;font-size:.74rem;font-weight:800}.room-card-body{text-align:center;padding:.9rem .85rem}.room-count{margin-bottom:.15rem;font-size:1rem;font-weight:800}.room-state{margin-bottom:.65rem;font-size:.68rem;font-weight:700}.room-residents{color:#51675a;flex-direction:column;gap:.28rem;font-size:.69rem;display:flex}.room-chip-btn{color:#47614f;background:#f7fbf8;border:1px solid #d6e5db;border-radius:999px;margin-left:.45rem;padding:.15rem .45rem;font-size:.62rem;font-weight:700}.room-card.available .room-card-header{background:#f59e0b}.room-card.available .room-card-body{background:#fff5db}.room-card.full .room-card-header{background:#2d6abf}.room-card.full .room-card-body{background:#e8f0fb}.room-card.partial .room-card-header{background:#f59e0b}.room-card.partial .room-card-body{background:#fff3e0}.room-card.empty .room-card-header{background:#ef4444}.room-card.empty .room-card-body{color:#c23f3f;background:#ffe9e9}.unassigned-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;padding:1rem;display:grid}.unassigned-card{background:linear-gradient(#fafdfe,#f6fbf8);border:1px solid #d7e8dd;border-radius:.65rem;flex-direction:column;justify-content:flex-end;align-items:center;gap:.4rem;min-height:180px;padding:1rem .8rem;display:flex}.unassigned-avatar{color:#3368c7;background:#eff5ff;border-radius:999px;justify-content:center;align-items:center;width:24px;height:24px;font-size:.6rem;font-weight:800;display:flex}.unassigned-name{color:#2b4033;font-size:.73rem;font-weight:700}.unassigned-meta{color:#7c9384;font-size:.66rem}.issue-board{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;padding:0 1rem 1rem;display:grid}.issue-column{flex-direction:column;gap:.75rem;display:flex}.issue-column-header{border:1px solid;border-radius:.6rem;justify-content:space-between;align-items:center;gap:.7rem;padding:.7rem .9rem;font-size:.74rem;font-weight:800;display:flex}.issue-column-header span:last-child{text-align:center;color:#fff;border-radius:.35rem;min-width:26px;padding:.12rem .4rem}.issue-column.pending .issue-column-header{color:#d48806;background:#fff8df;border-color:#f3d27a}.issue-column.pending .issue-column-header span:last-child{background:#f4a000}.issue-column.inprogress .issue-column-header{color:#2d6abf;background:#eef4ff;border-color:#7aa7f8}.issue-column.inprogress .issue-column-header span:last-child{background:#2d6abf}.issue-column.resolved .issue-column-header{color:#2c8a53;background:#eef9f1;border-color:#7bc695}.issue-column.resolved .issue-column-header span:last-child{background:#2c8a53}.issue-card{background:#fff;border:1px solid #d7e8dd;border-radius:.7rem;flex-direction:column;gap:.7rem;padding:.8rem .85rem;display:flex}.issue-column.pending .issue-card{background:#fffdf7;border-color:#f2ce72}.issue-column.inprogress .issue-card{background:#fbfdff;border-color:#79a5f4}.issue-column.resolved .issue-card{background:#fdfefd;border-color:#7bc695}.issue-tag{border-radius:999px;align-self:flex-start;padding:.16rem .5rem;font-size:.62rem;font-weight:700}.issue-column.pending .issue-tag{color:#d99200;background:#fff0c3}.issue-column.inprogress .issue-tag{color:#2d6abf;background:#e7f0ff}.issue-column.resolved .issue-tag{color:#2c8a53;background:#e3f6ea}.issue-card h3{color:#21382c;font-size:.84rem;font-weight:700}.issue-meta{color:#809587;flex-direction:column;gap:.12rem;font-size:.68rem;display:flex}.issue-update{background:#fff;border:1px solid;border-radius:.45rem;align-self:flex-end;padding:.3rem .55rem;font-size:.64rem;font-weight:700}.issue-column.pending .issue-update{color:#e49b11}.issue-column.inprogress .issue-update{color:#2d6abf}.issue-column.resolved .issue-update{color:#2c8a53}.profile-hero{background:linear-gradient(#fdfefe,#f4faf6);border:1px solid #d7e8dd;border-radius:.75rem;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.15rem 1.25rem;display:flex}.profile-identity{align-items:center;gap:1rem;display:flex}.profile-avatar{width:42px;height:42px;color:var(--green);background:#e7f3ea;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:800;display:flex}.profile-identity h3{color:#274132;font-size:1.1rem;font-weight:800}.profile-identity p{color:#7b9384;margin-top:.3rem;font-size:.74rem}.profile-pill-row{flex-wrap:wrap;gap:.45rem;margin-top:.65rem;display:flex}.profile-pill{color:#446a54;background:#eaf5ee;border-radius:.35rem;align-items:center;padding:.25rem .55rem;font-size:.64rem;font-weight:700;display:inline-flex}.profile-action{color:#2d6abf;white-space:nowrap;background:#fff;border:1px solid #4b8ef7;border-radius:.45rem;padding:.45rem .8rem;font-size:.68rem;font-weight:700}.profile-tabs{grid-template-columns:repeat(5,minmax(0,1fr));gap:.55rem;margin-top:.9rem;display:grid}.profile-tab{color:#7b9384;text-align:center;background:#f9fcfa;border:1px solid #cde0d4;border-radius:.45rem;padding:.45rem .5rem;font-size:.67rem;font-weight:700}.profile-tab.active{background:var(--green);border-color:var(--green);color:#fff}.profile-detail-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem .8rem;margin-top:1rem;display:grid}.profile-detail{flex-direction:column;gap:.28rem;display:flex}.profile-detail label{letter-spacing:.06em;text-transform:uppercase;color:#88a08e;font-size:.6rem;font-weight:800}.profile-detail input,.profile-detail select{color:#20362a;background:#fff;border:1px solid #cfe2d5;border-radius:.35rem;padding:.45rem .55rem;font-size:.74rem}.profile-form-actions{justify-content:flex-end;gap:.7rem;margin-top:1rem;display:flex}.settings-grid{grid-template-columns:minmax(0,1.45fr) minmax(320px,.9fr);align-items:start;gap:1rem;display:grid}.settings-panel-stack{flex-direction:column;gap:1rem;display:flex}.credit-panel{background:linear-gradient(#fffef9,#f5faf6);border:1px solid #d4e6d8;border-radius:.85rem;flex-direction:column;gap:1rem;padding:1rem;display:flex}.credit-balance{align-items:baseline;gap:.5rem;display:flex}.credit-balance strong{color:var(--green);font-size:clamp(1.8rem,2vw,2.4rem);line-height:1}.credit-balance span{color:var(--muted);font-size:.82rem;font-weight:700}.credit-note{color:#667b6e;font-size:.77rem;line-height:1.6}.credit-actions{flex-wrap:wrap;gap:.7rem;display:flex}.btn-outline{color:var(--green);background:#fff;border:1px solid #b9d4c1;border-radius:.6rem;justify-content:center;align-items:center;gap:.45rem;padding:.7rem 1rem;font-size:.82rem;font-weight:700;display:inline-flex}.btn-outline:hover{background:#f6fbf7}.btn-danger-outline{color:#fff;background:#dc2626;border:none;border-radius:.6rem;justify-content:center;align-items:center;padding:.7rem 1rem;font-size:.82rem;font-weight:700;display:inline-flex}.btn-danger-outline:hover:not(:disabled){background:#b91c1c}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem;display:grid}.events-layout{grid-template-columns:minmax(0,1.45fr) minmax(360px,.95fr);align-items:start;gap:1rem;display:grid}.events-sidebar{flex-direction:column;gap:1rem;display:flex}.events-calendar{flex-direction:column;gap:1rem;padding:1rem;display:flex}.calendar-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.calendar-title{flex-direction:column;gap:.12rem;display:flex}.calendar-title strong{color:#1f3527;font-size:1rem}.calendar-title span{color:#6d8274;font-size:.76rem}.calendar-weekdays{grid-template-columns:repeat(7,minmax(0,1fr));gap:.55rem;display:grid}.calendar-weekdays span{text-transform:uppercase;letter-spacing:.06em;color:#7b8f81;text-align:center;font-size:.72rem;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:.55rem;display:grid}.calendar-day{text-align:left;color:#1f3527;background:linear-gradient(#fff,#f8fbf9);border:1px solid #d8e7dc;border-radius:.9rem;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:.6rem;min-height:112px;padding:.8rem;transition:border-color .15s,transform .15s,box-shadow .15s;display:flex}.calendar-day:hover{border-color:#b8d4c0;transform:translateY(-1px);box-shadow:0 8px 22px #1126180f}.calendar-day.muted{opacity:.45}.calendar-day.today{border-color:#c9a84c}.calendar-day.selected{border-color:var(--green);background:linear-gradient(#fff,#eef7f1);box-shadow:0 0 0 2px #1a5c3814}.calendar-day-number{font-size:1rem;font-weight:800}.calendar-day-meta{color:#68806f;font-size:.74rem;line-height:1.45}.event-list{gap:.9rem;padding:1rem;display:grid}.event-card{background:linear-gradient(#fff,#fbfdfc);border:1px solid #d9e6dd;border-radius:.95rem;gap:.85rem;padding:1rem;display:grid}.event-card.active{border-color:var(--green);box-shadow:0 0 0 2px #1a5c3814}.event-card-head{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.event-card-head h3{color:#1e3526;font-size:.98rem}.event-card-head p{color:#728679;font-size:.76rem}.event-scope{text-transform:capitalize;border-radius:999px;justify-content:center;align-items:center;min-width:88px;padding:.35rem .65rem;font-size:.72rem;font-weight:800;display:inline-flex}.scope-brothers{color:#1f6a43;background:#e9f3ec}.scope-sisters{color:#3059b2;background:#eef3ff}.scope-all{color:#956500;background:#fff5df}.event-card-body{gap:.3rem;display:grid}.event-card-body p{color:#556960;font-size:.8rem}.event-stats{flex-wrap:wrap;gap:.45rem;display:flex}.event-stats span{color:#2a4333;background:#f1f6f3;border-radius:999px;padding:.35rem .6rem;font-size:.72rem;font-weight:700}.event-actions{flex-wrap:wrap;gap:.65rem;display:flex}.events-form{padding:1rem}.page-modal-backdrop{z-index:160;background:#08120c6b;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.page-modal{background:#fff;border:1px solid #d7e6dc;border-radius:1rem;width:min(100%,520px);overflow:hidden;box-shadow:0 24px 70px #0000002e}.assignment-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1rem;padding:1rem;display:grid}.review-stack{gap:1rem;padding:1rem;display:grid}.review-card{background:#fff;border:1px solid #d8e6dd;border-radius:.95rem;gap:.85rem;padding:1rem;display:grid}.highlight-card{background:#fffcf2;border-color:#eed48a}.review-card-head{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.review-card-head h3{color:#1f3529;font-size:.96rem}.review-card-head p{color:#7a9083;font-size:.74rem}.review-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;display:grid}.review-meta-grid strong{letter-spacing:.04em;text-transform:uppercase;color:#7d9387;margin-bottom:.2rem;font-size:.68rem;font-weight:800;display:block}.review-meta-grid span{color:#294133;font-size:.79rem;display:block}.review-details{color:#4d6257;font-size:.82rem;line-height:1.65}.resource-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;padding:1rem;display:grid}.resource-card{background:#fff;border:1px solid #d8e6dd;border-radius:.95rem;gap:.85rem;padding:1rem;display:grid}.resource-link{color:var(--green);font-size:.78rem;font-weight:700}.issue-preview{border:1px solid #d8e6dd;border-radius:.75rem;width:min(100%,320px)}.credit-list{gap:.55rem;display:grid}.credit-list-item{background:#fff;border:1px solid #ddebe1;border-radius:.65rem;padding:.7rem .85rem}.credit-list-item strong{color:#244030;margin-bottom:.15rem;font-size:.79rem;display:block}.credit-list-item span{color:#788d80;font-size:.72rem}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block}.mobile-header{display:flex}.admin-body{margin-left:0}.admin-main{padding:1.25rem}.form-grid{grid-template-columns:1fr}.reg-item{flex-direction:column;align-items:flex-start}.reg-item-actions{width:100%}.btn-approve,.btn-reject{text-align:center;flex:1}.student-topnav{padding:0 1.25rem}.user-pill{display:none}.student-main{margin:1.25rem auto;padding:0 1rem}.profile-card-body{padding:1.25rem}.auth-card{padding:2rem 1.5rem}.room-grid,.issue-board,.profile-detail-grid,.settings-grid,.events-layout,.field-grid,.review-meta-grid,.assignment-layout,.unassigned-grid{grid-template-columns:1fr}.profile-tabs{grid-template-columns:1fr 1fr}.profile-hero,.section-outline-header,.soft-toolbar,.event-card-head,.calendar-toolbar,.review-card-head{flex-direction:column;align-items:flex-start}.calendar-grid,.calendar-weekdays{grid-template-columns:repeat(2,minmax(0,1fr))}.table-actions{justify-content:flex-start}.panel-table{min-width:760px}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr 1fr}.calendar-grid,.calendar-weekdays{grid-template-columns:1fr}.calendar-day{min-height:92px}}@media (min-width:1500px){.form-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.brand-arabic,.auth-logo h1,.sidebar-brand h2,.mobile-brand,.student-brand{letter-spacing:.03em;font-family:Georgia,Times New Roman,serif;font-weight:700}.auth-logo h1{font-size:1.55rem}.sidebar-brand h2,.mobile-brand,.student-brand{font-size:1rem}:root{--sidebar-collapsed-w:76px}.sidebar{transition:width .22s,transform .25s,padding .22s}.sidebar-collapsed{width:var(--sidebar-collapsed-w);padding-inline:.55rem;overflow-x:hidden}.sidebar-collapsed-layout .admin-body{margin-left:var(--sidebar-collapsed-w)}.sidebar-collapsed .sidebar-brand{justify-content:center;padding-inline:0}.sidebar-collapsed .sidebar-brand>div:last-child{display:none}.sidebar-collapsed .nav-item,.sidebar-collapsed .nav-group-toggle{justify-content:center;padding-inline:.55rem}.sidebar-collapsed .nav-group-toggle-left{justify-content:center}.sidebar-collapsed .sidebar-footer{place-items:center;display:grid}.sidebar-collapse-btn{left:calc(var(--sidebar-w) - 14px);width:28px;height:28px;color:var(--green);z-index:120;background:#fff;border:1px solid #ffffff47;border-radius:999px;place-items:center;font-size:1.35rem;font-weight:800;line-height:1;display:grid;position:fixed;top:74px;box-shadow:0 8px 22px #00000029}.sidebar-collapsed .sidebar-collapse-btn{left:calc(var(--sidebar-collapsed-w) - 14px)}.page-header-with-action{align-items:flex-start;gap:.85rem;display:flex}.back-arrow-btn{width:38px;height:38px;color:var(--green);box-shadow:var(--shadow);background:#fff;border:1px solid #c8dfd0;border-radius:999px;flex-shrink:0;place-items:center;font-size:1.15rem;font-weight:800;display:inline-grid}@media (max-width:768px){.sidebar-collapsed-layout .admin-body{margin-left:0}.sidebar-collapse-btn{display:none}.sidebar.sidebar-collapsed{width:var(--sidebar-w);padding:1.25rem .875rem}.admin-main{padding:1rem}.page-header-with-action{align-items:center}.page-header h1{font-size:1.15rem}.section-outline-header .event-actions,.event-actions{width:100%}.event-actions>button,.event-actions>a{text-align:center;flex:140px;justify-content:center}.panel-table-wrap{-webkit-overflow-scrolling:touch;padding-inline:.75rem}.panel-table{min-width:680px}.page-modal-backdrop{align-items:flex-end;padding:.75rem}.page-modal{width:100%;max-height:88vh;overflow-y:auto}}@media (max-width:480px){.admin-main{padding:.85rem}.stats-grid{grid-template-columns:1fr}.section-outline-header{padding:.9rem}.back-arrow-btn{width:34px;height:34px}}.page-header-main{flex:1;min-width:220px}.page-header-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.back-arrow-btn{width:auto;height:auto;min-height:34px;color:var(--green);box-shadow:none;background:0 0;border:1px solid #d3e2d9;border-radius:.5rem;justify-content:center;align-items:center;gap:.3rem;padding:.35rem .7rem;font-size:.82rem;font-weight:800;display:inline-flex}.back-arrow-btn:hover{background:var(--green-light)}.planning-actions{flex-wrap:nowrap;align-items:center}.planning-actions>button{white-space:nowrap;width:auto}.issue-detail-modal{width:min(100%,680px)}@media (max-width:768px){.planning-actions{width:100%;padding-bottom:.15rem;overflow-x:auto}.planning-actions>button{flex:none}.page-header-actions{width:100%}}.sidebar{overflow:hidden}.sidebar-brand{z-index:2;background:var(--green);flex-shrink:0;position:sticky;top:0}.sidebar-section-badge{flex-shrink:0}.sidebar-nav{min-height:0;padding-right:.15rem;overflow-y:auto}.sidebar-footer{flex-shrink:0}.btn-danger,.btn-danger-outline{border-radius:.625rem;padding:.75rem 1rem;font-size:.875rem;font-weight:700;transition:background .15s,color .15s,border-color .15s}.btn-danger{color:#fff;background:#dc2626;border:1px solid #dc2626}.btn-danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.btn-danger-outline{color:#b91c1c;background:#fff;border:1px solid #fecaca}.btn-danger-outline:hover:not(:disabled){background:#fef2f2;border-color:#fca5a5}.confirm-dialog{width:min(100%,440px)}.confirm-dialog-body{gap:.85rem;padding:1.25rem;display:grid}.confirm-dialog-body h2{color:#1f3529;font-size:1rem}.confirm-dialog-body p{color:#5f7468;font-size:.86rem;line-height:1.55}.confirm-dialog-actions{justify-content:flex-end;margin-top:.25rem}.confirm-dialog-actions>button{width:auto;min-width:112px}.app-toast{z-index:220;background:#fff;border:1px solid;border-radius:.85rem;justify-content:space-between;align-items:flex-start;gap:.85rem;width:min(100vw - 2rem,360px);padding:.9rem 1rem;display:flex;position:fixed;top:1.25rem;right:1.25rem;box-shadow:0 18px 50px #0000002e}.app-toast-success{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.app-toast-error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.app-toast strong{margin-bottom:.15rem;font-size:.82rem;display:block}.app-toast p{font-size:.8rem;line-height:1.45}.app-toast button{color:currentColor;background:0 0;border:none;padding:.1rem;font-size:1.1rem;line-height:1}@media (max-width:768px){.app-toast{width:auto;inset:auto .75rem .75rem}}.student-announcement-panel{overflow:hidden}.student-section-tabs{background:#fbfdfb;border-bottom:1px solid #d7e8dd;gap:.6rem;padding:1rem;display:flex;overflow-x:auto}.student-section-tabs button{color:#315242;white-space:nowrap;background:#fff;border:1px solid #d4e7dc;border-radius:.75rem;align-items:center;gap:.55rem;padding:.65rem .85rem;font-size:.78rem;font-weight:800;display:inline-flex}.student-section-tabs button.active{background:var(--green);border-color:var(--green);color:#fff}.student-section-tabs button strong{min-width:1.35rem;height:1.35rem;color:var(--green);background:#edf6f0;border-radius:999px;place-items:center;font-size:.72rem;display:inline-grid}.student-section-tabs button.active strong{color:#fff;background:#ffffff2e}.student-card-list{gap:.85rem;padding:1rem;display:grid}.student-info-card{background:#fff;border:1px solid #dcebe2;border-radius:.9rem;gap:.65rem;padding:1rem;display:grid}.student-info-card h3{color:#1f3529;font-size:.95rem}.student-info-card p{color:#667d70;font-size:.78rem}.routine-compact-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;padding:1rem;display:grid}.routine-group-card{background:#fff;border:1px solid #dcebe2;border-radius:.95rem;align-content:start;gap:.75rem;padding:1rem;display:grid}.routine-group-head{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.routine-group-head h2{color:#1f3529;font-size:.92rem}.routine-group-head span{background:var(--green-light);color:var(--green);border-radius:999px;padding:.25rem .55rem;font-size:.75rem;font-weight:800}.routine-list-item{border-top:1px solid #edf4ef;justify-content:space-between;align-items:flex-start;gap:.75rem;padding-top:.75rem;display:flex}.routine-list-item h3{color:#223b2d;font-size:.84rem}.routine-list-item p{color:#72877a;margin-top:.18rem;font-size:.74rem}.routine-list-item button{flex-shrink:0;width:auto;padding:.45rem .65rem}@media (max-width:520px){.routine-list-item{flex-direction:column}.routine-list-item button{width:100%}}.routine-modal{flex-direction:column;width:min(96vw,680px);max-height:min(86vh,760px);display:flex}.routine-modal>.section-outline-header{flex-shrink:0;padding:.85rem 1rem}.routine-modal-form{min-height:0;padding:.85rem 1rem 0;overflow-y:auto}.routine-modal-form .field-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.routine-modal-form .field textarea{min-height:76px}.routine-modal-actions{z-index:2;background:#fff;border-top:1px solid #d7e8dd;margin:0 -1rem;padding:.8rem 1rem;position:sticky;bottom:0}.routine-modal-actions>button{width:auto;min-width:130px}@media (max-width:760px){.routine-modal{width:100%;max-height:90vh}.routine-modal-form .field-grid{grid-template-columns:1fr}.routine-modal-actions>button{flex:140px}}.page-modal-backdrop{overscroll-behavior:contain;align-items:center;overflow-y:auto}.page-modal{flex-direction:column;max-height:calc(100vh - 2rem);display:flex;overflow-y:auto}.page-modal>form,.page-modal .form-stack{min-height:0}.routine-modal{max-height:calc(100vh - 2rem)}.routine-modal-form{max-height:calc(100vh - 3rem);padding-bottom:0;overflow-y:auto}.confirm-dialog{max-height:calc(100vh - 2rem)}@media (max-width:760px){.page-modal-backdrop{align-items:flex-end;padding:.5rem}.page-modal,.routine-modal,.confirm-dialog{border-radius:.85rem;width:100%;max-height:calc(100vh - 1rem)}}.analytics-donut-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-top:1rem;display:grid}.analytics-donut-card{min-height:250px}.analytics-donut-body{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:1rem;padding:1rem;display:grid}.analytics-donut-wrap{place-items:center;width:128px;height:128px;display:grid;position:relative}.analytics-donut-wrap svg{overflow:visible}.analytics-donut-center{text-align:center;pointer-events:none;place-content:center;display:grid;position:absolute;inset:0}.analytics-donut-center strong{color:var(--text);font-size:1.25rem;line-height:1}.analytics-donut-center span{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem;font-size:.68rem}.analytics-donut-legend{gap:.55rem;min-width:0;display:grid}.analytics-donut-legend-row{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.5rem;font-size:.8rem;display:grid}.analytics-donut-legend-row>span{border-radius:999px;width:.75rem;height:.75rem}.analytics-donut-legend-row p{text-overflow:ellipsis;white-space:nowrap;color:var(--muted);overflow:hidden}.analytics-donut-legend-row strong{color:var(--text)}@media (max-width:560px){.analytics-donut-body{grid-template-columns:1fr;justify-items:center}.analytics-donut-legend{width:100%}}.profile-avatar img{object-fit:cover;border-radius:inherit;width:100%;height:100%}.profile-photo-panel{border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(135deg,#fbfdf9,#f2f7f1);grid-template-columns:auto minmax(0,1fr);align-items:center;gap:1rem;margin-bottom:1rem;padding:1rem;display:grid}.profile-photo-frame,.admin-profile-photo{border:1px solid var(--border);width:112px;height:112px;color:var(--muted);text-transform:uppercase;background:#eef5ef;border-radius:24px;place-items:center;font-size:.78rem;font-weight:800;display:grid;overflow:hidden}.profile-photo-frame img,.admin-profile-photo img{object-fit:cover;width:100%;height:100%}.profile-photo-panel h3{color:var(--green-dark);margin:0 0 .35rem}.profile-photo-panel p{color:var(--muted);margin:0 0 .8rem;font-size:.86rem}.profile-photo-actions{flex-wrap:wrap;gap:.55rem;display:flex}.disabled-control{opacity:.55;pointer-events:none}.student-performance-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.85rem;margin:1rem 0;display:grid}.student-performance-card{border:1px solid var(--border);text-align:center;background:#fff;border-radius:18px;justify-items:center;gap:.7rem;padding:1rem;display:grid;box-shadow:0 8px 22px #12482b0f}.student-ring{border-radius:999px;width:104px;height:104px;padding:9px}.student-ring>div{border-radius:inherit;background:#fff;align-content:center;place-items:center;width:100%;height:100%;display:grid}.student-ring strong{color:var(--green-dark);font-size:1.15rem;line-height:1}.student-ring span{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:.25rem;font-size:.66rem}.student-performance-card p{color:var(--muted);margin:0;font-size:.78rem;line-height:1.35}.admin-profile-overview{gap:1rem;padding:1.5rem 1.5rem 0;display:grid}.admin-profile-photo-card{border:1px solid var(--border);border-radius:var(--radius);background:#fbfdf9;align-items:center;gap:1rem;padding:1rem;display:flex}.admin-profile-performance{margin:0}@media (max-width:640px){.profile-photo-panel,.admin-profile-photo-card{grid-template-columns:1fr;justify-items:start}.profile-photo-frame,.admin-profile-photo{border-radius:20px;width:96px;height:96px}}.analytics-bar-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem;margin-top:1rem;display:grid}.analytics-bar-list{gap:.85rem;padding:1rem;display:grid}.analytics-bar-row{grid-template-columns:minmax(130px,1.2fr) minmax(120px,2fr) auto;align-items:center;gap:.75rem;display:grid}.analytics-bar-label{gap:.15rem;min-width:0;display:grid}.analytics-bar-label strong{color:var(--green-dark);text-overflow:ellipsis;white-space:nowrap;font-size:.86rem;overflow:hidden}.analytics-bar-label span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;overflow:hidden}.analytics-bar-track{background:#edf3ef;border-radius:999px;height:12px;overflow:hidden}.analytics-bar-track>div{border-radius:inherit;height:100%;transition:width .25s}.analytics-bar-value{color:var(--green-dark);text-align:right;min-width:42px;font-size:.82rem}@media (max-width:720px){.analytics-bar-row{grid-template-columns:1fr auto}.analytics-bar-track{grid-column:1/-1}}.student-name-link{color:var(--green-dark);font-weight:800;text-decoration:none}.student-name-link:hover{color:var(--green);text-decoration:underline}.room-bed-list{gap:.45rem;width:100%;margin-top:.65rem;display:grid}.room-bed-slot{background:#ffffff9e;border:1px solid #0f513221;border-radius:.65rem;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:.5rem;padding:.45rem .55rem;font-size:.75rem;display:grid}.room-bed-slot.occupied{background:#ffffffd1}.room-bed-slot.free{opacity:.86}.bed-label{background:var(--green-dark);color:#fff;border-radius:999px;place-items:center;width:1.55rem;height:1.55rem;font-size:.72rem;font-weight:900;display:grid}.assignment-bed-list{padding:1rem}.assignment-bed-list .room-bed-slot{background:#fbfdf9;grid-template-columns:auto minmax(0,1fr) auto}.admin-profile-actions-inline{flex-wrap:wrap;gap:.75rem;padding:0 1.5rem 1.25rem;display:flex}.profile-attendance-metrics{grid-template-columns:repeat(auto-fit,minmax(95px,1fr));gap:.75rem;padding:1rem;display:grid}.profile-attendance-metric{border:1px solid var(--border);text-align:center;background:#fbfdf9;border-radius:.9rem;gap:.2rem;padding:.85rem;display:grid}.profile-attendance-metric strong{color:var(--green-dark);font-size:1.3rem}.profile-attendance-metric span{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:800}.compact-review-card{padding:0;overflow:hidden}.compact-review-line{text-align:left;cursor:pointer;background:#fff;border:0;justify-content:space-between;align-items:center;gap:1rem;width:100%;padding:.95rem 1rem;display:flex}.compact-review-line:hover{background:#fbfdf9}.compact-review-line>span:first-child{gap:.2rem;min-width:0;display:grid}.compact-review-line strong{color:var(--green-dark)}.compact-review-line small{color:var(--muted);font-size:.76rem}.compact-review-details{border-top:1px solid var(--border);gap:.85rem;padding:1rem;display:grid}@media (max-width:640px){.assignment-bed-list .room-bed-slot{grid-template-columns:auto 1fr}.assignment-bed-list .room-bed-slot button{grid-column:1/-1;width:100%}.compact-review-line{flex-direction:column;align-items:flex-start}}.admin-profile-overview{row-gap:1.25rem}.admin-profile-actions-inline{border:1px solid var(--border);border-radius:var(--radius);background:#fbfdf9;align-items:center;margin:.35rem 1.5rem 1.35rem;padding:1rem}.admin-profile-actions-inline:before{content:"Student actions";color:var(--green-dark);text-transform:uppercase;letter-spacing:.06em;margin-right:auto;font-size:.75rem;font-weight:900}.emergency-contact-section{border:1px solid var(--border);border-radius:var(--radius);background:#fff;margin:0 1.5rem 1.5rem;overflow:hidden}.emergency-contact-section.in-form{margin:1rem 0 0}.section-outline-header.compact{border-bottom:1px solid var(--border);padding:1rem}.section-outline-header.compact h2{font-size:1rem}.emergency-contact-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:.75rem;padding:1rem;display:grid}.emergency-contact-card{background:linear-gradient(135deg,#fbfdf9,#f6faf7);border:1px solid #e1ece5;border-radius:.9rem;gap:.25rem;padding:.85rem;display:grid}.emergency-contact-card span{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:900}.emergency-contact-card strong{color:var(--green-dark);overflow-wrap:anywhere;font-size:.9rem}@media (max-width:640px){.admin-profile-actions-inline{margin-inline:1rem}.admin-profile-actions-inline:before{width:100%;margin-bottom:.25rem}.emergency-contact-section{margin-inline:1rem}}.fees-page .fees-hero{border-radius:var(--radius);background:linear-gradient(135deg,#fbfdf9,#edf6ef);border:1px solid #dce9df;padding:1.25rem}.fees-stats .stat-card h3{font-size:clamp(1.1rem,2vw,1.55rem)}.fees-action-strip{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:.85rem;margin:1rem 0;display:grid}.fees-action-strip>div{border:1px solid var(--border);background:#fff;border-radius:1rem;gap:.2rem;padding:1rem;display:grid}.fees-action-strip strong{color:var(--green-dark);font-size:1.4rem}.fees-action-strip span{color:var(--muted);font-size:.78rem}.fees-card-list{gap:.85rem;padding:1rem;display:grid}.fee-student-card{border:1px solid var(--border);background:#fff;border-left:5px solid #c9a84c;border-radius:1rem;grid-template-columns:minmax(220px,1.1fr) minmax(260px,2fr) auto;align-items:center;gap:1rem;padding:1rem;display:grid}.fee-student-card.paid{border-left-color:var(--green);background:#fbfdf9}.fee-student-card.overdue{border-left-color:#be123c}.fee-student-main{gap:.25rem;display:grid}.fee-student-main strong,.fee-student-main a{color:var(--green-dark);font-weight:900}.fee-student-main span,.fee-money-grid span{color:var(--muted);font-size:.74rem}.fee-money-grid{grid-template-columns:repeat(auto-fit,minmax(105px,1fr));gap:.65rem;display:grid}.fee-money-grid>div{background:#f6faf7;border-radius:.8rem;gap:.2rem;padding:.65rem;display:grid}.fee-money-grid strong{color:var(--green-dark);font-size:.92rem}.fee-card-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.55rem;display:flex}.paid-chip{color:var(--green-dark);font-size:.8rem;font-weight:900}.fees-plan-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;padding:1rem;display:grid}.fee-plan-card{border:1px solid var(--border);background:#fff;border-radius:1rem;gap:.75rem;padding:1rem;display:grid}.fee-plan-card>div{gap:.25rem;display:grid}.fee-plan-card span,.fee-plan-card p{color:var(--muted);margin:0;font-size:.8rem}.fee-plan-card h3{color:var(--green-dark);font-size:1.6rem}.student-next-due{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.85rem;padding:1rem;display:grid}.student-next-due>div{border:1px solid var(--border);background:#fbfdf9;border-radius:1rem;gap:.3rem;padding:1rem;display:grid}.student-next-due span{color:var(--muted);text-transform:uppercase;font-size:.75rem;font-weight:800}.student-next-due strong{color:var(--green-dark);font-size:1.05rem}@media (max-width:900px){.fee-student-card{grid-template-columns:1fr}.fee-card-actions{justify-content:flex-start}}.fees-action-strip.compact{margin-top:1rem}.fee-student-card.paid{opacity:.58;filter:grayscale(.55)}.fee-student-card.paid .student-name-link,.fee-student-card.paid .fee-student-main strong{color:#647067}.fee-student-card.unassigned{background:#f8fafc;border-left-color:#94a3b8}.fee-student-card.partial{border-left-color:#2563eb}.fee-card-actions .btn-primary,.fee-card-actions .btn-outline{white-space:nowrap;width:auto;padding:.5rem .8rem}.analytics-primary-bars{margin:1rem 0}.analytics-column-card,.admin-profile-column-section{overflow:hidden}.admin-profile-column-section{border:1px solid var(--border);background:#fff;border-radius:1rem;margin:0 1.5rem 1.5rem}.column-chart-shell,.profile-column-chart{grid-template-columns:42px minmax(0,1fr);gap:.75rem;min-height:300px;padding:1rem;display:grid}.column-chart-y-axis,.profile-column-y-axis{color:var(--muted);text-align:right;flex-direction:column;justify-content:space-between;padding:.25rem 0 4.4rem;font-size:.72rem;font-weight:800;display:flex}.column-chart-plot,.profile-column-plot{min-width:0;position:relative}.column-chart-grid,.profile-column-grid{pointer-events:none;flex-direction:column;justify-content:space-between;display:flex;position:absolute;inset:0 0 4.4rem}.column-chart-grid span,.profile-column-grid span{border-top:1px solid #dce7de}.column-chart-bars,.profile-column-bars{z-index:1;grid-auto-columns:minmax(76px,1fr);grid-auto-flow:column;align-items:end;gap:.9rem;height:100%;padding-bottom:.25rem;display:grid;position:relative;overflow-x:auto}.column-chart-item,.profile-column-item{text-align:center;grid-template-rows:minmax(150px,1fr) auto auto auto;place-items:end center;gap:.28rem;min-width:76px;height:100%;display:grid}.column-chart-bar-wrap,.profile-column-bar-wrap{border-radius:.45rem .45rem 0 0;align-items:end;width:42px;height:100%;display:flex}.column-chart-bar,.profile-column-bar{border-radius:.42rem .42rem 0 0;width:100%;min-height:4px;box-shadow:inset 0 -1px #0000001f,0 6px 12px #0f51321f}.column-chart-item strong,.profile-column-item strong{color:var(--green-dark);font-size:.82rem}.column-chart-item span,.profile-column-item span{color:#1f2a24;min-height:1.8rem;font-size:.72rem;font-weight:900;line-height:1.15}.column-chart-item small,.profile-column-item small{color:var(--muted);min-height:1.7rem;font-size:.65rem;line-height:1.15}@media (max-width:760px){.column-chart-shell,.profile-column-chart{grid-template-columns:34px minmax(0,1fr);padding:.8rem}.column-chart-bars,.profile-column-bars{grid-auto-columns:72px}}.analytics-chart-layout{grid-template-columns:minmax(420px,1.08fr) minmax(360px,.92fr);align-items:start;gap:1rem;margin-top:1rem;display:grid}.analytics-chart-left,.analytics-chart-right{min-width:0}.analytics-chart-layout .section-kicker{color:var(--green-dark);letter-spacing:.08em;text-transform:uppercase;margin:0 0 .5rem;font-size:.78rem;font-weight:900}.analytics-chart-layout .analytics-bar-grid,.analytics-chart-layout .analytics-donut-grid{margin-top:0}.analytics-chart-left .analytics-bar-grid{grid-template-columns:1fr}.analytics-chart-right .analytics-donut-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}@media (max-width:1200px){.analytics-chart-layout{grid-template-columns:1fr}.analytics-chart-right .analytics-donut-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media (max-width:640px){.analytics-chart-right .analytics-donut-body{grid-template-columns:1fr;justify-items:start}}.student-monthly-performance .section-outline-header{align-items:flex-start}.profile-chart-legend{flex-wrap:wrap;justify-content:flex-end;gap:.55rem;display:flex}.profile-chart-legend span{color:var(--muted);align-items:center;gap:.35rem;font-size:.74rem;font-weight:900;display:inline-flex}.profile-chart-legend i{border-radius:2px;width:10px;height:10px;display:inline-block}.profile-grouped-chart{grid-template-columns:42px minmax(0,1fr);gap:.75rem;min-height:330px;padding:1rem;display:grid}.profile-month-groups{z-index:1;grid-auto-columns:minmax(104px,1fr);grid-auto-flow:column;align-items:end;gap:1rem;height:100%;padding-bottom:.25rem;display:grid;position:relative;overflow-x:auto}.profile-month-group{text-align:center;grid-template-rows:minmax(180px,1fr) auto auto;place-items:end center;gap:.35rem;height:100%;display:grid}.profile-month-bars{align-items:end;gap:.32rem;height:100%;padding-inline:.25rem;display:flex}.profile-month-bar{border-radius:.28rem .28rem 0 0;width:22px;min-height:4px;box-shadow:inset 0 -1px #00000024,0 6px 10px #0f51321f}.profile-month-bar.academic{background:#2563eb}.profile-month-bar.religious{background:#0f766e}.profile-month-bar.activity{background:#c9a84c}.profile-month-group strong{color:var(--green-dark);font-size:.76rem;line-height:1.15}.profile-month-group small{color:var(--muted);min-height:1.5rem;font-size:.66rem;line-height:1.2}.empty-state.compact{min-height:auto;margin:1rem;padding:1rem}@media (max-width:760px){.profile-grouped-chart{grid-template-columns:34px minmax(0,1fr);padding:.8rem}.profile-month-groups{grid-auto-columns:96px}.profile-chart-legend{justify-content:flex-start}}.analytics-donut-card{min-width:0}.analytics-donut-center strong{text-overflow:ellipsis;max-width:72px;font-size:clamp(.95rem,1.4vw,1.15rem);overflow:hidden}.analytics-donut-center span{overflow-wrap:anywhere;justify-self:center;max-width:72px;font-size:.58rem;line-height:1.05}.analytics-donut-legend-row{align-items:start}.analytics-donut-legend-row p{white-space:normal;text-overflow:unset;overflow-wrap:anywhere;margin:0;line-height:1.15;overflow:visible}.analytics-donut-legend-row strong{line-height:1.15}.analytics-chart-right .analytics-donut-body{grid-template-columns:96px minmax(0,1fr)}.analytics-chart-right .analytics-donut-wrap,.analytics-chart-right .analytics-donut-wrap svg{width:96px;height:96px}.analytics-chart-right .analytics-donut-legend-row{gap:.35rem;font-size:.72rem}.analytics-chart-right .analytics-donut-legend-row>span{width:.55rem;height:.55rem;margin-top:.18rem}.sample-chart-note{color:#9a6b00;margin-top:.25rem;font-size:.75rem;font-weight:800}.profile-grouped-chart.is-sample .profile-month-bar{opacity:.78}.analytics-donut-card .content-card-header{padding:.8rem .9rem}.analytics-donut-card .content-card-header h2{overflow-wrap:anywhere;font-size:.9rem;line-height:1.15}.analytics-donut-body{min-width:0}.analytics-donut-wrap svg{width:100%;height:100%}.analytics-chart-right .analytics-donut-grid{grid-template-columns:repeat(2,minmax(190px,1fr));gap:.75rem}.analytics-chart-right .analytics-donut-body{grid-template-columns:82px minmax(0,1fr);align-items:center;gap:.55rem;padding:.75rem}.analytics-chart-right .analytics-donut-center strong{max-width:54px;font-size:.88rem}.analytics-chart-right .analytics-donut-center span{letter-spacing:.02em;max-width:54px;font-size:.5rem}.analytics-chart-right .analytics-donut-legend{gap:.32rem}.analytics-chart-right .analytics-donut-legend-row{grid-template-columns:8px minmax(0,1fr) auto;font-size:.66rem;line-height:1.08}.analytics-chart-right .analytics-donut-legend-row strong{font-size:.68rem}@media (max-width:1400px){.analytics-chart-right .analytics-donut-grid{grid-template-columns:1fr}.analytics-chart-right .analytics-donut-card{min-height:170px}}@media (max-width:1200px){.analytics-chart-right .analytics-donut-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}}.analytics-donut-center{flex-direction:column;justify-content:center;align-items:center;gap:.1rem;padding:.25rem;display:flex}.analytics-donut-center strong,.analytics-donut-center span{text-align:center;margin:0;display:block}.analytics-chart-right .analytics-donut-body{grid-template-columns:108px minmax(0,1fr);gap:.7rem}.analytics-chart-right .analytics-donut-wrap{width:108px;height:108px}.analytics-chart-right .analytics-donut-center strong{max-width:70px;font-size:1.02rem;line-height:1}.analytics-chart-right .analytics-donut-center span{max-width:70px;font-size:.55rem;line-height:1.05}.analytics-chart-right .analytics-donut-card{min-height:205px}@media (max-width:1400px){.analytics-chart-right .analytics-donut-body{grid-template-columns:108px minmax(0,1fr)}}.analytics-pie-card .content-card-header h2{overflow-wrap:anywhere}.analytics-pie-body{align-items:start}.analytics-pie-wrap{isolation:isolate;overflow:visible}.analytics-pie-wrap svg{filter:drop-shadow(0 8px 14px #0f51321f)}.analytics-pie-slice{cursor:pointer;transform-box:fill-box;transform-origin:50%;outline:none;transition:transform .16s,filter .16s,opacity .16s}.analytics-pie-slice:hover,.analytics-pie-slice:focus{filter:brightness(1.06);transform:scale(1.045)}.analytics-pie-total{color:var(--green-dark);justify-items:center;gap:.05rem;margin-top:.45rem;display:grid}.analytics-pie-total strong{font-size:1.05rem;line-height:1}.analytics-pie-total span{color:var(--muted);letter-spacing:.05em;text-transform:uppercase;font-size:.58rem;font-weight:900}.analytics-pie-tooltip{z-index:5;pointer-events:none;text-align:center;background:#fffffff5;border:1px solid #0f51322e;border-radius:.8rem;gap:.15rem;min-width:145px;padding:.6rem .7rem;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 14px 30px #0f51322e}.analytics-pie-tooltip strong{color:var(--green-dark);font-size:.78rem;line-height:1.15}.analytics-pie-tooltip span{color:var(--muted);font-size:.68rem;line-height:1.15}.analytics-pie-tooltip em{color:#9a6b00;font-size:.9rem;font-style:normal;font-weight:900}.analytics-pie-card .analytics-donut-center{display:none}.analytics-chart-right .analytics-pie-wrap{width:116px;height:auto}.analytics-chart-right .analytics-pie-body{grid-template-columns:122px minmax(0,1fr);gap:.7rem}.analytics-chart-right .analytics-pie-card{min-height:215px}@media (max-width:640px){.analytics-chart-right .analytics-pie-body,.analytics-pie-body{grid-template-columns:1fr;justify-items:center}.analytics-pie-tooltip{top:42%}}.profile-tabs button.profile-tab{border:1px solid var(--border);cursor:pointer;background:#fff}.profile-tabs button.profile-tab.active{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}.student-profile-tab-panel{margin-top:1rem;padding-bottom:.25rem}.document-upload-grid,.admin-document-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem;display:grid}.document-upload-card,.admin-document-card{border:1px solid var(--border);background:#fbfdf9;border-radius:.9rem;padding:.85rem}.document-upload-preview,.admin-document-card{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.document-upload-preview span,.admin-document-card span,.admin-document-card small{color:var(--muted);overflow-wrap:anywhere;font-size:.74rem}.admin-document-section,.student-documents-panel{border:1px solid var(--border);background:#fff;border-radius:1rem;margin:1rem 1.5rem;overflow:hidden}.admin-document-grid,.student-documents-panel .document-upload-grid{padding:1rem}.admin-document-card>div{gap:.2rem;display:grid}.admin-document-card strong{color:var(--green-dark);font-size:.9rem}.fee-row-menu-wrap{justify-items:start;gap:.35rem;display:grid;position:relative}.fee-row-menu-btn{border:1px solid var(--border);width:38px;height:38px;color:var(--green-dark);cursor:pointer;background:#fff;border-radius:999px;font-size:1.1rem;font-weight:900;line-height:1}.fee-row-menu{z-index:20;border:1px solid var(--border);background:#fff;border-radius:.8rem;gap:.45rem;width:132px;padding:.55rem;display:grid;position:absolute;top:42px;right:0;box-shadow:0 16px 28px #0f513229}.attend-present,.attend-absent,.attend-excused,.attend-late{cursor:pointer;color:#fff;border:none;border-radius:999px;padding:.5rem .85rem;font-size:.8rem;font-weight:700;transition:transform .15s,box-shadow .15s,opacity .15s}.attend-present{background:#16a34a;border:2px solid #16a34a}.attend-present.active{color:#16a34a;background:#fff}.attend-present:hover:not(.active){background:#15803d;border-color:#15803d}.attend-absent{background:#dc2626;border:2px solid #dc2626}.attend-absent.active{color:#dc2626;background:#fff}.attend-absent:hover:not(.active){background:#b91c1c;border-color:#b91c1c}.attend-excused{background:#ca8a04;border:2px solid #ca8a04}.attend-excused.active{color:#ca8a04;background:#fff}.attend-excused:hover:not(.active){background:#a16207;border-color:#a16207}.attend-late{background:#2563eb;border:2px solid #2563eb}.attend-late.active{color:#2563eb;background:#fff}.attend-late:hover:not(.active){background:#1d4ed8;border-color:#1d4ed8}.attend-present:hover,.attend-absent:hover,.attend-excused:hover,.attend-late:hover{transform:translateY(-1px)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
