:root{--hi-primary: #40527a;--hi-primary-light: #5a6c94;--hi-primary-gradient: linear-gradient(135deg, #40527a 0%, #5a6c94 100%);--hi-text: #333333;--hi-text-muted: #666666;--hi-text-subtle: #999999;--hi-surface: #f8f9fa;--hi-border: #dddddd;--hi-border-strong: #dee2e6;--hi-success: #4caf50;--hi-success-strong: #2e7d32;--hi-success-bg: #e8f5e8;--hi-info: #2196f3;--hi-info-strong: #1565c0;--hi-info-bg: #e3f2fd;--hi-warning: #ff9800;--hi-warning-hover: #f57c00;--hi-warning-strong: #856404;--hi-warning-bg: #fff3cd;--hi-error: #f44336;--hi-error-strong: #d32f2f;--hi-error-bg: #ffebee;--hi-link: #1976d2;--hi-radius-lg: 20px;--hi-radius-md: 15px;--hi-radius-sm: 10px;--color-primary: var(--hi-primary);--color-primary-hover: var(--hi-primary-light);--color-gradient: var(--hi-primary-gradient);--color-success: var(--hi-success);--color-warning: var(--hi-warning);--color-danger: var(--hi-error);--color-bg: var(--hi-surface);--color-card: #ffffff;--color-text: var(--hi-text);--color-text-secondary: var(--hi-text-muted);--color-border: var(--hi-border-strong);--radius: var(--hi-radius-sm);--radius-md: var(--hi-radius-md);--radius-lg: var(--hi-radius-lg);--radius-pill: 28px;--shadow: 0 20px 40px rgba(0, 0, 0, .1);--shadow-soft: 0 10px 24px rgba(0, 0, 0, .12);--transition-standard: .3s ease;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;font-size:16px;background:var(--color-gradient);background-attachment:fixed}h1,h2,h3,h4,h5,h6{margin-top:0;line-height:1.3}p{margin-top:0}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{background:var(--color-gradient);color:#fff;padding:.5rem 1rem;box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.header-content{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;min-height:68px;gap:1rem}.header-brand{display:flex;align-items:center;gap:.75rem;min-width:0}.header-brand-logo{width:auto;height:44px;max-width:180px;object-fit:contain;border-radius:6px;background-color:#fff;padding:.15rem .3rem}.header-title-group{display:flex;flex-direction:column;min-width:0}.header-title{font-size:1rem;font-weight:600;margin:0;white-space:normal}.header-subtitle{margin:0;font-size:.75rem;opacity:.95}@media(max-width:520px){.header-brand-logo{height:36px;max-width:145px}.header-subtitle{display:none}}.header-user{display:flex;align-items:center;gap:.75rem;font-size:.875rem}.header-display-name{display:none}@media(min-width:640px){.header-title{white-space:nowrap}.header-display-name{display:inline;opacity:.9}}.app-main{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:1.5rem 1rem}.app-footer{margin-top:1rem;text-align:center;padding:1.1rem 1rem 1.2rem;font-size:.75rem;color:#ffffffeb;border-top:1px solid rgba(255,255,255,.26);background:#40527a59}.app-footer p{margin:.25rem 0}.app-footer a{color:#fff}.card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:1px solid transparent;border-radius:var(--radius-pill);padding:.6rem 1.1rem;font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background-color var(--transition-standard),border-color var(--transition-standard),color var(--transition-standard),transform var(--transition-standard),box-shadow var(--transition-standard);text-decoration:none;line-height:1.5}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-primary{background:var(--color-gradient);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-soft)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--hi-error-strong);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.btn-secondary{background-color:#fff;color:var(--color-primary);border-color:var(--color-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--hi-info-bg);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.btn-outline{background-color:transparent;color:#fff;border-color:#ffffff80}.btn-outline:hover:not(:disabled){background-color:#ffffff26;border-color:#fffc}.btn-sm{padding:.25rem .75rem;font-size:.8125rem}.btn-block{display:flex;width:100%}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.375rem;font-size:.875rem;font-weight:500;color:var(--color-text)}input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],select,textarea{display:block;width:100%;padding:.5rem .75rem;font-size:.9375rem;font-family:inherit;line-height:1.5;color:var(--color-text);background-color:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);transition:border-color var(--transition-standard),box-shadow var(--transition-standard)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #40527a2e}input:disabled,select:disabled,textarea:disabled{background-color:var(--color-bg);opacity:.7;cursor:not-allowed}.form-error{color:var(--hi-error-strong);font-size:.875rem;margin-top:.25rem;margin-bottom:.5rem}.text-secondary{color:var(--color-text-secondary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.loading-container{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:3rem 1rem;color:var(--color-text-secondary)}.loading-container:before{content:"";width:24px;height:24px;border:3px solid rgba(64,82,122,.2);border-top-color:var(--color-primary);border-radius:50%;animation:spin .9s linear infinite}.loading-container p{margin:0}@keyframes spin{to{transform:rotate(360deg)}}.landing-page{display:flex;align-items:center;justify-content:center;min-height:68vh}.landing-card{width:100%;max-width:460px}.landing-card h2{margin-bottom:.5rem}.login-brand{text-align:center;margin-bottom:1rem}.login-brand img{width:auto;height:52px;max-width:190px;object-fit:contain}.login-form{margin-top:1.5rem}.landing-legal{margin-top:1.5rem;text-align:center;font-size:.875rem}.page-placeholder{text-align:center;padding:3rem 1rem}a{color:var(--hi-link);text-decoration:none;transition:color var(--transition-standard)}a:hover{text-decoration:underline}@media(min-width:640px){.app-main{padding:2rem 1.5rem}.header-title{font-size:1.1rem}.header-subtitle{font-size:.8125rem}}@media(min-width:960px){.app-main{padding:2rem}}.family-overview{display:flex;flex-direction:column;gap:1.5rem}.family-overview h2{margin-bottom:0}.student-card{display:flex;flex-direction:column;gap:1.25rem}.student-header{display:flex;align-items:center;gap:.75rem}.student-photo{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0}.student-photo-placeholder{display:flex;align-items:center;justify-content:center;background-color:var(--color-primary);color:#fff;font-size:1.25rem;font-weight:600}.student-name-level{display:flex;flex-direction:column;min-width:0}.student-name-level h3{margin:0;font-size:1.125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-name-level .text-secondary{font-size:.875rem}.enrollment-section h4,.waitlist-section h4{margin:0 0 .5rem;font-size:.9375rem;font-weight:600;color:var(--color-text)}.enrollment-list{display:flex;flex-direction:column;gap:.75rem}.enrollment-item{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg)}.enrollment-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.enrollment-start{font-size:.8125rem}.enrollment-slots{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.25rem}.slot-tag{display:inline-block;padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:999px;background-color:var(--hi-info-bg);color:var(--hi-info-strong);border:1px solid rgba(33,150,243,.35)}.waitlist-section{border-top:1px solid var(--color-border);padding-top:1rem}.waitlist-list{display:flex;flex-direction:column;gap:.75rem}.waitlist-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg)}.waitlist-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.badge{display:inline-block;padding:.125rem .5rem;font-size:.75rem;font-weight:600;border-radius:var(--radius-pill);width:fit-content}.badge-warning{background-color:var(--hi-warning-bg);color:var(--hi-warning-strong);border:1px solid rgba(255,152,0,.35)}.badge-info{background-color:var(--hi-info-bg);color:var(--hi-info-strong);border:1px solid rgba(33,150,243,.3)}.empty-state{color:var(--color-text-secondary);font-size:.875rem;font-style:italic;margin:0}.success-message{padding:.75rem 1rem;border-radius:var(--radius-md);background-color:var(--hi-success-bg);color:var(--hi-success-strong);font-size:.875rem;font-weight:500;border:1px solid rgba(76,175,80,.4)}.search-activities-btn{margin-top:.5rem}@media(max-width:480px){.enrollment-item,.waitlist-item{flex-direction:column;align-items:stretch}.enrollment-item .btn,.waitlist-item .btn{align-self:flex-end}}.search-page{width:100%}.search-header{margin-bottom:1.5rem}.search-header h2{margin-bottom:.25rem}.search-header .back-link{display:inline-block;margin-bottom:.75rem;font-size:.875rem}.disclaimer-text{font-size:.8125rem;color:var(--hi-warning-strong);background-color:var(--hi-warning-bg);border:1px solid rgba(255,152,0,.35);border-radius:var(--radius-md);padding:.5rem .75rem;margin-bottom:.5rem}.filter-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.filter-group{flex:1;min-width:180px}.filter-group input,.filter-group select{width:100%}.offerings-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.offerings-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.offerings-grid{grid-template-columns:repeat(3,1fr)}}.offering-card{display:flex;flex-direction:column;gap:.75rem}.offering-header h3{font-size:1rem;margin-bottom:.125rem}.offering-code{font-size:.75rem;color:var(--color-text-secondary);font-family:monospace}.offering-type{font-size:.8125rem;color:var(--color-text-secondary);font-weight:500}.offering-schedule{display:flex;flex-wrap:wrap;gap:.375rem}.offering-availability{font-size:.875rem;font-weight:600}.offering-badges{display:flex;flex-wrap:wrap;gap:.375rem}.badge-success{background-color:var(--hi-success-bg);color:var(--hi-success-strong);border:1px solid rgba(76,175,80,.35)}.badge-danger{background-color:var(--hi-error-bg);color:var(--hi-error-strong);border:1px solid rgba(244,67,54,.35)}.offering-actions{margin-top:auto}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background-color:var(--hi-success-strong);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.btn-warning{background-color:var(--color-warning);color:#fff}.btn-warning:hover:not(:disabled){background-color:var(--hi-warning-hover);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.disabled-btn{background-color:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:not-allowed;opacity:.7}.enrollment-result{border-radius:var(--radius-md);padding:.75rem 1rem;margin-bottom:1rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.enrollment-result p{margin:0;flex:1;min-width:200px}.enrollment-result.success{background-color:var(--hi-success-bg);border:1px solid rgba(76,175,80,.4);color:var(--hi-success-strong)}.enrollment-result.info{background-color:var(--hi-info-bg);border:1px solid rgba(33,150,243,.35);color:var(--hi-info-strong)}.enrollment-result.error{background-color:var(--hi-error-bg);border:1px solid rgba(244,67,54,.35);color:var(--hi-error-strong)}.error-container{text-align:center;padding:2rem 1rem}.error-container .btn{margin-top:1rem}.empty-container{text-align:center;padding:3rem 1rem}.confirm-overlay{position:fixed;inset:0;background-color:#2b37548c;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.confirm-dialog{max-width:420px;width:100%}.confirm-dialog h3{margin-bottom:.75rem}.confirm-actions{display:flex;gap:.75rem;margin-top:1rem}.confirm-actions .btn{flex:1}.admin-layout{display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(180deg,#40527a1a,#f8f9fabf 220px)}.admin-header{background:var(--color-gradient);color:#fff;padding:.5rem 1rem;box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.admin-header-content{display:flex;align-items:center;justify-content:space-between;min-height:68px;gap:1rem}.admin-header-title{font-size:1.125rem;font-weight:600;margin:0;white-space:nowrap}.admin-body{display:flex;flex:1;min-height:0}.admin-sidebar{width:220px;background-color:var(--hi-surface);border-right:1px solid var(--color-border);padding:1rem 0;flex-shrink:0;overflow-y:auto}.admin-nav-list{list-style:none;margin:0;padding:0}.admin-nav-link{display:block;padding:.625rem 1.25rem;color:var(--color-text);text-decoration:none;font-size:.9375rem;font-weight:500;border-left:3px solid transparent;transition:background-color var(--transition-standard),border-color var(--transition-standard)}.admin-nav-link:hover{background-color:var(--hi-info-bg);text-decoration:none}.admin-nav-link-active{background-color:var(--hi-info-bg);border-left-color:var(--color-primary);color:var(--color-primary);font-weight:600}.admin-main{flex:1;padding:1.5rem 2rem;overflow-y:auto;min-width:0}.admin-dashboard{display:flex;flex-direction:column;gap:1.5rem}.admin-dashboard h2{margin-bottom:0}.admin-dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.admin-dashboard-card{text-decoration:none;color:var(--color-text);transition:box-shadow var(--transition-standard),border-color var(--transition-standard),transform var(--transition-standard)}.admin-dashboard-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft);border-color:var(--color-primary);text-decoration:none}.admin-dashboard-card h3{margin-bottom:.5rem;font-size:1.0625rem}.admin-dashboard-card p{margin-bottom:0;font-size:.875rem}@media(max-width:768px){.admin-body{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--color-border);padding:.5rem 0}.admin-nav-list{display:flex;overflow-x:auto;gap:0}.admin-nav-link{white-space:nowrap;padding:.5rem 1rem;border-left:none;border-bottom:3px solid transparent;font-size:.8125rem}.admin-nav-link-active{border-left-color:transparent;border-bottom-color:var(--color-primary)}.admin-main{padding:1rem}}@media(min-width:769px){.admin-header-title{font-size:1.25rem}}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none}a:focus-visible{text-decoration:underline}.skip-to-content{position:absolute;top:-100%;left:1rem;z-index:1000;padding:.5rem 1rem;background-color:var(--color-primary);color:#fff;border-radius:var(--radius-pill);font-size:.875rem;font-weight:500;text-decoration:none;transition:top var(--transition-standard)}.skip-to-content:focus{top:.5rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}[aria-live]{position:relative}.admin-table-container{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{text-align:left;padding:.75rem;border-bottom:2px solid var(--color-border);font-weight:600;color:var(--color-text);white-space:nowrap}.admin-table td{padding:.75rem;border-bottom:1px solid var(--color-border);vertical-align:top}.admin-table tr:hover td{background-color:#2196f312}.admin-table .code-cell{font-family:monospace;font-size:.8125rem}.admin-pagination{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;font-size:.875rem;color:var(--color-text-secondary)}.admin-pagination-buttons{display:flex;gap:.5rem}.admin-filter-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;align-items:flex-end}.admin-filter-bar .form-group{margin-bottom:0;min-width:180px}.admin-section{margin-bottom:2rem}.admin-section h2{font-size:1.25rem;margin-bottom:1rem}.admin-section h3{font-size:1.0625rem;margin-bottom:.75rem}.admin-login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-gradient)}.admin-login-card{width:100%;max-width:400px;margin:1rem}.admin-login-card h2{margin-bottom:.25rem}.admin-login-card .text-secondary{margin-bottom:1.5rem}.token-display{background-color:var(--hi-warning-bg);border:2px solid var(--hi-warning);border-radius:var(--radius-md);padding:1rem;margin:1rem 0;word-break:break-all;font-family:monospace;font-size:.9375rem}.token-display-actions{display:flex;gap:.5rem;margin-top:.75rem}.detail-panel{background-color:var(--hi-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem;margin:.5rem 0}.detail-panel h4{font-size:.9375rem;margin:0 0 .5rem}.status-active{color:var(--color-success);font-weight:600}.status-inactive{color:var(--color-danger);font-weight:600}.status-pending{color:var(--color-warning);font-weight:600}.inline-edit{display:inline-flex;align-items:center;gap:.375rem}.inline-edit input{width:80px;padding:.25rem .5rem;font-size:.8125rem}.dashboard-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;margin-bottom:.5rem}.dashboard-stat-card{text-align:center;padding:1rem}.dashboard-stat-value{font-size:1.75rem;font-weight:700;color:var(--color-primary);line-height:1.2}.privacy-policy-page{max-width:900px;margin:0 auto;padding:2rem 1rem;background-color:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.privacy-policy-page h1{font-weight:600}.privacy-policy-page h2{font-size:1.15rem;margin-top:1.75rem;margin-bottom:.6rem}.privacy-policy-page h3{font-size:1rem;margin-top:1rem;margin-bottom:.4rem}.privacy-policy-page p,.privacy-policy-page li{line-height:1.55}.privacy-policy-page .updated-at{margin-bottom:2rem}.privacy-checkbox-label{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer}.privacy-checkbox-input{margin-top:.25rem;width:auto}.data-export-section{margin-top:2rem;text-align:center}.data-export-note{margin-top:.5rem;font-size:.85rem}.dashboard-stat-label{font-size:.8125rem;color:var(--color-text-secondary);margin-top:.25rem}.confirm-dialog .confirm-reason{font-style:italic;color:var(--color-text-secondary);margin:.5rem 0}
