:root{--ink:#191f28;--muted:#6b7684;--surface:#fff;--surface-muted:#f8fafc;--line:#0f172a14;--accent:#3182f6;--danger:#d14343;--shadow:0 12px 40px #0f172a0f;--sans:"Pretendard", "Noto Sans KR", "Apple SD Gothic Neo", "Segoe UI", sans-serif;--heading:"Pretendard", "Noto Sans KR", "Apple SD Gothic Neo", "Segoe UI", sans-serif;font:16px/1.5 var(--sans);letter-spacing:-.01em;color:var(--ink);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f4f6f8}*{box-sizing:border-box}html{min-height:100%}body{min-height:100svh;margin:0}body,button,input,textarea,select{font-family:var(--sans)}#root{min-height:100svh}h1,h2{font-family:var(--heading);color:var(--ink);margin:0;font-weight:800;line-height:1.25}h1{letter-spacing:-.04em;font-size:clamp(2rem,4vw,2.75rem)}h2{letter-spacing:-.03em;font-size:clamp(1.35rem,3vw,1.75rem)}p{color:var(--muted);margin:0}.page{isolation:isolate;--sticky-header-top:8px;--sticky-header-height:88px;--sticky-stack-gap:4px;--sticky-discovery-height:108px;--sticky-panel-top:calc(var(--sticky-header-top) + var(--sticky-header-height) + var(--sticky-stack-gap));--sticky-table-header-top:calc(var(--sticky-panel-top) + var(--sticky-discovery-height) + 8px);background:#f2f4f6;max-width:1320px;margin:0 auto;padding:10px 20px 56px}.page--auth{background:#f2f4f6;place-items:center;max-width:none;min-height:100svh;padding:40px 20px;display:grid}.app-header{top:var(--sticky-header-top);z-index:36;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:22px;justify-content:space-between;align-items:center;gap:14px;margin-bottom:6px;padding:14px 20px;display:flex;position:sticky}.app-header__identity{flex:auto;align-items:center;gap:10px;min-width:0;display:flex}.app-header__brand,.auth-intro{min-width:0}.app-header__brand{gap:2px;display:grid}.app-header__brand h2{letter-spacing:-.045em;font-size:clamp(1.1rem,1.45vw,1.3rem);line-height:1.06}.school-logo{flex:0 0 clamp(24px,1.7vw,28px);justify-content:center;align-items:center;width:clamp(24px,1.7vw,28px);height:clamp(24px,1.7vw,28px);font-size:clamp(20px,1.45vw,24px);line-height:1;display:inline-flex}.school-logo img{object-fit:contain;width:100%;height:100%;display:block}.app-header__nav{align-items:center;gap:22px;min-width:0;margin-left:18px;display:flex}.app-header__nav-button{color:#6b7684;cursor:pointer;background:0 0;border:0;min-height:40px;padding:0;font-size:15px;font-weight:700;transition:color .16s;position:relative}.app-header__nav-button:hover,.app-header__nav-button.is-active{color:var(--ink)}.app-header__nav-button.is-active:after{content:"";background:var(--ink);border-radius:999px;height:3px;position:absolute;bottom:-6px;left:0;right:0}.app-header__copy{max-width:58ch;margin-top:8px}.app-header__actions{flex-wrap:nowrap;flex:none;justify-content:flex-end;align-items:center;gap:12px;margin-left:auto;display:flex}.app-header__search{flex:0 150px;min-width:120px;display:block}.app-header__search-field{display:block}.app-header__search-input{width:100%;min-height:40px;color:var(--ink);background:#f8fafcf5;border:1px solid #94a3b833;border-radius:14px;outline:none;padding:0 12px;font-size:13px;font-weight:600;transition:border-color .16s,box-shadow .16s,background-color .16s}.app-header__search-input:focus{background:#fff;border-color:#3182f673;box-shadow:0 0 0 4px #3182f614}.app-header__search-input::placeholder{color:#8b95a1;font-weight:600}.profile-chip{background:var(--surface-muted);border:1px solid #e5e9f0f0;border-radius:16px;align-items:center;gap:8px;width:auto;min-width:0;max-width:160px;padding:8px 10px;display:flex}.profile-chip__avatar{width:34px;height:34px;color:var(--accent);background:#3182f61f;border-radius:999px;flex:0 0 34px;place-items:center;font-size:16px;font-weight:800;display:grid;overflow:hidden}.profile-chip__avatar img{object-fit:cover;width:100%;height:100%}.profile-chip__copy{gap:2px;min-width:0;display:grid}.profile-chip__copy strong{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.auth-shell{justify-content:center;width:100%;display:flex}.auth-panel{grid-template-columns:minmax(0,1.05fr) minmax(360px,.82fr);align-items:center;gap:28px;display:grid}.auth-title{max-width:10ch}.auth-copy{max-width:40ch;margin-top:14px;font-size:17px;line-height:1.7}.auth-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fff;border:1px solid #e5e9f0fa;border-radius:24px;width:min(100%,520px);padding:40px 36px;animation:.55s ease-out both auth-card-enter;box-shadow:0 28px 64px #0f172a1f}.auth-card__header{gap:8px;display:grid}.auth-card__header--center{text-align:center;justify-items:center}.auth-school-badge{background:linear-gradient(#f8fbff 0%,#f3f6fb 100%);border:1px solid #3182f61a;border-radius:999px;align-items:center;gap:12px;margin-bottom:8px;padding:10px 16px 10px 12px;display:inline-flex}.auth-school-badge__logo{border-radius:999px;flex:0 0 46px;width:46px;height:46px;display:block;box-shadow:0 10px 24px #18357d2e}.auth-school-badge__copy{text-align:left;gap:1px;display:grid}.auth-school-badge__copy strong{color:#191f28;letter-spacing:.08em;font-size:12px}.auth-school-badge__copy span{color:#8b95a1;letter-spacing:.08em;font-size:11px}.auth-icon{background:#f8fafc;border-radius:24px;place-items:center;width:72px;height:72px;margin-bottom:4px;font-size:34px;line-height:1;display:grid}.auth-system-title{color:#191f28;letter-spacing:-.04em;margin:0;font-size:clamp(2rem,4vw,2.4rem);font-weight:800}.auth-system-subtitle{color:#8b95a1;font-size:14px;font-weight:600}.auth-note{max-width:32ch;margin-top:8px;font-size:14px;line-height:1.65}.auth-form{gap:16px;margin-top:28px;display:grid}.auth-helper{color:#8b95a1;text-align:center;margin:0;font-size:13px;line-height:1.6}.google-button{width:100%;min-height:56px;color:var(--ink);cursor:pointer;background:#fff;border:1px solid #94a3b83d;border-radius:18px;justify-content:center;align-items:center;gap:12px;padding:16px;font-size:16px;font-weight:700;transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s;display:inline-flex;box-shadow:0 12px 28px #0f172a0d}.google-button:hover{background:#f8fafc;border-color:#3182f633;transform:translateY(-1px);box-shadow:0 16px 34px #0f172a14}.google-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.google-button__mark{color:#fff;background:linear-gradient(135deg,#4285f4 0%,#34a853 50%,#fbbc05 75%,#ea4335 100%);border-radius:999px;place-items:center;width:28px;height:28px;font-size:14px;font-weight:800;display:grid}.auth-error{color:var(--danger);margin:0;font-size:14px;font-weight:700}.auth-submit{width:100%}.auth-loading-card{width:100%;max-width:520px;margin-inline:auto}.detail-profile{align-items:center;gap:18px;min-width:0;display:flex}.detail-profile__avatar-button{cursor:pointer;background:0 0;border:0;flex:none;padding:0}.detail-profile__avatar-button:disabled{cursor:wait}.detail-profile__avatar{background:#eef4ff;border:1px solid #e5e9f0fa;border-radius:999px;width:108px;height:108px;position:relative;overflow:hidden;box-shadow:0 16px 34px #0f172a14}.detail-profile__copy{min-width:0}.detail-profile__fallback{place-items:center;width:100%;height:100%;font-size:40px;font-weight:800;display:grid}.detail-profile__overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffc7;place-items:center;display:grid;position:absolute;inset:0}.detail-profile__actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.detail-avatar-note{color:var(--muted);margin-top:8px;font-size:13px;line-height:1.55}.camera-button{align-items:center;gap:8px;display:inline-flex}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.avatar-spinner{border:3px solid #3182f62e;border-top-color:var(--accent);border-radius:999px;width:30px;height:30px;animation:.82s linear infinite spin}@keyframes auth-card-enter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.view-switcher{justify-content:center;margin-bottom:16px;display:flex}.view-switcher__track{background:#ffffffeb;border:1px solid #e5e9f0fa;border-radius:24px;gap:8px;padding:8px;display:inline-flex;box-shadow:0 12px 30px #0f172a0f}.view-switcher__button{min-height:48px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:18px;padding:0 18px;font-size:14px;font-weight:700;transition:background-color .16s,color .16s,box-shadow .16s}.view-switcher__button.is-active{background:var(--accent);color:#fff;box-shadow:0 10px 24px #3182f62e}.hero-card,.toolbar,.form-card,.batch-upload-card,.filter-card,.list-card,.empty-card,.detail-card{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:28px}.hero-card{grid-template-columns:minmax(0,1.5fr) minmax(280px,.9fr);gap:20px;padding:28px;display:grid}.workspace{grid-template-columns:minmax(0,1.55fr) minmax(340px,.9fr);align-items:start;gap:16px;display:grid}.hero-card,.toolbar{display:none}.workspace{grid-template-columns:minmax(320px,.96fr) minmax(0,1.92fr);gap:20px}.workspace--home{grid-template-columns:minmax(0,1fr)}.home-overview-grid{grid-template-columns:minmax(0,1.92fr) minmax(320px,.98fr);align-items:start;gap:20px;display:grid}.home-overview-grid>.list-card,.home-overview-grid>.empty-card,.home-overview-grid>.home-history-card{margin-top:0}.home-history-card{gap:16px;min-width:0;display:grid}.main-column,.detail-column{min-width:0}.main-column{align-content:start;gap:16px;display:grid}.main-column>.list-card,.main-column>.empty-card{order:1;margin-top:0}.main-column>.home-overview-grid{order:1}.main-column>.form-card{order:2}.main-column>.batch-upload-card{order:3}.detail-column,.home-history-card{top:var(--sticky-panel-top);position:sticky}.hero-content,.toolbar-copy{min-width:0}.hero-badge,.section-label,.toolbar-label{color:var(--accent);letter-spacing:-.01em;margin:0 0 10px;font-size:13px;font-weight:700}.hero-copy{max-width:56ch;margin-top:14px}.hero-side{gap:12px;display:grid}.summary-chip{background:var(--surface-muted);border:1px solid #e5e9f0e6;border-radius:22px;gap:8px;padding:18px 20px;display:grid}.summary-chip span{color:var(--muted);font-size:14px}.summary-chip strong{color:var(--ink);font-size:18px}.summary-chip.is-active{background:#3182f614;border-color:#3182f624}.toolbar{justify-content:space-between;align-items:center;gap:18px;margin-top:16px;padding:20px 24px;display:flex}.toolbar strong{color:var(--ink);font-size:17px;display:block}.toolbar-error,.detail-error{color:var(--danger);margin-top:6px}.detail-error{margin-bottom:0}.toolbar-actions{gap:10px;display:flex}.form-card,.batch-upload-card,.filter-card,.list-card,.empty-card,.detail-card{margin-top:16px;padding:24px}.list-card{flex-direction:column;min-height:0;display:flex;overflow:hidden}.detail-card{margin-top:0}.batch-upload-card__header{align-items:flex-start}.batch-upload-card__actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.batch-phase-card{background:linear-gradient(#fbfdff 0%,#f7faff 100%);border:1px solid #e5e9f0f5;border-radius:24px;gap:12px;margin-top:18px;padding:18px 20px;display:grid}.batch-phase-card__steps{flex-wrap:wrap;gap:8px;display:flex}.batch-phase-card__steps span{color:#7b8794;background:#eef2f7;border-radius:999px;align-items:center;min-height:34px;padding:0 12px;font-size:12px;font-weight:700;display:inline-flex}.batch-phase-card__steps span.is-active{color:var(--accent);background:#3182f61a}.batch-phase-card strong{color:var(--ink);font-size:16px}.batch-dropzone{text-align:center;background:#fbfcfe;border:1px dashed #94a3b857;border-radius:28px;justify-items:center;gap:12px;margin-top:16px;padding:28px 24px;transition:border-color .18s,background-color .18s,transform .18s,box-shadow .18s;display:grid}.batch-dropzone.is-dragging{background:#3182f60f;border-color:#3182f673;transform:translateY(-1px);box-shadow:0 14px 32px #3182f614}.batch-dropzone__icon{width:64px;height:64px;color:var(--accent);background:#3182f61a;border-radius:22px;place-items:center;font-size:28px;font-weight:800;display:grid}.batch-dropzone h3{color:var(--ink);margin:0;font-size:24px;font-weight:800}.batch-dropzone p{max-width:42ch}.batch-progress-card{background:#fff;border:1px solid #e5e9f0f5;border-radius:24px;gap:14px;margin-top:18px;padding:20px;display:grid}.batch-progress-card__summary{justify-content:space-between;align-items:center;gap:14px;display:flex}.batch-progress-card__copy{gap:4px;display:grid}.batch-progress-card__copy strong{color:var(--ink);letter-spacing:-.04em;font-size:clamp(1.9rem,4vw,2.5rem);font-weight:800}.batch-stat-list{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.batch-stat-list span{background:var(--surface-muted);min-height:34px;color:var(--muted);border-radius:999px;align-items:center;padding:0 12px;font-size:13px;font-weight:700;display:inline-flex}.batch-progress-bar{background:#eef2f7;border-radius:999px;width:100%;height:12px;overflow:hidden}.batch-progress-bar__fill{border-radius:inherit;background:linear-gradient(90deg,#8dbbff 0%,#3182f6 100%);height:100%;transition:width .24s}.batch-review-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:18px;display:grid}.batch-review-panel{background:#fff;border:1px solid #e5e9f0f5;border-radius:24px;padding:20px}.batch-review-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.batch-review-item{background:var(--surface-muted);border:1px solid #e5e9f0eb;border-radius:20px;gap:6px;padding:16px 18px;display:grid}.batch-review-item.is-warning{background:#fff9f0;border-color:#f08c002e}.batch-review-item strong{color:var(--ink);font-size:15px}.batch-review-item p{font-size:14px}.batch-status-chip{min-height:30px;color:var(--accent);background:#3182f614;border-radius:999px;justify-self:start;align-items:center;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.batch-status-chip.is-completed{color:#2f9e44;background:#2f9e441f}.batch-status-chip.is-failed,.batch-status-chip.is-warning{color:#d97706;background:#f08c001f}.batch-status-chip.is-uploading,.batch-status-chip.is-updating{color:var(--accent);background:#3182f61a}.dashboard-shell{gap:16px;display:grid}.dashboard-header-card,.dashboard-card{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:28px;padding:24px}.dashboard-summary-grid,.dashboard-grid{gap:16px;display:grid}.dashboard-summary-grid{grid-template-columns:minmax(0,1.1fr) minmax(260px,.9fr)}.dashboard-grid{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr)}.dashboard-card--emphasis{background:linear-gradient(#fff 0%,#f6faff 100%)}.dashboard-card-label{color:var(--muted);margin:0;font-size:15px;font-weight:700}.dashboard-card-value{color:var(--ink);letter-spacing:-.04em;margin-top:14px;font-size:clamp(2rem,4vw,3rem);font-weight:800;display:block}.dashboard-card-note{max-width:42ch;margin-top:10px}.dashboard-section-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.dashboard-chart-card{min-height:420px}.dashboard-chart-wrap{width:100%;height:320px}.dashboard-empty{text-align:center;place-items:center;min-height:220px;display:grid}.dashboard-empty p{color:#8b95a1}.dashboard-breakdown-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.dashboard-breakdown-item{background:var(--surface-muted);border:1px solid #e5e9f0e6;border-radius:22px;grid-template-columns:12px minmax(0,1fr) auto;align-items:center;gap:14px;padding:16px 18px;display:grid}.dashboard-breakdown-dot{border-radius:999px;width:12px;height:12px}.dashboard-breakdown-main{justify-content:space-between;align-items:center;gap:12px;display:flex}.dashboard-breakdown-main strong{color:var(--ink);font-size:15px}.dashboard-breakdown-main span,.dashboard-breakdown-value{color:var(--muted);font-size:14px;font-weight:700}.form-header,.filter-header{align-items:start}.form-header-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.form-description,.filter-description,.detail-subtitle{max-width:48ch;margin-top:8px}.detail-note{color:var(--muted);margin-top:8px;font-size:14px;display:none}.student-form,.counseling-form{margin-top:20px}.counseling-stack{gap:14px;display:grid}.input-card{background:linear-gradient(#fbfdff 0%,#f7faff 100%);border:1px solid #e5e9f0fa;border-radius:24px;padding:18px;box-shadow:inset 0 1px #ffffffe6,0 8px 20px #0f172a08}.field--card-sub{margin-top:14px}.form-grid,.filter-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.field{gap:8px;display:grid}.field--wide{grid-column:1/-1}.field-label{color:var(--ink);font-size:14px;font-weight:700}.field-input{width:100%;min-height:52px;color:var(--ink);background:#fff;border:1px solid #94a3b859;border-radius:16px;outline:none;padding:0 16px;font-size:16px;transition:border-color .16s,box-shadow .16s,background-color .16s}.field-select{cursor:pointer}.field-textarea{resize:vertical;min-height:180px;padding-block:14px}.field-input::placeholder,.field-textarea::placeholder{color:#9aa4b2}.field-input:focus,.field-textarea:focus{border-color:#3182f68c;box-shadow:0 0 0 4px #3182f61a}.field-input.is-error,.field-textarea.is-error{border-color:#d1434399;box-shadow:0 0 0 4px #d1434314}.field-message{min-height:20px;color:var(--muted);font-size:13px}.field-message.is-error{color:var(--danger)}.form-footer,.filter-actions,.detail-actions{justify-content:space-between;align-items:center;gap:16px;margin-top:20px;display:flex}.form-note{font-size:14px}.student-discovery{top:var(--sticky-panel-top);z-index:12;width:100%;margin:0 0 10px;position:sticky}.student-discovery__inner{background:#fff;border:1px solid #e5e9f0f0;border-radius:26px;gap:10px;padding:14px 20px;display:grid;box-shadow:0 16px 36px #0f172a14}.student-discovery__search,.student-discovery__filters{min-width:0}.student-discovery__search{display:none}.student-discovery__title{height:42px;color:var(--ink);letter-spacing:-.045em;white-space:nowrap;align-self:center;align-items:center;gap:10px;margin:0;font-size:clamp(1.1rem,1.45vw,1.3rem);font-weight:800;line-height:1;display:inline-flex}.student-discovery__title-icon{flex:0 0 clamp(24px,1.7vw,28px);justify-content:center;align-items:center;width:clamp(24px,1.7vw,28px);height:42px;font-size:1em;line-height:1;display:inline-flex;transform:translateY(1px)}.student-discovery__title-text{align-items:center;height:42px;line-height:1;display:inline-flex;transform:translateY(1px)}.student-discovery__filter-row{grid-template-columns:max-content max-content;justify-content:flex-start;align-items:center;gap:16px;min-height:42px;margin-bottom:0;display:grid}.student-discovery__filters{gap:10px;width:100%;display:grid}.student-discovery__filters--inline{grid-template-columns:minmax(360px,.92fr) minmax(0,1.08fr);align-items:center;gap:12px}.student-discovery__filter-block{gap:8px;width:100%;display:grid}.student-discovery__filter-block--grade,.student-discovery__filter-block--class{min-width:0}.student-discovery__subhead{color:var(--muted);font-size:13px;font-weight:700}.chip-row{gap:8px;width:100%;display:grid}.chip-row--grade{grid-template-columns:repeat(5,minmax(0,1fr))}.chip-row--grade-selected{grid-template-columns:repeat(3,minmax(0,1fr))}.chip-row--grade-inline{flex-wrap:nowrap;flex:0 auto;align-self:center;align-items:center;gap:8px;width:auto;height:42px;display:flex}.chip-row--grade-inline.chip-row--grade,.chip-row--grade-inline.chip-row--grade-selected{grid-template-columns:none}.chip-row--class{grid-template-columns:repeat(8,minmax(0,1fr))}.chip-row--class-inline{align-items:center}.chip-button{--chip-bg:#f8fafc;--chip-border:#94a3b833;--chip-color:#4e5968;--chip-hover-border:#3182f633;--chip-active-bg:#3182f61a;--chip-active-border:#3182f62e;--chip-active-color:var(--accent);--chip-active-shadow:0 8px 18px #3182f61f;border:1px solid var(--chip-border);background:var(--chip-bg);width:100%;min-height:42px;color:var(--chip-color);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;padding:0 14px;font-size:13px;font-weight:700;transition:transform .16s,background-color .16s,color .16s,border-color .16s,box-shadow .16s;display:inline-flex}.chip-row--grade-inline .chip-button{white-space:nowrap;width:auto;min-width:72px;height:42px;padding:0 16px}.chip-row--grade-inline .chip-button--reset{min-width:96px}.chip-button:hover{border-color:var(--chip-hover-border);transform:translateY(-1px)}.chip-button.is-active{border-color:var(--chip-active-border);background:var(--chip-active-bg);color:var(--chip-active-color);box-shadow:var(--chip-active-shadow)}.chip-button--reset{color:var(--ink);background:#f8fafcf5;border-color:#94a3b82e}.chip-button--all{--chip-bg:#fff1f3;--chip-border:#f48fb15c;--chip-color:#c24672;--chip-hover-border:#e9618c70;--chip-active-bg:#ffe0e8;--chip-active-border:#e15d8980;--chip-active-color:#ad305f;--chip-active-shadow:0 8px 18px #e573972e}.chip-button--grade-1{--chip-bg:#fff8de;--chip-border:#e5cd746b;--chip-color:#8c6a00;--chip-hover-border:#ddb5407a;--chip-active-bg:#ffefb9;--chip-active-border:#ddb5408c;--chip-active-color:#7a5b00;--chip-active-shadow:0 8px 18px #e5bf4a2e}.chip-button--grade-2{--chip-bg:#e9f5ff;--chip-border:#7db2e766;--chip-color:#2563a6;--chip-hover-border:#5f9bd97a;--chip-active-bg:#d9ecff;--chip-active-border:#5f9bd98a;--chip-active-color:#1e5b98;--chip-active-shadow:0 8px 18px #66a8e62e}.chip-button--grade-3{--chip-bg:#edf8ee;--chip-border:#86c28e66;--chip-color:#2f7a3a;--chip-hover-border:#5da86775;--chip-active-bg:#dff1e1;--chip-active-border:#5da86780;--chip-active-color:#276b31;--chip-active-shadow:0 8px 18px #67b57129}.chip-button--reset:disabled{cursor:default;opacity:.5;box-shadow:none;transform:none}.chip-row--class-inline .chip-button{letter-spacing:-.02em;min-height:38px;padding:0 8px;font-size:12px}.infinite-status,.infinite-sentinel{text-align:center;border-radius:20px;margin-top:16px;padding:14px 16px;font-size:14px;font-weight:600}.infinite-status{background:var(--surface-muted);color:var(--muted);border:1px solid #e5e9f0f0}.infinite-status.is-complete{color:var(--accent);background:#3182f614;border-color:#3182f624}.infinite-sentinel{color:var(--muted);background:#f8fafceb;border:1px dashed #94a3b847}.card-header,.detail-header,.section-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.card-header--student-list{grid-template-columns:1fr auto 1fr;align-items:center;gap:0;display:grid}.card-header--student-list>:first-child{text-align:center;grid-column:2;justify-self:center}.card-header--student-list>.card-count{grid-column:3;justify-self:end}.detail-header{align-items:flex-start}.detail-title,.group-title{color:var(--ink);margin:0;font-size:22px;font-weight:800;line-height:1.2}.detail-section+.detail-section{border-top:1px solid #0f172a14;margin-top:28px;padding-top:24px}.card-count,.group-count{background:var(--surface-muted);min-height:36px;color:var(--ink);border-radius:999px;align-items:center;padding:0 14px;font-size:14px;font-weight:700;display:inline-flex}.filter-summary{background:var(--surface-muted);border:1px solid #e5e9f0e6;border-radius:22px;justify-items:end;gap:6px;padding:14px 16px;display:grid}.filter-summary strong{color:var(--ink);font-size:26px}.filter-summary span{color:var(--muted);font-size:13px}.ghost-button,.primary-button,.secondary-button{cursor:pointer;border:0;border-radius:16px;min-height:48px;padding:0 18px;font-size:15px;font-weight:700;transition:transform .16s,box-shadow .16s,background-color .16s}.primary-button{background:var(--accent);color:#fff;box-shadow:0 12px 24px #3182f62e}.secondary-button{background:var(--surface-muted);color:var(--ink)}.ghost-button{color:var(--muted);background:0 0;border:1px solid #94a3b838}.ghost-button:hover,.primary-button:hover,.secondary-button:hover{transform:translateY(-1px)}.ghost-button:disabled,.primary-button:disabled,.secondary-button:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.record-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.student-grid__groups{gap:10px;padding-right:6px;display:grid}.student-grid{min-height:0;max-height:min(680px, calc(100vh - var(--sticky-panel-top) - 28px));scrollbar-gutter:stable;flex:auto;padding-right:0;position:relative;overflow-y:auto}.student-grid:after{content:"";pointer-events:none;z-index:3;background:linear-gradient(#fff 0%,#fffffff5 48%,#fff0 100%);height:12px;position:absolute;top:-18px;left:0;right:0}.student-grid__list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.student-grid__list--home{grid-template-columns:repeat(4,minmax(0,1fr))}.student-grid__list--counseling{grid-template-columns:repeat(3,minmax(0,1fr))}.student-grid__item{--student-card-bg:var(--surface-muted);--student-card-border:#e5e9f0eb;--student-card-selected-bg:#3182f60f;--student-card-selected-border:#3182f647;--student-card-selected-shadow:0 12px 28px #3182f61f;background:var(--student-card-bg);border:1px solid var(--student-card-border);cursor:pointer;text-align:left;border-radius:22px;grid-template-columns:64px minmax(0,1fr);place-items:center stretch;gap:12px;min-height:98px;padding:12px 14px;transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s;display:grid}.student-grid__item:hover{transform:translateY(-1px);box-shadow:0 10px 24px #0f172a0f}.student-grid__item.is-selected{border-color:var(--student-card-selected-border);background:var(--student-card-selected-bg);box-shadow:var(--student-card-selected-shadow)}.student-grid__item--summary{cursor:default;grid-template-columns:184px minmax(0,1fr);width:100%}.student-grid__item--summary:hover{box-shadow:none;transform:none}.student-grid__item--summary .student-avatar.student-grid__avatar{flex-basis:184px;width:184px;height:184px}.student-grid__item--summary .student-grid__content{gap:12px}.student-grid__item--summary .student-grid__identity{gap:6px}.student-grid__item--summary .student-grid__school-number{font-size:24px;line-height:1.15}.student-grid__item--summary .student-grid__name{font-size:30px;font-weight:800;line-height:1.18}.student-grid__item--summary .student-grid__count{min-height:40px;padding:0 16px;font-size:18px;font-weight:800}.student-grid__item--grade-1{--student-card-bg:#fff8de;--student-card-border:#e5cd746b;--student-card-selected-bg:#ffefb9;--student-card-selected-border:#ddb5408c;--student-card-selected-shadow:0 12px 28px #e5bf4a2e}.student-grid__item--grade-2{--student-card-bg:#e9f5ff;--student-card-border:#7db2e766;--student-card-selected-bg:#d9ecff;--student-card-selected-border:#5f9bd98a;--student-card-selected-shadow:0 12px 28px #66a8e62e}.student-grid__item--grade-3{--student-card-bg:#edf8ee;--student-card-border:#86c28e66;--student-card-selected-bg:#dff1e1;--student-card-selected-border:#5da86780;--student-card-selected-shadow:0 12px 28px #67b57129}.student-avatar{background:#e8f3ff;border-radius:999px;place-items:center;width:44px;height:44px;display:grid;overflow:hidden}.student-avatar img,.detail-profile__avatar-image{object-fit:cover;object-position:center top;width:100%;height:100%}.student-avatar.student-grid__avatar{flex:0 0 64px;width:64px;height:64px}.student-avatar span{place-items:center;width:100%;height:100%;font-size:18px;font-weight:800;display:grid}.student-grid__content{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:100%;min-width:0;display:flex}.student-grid__identity{flex-direction:column;align-items:center;gap:2px;width:100%;min-width:0;display:flex}.student-grid__name{text-overflow:ellipsis;white-space:nowrap;width:100%;min-width:0;color:var(--ink);letter-spacing:-.02em;text-align:center;font-size:14px;font-weight:700;line-height:1.25;display:block;overflow:hidden}.student-grid__school-number,.student-grid__count{color:var(--ink);letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin:0;font-size:15px;font-weight:700}.student-grid__school-number{white-space:nowrap;color:var(--ink);text-align:center;font-size:14px;line-height:1.1}.student-grid__count{min-height:22px;color:var(--accent);white-space:nowrap;background:#fff;border-radius:999px;justify-content:center;align-self:center;align-items:center;padding:0 7px;font-size:11px;font-weight:800;display:inline-flex}.record-content{margin-top:4px}.record-item{background:var(--surface-muted);border:1px solid #e5e9f0e6;border-radius:22px;padding:18px}.record-meta{color:var(--ink);justify-content:space-between;align-items:center;gap:12px;display:flex}.record-meta strong{color:var(--ink);font-size:16px}.record-badge{min-height:32px;color:var(--accent);background:#3182f61a;border-radius:999px;align-items:center;padding:0 12px;font-size:13px;font-weight:700;display:inline-flex}.record-content{color:var(--ink);white-space:pre-wrap;line-height:1.65}.counseling-board{width:100%;grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr)!important}.detail-placeholder,.record-empty{text-align:center;justify-items:center;gap:12px;display:grid}.record-empty{padding:20px 0 8px}.empty-card{text-align:center;justify-items:center;gap:12px;padding-block:40px;display:grid}.empty-card p,.detail-placeholder p,.record-empty p{max-width:52ch}.empty-icon{background:var(--surface-muted);width:72px;height:72px;color:var(--accent);border-radius:24px;place-items:center;font-size:28px;font-weight:800;display:grid}.skeleton-list,.record-skeleton-list{gap:12px;display:grid}.toast{z-index:20;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff5;border:1px solid #3182f633;border-radius:22px;min-width:min(360px,100vw - 32px);max-width:420px;padding:16px 18px;position:fixed;bottom:20px;right:20px;box-shadow:0 18px 40px #0f172a29}.toast strong{color:var(--ink);font-size:15px;display:block}.toast p{color:var(--muted);margin-top:4px;font-size:14px}.skeleton-row,.record-skeleton{background:linear-gradient(90deg,#edf2f7e6,#fffffff2,#edf2f7e6) 0 0/200% 100%;border-radius:22px;animation:1.25s linear infinite pulse}.skeleton-row{height:88px}.record-skeleton{height:140px}@keyframes pulse{0%{background-position:200% 0}to{background-position:-200% 0}}@media (width<=1080px){.auth-panel,.workspace,.home-overview-grid,.dashboard-summary-grid,.batch-review-grid,.dashboard-grid{grid-template-columns:1fr}.detail-column,.home-history-card{position:static}.counseling-board{grid-template-columns:1fr!important}}@media (width<=820px){.page{--sticky-header-top:12px;--sticky-header-height:150px;--sticky-stack-gap:6px;--sticky-discovery-height:132px;padding-inline:16px}.page--auth{padding-inline:16px}.hero-card,.dashboard-summary-grid,.form-grid,.filter-grid{grid-template-columns:1fr}.view-switcher{justify-content:stretch}.view-switcher__track{justify-content:stretch;width:100%}.view-switcher__button{flex:1}.toolbar,.form-footer,.filter-actions,.detail-actions,.detail-header,.section-row,.dashboard-section-header,.app-header,.batch-progress-card__summary,.student-discovery__meta{flex-direction:column;align-items:stretch}.form-header-actions,.toolbar-actions,.detail-profile__actions,.batch-upload-card__actions{flex-direction:column;width:100%}.filter-summary{justify-items:start;width:100%}.student-grid__list,.student-grid__list--home,.student-grid__list--counseling{grid-template-columns:repeat(3,minmax(0,1fr))}.student-grid{max-height:min(560px, calc(100vh - var(--sticky-panel-top) - 36px))}.detail-profile{flex-direction:column;align-items:flex-start;width:100%}.detail-profile__avatar{width:96px;height:96px}.record-meta{flex-direction:column;align-items:flex-start}.dashboard-breakdown-item{grid-template-columns:12px minmax(0,1fr)}.dashboard-breakdown-value{grid-column:2}.student-discovery__inner{padding:18px}.student-discovery__filters--inline{grid-template-columns:1fr}.student-discovery__filter-row,.chip-row--grade-inline{flex-wrap:wrap;height:auto;min-height:0}.chip-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.chip-row--grade-selected{grid-template-columns:repeat(2,minmax(0,1fr))}.chip-row--class,.chip-row--class-inline{grid-template-columns:repeat(4,minmax(0,1fr))}.auth-card{padding:32px 24px}.auth-school-badge{padding-inline:12px}.auth-school-badge__logo{flex-basis:42px;width:42px;height:42px}.auth-title{max-width:none}.profile-chip{min-width:0}.app-header__search{width:100%;min-width:0}.batch-dropzone{padding-inline:18px}.batch-dropzone h3{font-size:22px}.batch-stat-list{justify-content:flex-start}.toast{min-width:auto;max-width:none;bottom:16px;left:16px;right:16px}}@media (width<=768px){.page{--sticky-header-top:calc(env(safe-area-inset-top,0px) + 8px);--sticky-header-height:168px;--sticky-stack-gap:6px;--sticky-discovery-height:148px;padding:20px 12px 40px}.app-header{border-radius:20px;gap:14px;margin-bottom:6px;padding:14px}.app-header__brand h2{font-size:1.05rem;line-height:1.08}.app-header__identity{align-items:center;gap:12px;width:100%}.app-header__copy{margin-top:6px;font-size:14px;line-height:1.6}.school-logo{flex-basis:24px;width:24px;height:24px}.app-header__nav{gap:18px;margin-left:10px}.app-header__actions{flex-direction:column;align-items:stretch;width:100%}.app-header__search{width:100%;min-width:0}.profile-chip,.app-header__actions>.ghost-button{width:100%}.view-switcher{margin-bottom:12px}.view-switcher__track{border-radius:20px;width:100%;padding:6px}.workspace{flex-direction:column;gap:16px;display:flex}.home-overview-grid{gap:16px}.main-column,.detail-column{width:100%}.hero-card,.toolbar,.form-card,.batch-upload-card,.filter-card,.list-card,.empty-card,.detail-card{border-radius:24px;padding:18px}.hero-card{gap:16px}.toolbar strong{font-size:16px}.student-discovery{z-index:20}.student-discovery__inner{border-radius:22px;gap:14px;width:100%;padding:16px}.student-discovery__search,.student-discovery__search .field,.student-discovery__search .field-input{width:100%}.student-discovery__search .field-input{min-height:56px}.chip-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.chip-row--class,.chip-row--class-inline{grid-template-columns:repeat(4,minmax(0,1fr))}.chip-button{justify-content:center;width:100%;min-height:48px}.student-grid__list,.student-grid__list--home,.student-grid__list--counseling{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.student-grid{max-height:540px}.toolbar-actions,.form-header-actions,.detail-profile__actions,.batch-upload-card__actions{gap:10px}.toolbar-actions>button,.form-header-actions>button,.detail-profile__actions>button,.batch-upload-card__actions>button,.form-footer .primary-button{width:100%}.detail-profile__actions .ghost-button{justify-content:center}}@media (width<=560px){.page{--sticky-header-top:calc(env(safe-area-inset-top,0px) + 6px);--sticky-header-height:156px;--sticky-stack-gap:6px;--sticky-discovery-height:160px;padding-inline:10px}.hero-card,.toolbar,.form-card,.batch-upload-card,.filter-card,.list-card,.empty-card,.detail-card,.app-header{border-radius:20px}.chip-row{grid-template-columns:1fr}.chip-row--class,.chip-row--class-inline,.student-grid__list,.student-grid__list--home,.student-grid__list--counseling{grid-template-columns:repeat(2,minmax(0,1fr))}.student-grid{max-height:480px}.student-grid__item{grid-template-columns:52px minmax(0,1fr);min-height:92px;padding:10px}.student-avatar.student-grid__avatar{flex-basis:52px;width:52px;height:52px}.student-grid__school-number,.student-grid__count,.student-grid__name,.detail-avatar-note{font-size:13px}.profile-chip__copy span{white-space:normal;text-overflow:unset;overflow:visible}.app-header__identity{flex-wrap:wrap;align-items:center;gap:12px}.school-logo{flex-basis:22px;width:22px;height:22px}.app-header__nav{gap:16px;width:100%;margin-left:0;padding-left:34px}.app-header__nav-button{min-height:34px;font-size:14px}}
