body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}#root,body,html{height:100%}.ant-layout{min-height:100vh}.ant-layout-content{background:#fff;border-radius:6px;margin:24px 16px;padding:24px}.loading-container{align-items:center;display:flex;height:200px;justify-content:center}@media (max-width:768px){.ant-layout-content{margin:16px 8px;padding:16px}}.highlight-row>td{background-color:#e6f7ff!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.highlight-row:hover>td{background-color:#bae0ff!important}.login-container{align-items:center;background:linear-gradient(135deg,#036,#00264d);background-attachment:fixed;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-bg-image{background:url(/static/media/login-bg.faf36fbb79eeaa5507d5.jpg) 50%/cover no-repeat fixed,linear-gradient(135deg,#036,#00264d);filter:blur(2px);inset:0;position:absolute;transform:scale(1.02)}.login-overlay{background:radial-gradient(circle at 20% 30%,#ffffff26,#0000 50%),radial-gradient(circle at 80% 70%,#00000040,#0000 55%);inset:0;position:absolute}.login-content{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:24px;position:relative;z-index:1}.login-row{max-width:1200px;width:100%}.login-illustration{color:#fff}.illus-title{font-size:28px;font-weight:700;letter-spacing:.5px;margin-bottom:24px;text-align:center;text-shadow:0 2px 8px #0000004d;text-transform:uppercase}.illus-panels{grid-gap:24px;align-items:center;display:grid;gap:24px;grid-template-columns:280px 1fr 220px;grid-template-rows:220px 160px;justify-content:center}.illus-panels .panel{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff40;border:1px solid #ffffff59;border-radius:16px;box-shadow:0 10px 40px #0003}.panel.tall{grid-row:1/span 2}.panel.wide{grid-column:2;height:220px}.panel.donut{border-radius:999px;grid-column:3;height:120px}.panel.small{grid-column:3;height:160px}.login-right{display:flex;justify-content:flex-end}.login-background{position:relative;width:100%}.login-background:before{background:radial-gradient(circle at 25% 25%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 75% 75%,#ffffff1a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffffa!important;border:none;border-radius:20px!important;box-shadow:0 20px 60px #00000026;overflow:hidden;position:relative;width:100%;z-index:1}.login-card:before{background:linear-gradient(90deg,coral,coral);content:"";height:4px;left:0;position:absolute;right:0;top:0;z-index:-1}.login-header{margin-bottom:32px;padding:20px 0;text-align:center}.logo-container{margin-bottom:20px}.login-logo{height:64px;max-width:200px;object-fit:contain;width:auto}.login-title{color:#1a1a1a;font-size:24px;font-weight:600;margin-bottom:8px!important}.login-subtitle{color:#666;font-size:14px}.ant-form-item{margin-bottom:20px}.login-container .ant-input,.login-container .ant-input-affix-wrapper{border:1px solid #e0e0e0;border-radius:10px;font-size:14px;padding:12px 16px;transition:all .3s ease}.login-container .ant-input-affix-wrapper:hover,.login-container .ant-input:hover{border-color:#036;box-shadow:0 0 0 2px #0033661a}.login-container .ant-input-affix-wrapper-focused,.login-container .ant-input:focus{border-color:#036;box-shadow:0 0 0 2px #0363}.ant-btn-primary{background:coral!important;border:1px solid coral!important;border-radius:10px;box-shadow:0 4px 15px #ff7f504d;font-weight:500;transition:all .3s ease}.ant-btn-primary:hover{background:#ff6a33!important;box-shadow:0 6px 20px #ff7f5066;transform:translateY(-1px)}.ant-btn-primary:active{transform:translateY(0)}.ant-btn-primary[disabled]{background:#d9d9d9;box-shadow:none;transform:none}.login-footer{border-top:1px solid #f0f0f0;margin-top:24px;padding-top:20px;text-align:center}.ant-form-item-explain-error{color:#ff4d4f;font-size:12px;margin-top:4px}.ant-message{z-index:9999}@media (max-width:768px){.login-content{padding:12px}.login-illustration{display:none}.login-title{font-size:20px}.login-card{margin:10px auto}.login-header{margin-bottom:24px;padding:10px 0}}@media (max-width:480px){.login-title{font-size:18px}.login-subtitle{font-size:13px}.ant-btn-primary{font-size:15px;height:44px}}.ant-spin-spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-container .ant-btn:focus,.login-container .ant-input-affix-wrapper:focus-within,.login-container .ant-input:focus{outline:2px solid #036;outline-offset:2px}@media (prefers-contrast:high){.login-card{background:#fff!important;border:2px solid #000}.ant-btn-primary{background:#000!important;color:#fff!important}}.dashboard-layout{background:#f5f5f5;min-height:100vh}.dashboard-header{background:linear-gradient(135deg,#127feb,#003a7b);box-shadow:0 2px 8px #0000001a;padding:0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;height:64px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 24px}.logo-section h3{font-size:20px;font-weight:600;margin:0!important}.user-section .ant-btn{align-items:center;border-radius:20px;display:flex;gap:8px;height:auto;padding:8px 12px;transition:all .3s ease}.user-section .ant-btn:hover{background:#ffffff1a}.dashboard-content{background:#f5f5f5;padding:0}.content-container{margin:0 auto;max-width:1200px;padding:24px}.welcome-card{background:linear-gradient(135deg,#3459ff0d,#0016810d);border:none;border-radius:12px;box-shadow:0 4px 20px #00000014;margin-bottom:24px}.welcome-badge{background:#52c41a1a;border-radius:12px;padding:20px;text-align:center}.stat-card{border:none;border-radius:12px;box-shadow:0 2px 12px #0000000f;height:100%;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 20px #0000001f;transform:translateY(-2px)}.stat-card .ant-statistic-title{color:#666;font-size:14px;font-weight:500;margin-bottom:8px}.stat-card .ant-statistic-content{font-size:28px;font-weight:600}.feature-card{border:none;border-radius:12px;box-shadow:0 2px 12px #0000000f;height:100%}.feature-card .ant-card-head{border-bottom:1px solid #f0f0f0;border-radius:12px 12px 0 0}.feature-card .ant-card-head-title{font-size:16px;font-weight:600}.feature-list{display:flex;flex-direction:column;gap:16px}.feature-item{align-items:center;border-radius:8px;display:flex;gap:12px;padding:12px;transition:all .3s ease}.feature-item.completed{background:#52c41a14;border:1px solid #52c41a33}.feature-item.pending{background:#faad1414;border:1px solid #faad1433}.feature-item:hover{transform:translateX(4px)}.feature-item span{color:#333;font-size:14px;font-weight:500}.progress-card{background:linear-gradient(135deg,#667eea05,#764ba205);border:none;border-radius:12px;box-shadow:0 2px 12px #0000000f}.progress-item{border:2px solid #f0f0f0;border-radius:12px;padding:20px;text-align:center;transition:all .3s ease}.progress-item.active{background:#1890ff0d;border-color:#1890ff;transform:scale(1.02)}.progress-item:hover{border-color:#1890ff;box-shadow:0 4px 16px #1890ff1a}.ant-dropdown-menu{border:none;border-radius:8px;box-shadow:0 4px 20px #00000026}.ant-dropdown-menu-item{font-size:14px;padding:12px 16px}.ant-dropdown-menu-item:hover{background:#f5f5f5}.ant-dropdown-menu-item-danger:hover{background:#fff2f0;color:#ff4d4f}@media (max-width:768px){.content-container{padding:16px}.header-content{padding:0 16px}.logo-section h3{font-size:16px}.welcome-card .ant-row{text-align:center}.welcome-badge{margin-top:20px}.progress-item{margin-bottom:16px;padding:16px}}@media (max-width:576px){.stat-card .ant-statistic-content{font-size:24px}.feature-item{padding:8px}.feature-item span{font-size:13px}.user-section .ant-space{flex-direction:column;gap:4px}.user-section .ant-typography{font-size:12px}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.feature-card,.progress-card,.stat-card,.welcome-card{animation:slideIn .6s ease-out}.dashboard-loading{align-items:center;background:#f5f5f5;display:flex;height:100vh;justify-content:center}.status-indicator{border-radius:50%;display:inline-block;height:8px;margin-right:8px;width:8px}.status-indicator.connected{background:#52c41a;box-shadow:0 0 6px #52c41a66}.status-indicator.disconnected{background:#ff4d4f;box-shadow:0 0 6px #ff4d4f66}.dashboard-content::-webkit-scrollbar{width:6px}.dashboard-content::-webkit-scrollbar-track{background:#f1f1f1}.dashboard-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.dashboard-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.dashboard-page-shell{box-sizing:border-box;max-width:100%;padding:clamp(12px,3.8vw,24px)}.dashboard-page-welcome{color:#1890ff;font-size:clamp(1.1rem,4.2vw,1.5rem);font-weight:600;line-height:1.35;margin-bottom:clamp(14px,4vw,24px)}.dashboard-institution-banner{background:linear-gradient(180deg,#065dc0 88%,#e35f01);border-radius:8px;color:#fff;margin-bottom:clamp(14px,4vw,24px);padding:clamp(12px,3.8vw,24px)}.dashboard-institution-title{color:#fff;font-size:clamp(.88rem,3.4vw,1.125rem);font-weight:600;line-height:1.4;margin:0}.dashboard-tabs-responsive .ant-tabs-nav{margin-bottom:clamp(12px,3vw,18px)}.dashboard-tabs-responsive .ant-tabs-nav-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;touch-action:pan-x pan-y}.dashboard-tabs-responsive .ant-tabs-nav-list{flex-wrap:nowrap}.dashboard-tabs-responsive .ant-tabs-tab{-webkit-margin-end:4px!important;flex-shrink:0;margin-inline-end:4px!important}.dashboard-tab-label{align-items:center;display:inline-flex;font-size:clamp(13px,3.2vw,15px);gap:6px;white-space:nowrap}.dashboard-stat-grid{margin-bottom:clamp(20px,5vw,32px)}.dashboard-stat-grid .ant-statistic-title{font-size:clamp(12px,2.9vw,14px);white-space:normal;word-break:break-word}.dashboard-stat-grid .ant-card-body{padding:clamp(12px,3.2vw,24px)!important}.dashboard-stat-grid .ant-statistic-content-value{font-size:clamp(1.125rem,4vw,1.875rem)}.dashboard-chart-panel{margin-bottom:clamp(8px,2vw,12px)}.dashboard-chart-panel .ant-card-head-title{overflow:visible;padding-block:2px;white-space:normal}.dashboard-chart-title{font-size:clamp(13px,3.6vw,16px);line-height:1.35}.dashboard-chart-panel canvas{max-width:100%}.dashboard-report-embed,.dashboard-year-stats-embed{-webkit-overflow-scrolling:touch;max-width:100%;overflow-x:auto}@media (max-width:575px){.dashboard-report-embed,.dashboard-year-stats-embed{margin-left:clamp(-8px,-1.8vw,0);margin-right:clamp(-8px,-1.8vw,0)}}@media (prefers-reduced-motion:reduce){.dashboard-tabs-responsive .ant-tabs-nav-wrap{scroll-behavior:auto}}.admission-dashboard-widget{margin-top:24px}.admission-major-card{background:#f8fafc;border-radius:8px;text-align:center;transition:transform .2s,box-shadow .2s}.admission-major-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.admission-major-count{color:#1890ff;font-size:28px;font-weight:700;margin-bottom:4px}.admission-major-name{color:#64748b;font-size:13px;line-height:1.3}.grading-form .ant-radio-button-wrapper-checked:not(.ant-radio-button-wrapper-disabled){background-color:#1890ff!important;border-color:#1890ff!important;color:#fff!important}.grading-form .ant-radio-button-wrapper-checked:not(.ant-radio-button-wrapper-disabled):hover{background-color:#40a9ff!important;border-color:#40a9ff!important}.grading-group{border-bottom:1px solid #f0f0f0;margin-bottom:24px;padding-bottom:16px}.grading-criterion .ant-form-item-label{font-weight:500}:root{--main-table-radius:10px;--main-table-shadow:0 2px 16px 0 #00000012;--main-table-border:1px solid #e6e6e6;--main-table-header-bg:#f5f7fa;--main-table-header-color:#036;--main-table-padding:12px 8px;--main-table-font-size:13px;--main-table-font-weight:500;--main-table-row-hover:#f0f6ff}.page-makeup-management{font-family:Roboto,Arial,sans-serif}.page-makeup-management .ant-card{border:1px solid #e6e6e6;border:var(--main-table-border);border-radius:12px;box-shadow:0 2px 16px 0 #00000012;box-shadow:var(--main-table-shadow)}.filter-row{align-items:center;display:flex;gap:16px;margin-bottom:16px}.filter-row .ant-input-search,.filter-row .ant-select{font-size:16px;height:40px}.action-row{display:flex;gap:12px;justify-content:flex-end;margin-bottom:16px}.main-table-container{background:#fff;border:1px solid #e6e6e6;border:var(--main-table-border);border-radius:10px;border-radius:var(--main-table-radius);box-shadow:0 2px 16px 0 #00000012;box-shadow:var(--main-table-shadow);margin-bottom:24px;padding:16px 12px 12px}.ant-table{border-radius:10px!important;border-radius:var(--main-table-radius)!important;overflow:hidden}.ant-table-thead>tr>th{background:#f5f7fa!important;background:var(--main-table-header-bg)!important;color:#036!important;color:var(--main-table-header-color)!important;font-size:13px;font-size:var(--main-table-font-size);font-weight:500;font-weight:var(--main-table-font-weight);padding:12px 8px!important;padding:var(--main-table-padding)!important;text-align:center}.ant-table-tbody>tr>td{font-size:13px;padding:10px 6px!important;text-align:justify}.ant-table-tbody>tr{transition:background .2s}.ant-table-tbody>tr:hover{background:#f0f6ff!important;background:var(--main-table-row-hover)!important}.ant-table-tbody .ant-checkbox-wrapper,.ant-table-tbody input{align-items:center;display:flex;justify-content:center;margin:0 auto}.main-table-title{color:#036;font-size:18px;font-weight:700;margin-bottom:10px}@media (max-width:900px){.filter-row{align-items:stretch;flex-direction:column;gap:8px}.main-table-container{padding:8px 2px}.main-table-title{font-size:13px}.ant-table-tbody>tr>td,.ant-table-thead>tr>th{font-size:11px;padding:6px 2px!important}.action-row{flex-direction:column;gap:6px}}@media (max-width:600px){.main-table-title{font-size:12px;margin-bottom:4px}.main-table-container{margin-bottom:12px;padding:2px 0}.ant-table-tbody>tr>td,.ant-table-thead>tr>th{font-size:11px;padding:2px 1px!important}}.school-schedule-overview-wrapper{padding:16px}.school-schedule-controls{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000f;margin-bottom:12px}.schedule-header-title{margin-bottom:8px;text-align:center}.schedule-header-title h2{color:#333;font-size:18px;font-weight:700;margin:0;padding:8px 0;text-transform:uppercase}.schedule-table-scroll{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000000f;overflow-x:auto}.schedule-grid-table{border-collapse:collapse;font-size:12px;line-height:1.35;min-width:960px;width:100%}.schedule-grid-table td,.schedule-grid-table th{border:1px solid #c8d0d9;padding:4px 6px;vertical-align:top}.schedule-grid-table thead th{background:#e8f0fe;color:#1a3353;font-weight:600;padding:6px 8px;position:-webkit-sticky;position:sticky;text-align:center;top:0;white-space:nowrap;z-index:2}.col-class{min-width:80px;width:100px}.col-buoi{min-width:28px;text-align:center;width:30px}.col-day{min-width:110px;width:calc(14.28571% - 18.57143px)}.cell-class{color:#1a3353;font-size:11px;line-height:1.25}.cell-buoi,.cell-class{background:#fafbfc;font-weight:600;text-align:center;vertical-align:middle}.cell-buoi{color:#555}.cell-schedule{font-size:11px;min-height:28px;padding:3px 4px}.row-first-buoi td{border-top:2px solid #9ab}.schedule-cell-content{display:flex;flex-direction:column;gap:1px;padding:2px 0}.schedule-cell-content+.schedule-cell-content{border-top:1px dashed #ddd;margin-top:4px;padding-top:4px}.cell-subject{color:#1a73e8;font-size:11px;font-weight:600}.cell-buoi-so{color:#888;font-size:10px}.cell-teacher{color:#333;font-size:10.5px}.cell-room{color:#888;font-size:10px;font-style:italic}@media print{.ant-layout-header,.ant-layout-sider,.no-print,.school-schedule-controls{display:none!important}.ant-layout,.ant-layout-content,body,html{background:#fff!important;margin:0!important;overflow:visible!important;padding:0!important}.ant-layout{margin-left:0!important}.school-schedule-overview-wrapper{background:#fff;margin:0;padding:0}.schedule-print-area{width:100%}.schedule-table-scroll{border-radius:0;box-shadow:none;overflow:visible}.schedule-grid-table{font-size:9pt;min-width:0;page-break-inside:avoid}.schedule-grid-table th{background:#e0e8f0!important}.cell-buoi,.cell-class,.schedule-grid-table th{color-adjust:exact!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.cell-buoi,.cell-class{background:#f5f7f9!important}.schedule-header-title h2{font-size:16pt;margin-bottom:8px}@page{size:A4 landscape;margin:10mm}}.App{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh;text-align:center}.App-header{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem}.App-header h1{font-size:3rem;margin-bottom:1rem;text-shadow:2px 2px 4px #0000004d}.App-header p{font-size:1.2rem;margin-bottom:2rem;opacity:.9}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:2rem 0;max-width:800px;width:100%}.feature-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:15px;padding:1.5rem;transition:transform .3s ease}.feature-card:hover{transform:translateY(-5px)}.feature-card h3{color:#fff;margin-bottom:1rem}.feature-card ul{padding-left:1rem;text-align:left}.feature-card li{margin-bottom:.5rem;opacity:.9}.next-steps{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:15px;margin-top:3rem;max-width:600px;padding:2rem}.next-steps h3{margin-bottom:1rem}.next-steps ol{padding-left:1.5rem;text-align:left}.next-steps li{font-size:1.1rem;margin-bottom:.75rem}.next-steps code{background:#0000004d;border-radius:4px;color:gold;font-family:Courier New,monospace;padding:.2rem .5rem}.next-steps a{color:gold;text-decoration:none}.next-steps a:hover{text-decoration:underline}@media (max-width:768px){.App-header{padding:1rem}.App-header h1{font-size:2rem}.features-grid{gap:1rem;grid-template-columns:1fr}.feature-card,.next-steps{padding:1rem}}.highlight-row{background-color:#fffbe6!important}