@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-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--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;--color-red-50:#fef2f2;--color-red-600:#e40014;--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--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)}@supports (color:lab(0% 0 0)){:root,:host{--color-red-50:lab(96.5005% 4.18508 1.52328);--color-red-600:lab(48.4493% 77.4328 61.5452)}}}@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{.relative{position:relative}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.min-h-screen{min-height:100vh}.items-center{align-items:center}.justify-center{justify-content:center}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.bg-red-50{background-color:var(--color-red-50)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-10{padding-block:calc(var(--spacing) * 10)}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-red-600{color:var(--color-red-600)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.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{--font-stack:"Inter", "Anuphan", -apple-system, BlinkMacSystemFont, "SF Pro Display", sans-serif;--fw-normal:400;--fw-medium:500;--fw-semibold:600;--cream:#fcfbf7;--card:#fff;--ink:#14201a;--ink-soft:#14201a94;--line:#14201a1a;--leaf:#1b7a4b;--leaf-soft:#1b7a4b1a;--leaf2:#14613b;--sky:#27839e;--sky-soft:#27839e1a;--sun:#e8a23d;--sun2:#f2b65c;--sun-soft:#e8a23d26;--coral:#c9503a;--coral-soft:#c9503a1a;--grape:#6e5fc0;--grape-soft:#6e5fc01a;--g1:#1b7a4b;--g2:#27839e;--g3:#e8a23d;--g4:#3fb873;--g5:#1e8f88;--g6:#e8a23d;--g7:#27839e;--g8:#3fb873;--glass-bg:#ffffffb3;--glass-border:#ffffffb3;--glass-blur:8px;--glass-bg-strong:#ffffffd9;--shadow:0 8px 32px -8px #1b7a4b1f, 0 2px 8px -2px #0000000f;--shadow-sm:0 4px 16px -4px #1b7a4b1a, 0 1px 4px -1px #0000000a;--shadow-lg:0 16px 48px -12px #1b7a4b29;--shadow-glow:0 0 32px #1b7a4b26;--radius:24px;--radius-sm:14px;--radius-xs:8px;--transition:.2s ease;--transition-smooth:.4s cubic-bezier(.16, 1, .3, 1)}*{box-sizing:border-box;margin:0;padding:0}h1,h2,h3,h4,.font-mali{font-family:var(--font-stack);letter-spacing:-.01em;font-weight:600}body{font-family:var(--font-stack);color:var(--ink);-webkit-font-smoothing:antialiased;background:linear-gradient(135deg,#fcfbf7 0%,#f1f6ef 50%,#fcfbf7 100%);min-height:100vh;line-height:1.65;transition:color .3s;overflow-x:hidden}.dark{--cream:#0e1512;--card:#15201b;--ink:#e9efea;--ink-soft:#e9efea99;--line:#78c89624;--leaf:#3fb873;--leaf-soft:#3fb87329;--leaf2:#5ed38c;--sky:#4fb3d4;--sky-soft:#4fb3d429;--sun:#f2b65c;--sun-soft:#f2b65c29;--coral:#f2765c;--coral-soft:#f2765c29;--grape:#9b8be8;--grape-soft:#9b8be833;--glass-bg:#15201b8c;--glass-border:#78c8961a;--glass-bg-strong:#0e1512cc;--shadow:0 8px 32px -8px #00000073, 0 2px 8px -2px #0000004d;--shadow-sm:0 4px 16px -4px #0006, 0 1px 4px -1px #00000040;--shadow-lg:0 16px 48px -12px #0000008c;--shadow-glow:0 0 32px #3fb87333;--g1:#3fb873;--g2:#4fb3d4;--g3:#f2b65c;--g4:#5ed38c;--g5:#38c0a8;--g6:#f2b65c;--g7:#4fb3d4;--g8:#5ed38c}.dark body{background:linear-gradient(135deg,#0e1512 0%,#111a15 50%,#0e1512 100%)}.dark .bg-orb{opacity:.18}.dark .bg-kid{opacity:.05}.dark .accent-ring{opacity:.15}.dark .stat,.dark .card,.dark .att-row,.dark .student-card,.dark .dash-classroom-card,.dark .settings-card,.dark .modal,.dark .pcard,.dark .hero-child{background:var(--glass-bg);border-color:var(--glass-border)}.dark .tab.active{background:var(--glass-bg-strong)}.dark .tabs{background:var(--line)}.dark .form-input,.dark .form-select,.dark .form-textarea,.dark .search-wrap,.dark .search-select,.dark .att-btn,.dark .att-note,.dark .cal-day:not(.weekend):not(.holiday),.dark .assess-level-btn,.dark .assess-note-input,.dark .assess-tab,.dark .qa-score-btn,.dark .qa-input,.dark .field .inp{border-color:var(--line);color:var(--ink);background:#ffffff0f}.dark .tbl{background:#ffffff0a}.dark .tbl th{background:#ffffff0f}.dark .tbl tr:hover td{background:#ffffff0a}.dark .tbl td{border-top-color:var(--line)}.dark .cal-day.weekend{background:#ffffff08}.dark .cal-day.holiday{background:var(--coral-soft)}.dark .nav-item:hover,.dark .nav-user,.dark .assess-ind-num,.dark .assess-ind-age,.dark .qa-code,.dark .booklet-section-title{background:#ffffff0f}.dark .booklet-table th{background:#0000004d}.dark .booklet-school,.dark .booklet-subtitle,.dark .booklet-label{color:#aaa}.dark .booklet-title{color:#eee}.dark .assess-tab-count{background:#ffffff14}.dark .form-check{background:#ffffff0f}.dark .parent-topbar{background:var(--glass-bg-strong);border-color:var(--line)}.dark .print-page{color:var(--ink);background:#1a1a2e}@media print{.dark body{background:#fff!important}.dark .print-page{color:#000!important;background:#fff!important}}.theme-toggle{border:1.5px solid var(--line);background:var(--glass-bg);width:40px;height:40px;color:var(--ink-soft);cursor:pointer;transition:var(--transition-smooth);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.theme-toggle:hover{border-color:var(--sun);color:var(--sun);box-shadow:var(--shadow-glow)}.dark .theme-toggle:hover{border-color:var(--g8);color:var(--g8)}@keyframes bgShift{0%,to{background-position:0%}25%{background-position:100% 0}50%{background-position:100% 100%}75%{background-position:0 100%}}.bg-orbs{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.bg-orb{filter:blur(60px);opacity:.12;border-radius:50%;position:absolute}.bg-orb--1{background:linear-gradient(135deg, var(--g1), var(--g5));width:400px;height:400px;top:-15%;left:-10%}.bg-orb--2{background:linear-gradient(135deg, var(--g2), var(--g3));width:350px;height:350px;top:50%;right:-15%}.bg-orb--3{background:linear-gradient(135deg, var(--g4), var(--g7));width:300px;height:300px;bottom:-10%;left:30%}.bg-orb--4{background:linear-gradient(135deg, var(--g6), var(--g3));width:250px;height:250px;top:20%;right:30%}.bg-orb--5{background:linear-gradient(135deg, var(--g8), var(--g6));width:200px;height:200px;bottom:20%;right:10%}@keyframes orbA{0%,to{transform:translate(0)scale(1)rotate(0)}33%{transform:translate(50px,30px)scale(1.18)rotate(120deg)}66%{transform:translate(-25px,-15px)scale(.88)rotate(240deg)}}@keyframes orbB{0%,to{transform:translate(0)scale(1)rotate(0)}33%{transform:translate(-45px,-25px)scale(1.12)rotate(-120deg)}66%{transform:translate(18px,40px)scale(.92)rotate(-240deg)}}@keyframes orbC{0%,to{transform:translate(0)scale(1)}50%{transform:translate(-35px,-45px)scale(1.22)}}@keyframes orbD{0%,to{transform:translate(0)scale(1)}25%{transform:translate(25px,-35px)scale(1.25)}75%{transform:translate(-40px,25px)scale(.82)}}@keyframes orbE{0%,to{transform:translate(0)scale(1)}50%{transform:translate(25px,18px)scale(1.35)}}.bg-kids{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.bg-kid{opacity:.08;-webkit-user-select:none;user-select:none;font-size:48px;position:absolute}.bg-kid:first-child{font-size:40px;animation-delay:0s;top:8%;left:5%}.bg-kid:nth-child(2){font-size:52px;animation-delay:1.5s;top:15%;right:8%}.bg-kid:nth-child(3){font-size:44px;animation-delay:3s;bottom:12%;left:10%}.bg-kid:nth-child(4){font-size:38px;animation-delay:4.5s;bottom:20%;right:5%}.bg-kid:nth-child(5){font-size:50px;animation-delay:2s;top:50%;left:3%}.bg-kid:nth-child(6){font-size:42px;animation-delay:5.5s;top:40%;right:3%}@keyframes kidFloat{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-15px)rotate(5deg)}75%{transform:translateY(10px)rotate(-5deg)}}.particles{pointer-events:none;z-index:0;position:fixed;inset:0}.particle{border-radius:50%;position:absolute}@keyframes particleFloat{0%{opacity:0;transform:translateY(0)translate(0)scale(1)}10%{opacity:.7}90%{opacity:.7}to{opacity:0;transform:translateY(-100vh)translate(30px)scale(0)}}::selection{background:linear-gradient(135deg, var(--grape-soft), var(--sky-soft));color:var(--ink)}.shell{z-index:1;border-radius:28px;gap:0;max-width:1100px;min-height:calc(100vh - 56px);margin:24px auto 32px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 48px -12px #0000001f,0 2px 12px -4px #0000000f}.shell,.parent-wrap,.login-card{animation:fadeSlideIn .55s var(--transition-smooth) both}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stat:active,.student-card:active,.settings-card:active,.dash-classroom-card:active{transform:scale(.98)}.nav-item.active{background:linear-gradient(135deg, var(--grape-soft), #6c5ce714);color:var(--g1);font-weight:500;position:relative}.bottom-nav a.active:after{content:"";background:var(--leaf);border-radius:50%;width:4px;height:4px;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}@keyframes pulseDot{0%,to{opacity:1;transform:translate(-50%)scale(1)}50%{opacity:.5;transform:translate(-50%)scale(1.8)}}.btn-primary{position:relative;overflow:hidden}.btn-primary:before{content:"";background:linear-gradient(90deg,#0000,#ffffff40,#0000);width:50%;height:100%;position:absolute;top:0;left:-75%;transform:skew(-25deg)}@keyframes btnShine{0%{left:-75%}50%,to{left:125%}}input:focus-visible,textarea:focus-visible,select:focus-visible,.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--sky);outline:none;box-shadow:0 0 0 3px #3fa9e026,0 0 20px -4px #3fa9e033}.landing__badge{background:var(--grape-soft);letter-spacing:.04em;color:var(--g1);-webkit-backdrop-filter:blur(8px);border:1px solid #6c5ce733;border-radius:50px;align-items:center;gap:6px;margin-bottom:16px;padding:6px 16px;font-size:12px;font-weight:500;display:inline-flex}@keyframes badgePulse{0%,to{box-shadow:0 0 #6c5ce74d}50%{box-shadow:0 0 24px 4px #e9405740}}.brand .name{background:linear-gradient(135deg, var(--g8), var(--g3), var(--g2), var(--g1));-webkit-text-fill-color:transparent;letter-spacing:-.01em;background-size:300% 300%;-webkit-background-clip:text;background-clip:text;font-weight:600}@keyframes gradientText{0%,to{background-position:0%}50%{background-position:100%}}html{scroll-behavior:smooth}.btn{touch-action:manipulation;font-family:var(--font-stack);cursor:pointer;transition:var(--transition-smooth);border:none;border-radius:14px;align-items:center;gap:8px;padding:11px 18px;font-size:14px;font-weight:500;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";opacity:0;background:linear-gradient(135deg,#fff3,#fff0);transition:opacity .3s;position:absolute;inset:0}.btn:hover:after{opacity:1}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:disabled:after{display:none}.btn-primary{background:linear-gradient(135deg, var(--g1), var(--g5), var(--g2));color:#fff;background-size:200% 200%;justify-content:center;width:100%;box-shadow:0 6px 24px -6px #6c5ce766}@keyframes btnGradientShift{0%,to{background-position:0%}50%{background-position:100%}}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 32px -6px #6c5ce780}.btn-primary:active:not(:disabled){transform:scale(.97)}.btn-ghost{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));color:var(--ink);border:1px solid var(--glass-border)}.btn-ghost:hover{border-color:var(--leaf);color:var(--leaf);box-shadow:var(--shadow-glow)}.login-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--shadow), var(--shadow-glow);text-align:center;z-index:2;border-radius:30px;width:100%;max-width:400px;padding:38px 34px;position:relative}.login-logo{background:linear-gradient(135deg, var(--leaf-soft), #c8f0d6);border-radius:24px;place-items:center;width:74px;height:74px;margin:0 auto 16px;display:grid;box-shadow:0 4px 14px #3e9e5a2e}.login-card h2{font-family:var(--font-stack);color:var(--leaf);margin-bottom:2px;font-size:27px}.login-card .school{color:var(--ink-soft);margin-bottom:24px;font-size:14px}.field{text-align:left;margin-bottom:14px}.field label{color:var(--ink-soft);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.field .inp{-webkit-backdrop-filter:blur(6px);border:1.5px solid var(--line);background:#ffffff73;border-radius:14px;align-items:center;gap:10px;padding:12px 15px;display:flex}.field .inp input{font-family:var(--font-stack);width:100%;color:var(--ink);background:0 0;border:none;outline:none;font-size:15px}.role-hint{color:var(--ink-soft);background:var(--sun-soft);text-align:left;border-radius:14px;margin-top:20px;padding:11px 14px;font-size:12.5px;line-height:1.6}.role-hint code{background:var(--line);border-radius:6px;padding:1px 6px;font-size:12px}.sidebar{background:var(--glass-bg-strong);width:220px;-webkit-backdrop-filter:blur(calc(var(--glass-blur) * 1.4));border-right:1px solid var(--glass-border);z-index:10;border-radius:0 28px 28px 0;flex-direction:column;flex-shrink:0;gap:4px;height:100vh;padding:22px 16px;display:flex;position:sticky;top:0;overflow-y:auto;box-shadow:4px 0 30px -12px #6c5ce714}.brand{align-items:center;gap:10px;padding:6px 8px 20px;display:flex}.brand .logo{background:var(--leaf-soft);border-radius:14px;flex-shrink:0;place-items:center;width:42px;height:42px;display:grid}.brand .name{font-family:var(--font-stack);color:var(--leaf);letter-spacing:-.01em;font-size:20px;font-weight:600;line-height:1.1}.brand .sub{color:var(--ink-soft);font-size:11px;font-weight:400}.nav-label{color:var(--ink-soft);letter-spacing:.02em;padding:14px 12px 4px;font-size:11px;font-weight:500}.nav-item{cursor:pointer;color:var(--ink-soft);text-align:left;width:100%;font-size:15px;font-weight:500;font-family:var(--font-stack);background:0 0;border:none;border-radius:14px;align-items:center;gap:12px;padding:11px 12px;text-decoration:none;transition:all .18s;display:flex}.nav-item svg{flex-shrink:0;width:21px;height:21px}.nav-item:hover{background:var(--cream);color:var(--ink)}.nav-item.active{background:linear-gradient(135deg, var(--grape-soft), #6c5ce714);color:var(--g1);font-weight:500;box-shadow:0 2px 12px -4px #6c5ce726}.nav-item.active:before{content:"";background:linear-gradient(180deg, var(--g1), var(--g5));border-radius:0 4px 4px 0;width:3px;height:50%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-spacer{flex:1}.nav-user{background:var(--cream);color:var(--ink);border-radius:14px;align-items:center;gap:10px;padding:10px;display:flex}.avatar{color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:15px;font-weight:600;display:grid}.main{background:0 0;flex:1;min-width:0;padding:24px 28px 48px}.topbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:26px;display:flex}.greeting h1{font-size:27px;line-height:1.25}.greeting p{color:var(--ink-soft);font-size:15px}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(calc(var(--glass-blur) * 1.2));border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);padding:22px}.card:hover{box-shadow:var(--shadow), var(--shadow-glow);transform:translateY(-2px)}.stat{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);padding:20px;position:relative;overflow:hidden}.stat:hover{box-shadow:var(--shadow), var(--shadow-glow);transform:translateY(-2px)}.stat .ic{border-radius:14px;place-items:center;width:46px;height:46px;margin-bottom:12px;display:grid}.stat .num{font-family:var(--font-stack);font-size:30px;font-weight:700;line-height:1}.stat .lbl{color:var(--ink-soft);margin-top:4px;font-size:14px}.bottom-nav{bottom:max(16px, env(safe-area-inset-bottom,16px));background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);z-index:50;border-radius:22px;padding:6px 4px;display:none;position:fixed;left:12px;right:12px;box-shadow:0 8px 32px -4px #0000002e,0 2px 8px -2px #0000001a}.bottom-nav a{color:var(--ink-soft);border-radius:16px;flex-direction:column;flex:1;align-items:center;gap:2px;padding:6px 2px;font-size:10px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.bottom-nav a:hover{background:var(--leaf-soft);color:var(--leaf)}.bottom-nav a.active{color:var(--leaf);background:var(--leaf-soft)}.bottom-nav a svg{width:22px;height:22px}@media (max-width:860px){.shell{max-width:100%;box-shadow:none;border-radius:0;min-height:100vh;margin:0}.sidebar{display:none}.main{padding:0 16px 100px}.bottom-nav{display:flex}.greeting h1{font-size:22px}.topbar{z-index:40;background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);align-items:center;margin:0 -16px 20px;padding:14px 16px 12px;position:sticky;top:0}}.toast{background:var(--ink);color:#fff;z-index:100;border-radius:999px;padding:10px 20px;font-size:14px;font-weight:500;animation:.3s fadeInUp;position:fixed;bottom:90px;left:50%;transform:translate(-50%)}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.att-topbar{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);border-radius:18px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;padding:14px 18px;display:flex}.att-summary{flex-wrap:wrap;flex:1;gap:8px;display:flex}.att-sum-chip{border-radius:999px;align-items:center;gap:6px;padding:6px 14px;font-size:14px;font-weight:500;display:flex}.att-sum-num{font-family:var(--font-stack);font-size:18px}.att-list{flex-direction:column;gap:8px;display:flex}.att-row{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);border-radius:16px;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;display:flex}.att-row:hover{box-shadow:var(--shadow), var(--shadow-glow);transform:translateY(-1px)}.att-num{text-align:right;width:24px;color:var(--ink-soft);flex-shrink:0;font-size:13px}.att-avatar{width:40px;height:40px;font-family:var(--font-stack);border-radius:12px;flex-shrink:0;place-items:center;font-size:18px;font-weight:600;display:grid}.att-name{flex:1;min-width:130px}.att-fullname{font-size:15px;font-weight:500}.att-nick{color:var(--ink-soft);margin-left:4px;font-size:13px}.att-btns{flex-shrink:0;gap:10px;display:flex}.att-btn{border:1.5px solid var(--line);background:var(--cream);font-family:var(--font-stack);color:var(--ink-soft);cursor:pointer;text-align:center;border-radius:10px;min-width:58px;padding:9px 20px;font-size:14px;font-weight:500;transition:all .15s}.att-btn:hover{border-color:var(--leaf);color:var(--leaf)}.att-btn.active{font-weight:600}.att-note{background:var(--cream);border:1.5px solid var(--line);width:120px;font-family:var(--font-stack);color:var(--ink);border-radius:10px;outline:none;flex-shrink:0;padding:7px 11px;font-size:13px}.att-note:focus{border-color:var(--leaf)}@media (max-width:700px){.att-row{gap:8px;padding:10px 12px}.att-note{order:5;width:100%}.att-btns{order:4;gap:8px;width:100%}.att-btn{flex:1;padding:10px 6px;font-size:15px}}.cal-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.cal-dow{text-align:center;color:var(--ink-soft);padding:6px 0;font-size:12px;font-weight:500}.cal-dow.weekend{color:var(--coral)}.cal-day{border:1.5px solid var(--line);cursor:pointer;min-height:56px;font-family:var(--font-stack);background:#fff;border-radius:10px;flex-direction:column;justify-content:flex-start;align-items:center;gap:2px;padding:6px 4px;transition:all .15s;display:flex;position:relative}.cal-day:hover:not(:disabled){border-color:var(--leaf);background:var(--leaf-soft)}.cal-day.weekend{background:var(--cream);color:var(--ink-soft);cursor:default}.cal-day.holiday{background:var(--coral-soft);border-color:var(--coral)}.cal-day:disabled{cursor:default}.cal-day-num{font-size:15px;font-weight:500}.cal-holiday-dot{background:var(--coral);border-radius:50%;width:6px;height:6px}.cal-holiday-label{color:var(--coral);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:9px;font-weight:500;line-height:1.2;overflow:hidden}@media (max-width:500px){.cal-day{min-height:44px;padding:4px 2px}.cal-day-num{font-size:13px}.cal-holiday-label{display:none}}.qa-summary-chip{background:var(--leaf-soft);text-align:center;border-radius:16px;flex-direction:column;align-items:center;min-width:80px;padding:10px 20px;display:flex}.qa-indicator-list{flex-direction:column;gap:0;display:flex}.qa-row{border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 0;display:flex}.qa-row:last-child{border-bottom:none}.qa-code{background:var(--cream);width:32px;height:32px;color:var(--ink-soft);border-radius:8px;flex-shrink:0;place-items:center;font-size:13px;font-weight:500;display:grid}.qa-ind-name{flex:1;min-width:180px;font-size:14px;font-weight:500}.qa-score-btns{gap:6px;display:flex}.qa-score-btn{border:1.5px solid var(--line);background:var(--cream);width:36px;height:36px;font-family:var(--font-stack);color:var(--ink-soft);cursor:pointer;border-radius:10px;place-items:center;font-size:16px;font-weight:500;transition:all .15s;display:grid}.qa-score-btn:hover{border-color:var(--leaf);color:var(--leaf)}.qa-score-btn.active{font-weight:600}.qa-score-label{white-space:nowrap;font-size:13px;font-weight:500}.qa-inputs{flex-wrap:wrap;gap:6px;width:100%;padding-left:42px;display:flex}.qa-input{background:var(--cream);border:1.5px solid var(--line);min-width:120px;font-family:var(--font-stack);color:var(--ink);border-radius:10px;outline:none;flex:1;padding:7px 11px;font-size:13px}.qa-input:focus{border-color:var(--sky)}.print-page{border-radius:var(--radius);max-width:800px;box-shadow:var(--shadow-sm);background:#fff;margin:0 auto 32px;padding:20px}.print-page-break{page-break-after:always}.booklet-header{text-align:center;border-bottom:2px solid #222;margin-bottom:16px;padding-bottom:10px}.booklet-school{color:#333;font-size:14px}.booklet-title{font-family:var(--font-stack);letter-spacing:-.01em;margin:4px 0;font-size:22px;font-weight:600}.booklet-subtitle{color:#555;font-size:13px}.booklet-student-row{align-items:flex-start;gap:16px;margin-bottom:14px;display:flex}.booklet-avatar-box{flex-shrink:0}.booklet-avatar{background:var(--leaf-soft);width:60px;height:60px;font-family:var(--font-stack);color:var(--leaf);border:2px solid var(--leaf);border-radius:12px;place-items:center;font-size:28px;font-weight:700;display:grid}.booklet-info-grid{flex:1;grid-template-columns:1fr 1fr;gap:4px 16px;font-size:13px;display:grid}.booklet-label{color:#444;margin-right:4px;font-weight:500}.booklet-section-title{font-family:var(--font-stack);color:#222;border-left:4px solid var(--leaf);background:#f5f5f5;margin:12px 0 8px;padding:5px 10px;font-size:15px;font-weight:500}.booklet-att-row{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.booklet-att-chip{border-radius:10px;flex-direction:column;align-items:center;min-width:60px;padding:8px 14px;font-size:12px;font-weight:500;display:flex}.booklet-chip-num{font-size:20px;font-weight:600;line-height:1}.booklet-health-row{flex-wrap:wrap;gap:20px;margin-bottom:8px;font-size:13px;display:flex}.booklet-table{border-collapse:collapse;width:100%;font-size:12px}.booklet-table th{text-align:left;background:#f0f0f0;border:1px solid #ccc;padding:6px 8px;font-weight:500}.booklet-table td{vertical-align:top;border:1px solid #ddd;padding:5px 8px}.booklet-domain-row td{color:#1a7a3a;background:#eaf6ee;font-size:12px;font-weight:500}.booklet-sig-row{justify-content:space-around;gap:24px;margin-top:24px;display:flex}.booklet-sig-box{text-align:center;flex:1}.booklet-sig-line{border-bottom:1.5px solid #333;height:40px;margin-bottom:6px}.booklet-sig-label{color:#444;font-size:12px}.roster-table th,.roster-table td{white-space:nowrap}.roster-table td{font-size:13px}@media print{.no-print,.sidebar,.bottom-nav,.shell>.blob{display:none!important}.main{padding:0!important}.shell{display:block!important}body{font-size:12pt;background:#fff!important}.print-page{page-break-after:always;box-shadow:none!important;border-radius:0!important;max-width:none!important;margin:0!important;padding:12mm 14mm!important}.print-page:last-child{page-break-after:auto}.print-page-break{page-break-after:always}@page{size:A4;margin:10mm}body:has(#print-card) .modal-overlay>.modal>:not(#print-card){display:none!important}}.form-field{margin-bottom:14px}.form-field label{color:var(--ink-soft);margin-bottom:5px;font-size:13px;font-weight:500;display:block}.form-input,.form-select,.form-textarea{border:1.5px solid var(--line);width:100%;font-family:var(--font-stack);color:var(--ink);appearance:auto;background:#ffffff73;border-radius:12px;outline:none;padding:11px 14px;font-size:15px;transition:border-color .18s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--leaf)}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-grid{grid-template-columns:1fr 1fr;gap:0 16px;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:0 16px;display:grid}.form-section-title{font-family:var(--font-stack);color:var(--leaf);border-bottom:1.5px solid var(--line);margin:20px 0 12px;padding-bottom:6px;font-size:16px;font-weight:600}.form-section-title:first-child{margin-top:0}.form-check{background:var(--cream);border:1.5px solid var(--line);cursor:pointer;border-radius:12px;align-items:center;gap:10px;padding:12px 14px;font-size:15px;font-weight:500;display:flex}.form-check input[type=checkbox]{width:18px;height:18px;accent-color:var(--leaf);cursor:pointer}.form-hint{color:var(--ink-soft);margin-top:4px;font-size:12px}.form-required{color:var(--coral);margin-left:2px}.tabs{background:var(--line);border-radius:14px;gap:4px;width:fit-content;padding:4px;display:flex}.tab{font-family:var(--font-stack);color:var(--ink-soft);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:10px;padding:8px 18px;font-size:14px;font-weight:500;transition:all .18s}.tab.active{color:var(--leaf);background:#fff;box-shadow:0 2px 8px -4px #00000026}.badge{white-space:nowrap;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-block}.badge-active{background:var(--leaf-soft);color:var(--leaf)}.badge-graduated{background:var(--sky-soft);color:var(--sky)}.badge-transferred{background:var(--line);color:var(--ink-soft)}.badge-admin{background:var(--grape-soft);color:var(--grape)}.badge-teacher{background:var(--sun-soft);color:#9a6c00}.badge-true{background:var(--leaf-soft);color:var(--leaf)}.badge-false{background:var(--line);color:var(--ink-soft)}.student-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;display:grid}.student-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);color:var(--ink);transition:var(--transition-smooth);cursor:pointer;border-radius:18px;align-items:center;gap:14px;padding:14px 16px;text-decoration:none;display:flex}.student-card:hover{box-shadow:var(--shadow), var(--shadow-glow);transform:translateY(-2px)}.student-avatar{width:44px;height:44px;font-family:var(--font-stack);color:var(--ink);border-radius:14px;flex-shrink:0;place-items:center;font-size:20px;font-weight:600;display:grid}.student-info{flex:1;min-width:0}.student-name{white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.student-nick{color:var(--ink-soft);margin-left:4px;font-size:13px;font-weight:400}.student-meta{color:var(--ink-soft);gap:6px;font-size:13px;display:flex}.search-row{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.search-wrap{border:1.5px solid var(--line);background:#fff;border-radius:14px;flex:1;align-items:center;gap:10px;min-width:200px;padding:10px 14px;display:flex}.search-wrap input{font-family:var(--font-stack);color:var(--ink);background:0 0;border:none;outline:none;width:100%;font-size:15px}.search-select{border:1.5px solid var(--line);font-family:var(--font-stack);color:var(--ink);cursor:pointer;background:#fff;border-radius:14px;outline:none;padding:10px 14px;font-size:14px}.search-select:focus{border-color:var(--leaf)}.tbl-wrap{box-shadow:var(--shadow-sm);border-radius:18px;overflow-x:auto}.tbl{border-collapse:collapse;background:#fff;border-radius:18px;width:100%;overflow:hidden}.tbl th{background:var(--cream);text-align:left;color:var(--ink-soft);white-space:nowrap;padding:12px 16px;font-size:13px;font-weight:500}.tbl td{border-top:1px solid var(--line);vertical-align:middle;padding:13px 16px;font-size:14px}.tbl tr:hover td{background:var(--cream)}.icon-btn{border:1.5px solid var(--line);cursor:pointer;width:34px;height:34px;color:var(--ink-soft);background:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:all .18s;display:inline-flex}.icon-btn:hover{border-color:var(--leaf);color:var(--leaf)}.icon-btn.danger:hover{border-color:var(--coral);color:var(--coral)}.btn-danger{background:var(--coral-soft);color:var(--coral);border:none}.btn-danger:hover:not(:disabled){background:var(--coral);color:#fff}.btn-sm{border-radius:10px;padding:7px 14px;font-size:13px}.info-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.info-label{color:var(--ink-soft);margin-bottom:2px;font-size:12px;font-weight:500}.info-value{color:var(--ink);font-size:15px}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.section-head h2{font-family:var(--font-stack);font-size:20px}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-top:8px;display:grid}.settings-card{border-radius:var(--radius);box-shadow:var(--shadow-sm);color:var(--ink);background:#fff;padding:24px;text-decoration:none;transition:all .18s;display:block}.settings-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.settings-card-icon{border-radius:14px;place-items:center;width:48px;height:48px;margin-bottom:14px;display:grid}.settings-card h3{font-family:var(--font-stack);margin-bottom:4px;font-size:17px}.settings-card p{color:var(--ink-soft);font-size:13px;line-height:1.5}.modal-overlay{z-index:200;background:#00000059;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--glass-bg-strong);-webkit-backdrop-filter:blur(calc(var(--glass-blur) * 1.2));border:1px solid var(--glass-border);border-radius:var(--radius);width:100%;max-width:460px;box-shadow:var(--shadow-lg), var(--shadow-glow);max-height:90vh;padding:28px;overflow-y:auto}.modal-title{font-family:var(--font-stack);margin-bottom:20px;font-size:20px}@media (max-width:860px){.form-grid{grid-template-columns:1fr}.form-grid-3{grid-template-columns:1fr 1fr}.info-grid{grid-template-columns:1fr}.tabs{width:100%;overflow-x:auto}}@media (max-width:500px){.form-grid-3,.student-grid{grid-template-columns:1fr}.student-card{border-radius:14px;gap:10px;padding:12px 14px}.student-avatar{border-radius:10px;width:38px;height:38px;font-size:17px}.student-name{text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:14px;overflow:hidden}.student-nick{font-size:12px}.student-meta{flex-wrap:wrap;font-size:12px}}.assess-tabs{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.assess-tab{border:1.5px solid var(--line);font-family:var(--font-stack);color:var(--ink-soft);cursor:pointer;white-space:nowrap;background:#fff;border-radius:12px;align-items:center;gap:6px;padding:9px 16px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.assess-tab:hover{border-color:var(--leaf);color:var(--leaf)}.assess-tab.active{background:#fff;box-shadow:0 2px 8px -4px #0000002e}.assess-tab-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.assess-tab-count{background:var(--cream);border-radius:999px;padding:1px 6px;font-size:12px;font-weight:500}.assess-indicator-list{flex-direction:column;gap:0;display:flex}.assess-indicator-row{border-bottom:1px solid var(--line);align-items:flex-start;gap:14px;padding:14px 0;display:flex}.assess-indicator-row:last-child{border-bottom:none}.assess-ind-num{background:var(--cream);width:28px;height:28px;color:var(--ink-soft);border-radius:8px;flex-shrink:0;place-items:center;margin-top:2px;font-size:13px;font-weight:500;display:grid}.assess-ind-content{flex:1;min-width:0}.assess-ind-text{margin-bottom:6px;font-size:15px;font-weight:500;line-height:1.5}.assess-ind-age{color:var(--ink-soft);background:var(--cream);border-radius:6px;margin-bottom:8px;padding:2px 8px;font-size:11px;display:inline-block}.assess-level-btns{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.assess-level-btn{border:1.5px solid var(--line);background:var(--cream);font-family:var(--font-stack);color:var(--ink-soft);cursor:pointer;white-space:nowrap;border-radius:10px;padding:7px 14px;font-size:13px;font-weight:500;transition:all .15s}.assess-level-btn:hover{border-color:var(--leaf);color:var(--leaf)}.assess-level-btn.active{font-weight:600}.assess-note-input{background:var(--cream);border:1.5px solid var(--line);min-width:120px;max-width:200px;font-family:var(--font-stack);color:var(--ink);border-radius:10px;outline:none;flex:1;padding:7px 11px;font-size:13px}.assess-note-input:focus{border-color:var(--sky)}.assess-class-list{flex-direction:column;gap:0;display:flex}.assess-class-row{border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:12px;padding:10px 0;display:flex}.assess-class-row:last-child{border-bottom:none}.assess-class-name{min-width:110px;font-size:15px;font-weight:500}.domain-tab-btn{border:1.5px solid var(--line);border-left:4px solid var(--line);width:100%;font-family:var(--font-stack);color:var(--ink-soft);cursor:pointer;text-align:left;background:#fff;border-radius:12px;align-items:center;gap:8px;margin-bottom:8px;padding:10px 14px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.domain-tab-btn:hover,.domain-tab-btn.active{background:var(--cream)}.health-form-row{border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:flex-end;gap:12px;padding-bottom:16px;display:flex}.health-field{flex-direction:column;gap:4px;display:flex}.field-label{color:var(--ink-soft);font-size:12px;font-weight:500}.health-table{border-collapse:collapse;width:100%;font-size:14px}.health-table th{text-align:left;color:var(--ink-soft);border-bottom:2px solid var(--line);white-space:nowrap;padding:8px 12px;font-size:12px;font-weight:500}.health-table td{border-bottom:1px solid var(--line);vertical-align:middle;padding:10px 12px}.health-table tr:last-child td{border-bottom:none}.btn-icon{border:1.5px solid var(--line);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;transition:all .15s;display:inline-flex}.btn-icon:hover{background:var(--cream);border-color:currentColor}.form-group{margin-bottom:12px}.form-label{color:var(--ink-soft);margin-bottom:4px;font-size:13px;font-weight:500;display:block}@media (max-width:700px){.assess-class-row{gap:8px}.assess-level-btns{gap:5px}.assess-level-btn{padding:6px 10px;font-size:12px}.health-form-row{gap:8px}}.accent-ring{background:linear-gradient(90deg, transparent, var(--g1), var(--g2), var(--g3), var(--g8), transparent);z-index:2;opacity:.25;pointer-events:none;border-radius:10px;width:20vw;max-width:140px;height:3px;position:fixed;bottom:3%;left:50%;transform:translate(-50%)}@keyframes ringShimmer{0%,to{opacity:.2}50%{opacity:.5}}.dash-stats{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-bg{opacity:.45;border-radius:50%;width:70px;height:70px;position:absolute;bottom:-14px;right:-14px}.dash-charts{flex-wrap:wrap;gap:16px;margin-bottom:24px;display:flex}.dash-classroom-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;display:grid}.dash-classroom-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(calc(var(--glass-blur) * .8));border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);padding:18px}.dash-classroom-card:hover{box-shadow:var(--shadow), var(--shadow-glow);transform:translateY(-3px)}.dash-classroom-name{font-family:var(--font-stack);margin-bottom:2px;font-size:18px;font-weight:600}.dash-classroom-teacher{color:var(--ink-soft);font-size:13px}@media (max-width:860px){.dash-stats{grid-template-columns:repeat(2,1fr)}.dash-charts{flex-direction:column}}@media (max-width:500px){.dash-stats{grid-template-columns:repeat(2,1fr);gap:10px}}.parent-wrap{z-index:1;max-width:760px;margin:0 auto;padding:28px 18px 80px;position:relative}.ptop{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:8px 0 20px;display:flex}.ptop .hi{font-family:var(--font-stack);font-size:24px}.ptop .hi span{color:var(--leaf)}.child-switch{box-shadow:var(--shadow-sm);background:#fff;border-radius:999px;flex-wrap:wrap;gap:6px;padding:5px;display:flex}.child-switch-btn{font-family:var(--font-stack);cursor:pointer;color:var(--ink-soft);white-space:nowrap;background:0 0;border:none;border-radius:999px;align-items:center;gap:7px;padding:7px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .18s;display:flex}.child-switch-btn.active{background:var(--sky-soft);color:var(--sky)}.child-mini-av{color:#fff;width:24px;height:24px;font-size:11px;font-weight:500;font-family:var(--font-stack);border-radius:50%;flex-shrink:0;place-items:center;display:grid}.hero-child{background:linear-gradient(135deg, #fff, var(--leaf-soft));box-shadow:var(--shadow-sm);border-radius:28px;flex-wrap:wrap;align-items:center;gap:22px;margin-bottom:20px;padding:26px;display:flex}.hero-bigav{color:#fff;width:88px;height:88px;font-family:var(--font-stack);box-shadow:var(--shadow-sm);border-radius:26px;flex-shrink:0;place-items:center;font-size:40px;font-weight:700;display:grid}.hero-child .ci .nm{font-family:var(--font-stack);letter-spacing:-.01em;font-size:24px;font-weight:600}.hero-child .ci .de{color:var(--ink-soft);font-size:14px}.plant-wrap{text-align:center;margin-left:auto}.plant-cap{color:var(--ink-soft);margin-top:4px;font-size:12px}.pcards{grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:20px;display:grid}.pcard{box-shadow:var(--shadow-sm);background:#fff;border-radius:22px;padding:18px}.pcard .ph{align-items:center;gap:11px;margin-bottom:12px;display:flex}.pcard .pic{border-radius:13px;flex-shrink:0;place-items:center;width:40px;height:40px;font-size:20px;display:grid}.pcard .pt{font-family:var(--font-stack);font-size:16px;font-weight:600;line-height:1.2}.pcard .badge-p{border-radius:999px;margin-top:8px;padding:3px 11px;font-size:12.5px;font-weight:500;display:inline-block}.p-stars{color:var(--sun);letter-spacing:2px;font-size:18px}.p-info-line{border-bottom:1px dashed var(--line);justify-content:space-between;padding:6px 0;font-size:14px;display:flex}.p-info-line:last-child{border:none}.p-info-line b{font-weight:600}.parent-footer{text-align:center;color:var(--ink-soft);margin-top:24px;font-size:12.5px;line-height:1.7}.parent-logout{font-family:var(--font-stack);color:var(--ink-soft);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .18s;display:flex}.parent-logout:hover{color:var(--coral)}.parent-topbar{border-bottom:1px solid var(--line);z-index:10;background:#fff;justify-content:space-between;align-items:center;padding:14px 18px;display:flex;position:sticky;top:0}.parent-brand{font-family:var(--font-stack);color:var(--leaf);letter-spacing:-.01em;align-items:center;gap:8px;font-size:20px;font-weight:600;display:flex}.section-title{font-family:var(--font-stack);margin:4px 0 14px;font-size:18px}.theme-float{top:max(16px, env(safe-area-inset-top,16px));right:max(16px, env(safe-area-inset-right,16px));z-index:1000;position:fixed}@media (min-width:769px){.theme-float{top:20px;right:24px}}@keyframes theme-float-in{0%{opacity:0;transform:translateY(-8px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.theme-float{animation:.4s ease-out theme-float-in}@media (max-width:600px){.pcards{grid-template-columns:1fr}.hero-child{gap:14px;padding:18px}.hero-bigav{width:68px;height:68px;font-size:30px}.plant-wrap{display:none}.parent-wrap{padding:20px 14px 80px}}@media (max-width:768px){.bg-kid{animation:none!important}.particle{animation-duration:20s!important}.bg-orb{animation-duration:40s!important}body{background-size:100% 100%;background-attachment:scroll;animation:none}.btn-primary,.brand .name{animation:none}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@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}
