*{box-sizing:border-box}body{margin:0;background:#f5f7fb}.shell{min-height:100vh}.sidebar{background:#fff;border-right:1px solid #e8eaf0}.brand{height:58px;display:flex;align-items:center;gap:10px;padding:0 20px;font-weight:700;color:#1f2937}.topbar{height:58px;padding:0 18px;background:#fff;border-bottom:1px solid #e8eaf0;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:nowrap;overflow:hidden}.topbar-main{flex:1 1 auto;min-width:0;display:flex;align-items:center;gap:8px}.topbar-title{min-width:0}.topbar-copy{min-width:0;display:grid;gap:2px}.mobile-topbar-meta{display:none}.topbar-actions{flex:0 0 auto;min-width:max-content;display:inline-flex;align-items:center;flex-wrap:nowrap;white-space:nowrap}.desktop-topbar-meta{display:inline-flex;align-items:center}.mobile-menu-button{display:none}.content{padding:18px}.full{width:100%}.student-filters{flex:1 1 auto;min-width:0;flex-wrap:nowrap!important}.searchbar{flex:1 1 320px;min-width:240px;max-width:420px}.student-type-filter{flex:0 0 180px;min-width:0}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(145deg,#eef6ff,#fff 52%,#f1f8f4)}.login-panel{width:min(420px,100%);padding:28px;background:#fff;border:1px solid #e8eaf0;border-radius:8px;box-shadow:0 16px 50px #162b5014}.school-entry-panel{width:min(420px,100%)}.school-search{display:grid;grid-template-columns:minmax(180px,240px) minmax(220px,1fr) auto;gap:10px;align-items:center}.school-candidates{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.school-candidate{display:grid;gap:4px;min-height:64px;padding:10px 12px;text-align:left;border:1px solid #d9dfe9;border-radius:6px;background:#fff;cursor:pointer}.school-candidate.active{border-color:#1677ff;background:#eef6ff}.school-candidate span{color:#6b7280;font-size:12px}.compact-form-item{margin-bottom:10px}.login-links{display:flex;justify-content:center;gap:8px}.boot{min-height:100vh;display:grid;place-items:center}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 16px}.student-editor-page{min-height:calc(100vh - 94px)}.student-editor-header{padding:14px 16px;border:1px solid #e8eaf0;border-radius:8px;background:#fff}.student-editor-title{margin:0!important}.student-editor-page>.ant-form{padding:16px;border:1px solid #e8eaf0;border-radius:8px;background:#fff}.span-2{grid-column:span 2}.date-age-fields{display:flex;width:100%}.date-age-date{flex:1 1 auto;border-start-end-radius:0;border-end-end-radius:0}.date-age-value{display:flex;align-items:center;justify-content:center;flex:0 0 96px;min-height:32px;padding:4px 11px;margin-left:-1px;border:1px solid #d9d9d9;border-start-end-radius:6px;border-end-end-radius:6px;background:#fafafa;font-size:14px;color:#111827}.repeater{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr)) auto;gap:12px;align-items:end;padding:12px;border:1px solid #e8eaf0;border-radius:6px;overflow-x:auto}.guardian-repeater{grid-template-columns:repeat(4,minmax(150px,1fr)) auto}.mobile-cards{display:none}.student-summary-card{cursor:pointer}.student-summary-card:focus-visible{outline:2px solid #1677ff;outline-offset:2px}.student-card-profile{display:flex;align-items:center;gap:12px}.student-card-copy{min-width:0;display:grid;gap:4px}.student-card-copy .ant-typography{margin:0;overflow-wrap:anywhere}.info-rows{display:grid;gap:8px}.info-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;font-size:13px}.info-row span{color:#6b7280;flex:0 0 auto}.info-row strong{min-width:0;color:#111827;font-weight:500;text-align:right;overflow-wrap:anywhere}.data-list-description table{table-layout:fixed;width:100%}.data-list-description .ant-descriptions-item-label{width:40%}.data-list-description .ant-descriptions-item-content{width:60%;overflow-wrap:anywhere}.growth-album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.growth-album-item{min-width:0;overflow:hidden;border:1px solid #e8eaf0;border-radius:6px;background:#fff}.growth-album-item .ant-image,.growth-album-image-placeholder{width:100%;display:block}.growth-album-image,.growth-album-item .ant-image-img,.growth-album-image-placeholder{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block;background:#f5f7fb}.growth-album-image-placeholder{display:grid;place-items:center;padding:12px;color:#6b7280;text-align:center;overflow-wrap:anywhere}.growth-album-meta{padding:8px 10px}.card-actions{margin-top:12px;flex-wrap:wrap}@media(max-width:720px){.shell .sidebar{display:none}.topbar{height:auto;min-height:64px;padding:8px 10px;gap:10px;align-items:center;box-shadow:0 1px #1118270a}.mobile-menu-button{display:inline-flex;width:36px;height:36px;flex:0 0 36px;border:1px solid #e5e7eb;background:#fff}.topbar-main{align-items:center;gap:10px}.topbar-title{display:block;max-width:100%;font-size:16px;line-height:20px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-topbar-meta{display:flex;align-items:center;gap:6px;min-width:0}.mobile-topbar-meta .ant-tag{max-width:130px;margin-inline-end:0;overflow:hidden;text-overflow:ellipsis}.desktop-topbar-meta{display:none}.topbar-actions .ant-tag{margin-inline-end:0}.topbar-actions{gap:6px!important}.topbar-actions .ant-btn{width:36px;min-width:36px;padding-inline:0}.topbar-password-text{display:none}.content{padding:12px}.student-filters{flex-wrap:wrap!important}.searchbar,.student-type-filter{flex:1 1 100%;max-width:none}.form-grid{grid-template-columns:1fr}.student-editor-header,.student-editor-page>.ant-form{padding:12px}.school-search{grid-template-columns:1fr}.span-2{grid-column:span 1}.date-age-fields{align-items:stretch}.repeater{grid-template-columns:1fr}.desktop-table{display:none}.mobile-cards{display:grid;gap:12px}.mobile-cards .ant-card-actions>li{margin:6px 0}.ant-drawer-body,.ant-modal-body{padding:16px}.ant-input,.ant-input-affix-wrapper,.ant-input-affix-wrapper input,.ant-input-number-input,.ant-picker,.ant-picker input,.ant-select,.ant-select-selector,.ant-select-selection-item,.ant-select-selection-placeholder,.ant-select-selection-search-input,textarea.ant-input{font-size:16px!important}.ant-tabs-nav{margin-bottom:12px}.login-page{padding:16px}.login-panel{padding:22px}}
