@font-face{font-family:"72";font-style:normal;font-weight:300;src:url(/fonts/72-Light.woff2) format("woff2");font-display:swap}@font-face{font-family:"72";font-style:normal;font-weight:400;src:url(/fonts/72-Regular.woff2) format("woff2");font-display:swap}@font-face{font-family:"72";font-style:normal;font-weight:600;src:url(/fonts/72-Bold.woff2) format("woff2");font-display:swap}@font-face{font-family:"72";font-style:normal;font-weight:700;src:url(/fonts/72-Bold.woff2) format("woff2");font-display:swap}:root{--sap-blue: #0070f2;--sap-blue-dark: #0040b0;--sap-bg: #f5f6f7;--sap-shell: #354a5f;--ok: #256f3a;--warn: #e76500;--fail: #d20a0a;--info: #0070f2;--line: #d9d9d9;--field-line: #89919a;color:#1d2d3e;font-family:"72","72full",Segoe UI,system-ui,PingFang TC,Microsoft JhengHei,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;background:var(--sap-bg)}button{font-family:inherit;cursor:pointer}code{background:#00000010;padding:1px 5px;border-radius:3px;font-size:12px}.boot-screen{display:grid;place-items:center;height:100vh;color:#5a6b7b}.app-shell{min-height:100vh;display:flex;flex-direction:column}.system-header{background:var(--sap-shell);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:8px 18px}.system-header strong{font-size:15px}.system-header span{opacity:.8;margin-left:12px;font-size:12px}.icon-text-button{background:transparent;color:#fff;border:1px solid #ffffff55;border-radius:4px;padding:5px 10px;display:inline-flex;gap:6px;align-items:center;font-size:12px}.login-screen{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#0a6ed1,#354a5f)}.login-card{background:#fff;border-radius:10px;box-shadow:0 18px 48px #00000040;width:420px;max-width:92vw;padding:28px}.login-brand{display:flex;gap:14px;align-items:center;margin-bottom:18px}.sap-logo{background:var(--sap-blue);color:#fff;font-weight:800;padding:8px 12px;border-radius:6px;letter-spacing:1px}.login-brand h1{font-size:17px;margin:0}.login-brand p{margin:2px 0 0;color:#6a7888;font-size:12px}.login-tabs{display:flex;gap:6px;margin-bottom:14px}.login-tabs button{flex:1;padding:8px;border:1px solid var(--line);background:#f5f6f7;border-radius:6px}.login-tabs button.active{background:var(--sap-blue);color:#fff;border-color:var(--sap-blue)}.login-form{display:flex;flex-direction:column;gap:10px}.login-form label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#5a6b7b}.login-form input{padding:9px 10px;border:1px solid var(--line);border-radius:6px;font-size:14px}.login-error,.inline-error{color:var(--fail);font-size:13px;background:#ffe5e5;padding:8px 10px;border-radius:6px}.login-hint{margin-top:16px;font-size:12px;color:#6a7888;line-height:1.6}.primary-btn{background:var(--sap-blue);color:#fff;border:none;padding:10px 16px;border-radius:6px;font-size:14px;font-weight:600}.primary-btn:disabled{opacity:.6}.ghost-btn{background:#f5f6f7;border:1px solid var(--line);border-radius:6px;padding:6px 10px;display:inline-flex;gap:5px;align-items:center;font-size:12px}.student-home{padding:20px}.home-banner{background:#fff;border-radius:10px;padding:16px 20px;margin-bottom:16px;border-left:5px solid var(--sap-blue)}.home-banner h2{margin:0 0 4px}.home-banner p{margin:0;color:#6a7888;font-size:13px}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:14px}.module-card{background:#fff;border-radius:10px;padding:16px;box-shadow:0 2px 6px #00000012;display:flex;flex-direction:column}.module-card-head{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.module-code{background:var(--sap-shell);color:#fff;font-weight:700;font-size:12px;padding:2px 8px;border-radius:4px}.module-card-head h3{margin:0;font-size:16px}.module-en{color:#97a3b0;font-size:11px;width:100%}.module-summary{color:#54616e;font-size:12.5px;line-height:1.6;min-height:56px}.module-areas{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}.area-chip{background:#eef3f9;color:#0a6ed1;font-size:11px;padding:2px 7px;border-radius:10px}.module-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:auto}.module-btn{border:1px solid var(--line);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:3px;align-items:flex-start;background:#fafbfc;text-align:left}.module-btn span{font-weight:600;font-size:13px}.module-btn small{font-size:11px;color:#8a96a3}.module-btn.practice{border-left:3px solid #6aae3b}.module-btn em{font-style:normal;margin-left:6px}.module-btn em.completed{color:var(--ok);font-weight:600}.module-btn em.in-progress{color:#c87f0a;font-weight:600}.case-locked-note{margin-top:10px;font-size:11px;color:#8a96a3;display:flex;gap:5px;align-items:center}.sap-shell{display:flex;flex-direction:column;height:calc(100vh - 41px);background:#f7f8f9}.sap-toolbar{background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:7px 14px}.sap-back{background:#f0f1f2;border:1px solid var(--line);border-radius:5px;padding:5px 10px;display:inline-flex;gap:5px;align-items:center;font-size:12px}.sap-command{display:flex;align-items:center;gap:6px}.sap-command-label{font-size:11px;color:#8a96a3}.sap-command input{border:1px solid var(--line);border-radius:4px;padding:5px 8px;width:320px;background:#fffef5;font-family:monospace;font-size:12.5px}.sap-mode-badge{margin-left:auto;font-size:12px;padding:4px 10px;border-radius:12px}.sap-mode-badge.practice{background:#eaf6e1;color:#38761d}.sap-mode-badge.case{background:#e3effb;color:var(--sap-blue-dark)}.sap-body{flex:1;display:flex;min-height:0}.sap-process{width:280px;background:#fff;border-right:1px solid var(--line);overflow-y:auto}.sap-process-head{display:flex;align-items:center;gap:6px;padding:10px 12px;font-weight:600;font-size:13px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff}.sap-progress-pct{margin-left:auto;color:var(--sap-blue);font-size:12px}.sap-step-list{list-style:none;margin:0;padding:6px}.sap-step-list li{display:flex;align-items:center;gap:7px;padding:7px 8px;border-radius:6px;cursor:pointer;font-size:12.5px}.sap-step-list li:hover{background:#f3f5f7}.sap-step-list li.current{background:#e3effb}.sap-step-list li.done .sap-step-title{color:#6a7888}.ic-done{color:var(--ok);flex-shrink:0}.ic-todo{color:#c4ccd4;flex-shrink:0}.sap-step-no{color:#97a3b0;font-size:11px;min-width:16px}.sap-step-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sap-screen{flex:1;padding:18px 24px;overflow-y:auto}.sap-screen-head{display:flex;justify-content:space-between;align-items:baseline;border-bottom:2px solid var(--sap-blue);padding-bottom:8px}.sap-screen-head h2{margin:0;font-size:17px}.sap-role{color:#8a96a3;font-size:12px}.sap-objective{color:#44515e;line-height:1.7;font-size:13.5px}.sap-hint{background:#fff8e1;border:1px solid #f3e2a0;border-radius:6px;padding:9px 12px;font-size:12.5px;color:#7a5b00;display:flex;gap:7px;align-items:center;margin-bottom:12px}.sap-display-note{background:#eef3f9;border-radius:6px;padding:8px 12px;font-size:12.5px;color:#54616e;margin-bottom:12px}.sap-fields{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin:14px 0}.sap-field{display:flex;flex-direction:column;gap:4px}.sap-field label{font-size:12px;color:#44515e;display:flex;justify-content:space-between;align-items:baseline}.sap-field-en{color:#aab4bf;font-size:10.5px;font-family:monospace}.sap-field input,.sap-field select{padding:8px 9px;border:1px solid #b9c0c7;border-radius:4px;font-size:13px}.sap-field input:focus,.sap-field select:focus{outline:none;border-color:var(--sap-blue);box-shadow:0 0 0 2px #0a6ed133}.sap-field.has-error input,.sap-field.has-error select{border-color:var(--fail);background:#fff6f6}.sap-field-hint{color:#97a3b0;font-size:11px}.sap-field-error{color:var(--fail);font-size:11px}.sap-actions{margin:10px 0}.sap-step-passed{color:var(--ok);display:inline-flex;gap:6px;align-items:center;font-weight:600}.sap-status-bar{margin-top:12px;padding:8px 12px;border-radius:5px;font-size:13px;background:#eef1f4;border-left:4px solid #c4ccd4}.sap-status-bar.ok{background:#eaf6e1;border-color:var(--ok);color:#2c6b22}.sap-status-bar.fail{background:#ffecec;border-color:var(--fail);color:var(--fail)}.sap-footer{background:var(--sap-shell);color:#fff;display:flex;gap:20px;padding:6px 16px;font-size:12px}.sap-footer span:nth-child(2){margin-left:auto}.sap-complete-tag{color:#8be0a4;font-weight:600}.fiori-bar{background:var(--sap-shell);color:#fff;display:flex;align-items:center;gap:14px;padding:6px 14px}.fiori-bar .sap-back{background:#fff2;color:#fff;border-color:#fff4}.fiori-title{font-weight:600;font-size:13.5px}.fiori-bar .sap-mode-badge{margin-left:auto}.sap-toolbar .sap-step-tag{margin-left:auto;font-size:12px;color:#6a7888}.sap-step-list li.locked{opacity:.5;cursor:not-allowed}.ic-lock{color:#b0b8c0;flex-shrink:0}.sap-field-input{display:flex;gap:4px;align-items:stretch}.sap-field-input input,.sap-field-input select{flex:1}.f4-btn{background:#eef3f9;border:1px solid #b9c0c7;border-radius:4px;padding:0 8px;color:var(--sap-blue);display:inline-flex;align-items:center}.f4-btn:hover{background:#dbe8f6}.sap-system{width:240px;background:#fff;border-left:1px solid var(--line);overflow-y:auto;padding:10px}.sap-system-section{margin-bottom:16px}.sap-system-section h4{display:flex;align-items:center;gap:6px;font-size:12.5px;margin:0 0 6px;color:#44515e;border-bottom:1px solid #eee;padding-bottom:4px}.doc-flow{margin:0;padding-left:16px;font-size:11.5px;color:#2c6b22;line-height:1.7}.doc-flow li{font-family:monospace}.kv-list{list-style:none;margin:0;padding:0;font-size:11.5px}.kv-list li{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px dashed #eee;gap:8px}.kv-list li span{color:#6a7888;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kv-list li b{font-family:monospace}.muted-sm{color:#aab4bf;font-size:11.5px}.f4-overlay{position:fixed;inset:0;background:#0005;display:grid;place-items:center;z-index:50}.f4-dialog{background:#fff;border-radius:8px;width:380px;max-width:92vw;max-height:70vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 50px #00000050}.f4-dialog-head{background:var(--sap-blue);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:9px 12px;font-size:13px}.f4-dialog-head button{background:transparent;border:none;color:#fff}.f4-table{border-collapse:collapse;width:100%;font-size:12.5px;overflow-y:auto}.f4-table th{background:#f5f6f7;text-align:left;padding:6px 12px;position:sticky;top:0}.f4-table td{padding:7px 12px;border-top:1px solid #eee;cursor:pointer}.f4-table tr:hover td{background:#eef3f9}.f4-table td:first-child{font-family:monospace;font-weight:600;color:var(--sap-blue-dark)}.teacher-dash{display:flex;min-height:calc(100vh - 41px)}.dash-sidebar{width:240px;background:#fff;border-right:1px solid var(--line);padding:14px}.dash-sidebar h3{display:flex;gap:6px;align-items:center;font-size:14px}.class-list{list-style:none;margin:0 0 14px;padding:0}.class-list li{padding:8px 10px;border-radius:6px;cursor:pointer;display:flex;flex-direction:column}.class-list li:hover{background:#f3f5f7}.class-list li.active{background:#e3effb}.class-list li small{color:#8a96a3;font-size:11px}.new-class{display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--line);padding-top:12px}.new-class input{padding:7px;border:1px solid var(--line);border-radius:5px;font-size:13px}.dash-main{flex:1;padding:18px;display:flex;flex-direction:column;gap:14px}.dash-panel{background:#fff;border-radius:10px;padding:14px 16px;box-shadow:0 2px 6px #0000000d}.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.panel-head h3{margin:0;font-size:14px;display:flex;gap:6px;align-items:center}.panel-actions{display:flex;gap:8px}.invite-chips{display:flex;flex-wrap:wrap;gap:8px}.invite-chip{background:#eef3f9;border-radius:6px;padding:6px 12px;font-family:monospace;font-weight:700;color:var(--sap-blue-dark);display:flex;flex-direction:column}.invite-chip small{font-family:sans-serif;font-weight:400;color:#8a96a3;font-size:10px}.dash-panel textarea{width:100%;border:1px solid var(--line);border-radius:6px;padding:8px;font-family:monospace;font-size:12px;margin-bottom:8px}.muted{color:#97a3b0;font-size:12px}.progress-scroll{overflow-x:auto}.progress-table{border-collapse:collapse;width:100%;font-size:12px}.progress-table th,.progress-table td{border:1px solid #eceef0;padding:6px 9px;text-align:center;white-space:nowrap}.progress-table th{background:#f5f6f7;position:sticky;top:0}.progress-table td:first-child,.progress-table th:first-child{text-align:left}.cell-completed{background:#eaf6e1;color:#2c6b22;font-weight:600}.cell-in_progress{background:#fff5e0;color:#b3760a}.cell-not_started{color:#c4ccd4}.cell-total{font-weight:700;background:#eef3f9}.fiori-bar{background:var(--sap-shell);color:#fff;display:flex;align-items:center;gap:12px;padding:0 12px;height:44px}.fiori-home{background:transparent;border:none;color:#fff;opacity:.85;display:inline-flex;align-items:center;padding:6px;border-radius:6px}.fiori-home:hover{background:#fff2;opacity:1}.fiori-logo{font-weight:800;letter-spacing:.5px;font-size:16px}.fiori-bar .fiori-title{font-weight:400;font-size:14px;opacity:.95}.fiori-search{margin-left:auto;display:flex;align-items:center;gap:6px;background:#2a3a4a;border-radius:18px;padding:5px 12px;color:#aeb8c2}.fiori-search input{background:transparent;border:none;color:#fff;outline:none;width:130px;font-size:12.5px}.fiori-avatar{width:30px;height:30px;border-radius:50%;background:#5a6b7b;color:#fff;display:grid;place-items:center;font-size:12px;font-weight:600}.sap-toolbar{background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:6px 14px}.sap-screen{flex:1;padding:0;overflow:hidden;display:flex;flex-direction:column;background:var(--sap-bg)}.op-header{background:#fff;padding:14px 24px 10px;border-bottom:1px solid #eaecee}.op-title-row{display:flex;align-items:center;gap:12px}.op-title-row h2{margin:0;font-size:20px;font-weight:400;color:#1d2d3e}.obj-status{font-size:12px;padding:2px 10px;border-radius:12px;font-weight:600}.obj-status.ok{background:#ebf5eb;color:var(--ok)}.obj-status.neutral{background:#eef1f4;color:#5a6b7b}.op-subtitle{color:#5a6b7b;font-size:12.5px;margin-top:4px}.icon-tab-bar{background:#fff;display:flex;gap:2px;padding:0 16px;border-bottom:1px solid #eaecee;box-shadow:0 1px 2px #00000008}.icon-tab-bar button{background:transparent;border:none;padding:11px 16px;font-size:13.5px;color:#5a6b7b;border-bottom:3px solid transparent}.icon-tab-bar button:hover{color:var(--sap-blue)}.icon-tab-bar button.active{color:var(--sap-blue);border-bottom-color:var(--sap-blue);font-weight:600}.op-content{flex:1;overflow-y:auto;padding:16px 24px}.op-content .sap-objective{color:#44515e;line-height:1.7;font-size:13.5px;margin-top:0}.msg-strip{display:flex;gap:8px;align-items:center;padding:9px 12px;border-radius:6px;font-size:12.5px;margin:10px 0;border-left:4px solid}.msg-strip.info{background:#eaf1fb;border-color:var(--info);color:#0a3d8f}.msg-strip.success{background:#ebf5eb;border-color:var(--ok);color:#1c5631}.msg-strip.error{background:#fbeaea;border-color:var(--fail);color:#a30808}.msg-strip.neutral{background:#eef1f4;border-color:#b0bcc7;color:#44515e}.simple-form{background:#fff;border:1px solid #eaecee;border-radius:8px;padding:16px 18px}.form-row{display:grid;grid-template-columns:200px 1fr;gap:12px;align-items:start;padding:7px 0;border-bottom:1px solid #f3f4f5}.form-row:last-child{border-bottom:none}.form-label{font-size:13px;color:#1d2d3e;padding-top:7px;display:flex;flex-wrap:wrap;gap:4px;align-items:baseline}.form-label .req{color:var(--fail);font-weight:700}.form-label .sap-field-en{color:#aab4bf;font-size:10.5px;font-family:monospace;width:100%}.form-field{display:flex;flex-direction:column;gap:4px;max-width:360px}.sap-field-input{display:flex;gap:4px}.sap-field-input input,.sap-field-input select{flex:1;padding:7px 9px;border:none;border-bottom:2px solid var(--field-line);background:#f5f6f7;border-radius:4px 4px 0 0;font-size:13px}.sap-field-input input:focus,.sap-field-input select:focus{outline:none;border-bottom-color:var(--sap-blue);background:#fff}.form-row.has-error .sap-field-input input,.form-row.has-error .sap-field-input select{border-bottom-color:var(--fail);background:#fff6f6}.f4-btn{background:#fff;border:1px solid var(--field-line);border-radius:4px;padding:0 9px;color:var(--sap-blue);display:inline-flex;align-items:center}.f4-btn:hover{background:#eaf1fb}.op-footer-bar{background:#fff;border-top:1px solid #eaecee;padding:9px 24px;display:flex;align-items:center;gap:12px;box-shadow:0 -1px 3px #00000010}.op-footer-bar .primary-btn{display:inline-flex;gap:6px;align-items:center}.op-score{margin-left:auto;color:#5a6b7b;font-size:12.5px}.f4-filter{display:flex;align-items:center;gap:6px;padding:8px 12px;border-bottom:1px solid #eee;color:#8a96a3}.f4-filter input{flex:1;border:none;outline:none;font-size:13px}.f4-table-wrap{overflow-y:auto}.student-home{background:var(--sap-bg)}.module-card{border-radius:8px;border:1px solid #eaecee;box-shadow:0 1px 2px #0000000a;transition:box-shadow .15s}.module-card:hover{box-shadow:0 4px 14px #00000016}.module-code{background:var(--sap-blue)}.module-btn.practice{border-left:3px solid #2b7d2b}.module-btn.case{border-left:3px solid var(--sap-blue)}.module-btn:hover{background:#eaf1fb}.area-chip{background:#eaf1fb;color:var(--sap-blue-dark)}.primary-btn{background:var(--sap-blue);border-radius:6px}.primary-btn:hover:not(:disabled){background:var(--sap-blue-dark)}.system-header{background:var(--sap-shell)}.item-table-wrap{background:#fff;border:1px solid #eaecee;border-radius:8px;margin-top:14px;overflow:hidden}.item-table-head{padding:9px 14px;font-size:13px;font-weight:600;border-bottom:1px solid #eaecee;background:#fafbfc}.item-table{border-collapse:collapse;width:100%;font-size:12.5px}.item-table th{background:#f5f6f7;text-align:left;padding:8px 12px;border-bottom:1px solid #e0e3e6;font-weight:600;color:#44515e}.item-table td{padding:5px 12px;border-bottom:1px solid #f0f1f2}.item-table tr:hover td{background:#f7faff}.item-table .item-col-no{width:56px;color:#8a96a3;font-family:monospace}.item-table input{width:100%;border:none;border-bottom:2px solid var(--field-line);background:#f5f6f7;border-radius:4px 4px 0 0;padding:6px 8px;font-size:12.5px}.item-table input:focus{outline:none;border-bottom-color:var(--sap-blue);background:#fff}.item-table td.has-error input{border-bottom-color:var(--fail);background:#fff6f6}.ui5-wrap{display:flex;flex-direction:column;height:calc(100vh - 41px)}.ui5-toggle{display:flex;align-items:center;gap:12px;background:#2a3a4a;color:#cdd6df;padding:5px 14px;font-size:12px}.ui5-badge{font-weight:600;color:#8be0a4}.ui5-error{color:#ffb0b0}.ui5-toggle button{margin-left:auto;background:#ffffff1a;color:#fff;border:1px solid #ffffff33;border-radius:4px;padding:3px 10px;font-size:12px}.ui5-host{flex:1;min-height:0}.ui5-host>*{height:100%}.module-chapter{background:#eef3f9;color:var(--sap-blue-dark);font-weight:700;font-size:11px;padding:2px 8px;border-radius:4px;border:1px solid #cfe0f3}.system-header-left{display:flex;align-items:center;gap:22px}.header-nav{display:flex;gap:6px}.header-nav button{background:#ffffff14;color:#cdd6df;border:1px solid #ffffff2a;border-radius:6px;padding:5px 12px;font-size:12.5px;display:inline-flex;gap:6px;align-items:center}.header-nav button:hover{background:#ffffff28;color:#fff}.header-nav button.active{background:var(--sap-blue);color:#fff;border-color:var(--sap-blue);font-weight:600}
