:root{color-scheme:light;--bg-page: #eef3f9;--bg-panel: #ffffff;--text-primary: #0b1f3a;--text-secondary: #32455e;--border: #c7d3e0;--brand: #0054b8;--brand-strong: #003d87;--danger: #b00020;--warning: #9a6700;--success: #0b7a35;--surface-muted: #f7f9fc;--shadow-soft: 0 8px 20px rgba(7, 31, 76, .08)}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:18px;line-height:1.5;color:var(--text-primary);background:radial-gradient(circle at top right,#f8fbff 0%,var(--bg-page) 55%,#dde9f7 100%)}button,input,select,textarea{font:inherit}.app-root,.preview-frame{min-height:100%}.top-role-bar{display:flex;justify-content:space-between;gap:20px;align-items:center;padding:14px 24px;background:#072c61;color:#fff;border-bottom:4px solid #0c4eab}.top-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.a11y-btn{border:2px solid #93b7ef;background:#fff8de;color:#4f3a00;border-radius:10px;padding:9px 12px;font-weight:700;cursor:pointer}.a11y-btn.active{background:#ffeb9c;border-color:#ffd247}.device-profile-switch{display:inline-flex;align-items:center;border:2px solid #95b9ea;border-radius:10px;overflow:hidden;background:#eff5ff}.device-btn{border:0;border-right:1px solid #95b9ea;background:transparent;color:#0c386d;padding:8px 10px;font-weight:700;cursor:pointer}.device-btn:last-child{border-right:0}.device-btn.active{background:#fff;color:#062f64}.top-role-bar p{margin:0;font-size:16px;font-weight:600}.role-switch{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.role-btn{border:2px solid #93b7ef;background:#eff5ff;color:#0c386d;padding:10px 14px;border-radius:10px;font-weight:700;min-width:90px;cursor:pointer}.role-btn.active{background:#fff;border-color:#fff;color:#002a62}.app-shell{display:grid;grid-template-columns:310px 1fr;min-height:calc(100vh - 66px)}.sidebar{background:linear-gradient(180deg,#0b2e63,#041b3f);color:#fff;padding:20px 14px;display:flex;flex-direction:column;gap:20px}.mobile-close-btn{display:none;margin-left:auto;border:2px solid rgba(255,255,255,.4);background:transparent;color:#fff;border-radius:8px;width:38px;height:38px;align-items:center;justify-content:center}.brand-box{display:flex;gap:14px;align-items:center;padding:12px;border:1px solid rgba(255,255,255,.25);border-radius:14px;background:#ffffff14}.brand-box h1{margin:0;font-size:22px}.brand-box p{margin:0;font-size:14px;color:#c8ddff}.brand-icon{width:52px;height:52px;display:grid;place-items:center;border-radius:12px;background:#f8fbff;color:#003c84}.nav-menu{display:flex;flex-direction:column;gap:8px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:0;border-radius:10px;background:transparent;color:#d2e2ff;padding:12px;cursor:pointer;font-weight:600}.nav-item.active{background:#fff;color:#072c61}.nav-item span{flex:1}.sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.2);padding-top:16px}.role-pill{display:inline-block;background:#eaf3ff;color:#032d65;border-radius:999px;padding:6px 12px;font-size:14px;font-weight:700}.footer-row{margin-top:10px;display:flex;align-items:center;gap:8px;color:#bdd5ff;font-size:14px}.content-area{padding:24px;overflow:auto}.content-header h2{margin:0;font-size:32px;color:#05264f}.content-header{display:flex;align-items:center;gap:12px}.mobile-menu-toggle{display:none;align-items:center;gap:6px;border:2px solid #91b5e6;background:#f1f7ff;color:#0c427f;border-radius:10px;min-height:42px;padding:8px 12px;font-weight:700}.sidebar-backdrop{display:none}.app-root.device-profile-mobile,.app-root.device-profile-tablet{padding:14px}.app-root.device-profile-mobile .preview-frame,.app-root.device-profile-tablet .preview-frame{margin:0 auto;background:#f3f8ff;border:2px solid #b8cae6;border-radius:18px;overflow:hidden;box-shadow:0 14px 30px #041a3b33}.app-root.device-profile-mobile .preview-frame{max-width:430px;min-height:calc(100vh - 28px)}.app-root.device-profile-tablet .preview-frame{max-width:900px;min-height:calc(100vh - 28px)}.app-root.device-profile-mobile .top-role-bar,.app-root.device-profile-tablet .top-role-bar{position:sticky;top:0;z-index:60}.app-root.device-profile-mobile .app-shell,.app-root.device-profile-tablet .app-shell{grid-template-columns:1fr}.app-root.device-profile-mobile .sidebar,.app-root.device-profile-tablet .sidebar{position:fixed;top:0;left:0;width:min(88vw,360px);height:100vh;z-index:80;transform:translate(-102%);transition:transform .2s ease;overflow-y:auto}.app-root.device-profile-mobile .sidebar.open,.app-root.device-profile-tablet .sidebar.open{transform:translate(0)}.app-root.device-profile-mobile .sidebar-backdrop,.app-root.device-profile-tablet .sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;border:0;background:#05152d80;z-index:70}.app-root.device-profile-mobile .mobile-close-btn,.app-root.device-profile-mobile .mobile-menu-toggle,.app-root.device-profile-tablet .mobile-close-btn,.app-root.device-profile-tablet .mobile-menu-toggle{display:inline-flex}.app-root.device-profile-mobile .content-area,.app-root.device-profile-tablet .content-area{padding:16px}.app-root.device-profile-mobile .kpi-grid,.app-root.device-profile-mobile .two-cols,.app-root.device-profile-mobile .three-cols,.app-root.device-profile-mobile .summary-grid,.app-root.device-profile-mobile .segment-switch,.app-root.device-profile-mobile .stepper,.app-root.device-profile-mobile .check-grid,.app-root.device-profile-tablet .two-cols,.app-root.device-profile-tablet .summary-grid,.app-root.device-profile-tablet .stepper,.app-root.device-profile-tablet .check-grid{grid-template-columns:1fr}.app-root.device-profile-tablet .kpi-grid,.app-root.device-profile-tablet .three-cols{grid-template-columns:repeat(2,minmax(0,1fr))}.app-root.device-profile-mobile .action-row{display:none}.app-root.device-profile-mobile .mobile-submit-bar{position:sticky;bottom:76px;z-index:69;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px;border-radius:12px;border:1px solid #bfd2ea;background:#fffffffa}.app-root.device-profile-mobile .wizard-actions{box-shadow:0 -5px 14px #02173829}.app-root.device-profile-mobile .data-table{min-width:640px}.app-root.device-profile-tablet .data-table{min-width:760px}.content-body{margin-top:20px}.page-stack{display:flex;flex-direction:column;gap:16px}.mobile-submit-bar{display:none}.card{background:var(--bg-panel);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-soft);padding:16px}.card-header{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:12px}.card-header h3{margin:0;font-size:24px}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.kpi-card{padding:20px}.kpi-row{display:flex;justify-content:space-between;gap:8px}.kpi-label{margin:0;color:var(--text-secondary);font-weight:600}.kpi-value{margin:8px 0 0;font-size:38px;font-weight:800;line-height:1}.kpi-icon{width:52px;height:52px;border:2px solid #d3e3fa;border-radius:12px;display:grid;place-items:center;color:var(--brand-strong)}.money-value{margin:0;font-size:42px;font-weight:800;color:#003e87}.toolbar{margin-bottom:12px}.toolbar-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px}.input,select.input,textarea.input{width:100%;min-height:48px;border:2px solid #b7c9de;border-radius:10px;background:#fff;color:var(--text-primary);padding:10px 12px}.input:focus,select.input:focus,textarea.input:focus{outline:3px solid #a7c8ff;border-color:#3575cb}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;border-radius:10px;border:2px solid transparent;padding:10px 16px;font-weight:700;cursor:pointer}.btn:disabled{opacity:.65;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand-strong)}.btn-secondary{background:#fff;border-color:#366db6;color:#17467f}.table-scroll{width:100%;overflow-x:auto}.desktop-table-only{display:block}.mobile-record-list{display:none}.mobile-record-card{width:100%;text-align:left;border:2px solid #c0d2ea;border-radius:12px;background:#f8fbff;padding:10px;display:grid;gap:6px}.mobile-record-card p{margin:0}.mobile-record-detail{margin-top:10px;border:2px solid #bed2ec;border-radius:12px;padding:10px;background:#f3f8ff;display:grid;gap:6px}.mobile-record-detail h4,.mobile-record-detail p{margin:0}.mobile-detail-backdrop,.mobile-detail-dialog{display:none}.data-table{width:100%;border-collapse:collapse;min-width:820px}.data-table th,.data-table td{border-bottom:1px solid #d4dfeb;padding:10px;text-align:left;vertical-align:top}.data-table th{background:#f1f7ff;color:#113d72;font-weight:800}.subtle{margin:0;font-size:14px;color:#4f6681}.status-chip{display:inline-flex;align-items:center;font-size:14px;font-weight:700;border-radius:999px;padding:4px 10px;border:1px solid transparent}.status-done{background:#dff6e7;color:#0a5d2a;border-color:#96ddb2}.status-pending{background:#fff3d9;color:#865200;border-color:#e9c275}.status-overdue{background:#ffe5ea;color:#9f0b2f;border-color:#f7a9b8}.status-processing{background:#e4eeff;color:#164991;border-color:#abc6f7}.notice-banner{margin:0 0 12px;border:2px solid #f0c675;background:#fff7e6;border-radius:10px;padding:12px;color:#704000;font-weight:700}.stepper{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.step{border:2px solid #bdd0e4;border-radius:12px;padding:10px;background:#f8fbff;display:flex;align-items:center;gap:8px}.step-index{width:34px;height:34px;border-radius:50%;border:2px solid #aac2e5;display:grid;place-items:center;font-weight:800}.step.current{border-color:#3d74bb;background:#e8f2ff}.step.current .step-index,.step.done .step-index{background:#115cbf;border-color:#115cbf;color:#fff}.step-name{font-weight:700;font-size:16px}.step-note{background:#e8f2ff;color:#083a77;padding:6px 10px;border-radius:999px;font-size:14px;font-weight:700}.segment-switch{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:12px}.segment-btn{border:2px solid #95bbe8;background:#f5faff;color:#0d4487;border-radius:10px;min-height:52px;font-weight:700;cursor:pointer}.segment-btn.active{background:#0d60c8;border-color:#0d60c8;color:#fff}.form-grid{display:grid;gap:12px}.two-cols{grid-template-columns:repeat(2,minmax(0,1fr))}.three-cols{grid-template-columns:repeat(3,minmax(0,1fr))}.field{display:grid;gap:6px}.field-label{font-weight:700;color:#143d70}.required-star{color:#b00020}.field-help{color:#587192;font-size:14px}.lookup-row,.action-row,.wizard-actions,.time-row{display:flex;gap:10px;align-items:center}.wizard-actions{position:sticky;bottom:0;padding:10px;border:1px solid #bfd2ea;border-radius:12px;background:#fffffff7;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:10}.time-row span{font-weight:700;color:#385a83}.check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0;font-weight:600}.check-grid label{display:flex;gap:8px;align-items:center}.check-grid input[type=checkbox]{width:22px;height:22px}.section-title{margin:18px 0 10px;color:#07366d;font-size:20px}.summary-card{margin-top:14px;background:#eef6ff;border-color:#a8c8f2}.summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.summary-grid p{margin:0}.grand-total{grid-column:span 2;font-size:24px;color:#03346d}.success-text{margin-top:12px;padding:10px;border-radius:10px;background:#e5f8ec;border:2px solid #92d8a8;color:#0f6e31;font-weight:700}.error-text{margin-top:8px;color:#b00020;font-weight:700}.validation-panel{margin-top:12px;border:2px solid #c4d8f5;border-radius:10px;background:#f5f9ff;padding:10px}.validation-summary{margin:0 0 8px;font-weight:700;color:#0b3f7a}.validation-list{display:grid;gap:6px}.validation-item{margin:0;padding:8px;border-radius:8px;border:1px solid transparent}.severity-critical{background:#ffecee;border-color:#f2b7c1;color:#93223a}.severity-warning{background:#fff7e6;border-color:#f0d4a5;color:#7b4d00}.batch-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:12px}.batch-kpi{border:1px solid #c8d8ee;border-radius:10px;background:#f6faff;padding:10px}.batch-kpi p{margin:0;font-weight:600;color:#315277}.batch-kpi strong{display:block;margin-top:6px;font-size:30px;color:#04346e}.batch-code-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:10px}.batch-code-stats p{margin:0;padding:8px;border-radius:8px;border:1px solid #c8d8ee;background:#f6faff}.api-preview{margin-top:12px;background:#0e1c2f;color:#95f8ac;padding:12px;border-radius:12px}.api-preview h4{margin:0 0 8px;color:#b4fbc4}.api-preview pre{margin:0;white-space:pre-wrap;word-break:break-word;font-size:14px}.details-grid p,.guide-list{margin:0}.guide-list{display:grid;gap:8px;padding-left:24px}@media (max-width: 1440px){.kpi-grid,.three-cols{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 1080px){.top-role-bar,.top-controls,.lookup-row,.action-row,.wizard-actions,.time-row{flex-direction:column;align-items:stretch}.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;width:min(88vw,360px);height:100vh;z-index:50;border-bottom:0;transform:translate(-102%);transition:transform .2s ease;overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;border:0;background:#05152d80;z-index:40}.mobile-close-btn,.mobile-menu-toggle{display:inline-flex}.content-area{padding:16px}.page-stack{padding-bottom:18px}.two-cols,.three-cols,.summary-grid,.segment-switch,.stepper,.check-grid,.kpi-grid,.batch-kpi-grid,.batch-code-stats,.toolbar-row{grid-template-columns:1fr}.desktop-table-only{display:none}.mobile-record-list{display:grid;gap:10px}.mobile-detail-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0a172c80;border:0;z-index:120}.mobile-detail-dialog{display:block;position:fixed;left:10px;right:10px;bottom:10px;max-height:72vh;overflow-y:auto;z-index:130}.mobile-detail-dialog .mobile-record-detail{margin-top:0;background:#fff;box-shadow:0 10px 22px #02142f40}.content-header h2{font-size:28px}.card{padding:12px}.card-header h3{font-size:22px}.data-table{min-width:720px}}@media (min-width: 820px) and (max-width: 1180px){.content-area{padding:18px}.card{border-radius:14px}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.data-table{min-width:760px}}@media (min-width: 1024px) and (max-width: 1366px){.content-area{max-width:1024px}}@media (max-width: 768px){body{font-size:16px}.top-role-bar{padding:12px}.top-role-bar p{font-size:14px}.device-profile-switch{width:100%}.device-btn{flex:1}.role-btn{min-width:74px;padding:8px 10px;font-size:14px}.content-header h2{font-size:24px}.kpi-value{font-size:32px}.money-value,.grand-total{font-size:28px}.btn{width:100%}.wizard-actions{box-shadow:0 -5px 14px #02173829}.action-row{display:none}.mobile-submit-bar{position:sticky;bottom:76px;z-index:9;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px;border-radius:12px;border:1px solid #bfd2ea;background:#fffffffa}.page-stack{padding-bottom:120px}.data-table{min-width:640px}}.app-root.a11y-mode body{font-size:18px}.app-root.a11y-mode .content-header h2{font-size:36px}.app-root.a11y-mode .card-header h3{font-size:28px}.app-root.a11y-mode .btn,.app-root.a11y-mode .input,.app-root.a11y-mode .role-btn,.app-root.a11y-mode .nav-item,.app-root.a11y-mode .segment-btn{min-height:54px;font-size:19px}.app-root.a11y-mode .field-label,.app-root.a11y-mode .kpi-label,.app-root.a11y-mode .step-name,.app-root.a11y-mode .status-chip,.app-root.a11y-mode .role-pill,.app-root.a11y-mode .top-role-bar p{font-size:19px}.app-root.a11y-mode .kpi-value,.app-root.a11y-mode .money-value{font-size:46px}
