:root{--color-primary: #1a73e8;--color-primary-hover: #1557b0;--color-success: #0d7c3d;--color-warning: #f59e0b;--color-danger: #dc2626;--color-bg: #f8f9fa;--color-card: #ffffff;--color-text: #1f2937;--color-text-secondary: #6b7280;--color-border: #e5e7eb;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .1);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,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}h1,h2,h3,h4,h5,h6{margin-top:0;line-height:1.2}p{margin-top:0}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{background-color:var(--color-primary);color:#fff;padding:0 1rem;box-shadow:var(--shadow);position:sticky;top:0;z-index:100}.header-content{max-width:960px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;min-height:56px;gap:1rem}.header-title{font-size:1.125rem;font-weight:600;margin:0;white-space:nowrap}.header-user{display:flex;align-items:center;gap:.75rem;font-size:.875rem}.header-display-name{display:none}@media(min-width:640px){.header-display-name{display:inline;opacity:.9}}.app-main{flex:1;max-width:960px;width:100%;margin:0 auto;padding:1.5rem 1rem}.app-footer{text-align:center;padding:1rem;font-size:.75rem;color:var(--color-text-secondary);border-top:1px solid var(--color-border)}.card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);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);padding:.5rem 1rem;font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background-color .15s,border-color .15s,color .15s;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-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.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 .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a73e826}input:disabled,select:disabled,textarea:disabled{background-color:var(--color-bg);opacity:.7;cursor:not-allowed}.form-error{color:var(--color-danger);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;padding:3rem 1rem;color:var(--color-text-secondary)}.landing-page{display:flex;align-items:center;justify-content:center;min-height:60vh}.landing-card{width:100%;max-width:400px}.landing-card h2{margin-bottom:.5rem}.login-form{margin-top:1.5rem}.page-placeholder{text-align:center;padding:3rem 1rem}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}@media(min-width:640px){.app-main{padding:2rem 1.5rem}.header-title{font-size:1.25rem}}@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);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:#e0e7ff;color:#3730a3}.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);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:999px;width:fit-content}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-info{background-color:#dbeafe;color:#1e40af}.empty-state{color:var(--color-text-secondary);font-size:.875rem;font-style:italic;margin:0}.success-message{padding:.75rem 1rem;border-radius:var(--radius);background-color:#d1fae5;color:#065f46;font-size:.875rem;font-weight:500;border:1px solid #a7f3d0}.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(--color-text-secondary);background-color:#fef9c3;border:1px solid #fde68a;border-radius:var(--radius);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:#dcfce7;color:#166534}.badge-danger{background-color:#fee2e2;color:#991b1b}.offering-actions{margin-top:auto}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background-color:#0a6331}.btn-warning{background-color:var(--color-warning);color:#fff}.btn-warning:hover:not(:disabled){background-color:#d97706}.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);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:#dcfce7;border:1px solid #86efac;color:#166534}.enrollment-result.info{background-color:#dbeafe;border:1px solid #93c5fd;color:#1e40af}.enrollment-result.error{background-color:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.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:#00000080;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}.admin-header{background-color:#1e293b;color:#fff;padding:0 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:56px;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:#f1f5f9;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 .15s,border-color .15s}.admin-nav-link:hover{background-color:#e2e8f0;text-decoration:none}.admin-nav-link-active{background-color:#dbeafe;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 .15s,border-color .15s}.admin-dashboard-card:hover{box-shadow:0 2px 8px #0000001f;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);font-size:.875rem;font-weight:500;text-decoration:none;transition:top .15s}.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:#f1f5f9}.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-color:#1e293b}.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:#fef9c3;border:2px solid #f59e0b;border-radius:var(--radius);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:#f8fafc;border:1px solid var(--color-border);border-radius:var(--radius);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}.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}
