@import "https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box}html,body{color:#12213a;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#eaf1fb;margin:0;font-family:Be Vietnam Pro,Arial,Helvetica,sans-serif}button,input,select,textarea{font-family:Be Vietnam Pro,Arial,Helvetica,sans-serif}.auth-screen,.app-screen{background:#dce9fb;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-phone,.app-frame{background:#f7f9fe;width:100%;max-width:390px;min-height:780px;position:relative;overflow:hidden;box-shadow:0 22px 55px #0b2b5a30}.login-phone{background:linear-gradient(#0035ad 0%,#0873e3 55%,#28b6ff 100%);border-radius:0}.login-phone:before{content:"";background:radial-gradient(circle at top,#ffffff30,#0000 36%),radial-gradient(circle at bottom,#ffffff40,#0000 36%);position:absolute;inset:0}.login-hero{z-index:1;text-align:center;color:#fff;padding:72px 22px 0;position:relative}.login-logo{object-fit:cover;background:#fff;border-radius:50%;width:118px;height:118px;margin-bottom:22px}.login-hero h1{letter-spacing:.4px;margin:0 0 9px;font-size:21px;font-weight:900}.login-hero p{opacity:.92;margin:0;font-size:12px;font-weight:700;line-height:1.35}.login-form{z-index:1;padding:42px 22px;position:relative}.field-box{background:#fff;border-radius:12px;align-items:center;gap:12px;height:54px;margin-bottom:14px;padding:0 16px;display:flex;box-shadow:0 7px 18px #07368124}.field-box span{color:#66748b}.field-box input{color:#334155;border:0;outline:0;flex:1;font-weight:700}.field-box button{color:#64748b;background:0 0;border:0}.login-options{color:#fff;justify-content:space-between;align-items:center;margin-top:3px;font-size:12px;font-weight:700;display:flex}.login-options button{color:#fff;background:0 0;border:0;font-weight:700}.primary-login-button{color:#fff;background:linear-gradient(90deg,#0753c8,#0047bd);border:0;border-radius:26px;width:100%;height:52px;margin-top:58px;font-weight:900;box-shadow:0 15px 28px #002b8b55}.app-frame{background:#fff;flex-direction:column;display:flex}.app-header{color:#fff;background:#0353bd;align-items:center;gap:10px;height:58px;padding:0 12px;display:flex}.header-icon{color:#fff;background:0 0;border:0;width:34px;height:34px;font-size:24px}.header-title{text-align:center;flex:1}.header-title h1{margin:0;font-size:18px;font-weight:900}.header-title p{opacity:.9;margin:3px 0 0;font-size:11px}.tabbar{color:#fff;background:#0754bd;height:58px;display:flex;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -5px 18px #0b4da530}.tabbar button{color:#fff;opacity:.76;background:0 0;border:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;font-size:11px;font-weight:700;display:flex}.tabbar button span{font-size:18px}.tabbar button.active{opacity:1;background:#ffffff12}.date-row,.date-switch{color:#27364f;justify-content:center;align-items:center;gap:10px;margin-bottom:14px;font-size:13px;display:flex}.date-switch button{color:#0b57bd;background:#fff;border:0;font-size:22px}.summary-card{color:#31405d;background:#f1f2ff;border-radius:9px;gap:6px;margin-bottom:12px;padding:13px 17px;display:grid;box-shadow:0 4px 12px #0b215a10}.summary-card strong{color:#194b94}.summary-card span{font-size:13px}.card-list{gap:10px;display:grid}.round-card,.detail-card{background:#fff;border:1px solid #e8edf5;border-radius:10px;align-items:center;gap:10px;padding:12px;display:flex;box-shadow:0 3px 9px #1d315710}.round-mark{border-radius:50%;place-items:center;width:28px;height:28px;font-weight:900;display:grid}.round-mark.done{color:#16a34a;background:#eaf9ee}.round-mark.active{color:#2563eb;background:#e9f2ff}.round-mark.pending{color:#8792a6;background:#f8fafc}.round-info,.detail-card div{flex:1}.round-info h2,.detail-card h2{margin:0 0 4px;font-size:14px}.round-info p,.detail-card p,.detail-card small{color:#526070;margin:0 0 3px;font-size:12px;display:block}.mini-primary,.wide-primary,.extra-button,.bottom-actions .primary{color:#fff;background:#0754bd;border:0;border-radius:8px;padding:9px 12px;font-size:12px;font-weight:800}.text-action{color:#0754bd;background:0 0;border:0;font-size:11px;font-weight:800}.extra-button{color:#0754bd;background:#fff;border:1px solid #8fb4ee;border-radius:18px;width:100%;margin:12px 0}.wide-primary{border-radius:8px;width:100%;height:48px;margin-top:12px;position:sticky;bottom:8px}.pill-tabs{background:#fff;border-bottom:1px solid #e5eaf2;margin:-2px -13px 12px;padding:0 8px;display:flex}.pill-tabs button{color:#586579;background:0 0;border:0;border-bottom:2px solid #0000;flex:1;padding:11px 4px;font-size:12px;font-weight:700}.pill-tabs button.active{color:#0754bd;border-bottom-color:#0754bd}.status-badge{white-space:nowrap;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:800}.status-badge.success{color:#18944e;background:#e9f9ef}.status-badge.warning{color:#e08200;background:#fff2dd}.status-badge.neutral{color:#6a7485;background:#f2f5fa}.detail-card{cursor:pointer}.detail-card>span{color:#7b8797}.search-row{background:#fff;border:1px solid #e1e8f2;border-radius:8px;align-items:center;height:40px;margin-bottom:10px;padding:0 11px;display:flex}.search-row input{border:0;outline:0;flex:1}.class-list{background:#fff;border:1px solid #e8edf5;border-radius:10px;overflow:hidden}.class-row{cursor:pointer;border-bottom:1px solid #edf1f7;align-items:center;gap:10px;height:43px;padding:0 10px;display:flex}.class-row strong{flex:1;font-size:13px}.class-row:last-child{border-bottom:0}.bottom-actions{background:#fff;gap:12px;margin-top:12px;padding-top:10px;display:flex;position:sticky;bottom:2px}.bottom-actions button{color:#0f3e83;background:#fff;border:1px solid #bac7da;border-radius:8px;flex:1;height:44px;font-size:12px;font-weight:800}.bottom-actions .primary{color:#fff;background:#0754bd;border-color:#0754bd}.form-card,.confirm-card,.manage-panel{background:#fff;border:1px solid #e7edf6;border-radius:10px;margin-bottom:12px;padding:14px;box-shadow:0 3px 9px #1d31570c}.form-card label,.manage-panel h2{margin-bottom:10px;font-size:13px;font-weight:800;display:block}.radio-row{gap:28px;margin-bottom:18px;display:flex}.counter{align-items:center;gap:16px;display:flex}.counter button{color:#0754bd;background:#fff;border:1px solid #b9c7da;border-radius:7px;width:34px;height:30px;font-weight:900}.section-title{color:#234;margin:16px 0 10px;font-size:14px}.absent-list,.absent-summary{gap:8px;display:grid}.absent-list article,.absent-summary article,.summary-list article,.settings-list article,.manage-row{background:#fff;border:1px solid #e8edf5;border-radius:8px;align-items:center;gap:10px;padding:10px;display:flex}.absent-list article div,.settings-list article div{flex:1}.absent-list p,.settings-list p,.hint-box{color:#657184;margin:4px 0 0;font-size:12px}.absent-list button,.manage-row button{color:#dc2626;background:#fff0f1;border:0;border-radius:7px;padding:7px}.inline-form{gap:8px;margin:8px 0;display:grid}.inline-form input,.manage-panel select,.note-box{background:#fff;border:1px solid #dbe3ef;border-radius:8px;outline:0;width:100%;padding:11px}.inline-form button{color:#0754bd;background:#eef5ff;border:0;border-radius:8px;padding:10px;font-weight:800}.note-box{resize:none;height:74px}.confirm-card{gap:13px;display:grid}.confirm-card div{justify-content:space-between;align-items:center;display:flex}.confirm-card span{color:#657184;font-size:13px}.hint-box{background:#f6f9ff;border-radius:8px;padding:12px}.stat-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;display:grid}.stat-grid div{text-align:center;background:#fff;border:1px solid #edf1f7;border-radius:9px;padding:12px 6px}.stat-grid span{color:#657184;margin-bottom:7px;font-size:11px;display:block}.stat-grid strong{font-size:17px}.danger{color:#e11d48}.green{color:#10a25c}.orange{color:#f59e0b}.summary-list{gap:8px;display:grid}.summary-list article{cursor:pointer}.summary-list article div{flex:1}.summary-list p{color:#64748b;margin:4px 0 0;font-size:12px}.settings-list{gap:8px;margin-bottom:14px;display:grid}.manage-panel h2{font-size:15px}.manage-row{justify-content:space-between;margin-top:7px}.manage-row strong{flex:1}.manage-row span{color:#64748b;font-size:12px}@media (width>=520px){.login-phone,.app-frame{border-radius:28px;min-height:760px}.auth-screen,.app-screen{padding:20px}}.toast-message{z-index:5;color:#14763f;text-align:center;background:#ecfdf3;border:1px solid #c9f4d6;border-radius:9px;margin-bottom:10px;padding:10px 12px;font-size:13px;font-weight:800;position:sticky;top:0}.manage-title{color:#13213a;margin:0 0 10px;font-size:15px}.edit-panel{z-index:4;background:#fff;border:1px solid #b8d5ff;border-radius:12px;gap:8px;margin-bottom:12px;padding:12px;display:grid;position:sticky;top:0;box-shadow:0 10px 25px #0b3e851f}.edit-panel strong{color:#0754bd;font-size:14px}.edit-panel input,.round-config input,.date-switch input{background:#fff;border:1px solid #dbe3ef;border-radius:8px;outline:0;padding:10px}.row-actions{gap:8px;display:flex}.row-actions button{color:#16437c;background:#fff;border:1px solid #bed0e8;border-radius:8px;flex:1;padding:10px;font-weight:800}.row-actions button:last-child{color:#fff;background:#0754bd;border-color:#0754bd}.round-settings{gap:8px;display:grid}.round-config{grid-template-columns:1.2fr .9fr auto;align-items:center;gap:7px;display:grid}.round-config button,.report-actions button{color:#0754bd;background:#eef5ff;border:0;border-radius:8px;padding:10px;font-size:12px;font-weight:800}.manage-row button:nth-last-child(2){color:#0754bd;background:#eef5ff}.date-caption{text-align:center;color:#516176;margin:-8px 0 12px;font-size:12px;font-weight:800}.date-switch input{color:#26364f;text-align:center;height:38px;font-weight:800}.report-actions{grid-template-columns:1fr 1fr;gap:8px;margin:0 0 12px;display:grid}.report-actions button:last-child{color:#fff;background:#0754bd}.absent-summary article div{flex:1}.absent-summary p{color:#64748b;margin:4px 0 0;font-size:12px}.hint-box{line-height:1.45}.manage-panel select{margin-bottom:8px}.manage-row{align-items:center}.manage-row button{min-width:44px;font-size:12px;font-weight:800}@media (width<=370px){.round-config,.report-actions{grid-template-columns:1fr}}.compact-settings-list{background:#fff;border-top:1px solid #edf1f7;margin:-13px -13px 0;display:block}.settings-menu-row{text-align:left;cursor:pointer;background:#fff;border:0;border-bottom:1px solid #eef2f7;align-items:center;gap:14px;width:100%;min-height:78px;padding:12px 16px;display:flex}.settings-menu-row:active{background:#f6f9ff}.settings-menu-icon{color:#0754bd;background:#f1f6ff;border-radius:50%;flex:none;place-items:center;width:42px;height:42px;font-size:22px;font-weight:900;display:grid}.settings-menu-text{flex:1;gap:5px;min-width:0;display:grid}.settings-menu-text strong{color:#173763;letter-spacing:-.1px;font-size:16px;font-weight:800;line-height:1.15}.settings-menu-text small{color:#7b8494;font-size:13px;font-weight:600;line-height:1.25}.settings-menu-arrow{color:#5f6b7a;flex:none;font-size:34px;font-weight:300;line-height:1}.sub-back-button{color:#0754bd;background:#eef5ff;border:0;border-radius:999px;margin-bottom:10px;padding:8px 12px;font-size:12px;font-weight:800}.compact-panel{border-radius:12px;margin-bottom:10px;padding:12px}.compact-panel .manage-title{margin-bottom:12px}.compact-form{gap:8px;margin:8px 0 10px}.compact-form input,.compact-panel select,.compact-edit-panel input{min-height:42px;font-size:13px;font-weight:700}.compact-form button,.compact-rounds button{min-height:42px}.compact-manage-row{gap:7px;min-height:52px;padding:9px 10px}.compact-manage-row strong{color:#173763;font-size:13px}.compact-manage-row span{text-align:right;min-width:54px}.compact-manage-row button{min-width:40px;padding:7px 8px}.compact-edit-panel{top:0}.empty-text{color:#7b8494;text-align:center;margin:10px 0 0;font-size:13px;font-weight:600}.account-card{background:#fbfcff;border:1px solid #e8edf5;border-radius:12px;align-items:center;gap:12px;margin-bottom:10px;padding:12px;display:flex}.account-avatar{color:#0754bd;background:#eef5ff;border-radius:50%;place-items:center;width:46px;height:46px;font-size:24px;font-weight:900;display:grid}.account-card strong{color:#173763;margin-bottom:4px;font-size:15px;display:block}.account-card p{color:#64748b;margin:0;font-size:12px;font-weight:700}@media (width<=370px){.settings-menu-row{gap:11px;min-height:72px;padding:10px 13px}.settings-menu-icon{width:38px;height:38px;font-size:20px}.settings-menu-text strong{font-size:15px}.settings-menu-text small{font-size:12px}}.login-hero h1,.header-title h1{letter-spacing:-.2px;font-weight:800}.login-hero p,.header-title p{letter-spacing:-.1px;font-weight:600}.settings-menu-text strong{letter-spacing:-.25px;font-size:15px;font-weight:700;line-height:1.35}.settings-menu-text small{letter-spacing:-.15px;font-size:13px;font-weight:400;line-height:1.45}.round-info h2,.detail-card h2,.class-row strong,.manage-row strong,.compact-manage-row strong{letter-spacing:-.2px;font-weight:700}.round-info p,.detail-card p,.detail-card small,.summary-list p,.absent-list p,.settings-list p,.hint-box,.empty-text{letter-spacing:-.1px;font-weight:400;line-height:1.5}.primary-login-button,.mini-primary,.wide-primary,.extra-button,.bottom-actions .primary,.inline-form button,.compact-form button,.round-config button,.report-actions button{letter-spacing:-.1px;font-weight:700}.field-box input,.inline-form input,.manage-panel select,.note-box,.compact-form input,.compact-panel select,.compact-edit-panel input{font-weight:500}.logout-header-button{color:#fff;cursor:pointer;background:#ffffff24;border:1px solid #ffffff6b;border-radius:999px;min-width:74px;height:32px;font-size:11px;font-weight:700}.logout-header-button:active{background:#ffffff3d}.header-placeholder{width:74px;height:32px;display:block}.class-row-with-action{gap:8px}.class-row-with-action strong{flex:1}.class-row-with-action .status-badge{flex:none}.quick-full-button{color:#15803d;cursor:pointer;background:#ecfdf3;border:1px solid #22c55e;border-radius:999px;min-width:46px;height:30px;font-size:12px;font-weight:800}.quick-full-button:disabled{opacity:.65;cursor:not-allowed}.quick-full-button:active{background:#dcfce7}.staff-tabbar button{max-width:none}.login-hint{color:#ffffffe0;text-align:center;margin:14px 0 0;font-size:12px;font-weight:600;line-height:1.45}.app-shell{background:#eaf1fb;min-height:100vh}.app-main{justify-content:center;min-height:100vh;display:flex}.desktop-sidebar{display:none}.app-frame{background:#fff;flex-direction:column;width:100%;max-width:430px;min-height:100vh;display:flex;position:relative;overflow:hidden}.app-body{background:#fbfcff;flex:1;padding:13px 13px 82px;overflow:auto}.logout-header-button{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff24;border:1px solid #ffffff6b;border-radius:999px;width:74px;height:32px;font-size:11px;font-weight:700}.header-placeholder{flex-shrink:0;width:74px;height:32px;display:block}@media (width>=768px){.app-main{padding:24px}.app-frame{border-radius:24px;max-width:720px;min-height:calc(100vh - 48px);box-shadow:0 24px 70px #0f172a2e}.app-body{padding:18px 18px 90px}.card-list{grid-template-columns:repeat(2,minmax(0,1fr))}.class-list,.summary-list,.settings-list{max-width:none}.stat-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width>=1024px){.app-shell{grid-template-columns:270px 1fr;display:grid}.desktop-sidebar{color:#fff;background:#0754bd;flex-direction:column;min-height:100vh;padding:22px 16px;display:flex}.sidebar-brand{align-items:center;gap:12px;padding:8px 8px 24px;display:flex}.sidebar-logo{background:#ffffff2e;border-radius:14px;place-items:center;width:46px;height:46px;font-weight:800;display:grid}.sidebar-brand strong{font-size:18px;font-weight:800;display:block}.sidebar-brand span{opacity:.82;margin-top:2px;font-size:13px;display:block}.sidebar-nav{gap:8px;display:grid}.sidebar-nav button{color:#ffffffd1;cursor:pointer;text-align:left;background:0 0;border:0;border-radius:12px;align-items:center;gap:12px;height:46px;padding:0 14px;font-size:14px;font-weight:700;display:flex}.sidebar-nav button span{width:24px;font-size:18px}.sidebar-nav button.active,.sidebar-nav button:hover{color:#fff;background:#ffffff29}.sidebar-user{background:#ffffff1f;border-radius:16px;margin-top:auto;padding:14px}.sidebar-user strong{font-size:14px;display:block}.sidebar-user span{opacity:.82;margin-top:3px;font-size:12px;display:block}.sidebar-user button{color:#0754bd;cursor:pointer;background:#fff;border:0;border-radius:10px;width:100%;height:38px;margin-top:12px;font-weight:800}.app-main{justify-content:stretch;padding:28px}.app-frame{border-radius:24px;max-width:none;min-height:calc(100vh - 56px);box-shadow:0 24px 70px #0f172a1f}.app-header{border-radius:24px 24px 0 0;height:68px}.header-title{text-align:left}.header-title h1{font-size:22px}.header-title p{font-size:13px}.header-placeholder,.logout-header-button,.tabbar{display:none}.app-body{padding:22px}.card-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.round-card,.detail-card{min-height:110px}.class-list{border-radius:16px}.class-row{height:56px;padding:0 18px}.summary-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.settings-list.compact-settings-list{border:1px solid #e8edf5;border-radius:16px;margin:0;overflow:hidden}.manage-panel,.compact-panel,.form-card,.confirm-card{border-radius:16px}.bottom-actions{padding:14px 0 0;position:sticky;bottom:0}}@media (width>=1366px){.card-list,.summary-list{grid-template-columns:repeat(3,minmax(0,1fr))}.app-body{padding:26px}}.settings-menu-row-danger .settings-menu-icon{color:#dc2626;background:#fff1f2}.settings-menu-row-danger .settings-menu-text strong{color:#dc2626}.logout-settings-box{margin-top:12px}.logout-settings-button{color:#fff;cursor:pointer;background:#dc2626;border:0;border-radius:12px;width:100%;height:44px;font-size:14px;font-weight:700}.logout-settings-button:hover{background:#b91c1c}.logout-settings-button:active{background:#991b1b}.app-header .header-placeholder{flex-shrink:0;width:74px;height:32px;display:block}.logout-header-button{display:none}.staff-tabbar{grid-template-columns:1fr 1fr;display:grid}.staff-tabbar button:last-child,.staff-tabbar button:last-child span{color:#fff}.round-card-selected{border-color:#0754bd;box-shadow:0 8px 22px #0754bd2e}.system-picker-panel{background:#fff;border:1px solid #e5ecf6;border-radius:14px;margin-top:14px;padding:14px;box-shadow:0 4px 14px #0f172a0f}.system-picker-title{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.system-picker-title strong{color:#173763;font-size:15px;font-weight:800;display:block}.system-picker-title p{color:#64748b;margin:4px 0 0;font-size:12px;font-weight:500}.system-picker-list{gap:10px;display:grid}.system-picker-card{text-align:left;cursor:pointer;background:#f8fbff;border:1px solid #e5ecf6;border-radius:12px;gap:4px;width:100%;padding:12px;display:grid}.system-picker-card:hover,.system-picker-card:active{background:#eef5ff;border-color:#0754bd}.system-picker-name{color:#002b63;font-size:15px;font-weight:800}.system-picker-meta,.system-picker-status{color:#64748b;font-size:12px;font-weight:600}@media (width>=768px){.system-picker-list{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=1200px){.system-picker-list{grid-template-columns:repeat(4,minmax(0,1fr))}}.compact-class-form{grid-template-columns:1fr}.compact-class-form button{grid-column:auto}
