/*! tailwindcss v4.3.1 | MIT License | https://tailwindcss.com */
@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-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,utilities;@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/quicksand-vietnamese-400-normal-CYVZRxRj.woff2)format("woff2"),url(/assets/quicksand-vietnamese-400-normal-D4WCpyCa.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/quicksand-latin-ext-400-normal-BdPaGDPN.woff2)format("woff2"),url(/assets/quicksand-latin-ext-400-normal-BzqwlOho.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/quicksand-latin-400-normal-BSDtH9U0.woff2)format("woff2"),url(/assets/quicksand-latin-400-normal-BqXBKzPR.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/quicksand-vietnamese-500-normal-CMA0PiFa.woff2)format("woff2"),url(/assets/quicksand-vietnamese-500-normal-DdPH4leT.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/quicksand-latin-ext-500-normal-Rkq3IeWS.woff2)format("woff2"),url(/assets/quicksand-latin-ext-500-normal-BlYHgpcu.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/quicksand-latin-500-normal-_DbwbYKP.woff2)format("woff2"),url(/assets/quicksand-latin-500-normal-7J1fbcAD.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/quicksand-vietnamese-600-normal-dD2kotB2.woff2)format("woff2"),url(/assets/quicksand-vietnamese-600-normal-JmvBH-hY.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/quicksand-latin-ext-600-normal-fxOF3zcr.woff2)format("woff2"),url(/assets/quicksand-latin-ext-600-normal-BDPVAPCS.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/quicksand-latin-600-normal-DTBPeRoM.woff2)format("woff2"),url(/assets/quicksand-latin-600-normal-CkxN0sDw.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/quicksand-vietnamese-700-normal-5oDqeHTF.woff2)format("woff2"),url(/assets/quicksand-vietnamese-700-normal-BsIWXrxI.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/quicksand-latin-ext-700-normal-8b1JBoEj.woff2)format("woff2"),url(/assets/quicksand-latin-ext-700-normal-DbLsDSEV.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Quicksand;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/quicksand-latin-700-normal-Dpk7G9Y6.woff2)format("woff2"),url(/assets/quicksand-latin-700-normal-HjJN-aaT.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}*{box-sizing:border-box}.brand-product{color:#4d6f8f}.superadmin-panel{min-height:0;padding:12px 2px 24px;overflow-y:auto}.superadmin-hero{background:var(--theme-soft-gradient);border-radius:28px;justify-content:space-between;align-items:center;gap:18px;margin:0 0 16px;padding:26px;display:flex;box-shadow:0 14px 34px #4f80a81f}.superadmin-hero span{color:var(--blue-deep);text-transform:uppercase;font-size:12px;font-weight:900}.superadmin-hero h1{margin:8px 0;font-size:clamp(34px,4vw,58px);line-height:1}.superadmin-hero p{color:#586879;max-width:620px;margin:0;font-weight:700}.superadmin-table{margin-top:12px}.code-pill{background:var(--blue-soft);color:var(--blue-deep);border-radius:999px;align-items:center;min-height:32px;padding:0 12px;font-weight:900;display:inline-flex}.form-grid-two{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.form-grid-two label{gap:6px;display:grid}.form-grid-two span,.modal-subheading{color:#617080;text-transform:uppercase;font-size:12px;font-weight:900}.modal-subheading{border-top:1px solid #e8eef6;margin-top:4px;padding-top:14px}@media (width<=760px){.superadmin-hero{flex-direction:column;align-items:stretch}.form-grid-two{grid-template-columns:1fr}}:root{color:#181818;font-synthesis:none;text-rendering:optimizelegibility;--blue-soft:#d9f1ff;--blue:#74bff6;--blue-deep:#4d6f8f;--pink-soft:#ffe3ef;--pink:#f7a9c7;--pink-deep:#9b486b;--cream:#fff8fc;--surface:#fff;--app-bg:#f8fbff;--muted-bg:#f3f8fd;--theme-gradient:linear-gradient(135deg, #74bff6, #f7a9c7);--theme-soft-gradient:linear-gradient(135deg, #d6f1fff2, #ffdae9f0);background:#f8fbff;font-family:Quicksand,Inter,system-ui,sans-serif}body{background:radial-gradient(circle at 10% 8%, #ffd6e78c, transparent 26%), radial-gradient(circle at 92% 12%, #c2e8ff9e, transparent 28%), var(--app-bg);min-width:320px;min-height:100vh;margin:0}#root{min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer;border:0}button:disabled{cursor:not-allowed;opacity:.5}.app-loading{place-items:center;min-height:100vh;display:grid}.spinner{border:4px solid #fff;border-top-color:var(--blue);border-radius:999px;width:42px;height:42px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.app-frame{flex-direction:column;height:100svh;padding:10px 12px 12px;display:flex;overflow:hidden}.auth-screen{background:radial-gradient(circle at 12% 12%,#ffd6e7b8,#0000 28%),radial-gradient(circle at 86% 18%,#c2e8ffd1,#0000 30%),#f8fbff;grid-template-columns:minmax(0,1.1fr) minmax(360px,480px);align-items:stretch;gap:18px;min-height:100vh;padding:22px;display:grid}.auth-visual,.auth-card{background:#fff;border-radius:34px;box-shadow:0 18px 42px #4f80a81f}.auth-visual{background:linear-gradient(135deg,#d6f1fff2,#ffdae9f0),#fff;flex-direction:column;justify-content:space-between;min-height:650px;padding:34px;display:flex;position:relative;overflow:hidden}.auth-visual:after{content:"";background:#ffffff8c;border-radius:999px 999px 0 0;height:190px;position:absolute;bottom:-72px;left:8%;right:8%}.auth-brand{z-index:2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffc2;border-radius:999px;align-items:center;gap:12px;width:fit-content;min-height:62px;padding:9px 16px 9px 9px;display:flex;position:relative}.auth-brand-mark{background:#fff;border-radius:999px;place-items:center;width:44px;height:44px;display:grid;overflow:hidden;box-shadow:0 6px 14px #4f80a824}.auth-brand-mark img{object-fit:cover;width:100%;height:100%}.auth-brand strong,.auth-brand span{display:block}.auth-brand span{color:#617080;margin-top:2px;font-size:12px;font-weight:800}.auth-hero-copy{z-index:2;max-width:760px;position:relative}.auth-kicker,.auth-card-badge{color:#4d6f8f;text-transform:uppercase;background:#ffffffb8;border-radius:999px;align-items:center;width:fit-content;min-height:34px;padding:8px 13px;font-size:12px;font-weight:900;display:inline-flex}.auth-visual h1{letter-spacing:0;color:#272531;max-width:680px;margin:18px 0 14px;font-size:clamp(44px,6vw,84px);line-height:.96}.auth-visual p{color:#4e6073;max-width:520px;font-size:18px;font-weight:700}.auth-card{border:1px solid #b9e1facc;align-self:center;padding:34px;position:relative;overflow:hidden}.auth-card:before{content:"";background:#d9f1ff;border-radius:999px;width:180px;height:180px;position:absolute;top:-70px;right:-70px}.auth-card>*{z-index:1;position:relative}.auth-card .record-form input{background:#fbfdff;border:1px solid #e7edf5;border-radius:20px;min-height:56px}.auth-card .primary-action{background:linear-gradient(135deg,#74bff6,#f7a9c7);min-height:56px;box-shadow:0 14px 26px #74bff63d}.auth-card-note{color:#647487;margin:-2px 0 18px;font-weight:700}.auth-kid-row{z-index:2;flex-wrap:wrap;gap:12px;display:flex;position:relative}.auth-kid-row span{color:#3d5368;background:#ffffffc2;border-radius:28px;place-items:center;width:84px;height:84px;font-size:24px;font-weight:900;display:grid;transform:rotate(-5deg)}.auth-kid-row span:nth-child(2){background:#ffe1ede6;transform:rotate(4deg)}.auth-kid-row span:nth-child(3){background:#dcf4ffe6;transform:rotate(-2deg)}.auth-cloud{z-index:1;background:#ffffff94;border-radius:999px;position:absolute}.auth-cloud:before,.auth-cloud:after{content:"";background:inherit;border-radius:999px;position:absolute}.auth-cloud-one{width:160px;height:64px;top:16%;right:10%}.auth-cloud-one:before{width:78px;height:78px;bottom:18px;left:24px}.auth-cloud-one:after{width:96px;height:96px;bottom:10px;right:18px}.auth-cloud-two{opacity:.72;width:112px;height:46px;bottom:26%;left:12%}.auth-cloud-two:before{width:54px;height:54px;bottom:12px;left:16px}.auth-cloud-two:after{width:64px;height:64px;bottom:8px;right:12px}.auth-sun{z-index:1;color:#df9a15;background:#ffe99f;border-radius:999px;place-items:center;width:86px;height:86px;font-size:34px;font-weight:900;display:grid;position:absolute;bottom:30%;right:18%}.teacher-phone{background:radial-gradient(circle at 8% 8%, #ffe3efb8, transparent 28%), radial-gradient(circle at 88% 4%, #d9f1ffd1, transparent 30%), var(--app-bg);width:min(100%,1180px);height:100svh;margin:0 auto;padding:20px 18px 32px;overflow:hidden}.teacher-hero{background:var(--theme-soft-gradient);border-radius:32px;padding:28px 22px;position:relative;box-shadow:0 18px 38px #4f80a81f}.teacher-phone>.teacher-hero,.teacher-phone>.teacher-summary,.teacher-phone>.teacher-classes,.teacher-phone>.teacher-children{max-width:none}.teacher-hero p,.teacher-hero h1{margin:0}.teacher-hero p{color:#3f3f43;font-weight:800}.teacher-hero h1{letter-spacing:0;max-width:330px;margin-top:8px;font-size:40px;line-height:1}.teacher-profile-btn{background:#ffffffbf;border-radius:999px;width:46px;height:46px;font-weight:900;position:absolute;top:18px;right:18px}.teacher-summary,.teacher-classes,.teacher-children,.teacher-profile-card,.child-detail-card{background:#fff;border-radius:28px;margin-top:14px;padding:18px;box-shadow:0 8px 28px #0e0e0e09}.teacher-children{overscroll-behavior:contain;min-height:0;overflow-y:auto}.teacher-summary h2,.teacher-classes h2,.teacher-children h2,.teacher-profile-card h2,.child-detail-card h2{margin:0 0 12px;font-size:20px}.teacher-stats{grid-template-columns:repeat(3,1fr);gap:9px;display:grid}.teacher-stats span{color:#5d5d64;background:#f7f7ff;border-radius:22px;min-height:86px;padding:12px;font-size:12px;font-weight:800}.teacher-stats b{color:#171717;margin-bottom:7px;font-size:30px;line-height:1;display:block}.teacher-classes>div,.teacher-class-list{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;display:grid}.teacher-classes button,.teacher-class-list span{color:#222;background:#f7f7f7;border-radius:20px;align-items:center;gap:12px;min-height:56px;padding:0 16px;font-weight:800;display:flex}.teacher-classes button.active{background:var(--pink-soft);color:var(--pink-deep)}.teacher-classes button span{font-size:22px}.teacher-section-title{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.teacher-section-title span{color:#77777d;font-size:13px;font-weight:800}.teacher-list-tools{align-items:center;gap:10px;display:flex}.teacher-view-toggle{background:var(--muted-bg);border-radius:999px;gap:4px;min-height:40px;padding:4px;display:inline-flex}.teacher-view-toggle button{background:0 0;border-radius:999px;place-items:center;width:34px;height:32px;display:grid}.teacher-view-toggle button.active{background:var(--blue-soft);color:var(--blue-deep)}.teacher-search{background:#f6f6f6;border-radius:20px;align-items:center;gap:10px;min-height:50px;padding:0 15px;display:flex}.teacher-search input{background:0 0;border:0;outline:0;width:100%}.teacher-child-list{grid-template-columns:repeat(auto-fit,minmax(245px,1fr));gap:12px;margin-top:12px;display:grid}.teacher-child-list.list{grid-template-columns:1fr}.teacher-child-card{background:#fff7db;border-radius:26px;grid-template-columns:auto minmax(0,1fr);gap:12px;padding:14px;display:grid;box-shadow:inset 0 0 0 1px #ffffffb3}.teacher-child-list.list .teacher-child-card{grid-template-columns:auto minmax(0,1fr) auto;align-items:center}.teacher-child-list.list .teacher-check-btn{grid-column:auto;min-width:138px}.teacher-child-card:nth-child(2n){background:#e8f4ef}.teacher-child-card:nth-child(3n){background:#eee9ff}.teacher-child-main strong,.teacher-child-main span{display:block}.teacher-child-main strong{font-size:18px}.teacher-child-main span{color:#5f5f66;font-weight:700}.teacher-status{border-radius:999px;width:fit-content;margin-top:8px;padding:6px 10px;font-size:12px;font-style:normal;font-weight:900}.teacher-status.not_checked_in{color:#617080;background:#edf5fb}.teacher-status.present{color:#207a4c;background:#ddf7f1}.teacher-status.late{color:#82610b;background:#fff0bd}.teacher-status.checked_out{background:var(--blue-soft);color:var(--blue-deep)}.teacher-status.absent{background:var(--pink-soft);color:var(--pink-deep)}.teacher-check-btn{background:var(--theme-gradient);color:#fff;border-radius:18px;grid-column:1/-1;justify-content:center;align-items:center;gap:9px;min-height:50px;font-weight:900;display:flex}.edit-action,.table-action{background:var(--theme-gradient);color:#fff;border-radius:999px;min-height:38px;margin-top:14px;padding:0 14px;font-weight:800}.table-action{background:var(--theme-gradient);min-height:34px;margin-top:0}.table-action.secondary{color:#4d5d6d;background:#f8fbff}.table-actions-cell{flex-wrap:wrap;gap:8px;display:flex}.teacher-top{grid-template-columns:46px minmax(0,1fr) 46px;align-items:center;gap:8px;min-height:58px;display:grid}.teacher-top button{background:#fff;border-radius:999px;place-items:center;width:46px;height:46px;display:grid}.teacher-top strong,.teacher-profile-card,.child-detail-card{text-align:center}.teacher-photo{background:var(--theme-soft-gradient);border-radius:999px;place-items:center;width:98px;height:98px;margin:6px auto 12px;font-size:26px;font-weight:900;display:grid}.teacher-profile-card h1,.child-detail-card h1{margin:0}.teacher-profile-card p,.child-detail-card p{color:#66666d;margin:5px 0 18px;font-weight:700}.teacher-logout{background:var(--theme-gradient);color:#fff;border-radius:18px;justify-content:center;align-items:center;gap:9px;width:100%;min-height:52px;margin-top:18px;font-weight:900;display:flex}.info-line{text-align:left;border-top:1px solid #e7edf5;padding:12px 0}.info-line span,.history-list span,.history-list small{color:#77777d;font-size:12px;font-weight:800;display:block}.info-line strong{margin-top:3px;display:block}.history-list{text-align:left;gap:8px;display:grid}.history-list span,.history-list button{color:#3e3e44;text-align:left;background:#f6f6f6;border:0;border-radius:14px;padding:10px 12px}.history-list button{cursor:pointer}.history-list button strong{background:var(--blue-soft);width:fit-content;color:var(--blue-deep);border-radius:999px;margin-top:8px;padding:5px 9px;font-size:11px;display:block}.camera-screen{z-index:100;background:#050505;place-items:center;display:grid;position:fixed;inset:0}.camera-screen video{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.camera-close{z-index:2;background:#ffffffe6;border-radius:999px;width:48px;height:48px;position:absolute;top:18px;right:18px}.camera-bottom{z-index:2;text-align:center;background:linear-gradient(#0000,#000000b8);padding:22px 22px 34px;position:absolute;bottom:0;left:0;right:0}.camera-bottom p{color:#fff;font-weight:900}.camera-bottom button{color:#111;background:#fff;border-radius:999px;width:116px;height:116px;font-weight:900;box-shadow:inset 0 0 0 8px #ededed}.camera-fallback{z-index:1;color:#fff;text-align:center;max-width:280px}.camera-file-capture{color:#111;background:#fff;border-radius:999px;justify-content:center;align-items:center;min-height:48px;margin-top:14px;padding:0 18px;font-weight:900;display:inline-flex}.camera-file-capture input{display:none}.saved-flash{z-index:120;color:#207a4c;background:#fffffff5;border-radius:30px;place-items:center;gap:8px;min-width:250px;min-height:140px;padding:24px;font-size:20px;font-weight:900;animation:.9s both saved-pop;display:grid;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes saved-pop{0%{opacity:0;transform:translate(-50%,-50%)scale(.8)}20%,80%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(.96)}}.auth-card h2{margin:0;font-size:30px}.role-badge{color:#9b486b;background:#ffe3ef;border-radius:999px;min-height:34px;padding:8px 12px;font-size:12px;font-weight:800}.topbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffe6;border-radius:28px;justify-content:space-between;align-items:center;width:100%;height:58px;margin:0 auto 10px;padding:0 18px;display:flex;box-shadow:0 14px 34px #4f80a81f}.mobile-menu-button,.mobile-nav-head,.nav-backdrop{display:none}.brand,.profile-pill,.toolbar-actions,.quick-actions,.search-row,.row-actions,.section-heading{align-items:center;display:flex}.brand{gap:14px;min-width:0}.brand-logo{border-radius:14px;flex:none;width:40px;height:40px;box-shadow:0 8px 18px #4f80a829}.brand-mark{color:#111;letter-spacing:-.02em;place-items:center;width:42px;height:34px;font-size:12px;font-weight:700;display:grid}.brand-x{color:#151515;font-size:20px}.brand strong{font-size:18px}.profile-pill{gap:12px;font-weight:600}.profile-pill button,.view-buttons button,.soft-button,.quick-actions button,.nav-dot{background:var(--muted-bg);color:#111;border-radius:999px;place-items:center;width:42px;height:42px;display:inline-grid}.profile-photo{background:var(--theme-soft-gradient);border-radius:999px;place-items:center;width:36px;height:36px;font-size:12px;font-weight:700;display:grid}.app-body{background:linear-gradient(135deg,#d9f1ff94,#ffe3ef94),#f9fbff;border-radius:34px;flex:1;grid-template-columns:clamp(210px,16vw,260px) minmax(0,1fr);width:100%;min-height:0;margin:0 auto;display:grid;overflow:hidden;box-shadow:inset 0 0 0 1px #fff9,0 18px 38px #1616160d}.side-nav{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);overscroll-behavior:contain;background:#ffffffe0;border-radius:34px;flex-direction:column;gap:8px;height:calc(100svh - 92px);margin:14px 0;padding:22px 16px;display:flex;position:sticky;top:10px;overflow-y:auto;box-shadow:0 14px 34px #4f80a814}.mobile-nav-head{justify-content:space-between;align-items:center;min-height:46px;padding:0 8px 10px}.mobile-nav-head button{background:var(--muted-bg);border-radius:999px;place-items:center;width:38px;height:38px;display:grid}.side-title,.nav-item{color:#555;text-align:left;background:0 0;border-radius:24px;align-items:center;gap:12px;width:100%;min-height:48px;padding:4px 10px;font-weight:600;display:flex}.side-title{margin-bottom:8px}.side-title.active,.nav-item.active{background:var(--pink-soft);color:var(--pink-deep)}.side-title.active .nav-dot,.nav-item.active .nav-dot{background:#fff}.content-panel{overscroll-behavior:contain;min-width:0;min-height:0;padding:clamp(16px,2vw,28px);overflow-y:auto}.page-toolbar{justify-content:space-between;align-items:center;gap:16px;min-height:60px;margin-bottom:18px;display:flex}.page-toolbar h1{letter-spacing:0;margin:0;font-size:clamp(30px,3vw,44px);font-weight:600;line-height:1}.page-toolbar h1 span{color:#909096;font-weight:500}.toolbar-actions{gap:10px}.primary-action{background:var(--theme-gradient);color:#fff;border-radius:999px;justify-content:center;align-items:center;gap:10px;min-height:48px;padding:0 20px;font-weight:700;display:inline-flex;box-shadow:0 14px 26px #74bff63d}.search-row{gap:10px;margin-bottom:12px}.search-box{color:#7b7b80;background:#fff;border-radius:24px;align-items:center;gap:10px;width:min(390px,100%);height:50px;padding:0 18px;display:flex;box-shadow:0 4px 18px #00000008}.search-box input{background:0 0;border:0;outline:0;width:100%}.soft-button{gap:8px;width:auto;min-width:88px;padding:0 18px;font-weight:700;display:inline-flex}.view-buttons{gap:10px;margin-left:auto;display:flex}.view-buttons .active{background:var(--blue-soft);color:var(--blue-deep)}.kids-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;display:grid}.kid-card{text-align:center;background:#fff;border-radius:30px;flex-direction:column;align-items:center;min-height:292px;padding:40px 22px 18px;display:flex;position:relative;box-shadow:0 8px 28px #0e0e0e09}.kid-card.clickable,.directory-card.clickable,.clickable-row{cursor:pointer}.kid-card.clickable,.directory-card.clickable{transition:transform .18s,box-shadow .18s}.kid-card.clickable:hover,.directory-card.clickable:hover{transform:translateY(-2px);box-shadow:0 14px 34px #0e0e0e12}.clickable-row:hover td{background:#fafafa}.card-menu{color:#4c4c4c;background:0 0;position:absolute;top:20px;right:22px;transform:rotate(90deg)}.avatar{border-radius:999px;place-items:center;width:56px;height:56px;font-weight:800;display:grid;overflow:hidden}.avatar.large{width:104px;height:104px;font-size:24px}.avatar img{object-fit:cover;width:100%;height:100%}.kid-card h2{margin:14px 0 2px;font-size:19px;line-height:1.1}.kid-card p,.kid-card small{color:#64646b;margin:0;font-weight:500}.kid-card small{font-size:12px}.status-chip{border-radius:999px;min-height:25px;margin-top:10px;padding:5px 10px;font-size:11px;font-weight:800}.status-chip.present{color:#207a4c;background:#ddf7f1}.status-chip.checked_out{color:var(--blue-deep);background:var(--blue-soft)}.status-chip.late{color:#82610b;background:#fff0bd}.status-chip.absent{color:var(--pink-deep);background:var(--pink-soft)}.status-chip.not_checked_in{color:#617080;background:#edf5fb}.kid-detail-page{grid-template-columns:minmax(260px,.68fr) minmax(0,2.1fr);gap:12px;display:grid}.kid-profile-panel,.kid-info-panel,.kid-detail-card{background:#fff;border-radius:30px;box-shadow:0 8px 28px #0e0e0e09}.kid-profile-panel{text-align:center;align-content:center;justify-items:center;min-height:330px;padding:34px 22px;display:grid}.kid-detail-photo{position:relative}.kid-detail-photo .avatar.large{width:150px;height:150px;font-size:32px}.kid-detail-photo button{background:var(--blue-soft);width:44px;height:44px;color:var(--blue-deep);border-radius:999px;place-items:center;display:grid;position:absolute;top:8px;right:0}.kid-profile-panel h2{margin:18px 0 4px;font-size:26px;line-height:1.08}.kid-profile-panel p{color:#66666d;margin:0;font-weight:700}.kid-profile-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:24px;display:flex}.kid-profile-actions a,.kid-profile-actions button{background:var(--theme-gradient);color:#fff;border-radius:999px;align-items:center;gap:8px;min-height:48px;padding:0 20px;font-weight:900;text-decoration:none;display:inline-flex}.kid-info-panel{grid-template-columns:repeat(3,minmax(160px,1fr));align-content:center;gap:18px;min-height:330px;padding:28px;display:grid}.kid-field{gap:7px;min-width:0;display:grid}.kid-field span{font-weight:900}.kid-field strong{color:#222;overflow-wrap:anywhere;background:#f3f3f3;border-radius:999px;align-items:center;min-height:52px;padding:0 18px;font-weight:800;display:flex}.kid-detail-card{min-height:220px;padding:22px}.kid-detail-card.wide{grid-column:span 2}.kid-attendance-today{background:#f8f8f8;border-radius:22px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:14px;display:flex}.kid-attendance-today .status-chip{margin-top:0}.kid-history-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;display:grid}.kid-history-list span,.kid-history-list button{color:#55565d;text-align:left;background:#f7f7f7;border:0;border-radius:18px;padding:12px 14px;font-size:13px;font-weight:800}.kid-history-list button{cursor:pointer}.attendance-photo-pair{grid-template-columns:repeat(2,minmax(160px,1fr));gap:10px;margin:12px 0;display:grid}.attendance-photo-pair button{color:#222;text-align:left;background:#f8fbff;border-radius:22px;align-content:start;gap:8px;min-height:170px;padding:10px;font-weight:900;display:grid}.attendance-photo-pair button:disabled{cursor:default}.attendance-photo-pair img,.attendance-photo-pair button>svg{object-fit:cover;background:var(--blue-soft);border-radius:16px;width:100%;height:108px}.attendance-photo-pair button>svg{color:var(--blue-deep);padding:38px}.attendance-photo-pair span,.attendance-photo-pair small{display:block}.attendance-photo-pair small{color:#647487;font-size:12px}.attendance-detail-modal{justify-items:center;gap:10px;display:grid}.attendance-detail-modal .kid-attendance-today,.attendance-detail-modal .attendance-photo-pair{width:100%}.photo-preview-backdrop{z-index:130;background:#14181f6b;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.photo-preview-card{background:#fff;border-radius:30px;width:min(760px,100%);max-height:calc(100svh - 40px);padding:18px;overflow:auto}.photo-preview-card img{object-fit:contain;background:#111;border-radius:22px;width:100%;max-height:calc(100svh - 150px)}.directory-detail-page{grid-template-columns:minmax(260px,.72fr) minmax(0,2fr);gap:12px;display:grid}.detail-breadcrumb{flex-wrap:wrap;grid-column:1/-1;align-items:center;gap:12px;min-height:58px;display:flex}.detail-breadcrumb h2{margin:0;font-size:clamp(28px,3vw,42px);line-height:1}.detail-breadcrumb h2 span{color:#9aa2ad;font-weight:500}.detail-breadcrumb .primary-action{margin-left:auto}.detail-profile-panel{text-align:center;background:#fff;border-radius:30px;align-content:center;justify-items:center;min-height:330px;padding:34px 22px;display:grid;box-shadow:0 8px 28px #0e0e0e09}.directory-avatar.large{border-radius:999px;width:128px;height:128px;font-size:34px}.directory-avatar.large img{border-radius:inherit;object-fit:cover;width:100%;height:100%}.detail-profile-panel h2{margin:18px 0 4px;font-size:26px;line-height:1.08}.detail-profile-panel p{color:#66666d;margin:0;font-weight:700}.detail-child-grid,.detail-chip-list{gap:10px;display:grid}.detail-child-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.detail-child-grid.compact{grid-template-columns:1fr}.detail-child-card{background:#f8fbff;border-radius:22px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;min-width:0;padding:12px;display:grid}.detail-child-card strong,.detail-child-card span{display:block}.detail-child-card strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.detail-child-card span{color:#64646b;margin-top:3px;font-size:13px;font-weight:700}.detail-chip-list span{color:#4d5d6d;background:#f8fbff;border-radius:18px;padding:13px 14px;font-weight:850}.quick-actions{justify-content:center;gap:10px;margin-top:auto}.quick-actions button{background:#f7f7ff}.teacher-layout{gap:16px;display:grid}.stat-strip{grid-template-columns:repeat(4,minmax(120px,1fr));gap:12px;display:grid}.stat-card,.info-card,.class-section,.table-card,.empty-state,.modal-card{background:#fff;border-radius:30px;box-shadow:0 8px 28px #0e0e0e09}.stat-card{padding:18px}.stat-card strong{font-size:34px;display:block}.stat-card span{color:#555;font-weight:700}.stat-card.mint{background:#ddf7f1}.stat-card.peach{background:var(--pink-soft)}.stat-card.yellow{background:#fff0bd}.stat-card.lavender{background:var(--blue-soft)}.class-section{padding:18px}.section-heading{justify-content:space-between;gap:10px;margin-bottom:14px}.section-heading h2{margin:0}.section-heading span,.teacher-row span,.info-card p,.info-card small{color:#64646b;font-weight:600}.teacher-list{gap:10px;display:grid}.teacher-row{background:#f8f8f8;border-radius:24px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:14px;min-height:78px;padding:10px;display:grid}.teacher-row strong,.teacher-row span{display:block}.row-actions{gap:8px}.row-actions button{background:#fff;border-radius:999px;align-items:center;gap:8px;min-height:40px;padding:0 14px;font-weight:700;display:inline-flex}.mini-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.admin-dashboard{gap:16px;display:grid}.admin-stat-grid{grid-template-columns:repeat(4,minmax(150px,1fr));gap:12px;display:grid}.admin-quick-grid{grid-template-columns:repeat(4,minmax(170px,1fr));gap:12px;display:grid}.admin-quick-grid button,.dashboard-panel{background:#fff;border-radius:30px;box-shadow:0 8px 28px #0e0e0e09}.admin-quick-grid button{text-align:left;align-content:center;gap:8px;min-height:130px;padding:18px;display:grid}.admin-quick-grid span{font-size:18px;font-weight:900}.admin-quick-grid small{color:#66666d;font-weight:700}.admin-dashboard-columns{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;display:grid}.dashboard-panel{min-height:320px;padding:20px}.dashboard-list{gap:10px;display:grid}.dashboard-list div,.dashboard-list p{background:#f7f7f7;border-radius:18px;margin:0;padding:13px 14px}.dashboard-list strong,.dashboard-list span{display:block}.dashboard-list span{color:#66666d;margin-top:3px;font-size:13px;font-weight:700}.directory-shell{gap:12px;display:grid}.directory-filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.directory-filters .search-box{flex:280px;margin:0}.directory-select{color:#4d4d55;background:#fff;border-radius:24px;align-items:center;gap:8px;min-width:170px;min-height:50px;padding:0 14px;display:inline-flex;box-shadow:0 4px 18px #00000008}.directory-select select{color:#222;background:0 0;border:0;outline:0;min-width:0;max-width:190px;font-weight:800}.directory-toolbar{background:#fff;border-radius:24px;justify-content:flex-end;align-items:center;gap:12px;min-height:50px;padding:6px 8px 6px 16px;display:flex;box-shadow:0 8px 28px #0e0e0e09}.directory-toolbar span{color:#66666d;margin-right:auto;font-size:13px;font-weight:800}.directory-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;display:grid}.directory-card{text-align:center;background:#fff;border-radius:30px;flex-direction:column;align-items:center;gap:0;min-height:280px;padding:38px 22px 18px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 28px #0e0e0e09}.directory-avatar{border-radius:999px;flex:0 0 96px;place-items:center;width:96px;height:96px;margin-bottom:14px;font-size:24px;font-weight:900;display:grid;overflow:hidden}.directory-avatar img{border-radius:inherit;object-fit:cover;width:100%;height:100%;display:block}.directory-card h2{overflow-wrap:anywhere;-webkit-line-clamp:2;-webkit-box-orient:vertical;width:100%;min-height:44px;margin:0 0 5px;font-size:19px;line-height:1.15;display:-webkit-box;overflow:hidden}.directory-card p,.directory-card span,.directory-card small{color:#64646b;overflow-wrap:anywhere;max-width:100%;margin:0;font-weight:600}.directory-card small{overflow-wrap:anywhere;max-width:100%;margin-top:10px;font-size:12px}.directory-card .edit-action,.directory-card .quick-actions{margin-top:auto}.class-card{text-align:left;align-items:stretch;gap:8px}.class-card .status-chip{align-self:flex-start;margin-top:0}.class-card h2{margin-top:8px}.class-card .meter{margin:8px 0 2px}.class-card-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-top:auto;display:flex}.class-card-actions .soft-button,.class-card-actions .edit-action{min-height:42px;margin-top:0}.meter.wide{width:min(260px,100%)}.directory-card .card-menu{transform:none}.directory-shell .table-card{box-shadow:0 8px 28px #0e0e0e09}.pagination-bar{background:#fff;border-radius:24px;justify-content:center;align-items:center;gap:10px;min-height:52px;padding:7px;display:flex;box-shadow:0 8px 28px #0e0e0e09}.pagination-bar div{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.pagination-bar button{color:#222;background:#f7f7f7;border-radius:999px;min-width:38px;min-height:38px;padding:0 12px;font-weight:800}.pagination-bar button.active{background:var(--pink-soft);color:var(--pink-deep)}.admin-teacher-preview{gap:14px;display:grid}.admin-preview-bar{background:#fff;border-radius:26px;justify-content:space-between;align-items:center;gap:16px;min-height:82px;padding:16px 18px;display:flex;box-shadow:0 8px 28px #0e0e0e09}.admin-preview-bar strong,.admin-preview-bar span{display:block}.admin-preview-bar strong{font-size:18px}.admin-preview-bar span{color:#66666d;margin-top:3px;font-size:13px;font-weight:700}.admin-preview-bar select{background:#fafafa;border:1px solid #ededed;border-radius:18px;min-width:min(320px,100%);min-height:46px;padding:0 14px}.admin-teacher-preview .teacher-phone{border-radius:30px;width:100%;max-width:none;min-height:auto}.attendance-page{gap:14px;display:grid}.attendance-hero{background:#fff;border-radius:30px;justify-content:space-between;align-items:center;gap:16px;min-height:112px;padding:20px;display:flex;box-shadow:0 8px 28px #0e0e0e09}.attendance-hero span,.attendance-filter-bar span{color:#77767f;text-transform:uppercase;font-size:12px;font-weight:900}.attendance-hero h2{margin:4px 0;font-size:clamp(28px,4vw,46px);line-height:1}.attendance-hero p{color:#64646b;margin:0;font-weight:700}.attendance-summary-grid{grid-template-columns:repeat(6,minmax(130px,1fr));gap:10px;display:grid}.attendance-summary-grid .stat-card{min-height:104px}.attendance-summary-grid .stat-card strong{font-size:30px}.attendance-filter-bar{background:#fff;border-radius:28px;grid-template-columns:minmax(240px,1.4fr) 170px repeat(3,minmax(150px,1fr));gap:10px;padding:10px;display:grid;box-shadow:0 8px 28px #0e0e0e09}.attendance-filter-bar label{background:#f8f8f8;border-radius:20px;gap:6px;min-width:0;padding:10px 12px;display:grid}.attendance-filter-bar input,.attendance-filter-bar select{color:#222;background:0 0;border:0;outline:0;width:100%;min-height:34px;font-weight:800}.attendance-search-filter div{align-items:center;gap:8px;min-height:34px;display:flex}.attendance-class-stack,.attendance-list-mode{gap:12px;display:grid}.attendance-class-section{background:#fff;border-radius:30px;padding:18px;box-shadow:0 8px 28px #0e0e0e09}.attendance-class-header{grid-template-columns:minmax(0,1fr) minmax(160px,220px);align-items:center;gap:14px;display:grid}.attendance-class-title{align-items:center;gap:12px;min-width:0;display:flex}.attendance-class-title>span{background:var(--blue-soft);border-radius:18px;flex:none;place-items:center;width:54px;height:54px;font-size:24px;display:grid}.attendance-class-title h3{margin:0;font-size:24px;line-height:1.1}.attendance-class-title p{color:#64646b;margin:4px 0 0;font-weight:700}.attendance-progress{justify-items:end;gap:8px;display:grid}.attendance-progress strong{font-size:22px}.attendance-progress span{background:#f1f1f8;border-radius:999px;width:100%;height:10px;overflow:hidden}.attendance-progress i{border-radius:inherit;background:#7b68ee;height:100%;display:block}.attendance-counts{flex-wrap:wrap;gap:8px;margin:16px 0;display:flex}.attendance-counts span{border-radius:999px;min-height:30px;padding:7px 11px;font-size:12px;font-weight:900}.attendance-counts .present{color:#207a4c;background:#def5e8}.attendance-counts .late{color:#82610b;background:#fff0bd}.attendance-counts .checked_out{color:#245f9f;background:#dfeeff}.attendance-counts .absent{color:#a13232;background:#ffe1df}.attendance-counts .not_checked_in{color:#77767f;background:#f1f1f8}.attendance-kid-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:10px;display:grid}.attendance-kid-card{background:#fafafa;border-radius:24px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;min-width:0;min-height:112px;padding:12px;display:grid}.attendance-kid-main{min-width:0}.attendance-kid-main strong,.attendance-kid-main span{display:block}.attendance-kid-main strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.attendance-kid-main span{color:#64646b;overflow-wrap:anywhere;margin-top:3px;font-size:13px;font-weight:700}.attendance-kid-card .status-chip{white-space:nowrap;justify-self:end;margin-top:0}.attendance-times{flex-wrap:wrap;grid-column:2/-1;gap:8px;display:flex}.attendance-times span{color:#64646b;background:#fff;border-radius:999px;align-items:center;gap:5px;min-height:30px;padding:6px 9px;font-size:12px;font-weight:800;display:inline-flex}.info-card{padding:22px}.info-card.wide{max-width:720px}.meter{background:#e7edf5;border-radius:999px;height:10px;margin:18px 0 8px;overflow:hidden}.meter span{border-radius:inherit;background:var(--theme-gradient);height:100%;display:block}.table-card{overflow:auto}table{border-collapse:collapse;width:100%;min-width:720px}th,td{text-align:left;border-bottom:1px solid #e7edf5;padding:15px 18px}th{color:#77777d;text-transform:uppercase;font-size:12px}.empty-state{text-align:center;grid-column:1/-1;padding:44px}.empty-state h2{margin:0 0 8px}.empty-state p{color:#77777d;margin:0}.modal-backdrop{z-index:50;background:#1414143d;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal-card{width:min(560px,100%);padding:22px}.record-form{gap:10px;display:grid}.record-form input,.record-form select,.record-form textarea{background:#fafafa;border:1px solid #ededed;border-radius:18px;outline:0;width:100%;min-height:46px;padding:0 14px}.record-form textarea{min-height:90px;padding-top:12px}.photo-upload-field{gap:8px;display:grid}.photo-upload-field>span{color:#647487;text-transform:uppercase;font-size:12px;font-weight:900}.photo-upload-field div{background:#fbfdff;border:1px dashed #b9e1fa;border-radius:22px;align-items:center;gap:14px;min-height:92px;padding:12px;display:flex}.photo-upload-field img,.photo-upload-field div>svg{object-fit:cover;background:var(--blue-soft);border-radius:999px;width:68px;height:68px;padding:0}.photo-upload-field div>svg{color:var(--blue-deep);padding:18px}.photo-upload-field strong{font-weight:900}.photo-upload-field input{background:0 0;border:0;min-height:auto;padding:0}@media (width<=1100px){.kids-grid,.mini-grid,.admin-stat-grid,.admin-quick-grid,.attendance-summary-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}.admin-dashboard-columns,.kid-detail-page,.directory-detail-page{grid-template-columns:1fr}.kid-info-panel{grid-template-columns:repeat(2,minmax(160px,1fr))}.kid-detail-card.wide{grid-column:span 1}.detail-breadcrumb .primary-action{margin-left:0}.attendance-filter-bar{grid-template-columns:repeat(2,minmax(180px,1fr))}}@media (width>=900px) and (orientation:landscape){.teacher-phone{grid-template-rows:auto auto minmax(0,1fr);grid-template-columns:minmax(280px,.78fr) minmax(0,1.42fr);align-content:start;gap:16px;display:grid}.teacher-hero,.teacher-summary,.teacher-classes{grid-column:1}.teacher-children{grid-area:1/2/span 3;height:calc(100svh - 40px);min-height:0;margin-top:0}.teacher-top,.teacher-profile-card,.child-detail-card{grid-column:1/-1;justify-self:center;width:100%;max-width:760px}}@media (width>=781px) and (orientation:portrait){.teacher-phone{overscroll-behavior:contain;max-width:820px;padding:22px;overflow-y:auto}.teacher-hero{min-height:170px}.teacher-hero h1{max-width:560px;font-size:48px}.teacher-summary,.teacher-classes,.teacher-children{padding:22px}.teacher-child-list.grid{grid-template-columns:repeat(2,minmax(0,1fr))}.teacher-top,.teacher-profile-card,.child-detail-card{width:100%;max-width:760px;margin-left:auto;margin-right:auto}}@media (width<=780px){.auth-screen{grid-template-columns:1fr;padding:10px}.auth-visual{min-height:430px;padding:22px}.auth-visual h1{font-size:42px}.auth-card{padding:24px}.auth-kid-row span{border-radius:22px;width:62px;height:62px;font-size:18px}.auth-cloud-one{top:90px;right:-20px}.auth-sun{width:64px;height:64px;font-size:26px;bottom:90px;right:22px}.app-frame{padding:8px}.topbar{z-index:60;border-radius:28px;justify-content:flex-start;gap:10px;height:64px;margin-bottom:8px}.mobile-menu-button{background:#f7f7ff;border-radius:999px;flex:none;place-items:center;width:42px;height:42px;display:grid}.profile-pill{margin-left:auto}.profile-pill span:not(.profile-photo),.brand-x{display:none}.app-body{border-radius:0;grid-template-columns:1fr;min-height:0}.side-nav{z-index:80;border-radius:0 28px 28px 0;grid-template-columns:none;width:min(82vw,320px);height:100svh;margin:0;padding:18px 14px;transition:transform .22s;display:flex;position:fixed;top:0;left:0;transform:translate(-106%);box-shadow:18px 0 38px #1616161f}.side-nav.open{transform:translate(0)}.mobile-nav-head{display:flex}.nav-backdrop{z-index:70;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#14181f47;position:fixed;inset:0}.nav-backdrop.show{display:block}.side-title,.nav-item{flex-direction:row;justify-content:flex-start;gap:12px;min-height:52px;padding:6px 10px;font-size:14px}.content-panel{padding:18px 10px}.page-toolbar,.search-row,.directory-filters{flex-wrap:wrap;align-items:stretch}.search-box,.directory-select{width:100%}.directory-select select{width:100%;max-width:none}.view-buttons{margin-left:0}.kids-grid,.mini-grid,.kid-info-panel,.stat-strip,.admin-stat-grid,.admin-quick-grid,.attendance-summary-grid,.attendance-filter-bar{grid-template-columns:1fr}.admin-quick-grid button{min-height:92px}.kid-profile-panel,.kid-info-panel,.kid-detail-card,.detail-profile-panel{border-radius:24px}.kid-info-panel{gap:12px;padding:18px}.kid-profile-panel{min-height:280px}.kid-detail-photo .avatar.large{width:124px;height:124px}.attendance-hero,.attendance-class-header{grid-template-columns:1fr}.attendance-hero{flex-direction:column;align-items:stretch}.attendance-hero .teacher-view-toggle{width:fit-content}.attendance-progress{justify-items:stretch}.attendance-kid-grid{grid-template-columns:1fr}.attendance-kid-card{grid-template-columns:auto minmax(0,1fr)}.attendance-kid-card .status-chip,.attendance-times{grid-column:1/-1;justify-self:start}.teacher-phone{width:100%;padding:16px 14px 28px}.teacher-child-list,.teacher-classes>div,.teacher-class-list{grid-template-columns:1fr}.teacher-child-list.list .teacher-child-card{grid-template-columns:auto minmax(0,1fr)}.teacher-child-list.list .teacher-check-btn{grid-column:1/-1;min-width:0}.teacher-row{grid-template-columns:auto minmax(0,1fr)}.row-actions{grid-column:1/-1;justify-content:flex-end}}
