:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;color:#101c29;background:#f8f9ff;color-scheme:light;scroll-padding-top:160px;scroll-padding-bottom:160px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f8f9ff}button,input{font:inherit}button{min-height:48px;border:0;border-radius:4px;padding:0 16px;color:#000814;background:#ffc300;font-weight:700;cursor:pointer}.secondary-button{border:1px solid #c3c6d0;color:#003566;background:#fff}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.app-shell{width:min(100%,520px);min-height:100vh;margin:0 auto;padding:max(16px,env(safe-area-inset-top)) 16px calc(88px + env(safe-area-inset-bottom))}.topbar,.sync-strip,.teen-card,.bottom-nav,.dialog-actions{display:flex;align-items:center;gap:12px}.topbar{justify-content:space-between;margin-bottom:16px}.topbar h1,.search-section h2,.teen-card h3,.dialog h2{margin:0;letter-spacing:0}.topbar h1{font-size:24px;line-height:32px}.eyebrow{margin:0 0 4px;color:#485f83;font-weight:700}.icon-button{width:48px;padding:0;border:1px solid #c3c6d0;background:#fff;color:#003566}.sync-strip{justify-content:space-between;min-height:56px;padding:8px 12px;border:1px solid #bed6ff;border-radius:8px;background:#e4efff}.sync-strip button{min-height:40px}.search-section{margin-top:20px}.search-section h2{font-size:20px;line-height:28px;margin-bottom:12px}.search-label{display:grid;gap:8px;color:#43474f;font-weight:600}.search-input{display:flex;align-items:center;gap:8px;min-height:52px;border:1px solid #c3c6d0;border-radius:4px;padding:0 12px;background:#fff}.search-input input{width:100%;border:0;outline:0;background:transparent}.form-grid{display:grid;gap:12px}.form-grid input{min-height:52px;border:1px solid #c3c6d0;border-radius:4px;padding:0 12px;background:#fff}.teen-list{margin-top:16px}.today-list{display:grid;gap:10px;margin-top:20px}.today-list h2{margin:0;font-size:20px;line-height:28px;letter-spacing:0}.profile-section{display:grid;gap:12px;margin-top:20px}.profile-section h2{margin:0;font-size:20px;line-height:28px;letter-spacing:0}.profile-card{border:1px solid #dde9fb;border-radius:8px;padding:14px;background:#fff}.profile-card h3{margin:0 0 10px;font-size:22px;line-height:30px;letter-spacing:0}.profile-card dl{display:grid;gap:8px;margin:0}.profile-card dl div{display:grid;grid-template-columns:96px minmax(0,1fr);gap:8px}.profile-card dt{color:#43474f;font-weight:700}.profile-card dd{margin:0;overflow-wrap:anywhere}.admin-dashboard{display:grid;gap:16px;margin-top:20px}.admin-dashboard h2,.admin-panel h3{margin:0;letter-spacing:0}.admin-dashboard h2{font-size:20px;line-height:28px}.admin-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.metric-card{min-height:84px;border:1px solid #dde9fb;border-radius:8px;padding:12px;background:#fff}.metric-card strong,.metric-card span{display:block}.metric-card strong{font-size:24px;line-height:30px;color:#003566}.metric-card span{margin-top:4px;color:#43474f;font-weight:700}.admin-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.admin-actions a{display:flex;align-items:center;gap:8px;min-height:48px;border:1px solid #c3c6d0;border-radius:4px;padding:0 12px;color:#003566;background:#fff;text-decoration:none;font-weight:700}.admin-panel{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid #dde9fb;border-radius:8px;padding:14px;background:#fff}.admin-panel.compact{justify-content:flex-start}.admin-panel.stack{align-items:flex-start}.admin-panel.stack>div{width:100%}.admin-panel h3{font-size:18px;line-height:24px}.admin-panel p{margin:4px 0 0;color:#43474f;line-height:1.5}.admin-panel button{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto}.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}.admin-form-grid.single{grid-template-columns:minmax(0,1fr) auto;align-items:end}.admin-form-grid label{display:grid;gap:6px;color:#43474f;font-weight:700}.admin-form-grid input,.admin-form-grid select{width:100%;min-height:48px;border:1px solid #c3c6d0;border-radius:4px;padding:0 10px;background:#fff;font-size:1rem;font-family:inherit}.add-user-form{display:flex;flex-direction:column;gap:12px;margin-top:12px}.add-user-form h4{margin:0;font-size:16px;color:#1a1c1e}.add-user-form label,.add-user-form-field{display:grid;gap:6px;color:#43474f;font-weight:700}.add-user-form input,.add-user-form select{width:100%;min-height:48px;border:1px solid #c3c6d0;border-radius:4px;padding:0 10px;background:#fff;font-size:1rem;font-family:inherit;box-sizing:border-box}.select-field{position:relative;width:100%}.select-field__trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;min-height:48px;padding:0 12px;border:1px solid #c3c6d0;border-radius:4px;background:#fff;color:#101c29;font-size:1rem;font-weight:400;font-family:inherit;text-align:right;cursor:pointer;box-sizing:border-box}.select-field__trigger:focus-visible,.select-field__trigger[aria-expanded=true]{outline:none;border-color:#003566;box-shadow:0 0 0 1px #003566}.select-field__trigger:disabled{opacity:.6;cursor:not-allowed}.select-field__value{flex:1;text-align:right}.select-field__chevron{flex-shrink:0;color:#737780;transition:transform .15s ease}.select-field__chevron--open{transform:rotate(180deg)}.select-field__menu{position:absolute;z-index:20;top:calc(100% + 4px);right:0;left:0;margin:0;padding:4px;list-style:none;background:#fff;border:1px solid #c3c6d0;border-radius:8px;box-shadow:0 4px 16px #0020411f}.select-field__option{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:44px;padding:0 12px;border-radius:4px;color:#101c29;text-align:right;cursor:pointer}.select-field__option:hover,.select-field__option:focus-visible{background:#eef4ff;outline:none}.select-field__option--selected{background:#e4efff;color:#003566;font-weight:600}.select-field__check{flex-shrink:0;color:#003566}.add-user-form button[type=button]{width:100%;margin-top:4px}.button-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.report-button-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:10px}.report-button-grid button{min-height:48px;width:100%}.report-button-grid button:last-child:nth-child(odd){grid-column:1 / -1}.csv-export-btn{display:flex;align-items:center;gap:8px;margin-top:12px;width:100%;justify-content:center}.button-row.compact{margin-top:0}.button-row button{min-height:40px}.admin-list{display:grid;gap:8px;margin-top:10px}.admin-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:42px;border:1px solid #dde9fb;border-radius:4px;padding:8px 10px;background:#f8f9ff}.admin-row.stacked{display:grid;justify-content:stretch}.admin-row span,.admin-row strong{min-width:0;overflow-wrap:anywhere}.conflict-card{display:flex;flex-direction:column;gap:10px;border:1px solid #dde9fb;border-radius:8px;padding:12px;background:#fff}.conflict-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.conflict-meta{display:flex;align-items:center;gap:6px;flex-shrink:0}.conflict-time{font-size:12px;color:#888;white-space:nowrap}.conflict-type-label{font-weight:700;font-size:15px}.status-pill.status-resolved{background:#d4edda;color:#155724}.status-pill.status-rejected{background:#f8d7da;color:#721c24}.conflict-summary{font-size:14px;color:#43474f}.conflict-desc{margin:0;color:#444;line-height:1.5}.conflict-fields{margin:0;display:grid;grid-template-columns:auto 1fr;gap:4px 12px;align-items:baseline}.conflict-fields dt{font-weight:600;color:#555;white-space:nowrap}.conflict-fields dd{margin:0;color:#222;word-break:break-word}.conflict-payload-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;width:100%}.payload-preview{width:100%;max-height:120px;overflow:auto;margin:4px 0;border:1px solid #c3c6d0;border-radius:4px;padding:8px;direction:ltr;text-align:left;background:#fff;font-size:12px;line-height:1.4;white-space:pre-wrap}.payload-preview strong{display:block;margin-bottom:4px;direction:rtl;text-align:right}.payload-preview pre{margin:0;white-space:pre-wrap}.status-pill{flex:0 0 auto;border-radius:999px;padding:4px 8px;color:#003566;background:#e4efff;font-size:13px;font-weight:700}.teen-card{flex-direction:column;align-items:center;text-align:center;gap:6px;border:1px solid #dde9fb;border-radius:12px;background:#fff;padding:12px 8px}.teen-card--marked{background:#f0fdf4;border-color:#86efac}.teen-card--list{flex-direction:row;text-align:right;gap:10px;padding:10px 12px;align-items:center}.teen-card--list .teen-card-text{flex:1;min-width:0}.teen-card--list .teen-card-mark-btn{width:auto;min-width:72px;flex-shrink:0;padding:0 12px}.teen-card--list .teen-card-status{width:auto;min-width:72px;flex-shrink:0}.teen-card--list .teen-card-cancel{width:auto;min-width:60px;flex-shrink:0}.teen-card--list .teen-card-confirm-void{flex-shrink:0;width:auto}.teens-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.teens-grid--list{grid-template-columns:1fr}.attendance-state{font-weight:700}.empty-state{margin:0;padding:16px;border:1px dashed #c3c6d0;border-radius:8px;color:#43474f;background:#fff}.teen-card-mark-btn{width:100%;height:36px;background:#ffc300;color:#000814;border:none;border-radius:8px;font-weight:700;font-size:14px;cursor:pointer}.teen-card-mark-btn:active{filter:brightness(.9)}.teen-card-checkbox{width:22px;height:22px;cursor:pointer;accent-color:#0B315F;flex-shrink:0}.teen-card-marked-time{font-size:11px;color:#16a34a;font-weight:600}.teen-card-confirm-void{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}.teen-card-confirm-prompt{font-size:12px;font-weight:600;color:#4b5563;text-align:center}.teen-card-confirm-buttons{display:flex;gap:4px;width:100%}.teen-card-confirm-yes,.teen-card-confirm-no{flex:1;padding:7px 4px;border-radius:8px;font-weight:700;font-size:13px;cursor:pointer;font-family:inherit;min-height:36px}.teen-card-confirm-yes{background:#fef2f2;color:#b91c1c;border:1px solid #fca5a5}.teen-card-confirm-no{background:#0b315f;color:#fff;border:none}.teen-card-status{display:flex;align-items:center;justify-content:center;gap:4px;width:100%;height:36px;background:#dcfce7;border-radius:8px;font-size:12px;font-weight:700;color:#16a34a}.mark-toast{position:fixed;bottom:90px;left:50%;transform:translate(-50%);background:#002041;color:#fff;padding:10px 22px;border-radius:99px;font-size:14px;font-weight:600;z-index:9999;white-space:nowrap;pointer-events:none;animation:toast-show 2.5s ease forwards}@keyframes toast-show{0%{opacity:0;transform:translate(-50%) translateY(8px)}12%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1}to{opacity:0}}.teen-card-cancel{width:100%;background:transparent;border:none;color:#dc2626;font-size:12px;font-weight:600;cursor:pointer;padding:4px 0;min-height:32px;font-family:inherit;opacity:.75;transition:opacity .15s}.teen-card-cancel:hover,.teen-card-cancel:active{opacity:1}.teen-card-cancel:focus-visible{outline:2px solid #dc2626;outline-offset:2px;border-radius:4px;opacity:1}.bottom-nav{position:fixed;right:0;left:0;bottom:var(--visual-viewport-bottom-offset, 0px);justify-content:space-around;z-index:50;height:72px;min-height:72px;padding:8px 16px max(8px,env(safe-area-inset-bottom));border-top:1px solid #c3c6d0;background:linear-gradient(to bottom,#ffffffed,#f0f6fff5),url(/images/footer-bg.png) center / cover no-repeat}.bottom-nav a{display:grid;justify-items:center;min-width:92px;color:#485f83;text-decoration:none;font-weight:700}.bottom-nav a[aria-current=page]{color:#003566}.legal-footer{position:relative;z-index:2;display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:24px;padding:12px 0;background:#f8f9ff}.admin-legal-footer{position:sticky;top:96px;z-index:30;border-bottom:1px solid #dde9fb;box-shadow:0 6px 16px #00204114}.link-button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;min-width:128px;border:1px solid transparent;padding:0 8px;color:#003566;background:transparent;text-decoration:underline}.legal-inline-actions{display:flex;justify-content:flex-start}.legal-shell{padding-bottom:max(24px,env(safe-area-inset-bottom))}.legal-page{display:grid;gap:14px;margin-top:16px}.legal-sections{display:grid;gap:10px}.legal-section{border:1px solid #dde9fb;border-radius:8px;padding:14px;background:#fff}.legal-section h2{margin:0;font-size:18px;line-height:24px;letter-spacing:0}.legal-section p{margin:6px 0 0;color:#43474f;line-height:1.6}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:end center;padding:16px;padding-bottom:max(16px,env(safe-area-inset-bottom));background:#0006}.dialog{width:min(100%,480px);border-radius:8px;padding:18px;background:#fff}.dialog p{line-height:1.6}.dialog-actions{flex-direction:column;align-items:stretch;margin-top:16px}.danger{background:#ba1a1a;color:#fff}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important}}.glass-card{background:#ffffffd9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid #E9ECEF}.bento-cell{border-radius:12px;padding:14px;display:flex;flex-direction:column;justify-content:space-between;aspect-ratio:1}.metric-number{font-size:30px;font-weight:700;line-height:38px;letter-spacing:-.02em;color:#002041}.bento-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.bento-cell-clickable{position:relative;cursor:pointer;transition:box-shadow .15s ease,transform .1s ease,border-color .15s ease;font-family:inherit;text-align:inherit}.bento-cell-clickable:hover{box-shadow:0 4px 16px #0020411a;border-color:#00204133!important}.bento-cell-clickable:active{transform:scale(.97);box-shadow:none}.card-drill-chevron{position:absolute;bottom:10px;left:10px;color:#c5cdd6;transition:color .15s ease,transform .15s ease}.bento-cell-clickable:hover .card-drill-chevron{color:#485f83;transform:translate(-2px)}.avatar-circle{width:48px;height:48px;border-radius:50%;background:#e4efff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#003566;flex-shrink:0;cursor:pointer}.teen-card-text{display:flex;flex-direction:column;gap:2px;width:100%;min-width:0}.avatar-wrapper{position:relative;display:inline-flex;flex-shrink:0}.teen-badge-new{position:absolute;top:-8px;right:-10px;padding:2px 6px;background:#d4a017;color:#fff;font-size:11px;font-weight:700;border-radius:8px;pointer-events:none;box-shadow:0 1px 3px #00000040;line-height:1.4;white-space:nowrap}.teen-card-name{margin:0;font-size:13px;font-weight:700;color:#002041;line-height:1.3;overflow-wrap:break-word}.teen-card-school{font-size:11px;color:#5f6570;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;display:flex;align-items:flex-end}.modal-sheet{width:100%;max-width:520px;margin:0 auto;background:#fff;border-radius:16px 16px 0 0;padding:12px 20px 32px;transform:translateY(0);transition:transform .3s ease}.modal-sheet.entering{animation:slideUp .3s ease forwards}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{width:32px;height:4px;background:#c3c6d0;border-radius:2px;margin:0 auto 16px}.field-wrapper{position:relative;display:flex;align-items:center;border:1px solid #c3c6d0;border-radius:12px;height:56px;background:#fff;transition:border-color .15s,box-shadow .15s}.field-wrapper:focus-within{border-color:#003566;box-shadow:0 0 0 1px #003566}.field-wrapper--invalid{border-color:#ba1a1a;box-shadow:0 0 0 1px #ba1a1a}.field-error{margin:6px 0 0;font-size:14px;color:#b42318;font-weight:600}.field-icon{position:absolute;right:14px;color:#737780;pointer-events:none;flex-shrink:0}.field-icon-left{position:absolute;left:14px;color:#737780;cursor:pointer;background:none;border:none;min-height:0;padding:0}.field-input{width:100%;height:100%;border:0;outline:0;background:transparent;padding:0 44px;font-size:16px;font-family:inherit}.login-card{background:#fff;border-radius:12px;border:1px solid rgba(195,198,208,.3);padding:24px;box-shadow:0 1px 4px #00204114}.login-error{margin-top:10px;padding:10px 12px;border-radius:8px;background:#ffdad6;color:#ba1a1a;font-size:14px;font-weight:500}.logo-circle{width:152px;height:152px;border-radius:24px;background:radial-gradient(circle at 38% 24%,#fffffff2,#f8f9ffb3 44%,#e4efff9e);border:1px solid rgba(255,255,255,.82);display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 20px 46px #0b315f38,inset 0 1px #fffffff5;transform:perspective(520px) rotateX(2deg)}.fab{position:fixed;bottom:88px;left:16px;width:56px;height:56px;border-radius:50%;background:#ffc300;color:#000814;border:0;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0003;min-height:0;padding:0;z-index:40}.hero-card{position:relative;width:100%;height:160px;border-radius:16px;overflow:hidden}.hero-card img{width:100%;height:100%;object-fit:cover}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,32,65,.8),transparent);display:flex;flex-direction:column;justify-content:flex-end;padding:14px 16px}.hero-title{color:#fff;font-size:20px;font-weight:600}.hero-sub{color:#fffc;font-size:12px;font-weight:600;margin-top:2px}.quick-action-row{display:flex;align-items:center;gap:12px;height:56px;border:1px solid #003566;border-radius:8px;padding:0 16px;color:#003566;background:#fff;font-weight:700;text-decoration:none;cursor:pointer;width:100%}.quick-action-chevron{margin-right:auto;color:#737780}.count-badge{display:inline-flex;align-items:center;border-radius:999px;background:#e4efff;color:#003566;font-size:14px;font-weight:700;padding:4px 12px;margin-bottom:16px}.login-dot-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.03;z-index:0;background-image:radial-gradient(#002041 1px,transparent 1px);background-size:20px 20px}.bottom-nav-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;flex:1;min-height:48px;color:#5f6570;text-decoration:none;font-size:12px;font-weight:600;cursor:pointer;background:none;border:0;padding:0;border-top:2px solid transparent;transition:color .15s,border-color .15s}.bottom-nav-tab[aria-current=page]{color:#003566;border-top-color:#003566}.greeting-section{margin-bottom:20px}.greeting-title{font-size:30px;font-weight:700;line-height:38px;letter-spacing:-.02em;color:#002041;margin:0 0 4px}.greeting-sub{font-size:16px;color:#43474f;margin:0}.search-bar{position:relative;display:flex;align-items:center;height:56px;border:1px solid #c3c6d0;border-radius:12px;background:#fff;padding:0 14px;gap:10px;transition:border-color .15s}.search-bar:focus-within{border-color:#003566}.search-bar input{flex:1;border:0;outline:0;background:transparent;font-size:16px;font-family:inherit}.search-clear{background:none;border:none;min-height:0;padding:4px;color:#737780;cursor:pointer;display:flex;align-items:center}.temp-creds-banner{margin-top:16px;padding:16px;background:#eef6ee;border:1px solid #1b6b2f;border-radius:8px}.temp-creds-title{font-weight:700;color:#1b6b2f;margin:0 0 4px}.temp-creds-body{font-size:13px;color:#43474f;margin:0 0 12px}.temp-creds-row{display:flex;gap:8px;align-items:baseline;margin-bottom:6px}.temp-creds-label{font-size:13px;font-weight:600;color:#43474f;min-width:80px}.temp-creds-value{font-family:monospace;font-size:14px;direction:ltr;color:#002041}.temp-creds-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
