:root{color-scheme:light;font-family:Inter,SF Pro Display,PingFang SC,Microsoft YaHei,system-ui,sans-serif;color:#101817;background:#f5f7f8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #f5f7f8;--panel: #ffffff;--panel-soft: #fbfcfc;--text: #101817;--muted: #64706d;--faint: #8c9794;--border: #dce4e2;--border-strong: #cbd8d5;--primary: #00796f;--primary-strong: #00645c;--primary-soft: #e7f5f3;--blue: #2166e8;--blue-soft: #eaf1ff;--green: #15965a;--green-soft: #e8f7ef;--orange: #f59e0b;--orange-soft: #fff6e4;--red: #ef4444;--red-soft: #fff0f0;--shadow: 0 10px 30px rgba(16, 24, 23, .07);--shadow-light: 0 1px 2px rgba(16, 24, 23, .04)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-width:1260px}button,input,textarea{font:inherit}button{cursor:pointer}input,textarea{color:var(--text)}.app-shell{min-height:100vh;display:grid;grid-template-rows:58px minmax(0,1fr);background:var(--bg)}.topbar{height:58px;display:grid;grid-template-columns:260px minmax(500px,1fr) auto auto;align-items:center;gap:16px;padding:0 18px;background:#fff;border-bottom:1px solid var(--border)}.brand-group{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{width:36px;height:36px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#008679,#006d63);border-radius:8px}.brand-title{overflow:hidden;font-size:20px;font-weight:850;letter-spacing:0;text-overflow:ellipsis;white-space:nowrap}.nav-tabs{min-width:0;display:flex;align-items:stretch;gap:18px;height:100%;overflow:hidden}.nav-tab{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:max-content;padding:0 2px;border:0;background:transparent;color:#25302d;font-size:14px;font-weight:650}.nav-tab:after{position:absolute;right:0;bottom:0;left:0;height:3px;background:transparent;content:""}.nav-tab.is-active{color:var(--primary);font-weight:850}.nav-tab.is-active:after{background:var(--primary)}.order-strip{display:flex;align-items:center;gap:16px;color:#1f2b28;font-size:13px;white-space:nowrap}.top-tools{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:10px}.top-icon-button,.user-menu,.icon-only-button{border:1px solid transparent;background:transparent;color:#1e2926}.top-icon-button{position:relative;width:34px;height:34px;display:grid;place-items:center;border-radius:7px}.top-icon-button:hover,.top-icon-button.is-active,.icon-only-button:hover,.icon-only-button.is-active{border-color:var(--border);background:var(--panel-soft)}.top-popover{position:absolute;top:44px;right:0;z-index:30;width:260px;display:grid;gap:5px;padding:12px;border:1px solid var(--border);border-radius:7px;background:#fff;box-shadow:var(--shadow)}.top-popover strong,.top-popover span,.top-popover small{display:block}.top-popover strong{font-size:14px}.top-popover span{color:#24312e;font-size:13px;font-weight:750}.top-popover small{color:var(--muted);line-height:1.45}.top-icon-button.has-badge span{position:absolute;top:3px;right:0;min-width:16px;height:16px;display:grid;place-items:center;border:2px solid #fff;border-radius:999px;color:#fff;background:#e11d1d;font-size:10px;font-weight:850}.user-menu{height:36px;display:inline-flex;align-items:center;gap:8px;padding:0 2px 0 6px;font-size:14px;font-weight:650}.avatar{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;color:#111827;background:#e6eaee}.page-body{height:calc(100vh - 58px);min-height:0;padding:14px 16px;overflow:hidden}.page-home .page-body{height:auto;min-height:calc(100vh - 58px);overflow:visible}.app-page,.split-page{height:calc(100vh - 86px);min-width:0;max-width:100%;min-height:0;overflow:hidden}.panel{min-width:0;min-height:0;background:var(--panel);border:1px solid var(--border);border-radius:7px;box-shadow:var(--shadow-light)}.panel-header{min-height:43px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 14px;border-bottom:1px solid var(--border)}.panel-header>div{display:inline-flex;align-items:center;gap:8px;min-width:0;color:var(--text);font-size:13px;font-weight:850}.panel-header svg{flex:0 0 auto;color:var(--primary)}.panel-header small{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;font-weight:600}.panel-icon-button{width:28px;height:28px;display:inline-grid;place-items:center;border:1px solid transparent;border-radius:5px;color:var(--primary);background:transparent}.panel-icon-button:hover{border-color:var(--border);background:var(--primary-soft)}.button{min-width:0;height:36px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;border:1px solid #7bbeb8;border-radius:6px;color:var(--primary);background:#fff;font-size:13px;font-weight:800;white-space:nowrap}.button svg{flex:0 0 auto}.button input[type=file]{display:none}.button-primary{color:#fff;background:linear-gradient(180deg,#00877b,#006d64);border-color:var(--primary);box-shadow:0 6px 14px #00796f2e}.button-danger{color:#ef2929;border-color:#ff9c9c}.button:hover{filter:brightness(.985)}.button:disabled,.segmented:disabled{cursor:not-allowed;opacity:.48;filter:none}.page-command-bar{width:min(100%,calc(100vw - 32px));max-width:100%;min-width:0;min-height:48px;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:12px}.page-title{display:inline-flex;align-items:center;gap:10px}.page-title svg{color:var(--primary)}.page-title h1{margin:0;color:var(--text);font-size:24px;font-weight:900;line-height:1.15}.command-actions,.stage-actions,.toolbar-controls,.two-buttons{min-width:0;display:flex;align-items:center;flex-wrap:wrap;gap:10px}.command-actions{justify-content:flex-end}.status-badge{min-height:22px;display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border:1px solid var(--border);border-radius:4px;color:var(--muted);background:#f8faf9;font-size:12px;font-weight:800;white-space:nowrap}.status-success{color:#118247;background:var(--green-soft);border-color:#bfe7ce}.status-warning,.status-processing{color:#f28a00;background:var(--orange-soft);border-color:#ffd798}.status-danger{color:#ef2929;background:var(--red-soft);border-color:#ffb9b9}.status-info{color:#1764d8;background:var(--blue-soft);border-color:#bcd2ff}.status-muted{color:#66716d;background:#f5f7f8}.green{color:var(--green)}.filter-row{display:grid;grid-template-columns:minmax(210px,1.2fr) repeat(5,minmax(122px,.55fr)) auto;align-items:center;gap:12px;margin-bottom:12px}.filter-row.compact{grid-template-columns:minmax(210px,1fr) repeat(4,minmax(112px,.42fr)) auto}.search-box,.select-box,.date-range{min-width:0;display:flex;align-items:center;gap:8px}.search-box{height:36px;padding:0 12px;border:1px solid var(--border);border-radius:5px;background:#fff}.search-box svg{flex:0 0 auto;color:#6c7774}.search-box input{width:100%;min-width:0;border:0;outline:0;color:var(--text);background:transparent;font-size:13px}.select-box span,.date-range>span:first-child{color:var(--muted);font-size:13px;white-space:nowrap}.select-box button,.date-range button{min-width:90px;height:34px;display:inline-flex;align-items:center;justify-content:space-between;gap:8px;padding:0 10px;border:1px solid var(--border);border-radius:5px;color:#24302d;background:#fff;font-size:13px}.date-range{justify-content:center;height:36px;padding:0 10px;border:1px solid var(--border);border-radius:5px;background:#fff}.date-range button{min-width:84px;height:auto;padding:0;border:0;color:#8c9692}.subhead,.section-title{display:block;margin:0 0 10px;color:#1f2b28;font-size:13px;font-weight:850}.section-title{margin-top:14px}.data-table,.mini-table{width:100%;border-collapse:collapse;table-layout:fixed}.data-table th,.data-table td,.mini-table th,.mini-table td{height:44px;padding:0 12px;border-bottom:1px solid var(--border);overflow:hidden;color:#1f2b28;font-size:13px;text-align:left;text-overflow:ellipsis;white-space:nowrap}.data-table th,.mini-table th{color:#1c2623;background:#fafcfc;font-size:12px;font-weight:850}.data-table tr.is-selected,.mini-table tr.is-selected{background:linear-gradient(90deg,#effafb,#f5fbfb)}.link-cell{color:var(--primary)!important;font-weight:800}.table-action{height:30px;padding:0 14px;border:1px solid #7bbeb8;border-radius:5px;color:var(--primary);background:#fff;font-size:13px;font-weight:850}.pagination{min-height:50px;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:0 14px;color:var(--muted);font-size:13px}.pagination>div{display:inline-flex;align-items:center;gap:6px}.pagination button{width:30px;height:30px;display:inline-grid;place-items:center;border:1px solid var(--border);border-radius:6px;color:#26322f;background:#fff}.pagination button.is-active{color:#fff;background:var(--primary);border-color:var(--primary)}.pagination button:disabled{cursor:not-allowed;color:var(--faint);background:#f7f9f9}.check-square{width:16px;height:16px;display:inline-grid;place-items:center;border-radius:3px;color:#fff;background:var(--primary)}.more-icon{color:#1f2b28;font-size:16px;font-weight:900;letter-spacing:1px}.orders-page{display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr) 132px;gap:8px}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:12px}.metric-card{min-height:94px;display:flex;align-items:center;gap:18px;padding:20px 24px;background:#fff;border:1px solid var(--border);border-radius:7px}.metric-card>span{width:48px;height:48px;display:grid;place-items:center;border-radius:8px}.metric-card small{display:block;color:#64706d;font-size:14px;font-weight:650}.metric-card strong{display:block;margin-top:4px;color:#0f172a;font-size:28px;line-height:1}.metric-blue>span{color:#2469e8;background:var(--blue-soft)}.metric-orange>span{color:#f59e0b;background:var(--orange-soft)}.metric-green>span{color:#15965a;background:var(--green-soft)}.metric-red>span{color:#ef4444;background:var(--red-soft)}.orders-layout{min-height:0;display:grid;grid-template-columns:minmax(760px,1fr) 395px;gap:14px}.order-table-panel{min-height:0;overflow:hidden}.order-detail-panel{display:flex;flex-direction:column;padding-bottom:14px;overflow:hidden}.detail-title{min-height:54px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid var(--border)}.detail-title strong{font-size:17px}.order-card-hero{display:grid;grid-template-columns:122px 1fr;gap:16px;padding:18px 16px;border-bottom:1px solid var(--border)}.order-card-hero .mini-polo{width:108px;height:148px}.detail-line{display:grid;grid-template-columns:90px minmax(0,1fr);align-items:center;min-height:24px;gap:8px}.detail-line dt{color:var(--muted);font-size:13px}.detail-line dd{min-width:0;margin:0;overflow:hidden;color:#1e2926;font-size:13px;font-weight:650;text-overflow:ellipsis;white-space:nowrap}.size-chips{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 12px;border-bottom:1px solid var(--border)}.size-chips span{min-width:44px;height:30px;display:inline-grid;place-items:center;padding:0 9px;border:1px solid var(--border);border-radius:5px;color:#34403c;background:#fafcfc;font-size:12px}.order-detail-panel .section-title{padding:0 16px}.progress-steps{display:grid;gap:8px;padding:0 16px 14px}.progress-step{display:grid;grid-template-columns:18px 1fr 96px 36px;align-items:center;gap:8px;min-height:28px;color:var(--muted);font-size:12px}.progress-step span{width:16px;height:16px;display:grid;place-items:center;border:1px solid #c8d4d1;border-radius:50%}.progress-step.is-done span{color:#fff;background:var(--primary);border-color:var(--primary)}.progress-step.is-active span{color:var(--blue);border-color:var(--blue)}.progress-step strong{color:#293532;font-weight:750}.drawer-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:auto;padding:14px 16px 0}.drawer-actions .button:first-child,.drawer-actions .button:last-child{grid-column:1 / -1}.recent-panel{min-height:120px;padding:0 14px}.recent-title{height:44px;display:flex;align-items:center;justify-content:space-between}.recent-title button{display:inline-flex;align-items:center;gap:4px;border:0;color:var(--primary);background:transparent;font-weight:800}.activity-strip{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.activity-item{position:relative;display:grid;grid-template-columns:24px 1fr auto;grid-template-rows:20px 20px;gap:0 8px;padding-right:16px;border-right:1px solid var(--border)}.activity-item strong,.activity-item small{grid-column:2 / 4;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-item strong{color:#1f2b28;font-size:13px}.activity-item small,.activity-item span:not(.activity-dot){color:var(--muted);font-size:12px}.activity-dot{grid-row:span 2;width:20px;height:20px;border-radius:50%;background:var(--primary)}.activity-dot.info{background:var(--blue)}.activity-dot.warn{background:var(--orange)}.activity-dot.danger{background:var(--red)}.home-page{min-height:calc(100vh - 86px);display:grid;grid-template-rows:230px 104px minmax(320px,auto) auto;gap:12px;overflow:visible}.home-hero{min-height:0;display:grid;grid-template-columns:minmax(420px,.9fr) minmax(520px,1.1fr);gap:22px;padding:22px 24px;overflow:hidden}.home-hero-copy{min-width:0;display:flex;flex-direction:column;justify-content:center}.home-hero-copy>span{color:var(--primary);font-size:13px;font-weight:900}.home-hero-copy h1{margin:8px 0;color:var(--text);font-size:34px;line-height:1.08;letter-spacing:0}.home-hero-copy p{max-width:560px;margin:0;color:var(--muted);font-size:14px;line-height:1.7}.home-hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.home-hero-preview{position:relative;min-width:0;min-height:0;display:grid;place-items:center;border:1px solid var(--border);border-radius:7px;background:radial-gradient(circle at 54% 96%,rgba(16,24,23,.1),transparent 28%),linear-gradient(180deg,#fff,#f8faf9);overflow:hidden}.home-hero-preview .mockup-pair{min-height:0;padding:8px 22px 20px}.home-hero-preview .design-product-pair{max-height:190px}.home-hero-status{position:absolute;right:14px;bottom:14px;display:grid;gap:4px;min-width:260px;padding:12px;border:1px solid rgba(220,228,226,.9);border-radius:7px;background:#ffffffeb;box-shadow:0 12px 30px #1018171f}.home-hero-status strong{color:var(--text);font-size:13px}.home-hero-status span:last-child{color:var(--muted);font-size:12px}.home-stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.home-stat-card{min-width:0;min-height:0;display:grid;grid-template-columns:50px minmax(0,1fr);align-items:center;gap:14px;padding:16px 18px;border:1px solid var(--border);border-radius:7px;background:#fff}.home-stat-card>span{width:46px;height:46px;display:grid;place-items:center;border-radius:8px}.home-stat-card small,.home-stat-card em{display:block;min-width:0;overflow:hidden;color:var(--muted);font-size:12px;font-style:normal;text-overflow:ellipsis;white-space:nowrap}.home-stat-card strong{display:block;margin:2px 0;color:var(--text);font-size:27px;line-height:1}.home-main-grid{min-height:0;display:grid;grid-template-columns:minmax(720px,1fr) 390px;gap:12px}.home-shortcuts,.home-todo-panel,.home-flow-card,.home-workload-card{min-height:0;overflow:visible}.home-shortcuts{display:grid;grid-template-rows:43px auto}.shortcut-grid{min-height:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding:14px}.shortcut-card{min-width:0;display:grid;grid-template-columns:42px minmax(0,1fr);grid-template-rows:auto auto auto;align-items:center;gap:6px 12px;padding:14px;border:1px solid var(--border);border-radius:7px;color:var(--text);background:#fbfcfc;text-align:left}.shortcut-card:hover{border-color:#9ed0c9;background:#f3fbf9}.shortcut-icon{grid-row:span 2;width:42px;height:42px;display:grid;place-items:center;border-radius:8px;color:var(--primary);background:var(--primary-soft)}.shortcut-card strong,.shortcut-card small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shortcut-card strong{font-size:14px}.shortcut-card small{grid-column:2;color:var(--muted);font-size:12px}.shortcut-card .status-badge{grid-column:2;justify-self:start}.home-todo-panel{display:grid;grid-template-rows:43px auto}.todo-list{display:grid;align-content:start;gap:10px;padding:14px;overflow:visible}.todo-item{min-width:0;display:grid;grid-template-columns:10px minmax(0,1fr) 18px;align-items:center;gap:12px;padding:13px 12px;border:1px solid var(--border);border-radius:7px;background:#fff;color:var(--text);text-align:left}.todo-item>span{width:10px;height:42px;border-radius:999px;background:var(--primary)}.todo-warning>span{background:var(--orange)}.todo-danger>span{background:var(--red)}.todo-info>span{background:var(--blue)}.todo-success>span{background:var(--green)}.todo-item strong,.todo-item small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.todo-item strong{font-size:13px}.todo-item small{margin-top:4px;color:var(--muted);font-size:12px}.todo-item svg{color:var(--muted)}.home-bottom-grid{min-height:220px;display:grid;grid-template-columns:minmax(720px,1fr) 390px;gap:12px}.home-flow-card{display:grid;grid-template-rows:43px auto}.home-flow-card .workflow-line{height:100%;align-items:center;padding:16px 22px}.home-workload-card{display:grid;grid-template-rows:43px auto}.workload-bars{display:grid;align-content:center;gap:10px;padding:12px 16px 10px}.workload-row{display:grid;gap:6px}.workload-row>div{display:flex;align-items:center;justify-content:space-between;gap:12px}.workload-row strong{color:var(--text);font-size:13px}.workload-row span{color:var(--muted);font-size:12px}.workload-row .progress b{right:0;bottom:10px;color:var(--muted);font-size:11px}.access-page{height:calc(100vh - 86px);min-height:0;display:grid;grid-template-rows:auto 104px minmax(0,1fr) 222px;gap:12px;overflow:hidden}.access-stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.access-layout{min-height:0;display:grid;grid-template-columns:286px minmax(720px,1fr) 372px;gap:12px}.role-panel,.user-table-panel,.application-panel,.registration-settings,.access-editor-panel{min-height:0;overflow:hidden}.role-panel{display:grid;grid-template-rows:43px minmax(0,1fr)}.role-list{display:grid;align-content:start;gap:10px;padding:12px;overflow:auto}.role-card{display:grid;gap:10px;padding:12px;border:1px solid var(--border);border-radius:7px;background:#fff}.role-card.is-active{border-color:#8ccdc7;background:#f3fbfa}.role-card strong,.role-card span{display:block}.role-card strong{color:var(--text);font-size:14px}.role-card div>span{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.55}.permission-chip-list{display:flex;flex-wrap:wrap;gap:6px}.permission-chip-list span{min-height:24px;display:inline-flex;align-items:center;padding:2px 8px;border:1px solid #bfe0dc;border-radius:5px;color:var(--primary);background:var(--primary-soft);font-size:12px;font-weight:800}.user-table-panel{display:grid;grid-template-rows:43px auto minmax(0,1fr) 48px}.access-filter-row{display:grid;grid-template-columns:minmax(220px,1fr) repeat(3,minmax(116px,.36fr));gap:10px;padding:12px;border-bottom:1px solid var(--border)}.access-user-table th,.access-user-table td{height:46px;padding:0 9px;font-size:12px}.user-name-button{min-width:0;display:inline-flex;align-items:center;gap:8px;border:0;color:var(--primary);background:transparent;font-size:12px;font-weight:850}.mini-avatar{width:24px;height:24px}.access-row-actions{display:inline-flex;align-items:center;gap:6px}.access-row-actions button{height:28px;padding:0 8px;border:1px solid var(--border);border-radius:5px;color:var(--primary);background:#fff;font-size:12px;font-weight:800}.access-row-actions button.danger{color:var(--red);border-color:#ffb9b9}.access-side-column{min-height:0;display:grid;grid-template-rows:minmax(0,1fr) auto;gap:12px}.application-panel{display:grid;grid-template-rows:43px minmax(0,1fr)}.application-list{display:grid;align-content:start;gap:10px;padding:12px;overflow:auto}.application-card{display:grid;gap:8px;padding:12px;border:1px solid var(--border);border-radius:7px;background:#fff}.application-card>div:first-child{display:flex;align-items:center;justify-content:space-between;gap:10px}.application-card strong{color:var(--text);font-size:14px}.application-card small,.application-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.55}.application-approved{background:#fbfffd}.application-rejected{background:snow}.application-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.application-actions .button{height:32px;padding:0 10px}.registration-settings{display:grid;align-content:start;gap:10px;padding-bottom:12px}.registration-settings .toggle-line,.registration-settings .select-box{padding:0 14px}.registration-settings .select-box{display:grid;grid-template-columns:76px minmax(0,1fr)}.access-editor-panel{display:grid;grid-template-rows:43px minmax(0,1fr)}.access-editor-body{min-height:0;display:grid;grid-template-columns:minmax(620px,1fr) 320px auto;align-items:center;gap:18px;padding:14px}.access-form-grid{min-width:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.access-field{min-width:0;display:grid;gap:6px}.access-field span{color:var(--muted);font-size:12px;font-weight:700}.access-field input,.access-field select{width:100%;min-width:0;height:34px;padding:0 10px;border:1px solid var(--border);border-radius:5px;color:var(--text);background:#fff;font-size:13px}.access-field input[readonly],.access-field select:disabled{color:#53605c;background:#f7f9f9}.editor-permissions{display:grid;gap:10px;padding:12px;border:1px solid var(--border);border-radius:7px;background:#fbfcfc}.editor-permissions strong{color:var(--text);font-size:13px}.editor-actions{display:grid;gap:10px;min-width:150px}.workbench-layout{height:calc(100vh - 86px);min-height:0;display:grid;grid-template-columns:48px 256px minmax(0,1fr) 304px;grid-template-rows:minmax(0,1fr) 154px;gap:12px}.module-rail{min-height:0;display:flex;flex-direction:column;align-items:center;gap:8px;padding:10px 5px;background:#fff;border:1px solid var(--border);border-radius:7px}.rail-button{width:38px;min-height:43px;display:grid;place-items:center;gap:2px;border:0;border-radius:6px;color:#57635f;background:transparent;font-size:10px}.rail-button.is-active,.rail-button:hover{color:var(--primary);background:var(--primary-soft)}.rail-spacer{flex:1}.left-panel,.right-panel{display:flex;flex-direction:column;overflow:hidden}.right-panel{overflow-y:auto}.upload-stack{display:grid;gap:8px;margin:14px}.rail-context-panel{display:grid;gap:8px;margin:12px 14px 0;padding:10px;border:1px solid #bfe0dc;border-radius:7px;background:#f5fbfa}.rail-context-panel>span{color:var(--primary);font-size:11px;font-weight:850}.rail-context-panel strong{color:var(--text);font-size:13px}.rail-context-panel p{margin:0;color:var(--muted);font-size:12px;line-height:1.45}.rail-context-metrics{display:flex;flex-wrap:wrap;gap:6px}.rail-context-metrics em{padding:3px 7px;border:1px solid var(--border);border-radius:999px;color:#33413e;background:#fff;font-size:11px;font-style:normal;font-weight:750}.rail-context-actions .button{width:100%;height:30px;justify-content:center;font-size:12px}.upload-box{min-height:104px;display:grid;place-items:center;gap:5px;border:1px dashed #b6c3bf;border-radius:7px;color:var(--muted);background:#fbfcfc;font-size:12px}.upload-box-compact{min-height:78px;grid-template-columns:30px minmax(0,1fr);justify-items:start;padding:12px}.upload-box-compact small{grid-column:2}.upload-box input{display:none}.upload-box svg,.upload-box span{color:var(--primary)}.upload-box span{font-weight:850}.upload-box small{max-width:210px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.panel-section,.control-group,.style-section{display:grid;gap:8px;padding:12px 14px;border-top:1px solid var(--border)}.panel-section:first-of-type{border-top:0}.panel-section h3,.control-group h3,.style-section h3{margin:0;color:#1f2b28;font-size:13px;font-weight:850}.asset-row,.layer-row,.part-row,.uv-part-row{min-height:38px;display:grid;align-items:center;gap:8px;border:1px solid var(--border);border-radius:6px;background:#fff}.asset-row{grid-template-columns:20px minmax(0,1fr) 26px;padding:7px 9px}.asset-row.is-active{border-color:#a8d4cf;background:#f4fbfa}.asset-row.is-warning{border-color:#ffd798;background:#fffaf0}.asset-row.is-warning>svg:last-child{color:var(--orange)}.row-icon-button{width:24px;height:24px;display:grid;place-items:center;border:1px solid transparent;border-radius:5px;color:var(--primary);background:transparent}.row-icon-button:hover{border-color:var(--border);background:var(--primary-soft)}.asset-row strong,.asset-row span,.layer-row span,.part-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-row strong{display:block;color:#1e2926;font-size:12px}.asset-row span{display:block;margin-top:2px;color:var(--muted);font-size:11px}.layer-row{grid-template-columns:16px minmax(0,1fr) 24px 34px 34px 24px;padding:7px 8px;color:#293532;font-size:12px}.layer-row.is-hidden{border-style:dashed;color:var(--muted);background:#f8fafa}.layer-row.is-hidden .check-square{border-color:#cbd8d5;background:#eef3f2}.layer-row.is-hidden .row-icon-button{color:var(--muted)}.layer-row.is-locked .row-icon-button{color:var(--faint)}.layer-row.is-locked .lock-button,.part-row.is-locked .lock-button{color:#4b5652}.layer-row.is-unlocked .lock-button,.part-row.is-unlocked .lock-button{color:var(--primary);background:var(--primary-soft)}.issue-card.issue-status-已修复,.issue-card.issue-status-已忽略{border-color:#cfe1dd;background:#f8fbfa}.issue-card.issue-status-已修复 .issue-number{background:var(--green)}.issue-card.issue-status-已忽略 .issue-number{background:var(--muted)}.uv-grid-hidden .grid-lines,.uv-grid-hidden .ruler-x,.uv-grid-hidden .ruler-y{opacity:.12}.layer-row small,.layer-row>span:last-of-type{color:var(--muted);font-size:11px}.part-grid{display:grid;gap:7px}.part-row,.uv-part-row{width:100%;grid-template-columns:minmax(0,1fr) 24px 24px;min-height:34px;padding:0 8px 0 0;text-align:left}.part-main-button{min-width:0;height:100%;display:grid;grid-template-columns:14px minmax(0,1fr);align-items:center;gap:8px;padding:0 0 0 9px;border:0;color:inherit;background:transparent;text-align:left}.part-row.is-selected,.uv-part-row.is-selected{border-color:#7abeb7;background:var(--primary-soft)}.part-color{width:12px;height:12px;border-radius:2px;background:var(--part-color)}.workbench-stage{min-width:0;min-height:0;display:grid;grid-template-rows:46px minmax(0,1fr);gap:10px}.stage-topline{display:flex;align-items:center;justify-content:space-between;gap:18px}.stage-topline h1{margin:0;color:var(--text);font-size:18px;font-weight:900}.stage-topline span{display:block;margin-top:4px;color:var(--muted);font-size:12px}.stage-content{min-height:0;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(280px,.92fr);gap:12px}.canvas-panel-inner{min-height:0;display:grid;grid-template-rows:48px minmax(0,1fr);overflow:hidden;background:#fff;border:1px solid var(--border);border-radius:7px}.canvas-panel-inner.is-compact{height:100%;border:0}.canvas-tools{display:flex;align-items:center;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border);background:#fbfcfc}.tool-button{min-width:38px;height:32px;display:grid;place-items:center;gap:1px;border:1px solid transparent;border-radius:5px;color:#5d6865;background:transparent;font-size:9px;font-weight:700}.tool-button.is-active,.tool-button:hover{color:var(--primary);border-color:#bfe0dc;background:#edf8f6}.canvas-sync{margin-left:auto;display:inline-flex;align-items:center;gap:6px;border:1px solid transparent;border-radius:5px;padding:0 8px;color:var(--primary);background:transparent;font-size:12px;font-weight:850;white-space:nowrap}.canvas-sync:hover{border-color:#bfe0dc;background:#edf8f6}.canvas-grid-hidden .grid-lines,.canvas-rulers-hidden .ruler-x,.canvas-rulers-hidden .ruler-y,.canvas-bleed-hidden .bleed-outline{display:none}.canvas-frame{position:relative;min-height:0;margin:12px;padding:28px 0 0 34px;border:1px solid var(--border);border-radius:7px;background:#fff;overflow:auto}.ruler-x,.ruler-y{position:absolute;color:var(--muted);font-size:10px;-webkit-user-select:none;user-select:none}.ruler-x{top:8px;right:18px;left:58px;display:flex;justify-content:space-between;padding-bottom:5px;border-bottom:1px solid #e5ebe9}.ruler-y{top:42px;bottom:18px;left:10px;display:flex;flex-direction:column;justify-content:space-around;padding-right:5px;border-right:1px solid #e5ebe9}.template-svg{min-width:100%;min-height:100%;display:block;touch-action:none;transform-origin:0 0}.canvas-artwork-editable .template-svg,.canvas-artwork-editable .design-template-part{cursor:grab}.canvas-artwork-dragging .template-svg,.canvas-artwork-dragging .design-template-part{cursor:grabbing}.template-source-page{fill:#fbfcfc}.template-source-crop-frame{fill:transparent;stroke:var(--border);stroke-width:1.2;pointer-events:none}.template-source-lineart{opacity:.9;mix-blend-mode:multiply;pointer-events:none}.grid-lines line{stroke:#edf1ef;stroke-width:1}.guide-legend line{stroke-width:2;stroke-dasharray:6 5}.guide-legend .bleed{stroke:#ff6b6b}.guide-legend .cut{stroke:#7a8380}.guide-legend .safe{stroke:#35b46e}.guide-legend text{fill:var(--muted);font-size:14px;font-weight:650}.template-part{cursor:pointer}.template-mirror-part{opacity:.92;pointer-events:none}.pdf-template-part path,.pdf-template-part rect{vector-effect:non-scaling-stroke}.part-outline{fill:transparent;stroke:#28312e;stroke-width:2}.template-part.is-selected .part-outline{stroke:#2166e8;stroke-width:4}.safe-outline,.bleed-outline{fill:transparent;stroke-width:2;stroke-dasharray:7 7}.safe-outline{stroke:#35b46ecc}.bleed-outline{stroke:#ff5757db}.fabric-lines{fill:transparent;stroke:#ffffff2e;stroke-width:10}.template-part text{fill:#17201dad;font-size:22px;font-weight:850;pointer-events:none}.template-part-label{fill:#384542;font-size:16px;font-weight:850;paint-order:stroke;stroke:#ffffffe6;stroke-width:6}.template-detail-collar,.template-detail-placket{fill:#006f39f5;stroke:#0736228c;stroke-width:2;vector-effect:non-scaling-stroke}.template-detail-button{fill:#fff;stroke:#0736228c;stroke-width:2;vector-effect:non-scaling-stroke}.selection-box rect{fill:transparent;stroke:#2166e8;stroke-width:2;stroke-dasharray:8 8}.selection-box circle{fill:#fff;stroke:#2166e8;stroke-width:3}.variable-slot{pointer-events:none}.variable-slot rect{fill:#2563eb1a;stroke:#2563ebb8;stroke-width:2;stroke-dasharray:8 6}.variable-slot text{fill:#2166e8;font-size:20px;font-weight:850}.mockup-panel{display:grid;grid-template-rows:43px 42px minmax(0,1fr) 84px;overflow:hidden}.mockup-tabs,.model-tabs,.approval-tabs{display:flex;align-items:center;gap:7px;padding:8px 12px 4px}.segmented{height:30px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;border:1px solid var(--border);border-radius:5px;color:#293532;background:#fff;font-size:13px;font-weight:800}.segmented.is-active{color:#fff;background:var(--primary);border-color:var(--primary)}.icon-only-button{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--border);border-radius:6px;background:#fff}.mockup-stage,.approval-mockup-canvas,.check-mockup-stage{position:relative;min-height:0;display:grid;place-items:center;background:radial-gradient(circle at 50% 88%,rgba(16,24,23,.13),transparent 28%),linear-gradient(180deg,#fff,#f7f9f9);overflow:hidden}.mockup-stage.is-expanded{border:2px solid var(--primary);background:radial-gradient(circle at 50% 88%,rgba(16,24,23,.18),transparent 30%),linear-gradient(180deg,#fff,#eef7f6)}.mockup-stage.is-expanded .mockup-pair{transform:scale(1.08)}.mockup-state-line{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 12px;color:var(--muted);font-size:12px;font-weight:750}.mockup-pair{width:100%;height:100%;min-height:0;display:flex;align-items:center;justify-content:center;gap:6%;padding:18px}.mockup-pair.is-design-render{padding:0;background:#fff}.mockup-pair.is-rendered-mockup{padding:8px 10px;background:#fff}.design-product-pair{width:100%;height:100%;display:block;object-fit:contain}.rendered-mockup-svg{width:100%;height:100%;display:block}.rendered-mockup-bg{fill:#fff}.rendered-mockup-floor{fill:#10181724;filter:blur(4px)}.rendered-shirt image{pointer-events:none}.rendered-shirt-base{fill:#f8faf8}.rendered-source-piece-fill{stroke:none}.rendered-source-piece-texture{opacity:.34;pointer-events:none}.rendered-source-piece-shade{opacity:.38;mix-blend-mode:multiply;pointer-events:none}.rendered-source-piece-outline{fill:none;stroke:#0c12117a;stroke-width:1.5;vector-effect:non-scaling-stroke}.rendered-shirt-outline{fill:none;stroke:#0c121175;stroke-width:1.4;vector-effect:non-scaling-stroke}.rendered-shirt-seam{fill:none;stroke:#ffffff73;stroke-width:1.2;stroke-dasharray:4 4;vector-effect:non-scaling-stroke}.rendered-collar,.rendered-back-collar,.rendered-placket{fill:none;stroke:#082d2273;stroke-width:1.2;vector-effect:non-scaling-stroke}.rendered-button{fill:#fff;stroke:#082d2273;stroke-width:1}.rendered-front-logo,.rendered-front-number,.rendered-back-name,.rendered-back-number{fill:#fff;paint-order:stroke;stroke:#00704beb;font-family:Impact,Inter,sans-serif;font-weight:950;text-anchor:middle}.rendered-front-logo{font-family:Georgia,serif;font-size:18px;font-style:italic;letter-spacing:0;stroke-width:4}.rendered-front-number{font-size:38px;stroke-width:4}.rendered-back-name{font-size:24px;letter-spacing:0;stroke-width:4}.rendered-back-number{font-size:70px;stroke-width:5}.rendered-model-preview{width:min(100%,520px);height:min(100%,520px);display:grid;place-items:center}.rendered-model-preview .rendered-mockup-svg{max-width:100%;max-height:100%}.polo{position:relative;width:min(43%,290px);height:auto;min-height:0;max-height:92%;aspect-ratio:.62 / 1;filter:drop-shadow(0 22px 24px rgba(16,24,23,.16))}.polo.back{transform:translateY(-6px) scale(.96)}.polo.model-mode{width:min(62%,360px);min-height:430px;max-height:86%;transform:rotateY(-8deg) rotateX(2deg)}.design-model-render{width:100%;height:100%;display:block;object-fit:contain}.polo-body,.polo-sleeve,.polo-collar,.back-collar{background-image:linear-gradient(90deg,rgba(0,0,0,calc(.12 * var(--shadow-strength, 1))),#ffffff38 35%,rgba(0,0,0,calc(.18 * var(--shadow-strength, 1)))),var(--mockup-pattern);background-size:auto,var(--mockup-size);background-position:center,var(--mockup-x) var(--mockup-y);background-repeat:no-repeat,no-repeat}.polo-body{position:absolute;top:17%;left:14%;width:72%;height:72%;overflow:hidden;border-radius:20px 20px 34px 34px/18px 18px 14px 14px;clip-path:polygon(13% 0,87% 0,100% 18%,92% 100%,8% 100%,0 18%)}.polo-fabric{position:absolute;inset:0;transform:rotate(var(--mockup-rotation));background:radial-gradient(circle at 28% 14%,rgba(255,255,255,.18),transparent 24%),repeating-linear-gradient(90deg,rgba(255,255,255,calc(.08 * var(--texture-strength, 1))) 0 1px,transparent 1px 4px),repeating-linear-gradient(0deg,rgba(255,255,255,calc(.07 * var(--texture-strength, 1))) 0 1px,transparent 1px 6px);mix-blend-mode:soft-light}.polo-sleeve{position:absolute;top:27%;width:36%;height:24%;border-radius:12px 12px 20px 20px}.polo-sleeve.left{left:-1%;transform:rotate(12deg);clip-path:polygon(76% 0,4% 28%,22% 100%,100% 70%)}.polo-sleeve.right{right:-1%;transform:rotate(-12deg);clip-path:polygon(24% 0,96% 28%,78% 100%,0 70%)}.polo-collar,.back-collar{position:absolute;z-index:2;top:5%;left:19%;width:62%;height:16%;background-color:#057a31;border-radius:12px 12px 18px 18px;clip-path:polygon(14% 8%,86% 8%,100% 54%,69% 100%,50% 62%,31% 100%,0 54%)}.back-collar{top:8%;height:10%;clip-path:polygon(12% 0,88% 0,100% 62%,50% 100%,0 62%)}.polo-placket{position:absolute;z-index:3;top:13%;left:46.8%;width:6.4%;height:30%;display:grid;justify-items:center;gap:9px;padding-top:18px;background:#067d33;border:1px solid rgba(0,0,0,.16)}.polo-placket span{width:12px;height:12px;border:1px solid rgba(0,0,0,.18);border-radius:50%;background:#f8faf9}.front-logo{position:absolute;z-index:3;top:38%;left:15%;width:70%;color:#fff;font-size:clamp(14px,1.45vw,18px);font-style:italic;font-weight:900;text-align:center;text-shadow:2px 0 #057a31,-2px 0 #057a31,0 2px #057a31,0 -2px #057a31;white-space:nowrap}.front-number,.back-number,.back-name{position:absolute;z-index:3;color:#fff;font-family:Impact,Inter,sans-serif;font-weight:950;line-height:.9;text-shadow:3px 0 #057a31,-3px 0 #057a31,0 3px #057a31,0 -3px #057a31}.front-number{right:14%;bottom:28%;font-size:clamp(38px,4vw,62px)}.back-name{top:27%;left:9%;width:82%;font-size:clamp(20px,2.15vw,32px);letter-spacing:0;text-align:center}.back-number{top:42%;left:13%;width:74%;font-size:clamp(50px,5.4vw,84px);text-align:center}.polo-shadow{position:absolute;right:12%;bottom:1%;left:12%;height:18px;border-radius:50%;background:#10181733;filter:blur(10px)}.mockup-thumbnails{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;padding:8px 10px 10px;border-top:1px solid var(--border)}.mockup-thumb{min-width:0;display:grid;place-items:center;gap:3px;border:1px solid var(--border);border-radius:6px;background:#fbfcfc;color:var(--muted);font-size:10px;white-space:nowrap}.mockup-thumb.is-selected{color:var(--primary);border-color:#9ed0c9;background:var(--primary-soft)}.thumb-shirt{width:32px;height:38px;border-radius:9px 9px 12px 12px;clip-path:polygon(18% 0,82% 0,100% 18%,93% 100%,7% 100%,0 18%);background:linear-gradient(135deg,#f4c419 0 45%,#057a31 45% 65%,#17120f 65% 72%,#f4c419 72% 100%);box-shadow:inset 0 0 10px #17201d24}.thumb-shirt.is-rendered-thumb{background-image:linear-gradient(90deg,#00000029,#ffffff38 42%,#00000029),var(--thumb-pattern);background-size:auto,cover;background-position:center}.thumb-1,.thumb-3{background:linear-gradient(135deg,#f4c419 0 55%,#057a31 55% 76%,#17120f 76% 84%,#f4c419 84% 100%)}.selected-part{display:grid;gap:6px;margin:14px;padding:12px;border:1px solid #cbdffb;border-radius:7px;background:#f6f9ff}.selected-part span{color:var(--muted);font-size:11px}.selected-part strong{color:#2166e8;font-size:13px}.range-row{display:grid;grid-template-columns:76px minmax(0,1fr) 58px;align-items:center;gap:10px;color:var(--muted);font-size:12px}.range-row input{width:100%;accent-color:var(--primary)}.range-row output,.parameter-row strong{color:var(--text);font-size:12px;font-weight:850;text-align:right}.parameter-row,.status-line,.toggle-line{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:26px;color:var(--muted);font-size:12px}.status-line,.toggle-line{justify-content:flex-start}.status-line.is-good svg{color:var(--primary)}.status-line.is-warning svg{color:var(--orange)}.status-line.is-muted svg{color:var(--faint)}.toggle{width:30px;height:16px;display:inline-block;border:1px solid #b7c3c0;border-radius:999px;background:#fff}.toggle-button{width:34px;height:20px;display:inline-grid;place-items:center;padding:0;border:0;background:transparent}.toggle:after{width:12px;height:12px;display:block;margin:1px;border-radius:50%;background:#a9b4b0;content:""}.toggle.is-on{border-color:var(--primary);background:var(--primary)}.toggle.is-on:after{margin-left:15px;background:#fff}.output-tray{grid-column:1 / -1;min-height:0;display:grid;grid-template-columns:180px minmax(0,1fr) 148px;align-items:center;gap:12px;padding:12px;background:#fff;border:1px solid var(--border);border-radius:7px}.tray-title{display:grid;grid-template-columns:18px 1fr;gap:7px 8px;align-items:center}.tray-title svg{color:var(--primary)}.tray-title small{grid-column:2;color:var(--muted);font-size:11px}.file-strip{min-width:0;display:grid;grid-template-columns:repeat(6,minmax(136px,1fr));gap:8px}.file-chip{min-width:0;min-height:90px;display:grid;grid-template-columns:40px minmax(0,1fr) auto;grid-template-rows:1fr 24px;gap:6px 9px;padding:10px;border:1px solid var(--border);border-radius:7px;background:#fbfcfc}.file-chip strong,.file-chip small{min-width:0;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-chip strong{color:var(--text);font-size:12px}.file-chip small{color:var(--muted);font-size:11px}.file-chip button:not(.file-more-button){grid-column:2;grid-row:2;justify-self:start;display:inline-flex;align-items:center;gap:4px;border:0;color:var(--primary);background:transparent;font-size:12px;font-weight:800}.file-more-button{grid-column:1;grid-row:2;justify-self:start;width:28px;height:24px;display:inline-grid;place-items:center;border:0;color:#293532;background:transparent}.file-chip.is-actions-open{border-color:#9ed0c9;background:#f4fbfa}.file-chip-status{grid-column:3;grid-row:2;justify-self:end;align-self:center;color:var(--muted);font-size:11px;white-space:nowrap}.file-type,.file-icon{width:38px;height:42px;display:grid;place-items:center;border-radius:6px;color:var(--primary);background:var(--primary-soft);font-size:11px;font-weight:900}.type-pdf,.file-icon.pdf{color:#ef2929;background:#fff2f2}.type-ai,.file-icon.ai{color:#e88b00;background:#fff5dd}.tray-actions{display:grid;gap:8px}.names-page{display:grid;grid-template-columns:450px minmax(520px,1fr) 324px;grid-template-rows:minmax(0,1fr) 190px;gap:12px}.roster-panel,.style-panel{display:flex;flex-direction:column;overflow:hidden}.import-section,.field-map,.roster-settings{display:grid;gap:10px;padding:14px;border-bottom:1px solid var(--border)}.import-section small{color:var(--muted);font-size:12px}.two-buttons .button{flex:1}.field-map-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.roster-table th,.roster-table td{height:36px;padding:0 8px;font-size:12px}.roster-table .status-line{min-height:22px}.inline-alert{display:flex;align-items:center;gap:8px;min-height:34px;margin:0 14px;padding:0 10px;color:#ed8a00;background:#fff7e8;font-size:12px}.roster-settings{grid-template-columns:auto auto auto 74px auto;align-items:center;margin-top:auto}.roster-settings label{display:inline-flex;align-items:center;gap:5px;color:#34403c;font-size:12px}.names-preview{min-width:0;min-height:0;display:grid;grid-template-rows:48px minmax(0,1fr) 220px;gap:10px}.big-preview-panel{display:grid;grid-template-rows:minmax(0,1fr) 36px;overflow:hidden}.big-preview-panel .mockup-pair{min-height:0}.preview-meta{display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-top:1px solid var(--border);color:var(--muted);font-size:12px}.variable-panel{display:grid;grid-template-rows:43px minmax(0,1fr);overflow:hidden}.style-panel{overflow-y:auto}.style-section h3{display:flex;align-items:center;justify-content:space-between}.style-section>div{display:grid;gap:10px}.color-control{display:grid;grid-template-columns:78px repeat(3,minmax(0,1fr));align-items:center;gap:6px;color:var(--muted);font-size:12px}.color-control button{height:28px;display:inline-flex;align-items:center;justify-content:center;gap:4px;border:1px solid var(--border);border-radius:5px;background:#fff;color:#34403c;font-size:12px}.color-control button.is-active{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.swatch{width:12px;height:12px;border:1px solid var(--border);border-radius:2px}.swatch.white{background:#fff}.swatch.green{background:#07813b}.vertical-actions{display:grid;gap:10px;padding:14px}.generation-queue{grid-column:1 / -1;display:grid;grid-template-columns:210px minmax(0,1fr);align-items:center;gap:12px;padding:12px 16px}.queue-title{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.queue-title strong{flex-basis:100%}.queue-cards{min-width:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.queue-card{min-width:0;display:grid;grid-template-columns:58px minmax(0,1fr) 20px;align-items:center;gap:12px;padding:10px;border:1px solid var(--border);border-radius:7px}.queue-card>svg{color:#ef2929}.queue-card strong,.queue-card small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.queue-card strong{font-size:13px}.queue-card small{color:var(--muted);font-size:12px}.templates-page{min-width:0;max-width:100%;display:grid;grid-template-rows:auto auto auto minmax(0,1fr) 158px;gap:12px}.template-local-import{min-height:58px;display:grid;grid-template-columns:minmax(260px,1fr) auto auto;align-items:center;gap:12px;padding:10px 12px}.template-local-import strong,.template-local-import span{display:block}.template-local-import strong{color:var(--text);font-size:13px}.template-local-import span{margin-top:3px;color:var(--muted);font-size:12px;line-height:1.4}.template-file-upload{min-width:150px;height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 12px;border:1px solid var(--primary);border-radius:6px;color:var(--primary);background:var(--primary-soft);font-size:13px;font-weight:850;cursor:pointer}.template-file-upload input{display:none}.template-layout{min-height:0;display:grid;grid-template-columns:150px minmax(330px,.75fr) minmax(430px,1fr) minmax(292px,.6fr);gap:12px}.category-rail{display:flex;flex-direction:column;gap:6px;padding:18px 14px}.category-rail button{min-height:40px;display:flex;align-items:center;gap:10px;border:0;border-radius:6px;color:#273330;background:transparent;font-weight:700;text-align:left}.category-rail button.is-active{color:var(--primary);background:var(--primary-soft)}.category-rail .settings-link{margin-top:auto}.template-list-panel{min-width:0;min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr) 46px;justify-items:stretch;overflow:hidden}.template-list-panel>*{width:100%;min-width:0;max-width:100%}.template-list-panel .filter-row.compact{grid-template-columns:minmax(0,1fr) repeat(2,minmax(84px,.45fr));gap:8px;overflow:hidden}.template-card-list{width:100%;min-width:0;display:grid;align-content:start;gap:8px;overflow:auto}.template-card{min-width:0;max-width:100%;display:grid;grid-template-columns:112px minmax(0,1fr) 74px;gap:12px;min-height:112px;padding:10px;border:1px solid var(--border);border-radius:7px;background:#fff;overflow:hidden;text-align:left}.template-card.is-active{border-color:var(--primary);box-shadow:inset 3px 0 0 var(--primary)}.template-card strong,.template-card span,.template-card small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-card strong{color:var(--primary);font-size:14px}.template-card span,.template-card small{color:var(--muted);font-size:12px;line-height:1.8}.template-empty-state{min-height:142px;display:grid;place-items:center;gap:6px;padding:18px;border:1px dashed var(--border-strong);border-radius:7px;color:var(--muted);background:#fbfcfc;text-align:center}.template-empty-state strong{color:#273330;font-size:14px}.template-edit-form{display:grid;gap:9px;padding:0 16px 12px}.template-field{display:grid;gap:5px}.template-field span{color:var(--muted);font-size:12px;font-weight:800}.template-field input,.template-field select{width:100%;min-height:34px;padding:0 9px;border:1px solid var(--border);border-radius:6px;outline:0;color:#25312e;background:#fff}.template-field input[readonly]{color:var(--muted);background:#f7faf9}.template-outline-thumb{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1.2fr .7fr;gap:5px;padding:7px;border:1px solid var(--border);border-radius:6px;background:#fbfcfc}.template-outline-thumb span{border:1px solid #b8c3bf;border-radius:18px 18px 4px 4px;background:#fff;clip-path:polygon(12% 16%,38% 0,62% 0,88% 16%,100% 36%,86% 46%,82% 100%,18% 100%,14% 46%,0 36%)}.template-preview-panel{min-height:0;display:grid;grid-template-rows:43px minmax(0,1fr);overflow:hidden}.template-preview-switch{display:inline-flex;gap:4px;padding:3px;border:1px solid var(--border);border-radius:6px;background:#f7faf9}.template-preview-switch button{height:26px;padding:0 9px;border:0;border-radius:4px;color:var(--muted);background:transparent;font-size:12px;font-weight:850}.template-preview-switch button.is-active{color:#fff;background:var(--primary)}.original-template-preview{min-height:0;display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(430px,1fr) auto;gap:12px;padding:12px;background:#fff;overflow:auto}.original-template-frame{min-height:0;display:grid;place-items:center;border:1px solid var(--border);border-radius:7px;background:#fafafa;overflow:hidden}.original-template-frame img{width:100%;height:100%;display:block;object-fit:contain}.original-template-audit{min-height:0;display:grid;grid-template-columns:minmax(220px,.8fr) minmax(260px,1fr);align-content:start;gap:10px}.original-template-audit section:last-child{grid-column:1 / -1}.source-audit-title{display:grid;gap:6px;padding:12px;border:1px solid var(--border);border-radius:7px;background:#fbfcfc}.source-audit-title strong{color:#182321;font-size:14px;line-height:1.35}.source-audit-title span{color:var(--muted);font-size:12px;line-height:1.5}.original-template-audit section{display:grid;gap:7px;padding:12px;border:1px solid var(--border);border-radius:7px;background:#fff;overflow-x:auto}.original-template-audit h3{margin:0;color:#273330;font-size:12px;font-weight:900;letter-spacing:0}.source-check-grid{display:grid;gap:6px}.measurement-title{display:flex;align-items:center;justify-content:space-between;gap:8px}.measurement-title button{min-height:28px;padding:0 9px;border:1px solid #7bbeb8;border-radius:5px;color:var(--primary);background:#fff;font-size:12px;font-weight:850}.original-measure-table{width:100%;border-collapse:collapse;color:#34403c;font-size:11px}.original-measure-table th,.original-measure-table td{height:26px;padding:0 5px;border:1px solid #d4dcda;text-align:left;white-space:nowrap}.original-measure-table th{color:#66716f;background:#f7faf9;font-weight:850}.outline-canvas{position:relative;min-height:0;padding:18px;background:#fff}.outline-canvas svg{width:100%;height:calc(100% - 48px);display:block}.outline-canvas .template-part text{font-size:18px}.source-slice-canvas svg{min-height:0}.source-slice-page{fill:#fbfcfc}.source-slice-view rect{fill:#fff;stroke:var(--border)}.source-slice-part{cursor:pointer}.source-slice-part path{fill:#007e7006;stroke:#007e7057;stroke-width:1.6;stroke-dasharray:8 8;vector-effect:non-scaling-stroke}.source-slice-part text{fill:#111827d1;paint-order:stroke;stroke:#fffffff0;stroke-width:8;font-size:18px;font-weight:900;pointer-events:none}.source-slice-part.is-selected path{fill:#007e7021;stroke:var(--primary);stroke-width:3}.source-slice-part.is-selected text{fill:var(--primary)}.source-slice-strip{cursor:pointer}.source-slice-strip rect{fill:#fff;stroke:var(--border-strong)}.source-slice-strip text{fill:#273330;font-size:14px;font-weight:850;pointer-events:none}.source-slice-strip .is-selected rect{fill:var(--primary-soft);stroke:var(--primary)}.source-slice-strip .is-selected text{fill:var(--primary)}.template-info-column{min-height:0;display:grid;grid-template-rows:minmax(0,1fr) 144px;gap:12px}.info-card{display:grid;align-content:start;gap:8px;padding-bottom:12px;overflow:auto}.info-card .detail-line{padding:0 16px;min-height:28px}.template-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px}.template-actions .button-danger{grid-column:1 / -1}.version-table{overflow:hidden}.version-table .mini-table td{height:34px}.order-meta-line{min-height:34px;display:flex;align-items:center;gap:28px;margin:-4px 0 12px;color:#34403c;font-size:13px}.order-meta-line b{color:#f28a00}.order-meta-line b.flow-success{color:var(--green)}.order-meta-line b.flow-danger{color:var(--red)}.order-meta-line b.flow-info{color:var(--blue)}.flow-notice{min-height:42px;display:flex;align-items:center;gap:10px;margin-bottom:12px;padding:8px 12px;border:1px solid var(--border);border-radius:7px;color:#31403c;background:#fff;font-size:13px}.flow-notice span:not(.status-badge){min-width:0;flex:1}.flow-notice-warning{border-color:#ffd798;background:#fffaf0}.flow-notice-success{border-color:#bfe7ce;background:#f4fbf7}.flow-notice-danger{border-color:#ffb9b9;background:#fff7f7}.flow-notice-info{border-color:#bcd2ff;background:#f5f8ff}.action-notice{min-height:40px;display:grid;grid-template-columns:18px minmax(0,1fr);align-items:start;gap:8px;margin:0 0 10px;padding:9px 12px;border:1px solid #bcd2ff;border-radius:7px;color:#293532;background:#f5f8ff}.action-notice svg{margin-top:2px}.action-notice strong,.action-notice span{display:block;min-width:0}.action-notice strong{font-size:13px}.action-notice span{margin-top:2px;color:var(--muted);font-size:12px;line-height:1.4}.action-notice-success{border-color:#bfe7ce;background:#f4fbf7}.action-notice-warning{border-color:#ffd798;background:#fffaf0}.action-notice-danger{border-color:#ffb9b9;background:#fff7f7}.approval-page{display:grid;grid-template-rows:auto auto auto minmax(0,1fr) 94px;gap:0}.approval-layout{min-height:0;display:grid;grid-template-columns:356px minmax(600px,1fr) 324px;gap:12px;overflow:hidden}.approval-left{display:flex;flex-direction:column;gap:12px;padding:0 14px 14px;overflow:hidden}.approval-left .panel-header{margin:0 -14px}.people-table td{height:42px}.current-style{margin-top:auto}.current-style .mini-polo-pair{width:244px;height:142px;margin-top:10px;border:1px solid var(--border);border-radius:6px}.approval-preview{display:grid;grid-template-rows:52px minmax(0,1fr) 42px;overflow:hidden}.approval-tabs{justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border)}.approval-tabs>div{display:inline-flex;gap:6px}.approval-mockup-canvas .mockup-pair{min-height:570px}.pin,.issue{position:absolute;width:28px;height:28px;display:grid;place-items:center;border:2px solid #fff;border-radius:50%;color:#fff;background:#1f6fff;font-size:13px;font-weight:900;box-shadow:0 5px 12px #00000029}.pin-one{top:27%;left:45%}.pin-two{top:30%;right:24%}.approval-note{margin:0;padding:0 18px;color:var(--muted);font-size:12px;line-height:42px}.approval-side{min-height:0;display:grid;align-content:start;gap:8px;padding-bottom:12px;overflow-y:auto}.approval-side .detail-line,.approval-side .status-line,.approval-side .section-title{padding:0 16px}.comment-box{width:calc(100% - 32px);min-height:92px;margin:0 16px;padding:10px;resize:none;border:1px solid var(--border);border-radius:6px;outline:0;color:#293532;font-size:13px}.workflow-bar{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));align-items:center;gap:12px;margin-top:12px;padding:14px 28px}.workflow-step{position:relative;display:grid;grid-template-columns:42px minmax(0,1fr);gap:4px 10px;align-items:center}.workflow-step:after{position:absolute;top:20px;right:-16px;width:36px;border-top:1px dashed #b6c3bf;content:""}.workflow-step:last-child:after{display:none}.workflow-step>span{grid-row:span 2;width:42px;height:42px;display:grid;place-items:center;border-radius:50%;color:#83908c;background:#edf1ef}.workflow-step.is-done>span,.workflow-step.is-active>span{color:#fff;background:var(--primary)}.workflow-step.is-active>span{background:#1f6fff}.workflow-step strong{color:#273330;font-size:13px}.workflow-step small{color:var(--muted);font-size:12px}.export-page{display:grid;grid-template-rows:auto auto auto minmax(0,1fr) 114px;gap:0}.export-layout{min-height:0;display:grid;grid-template-columns:35% minmax(520px,1fr) 330px;gap:12px}.export-list,.file-package,.export-settings{overflow:hidden}.export-list{display:grid;grid-template-rows:43px auto 48px}.export-list .mini-table th,.export-list .mini-table td{height:44px;padding:0 8px;font-size:12px}.export-list .mini-table{align-self:start}.file-package{display:flex;flex-direction:column}.file-count{margin:10px 16px;color:var(--muted);font-size:12px}.file-group{border-top:1px solid var(--border)}.file-group h3{height:34px;display:flex;align-items:center;gap:7px;margin:0;padding:0 16px;color:#24302d;background:#fbfcfc;font-size:13px}.file-row{display:grid;grid-template-columns:34px minmax(150px,1fr) 120px 74px 134px 20px 20px;align-items:center;gap:10px;min-height:38px;padding:0 12px;border-top:1px solid var(--border);color:#34403c;font-size:12px}.file-icon{width:24px;height:24px;font-size:8px}.export-settings{display:grid;align-content:start;gap:10px;padding-bottom:14px}.export-settings .select-box,.export-settings .toggle-line,.export-settings .section-title{padding:0 16px}.export-settings .select-box{display:grid;grid-template-columns:86px minmax(0,1fr)}.export-settings .select-box button{width:100%}.export-settings .mini-polo-pair{margin:0 16px;height:150px;border:1px solid var(--border);border-radius:6px}.export-taskbar{display:grid;grid-template-columns:minmax(360px,1fr) 110px 90px 90px repeat(4,auto);align-items:center;gap:18px;margin-top:12px;padding:14px 16px}.export-taskbar>div:first-child{display:grid;grid-template-columns:120px 1fr;align-items:center;gap:8px 14px}.export-taskbar>div:first-child .progress{grid-column:1 / -1}.task-metric{display:grid;gap:4px;justify-items:center;padding:0 18px;border-left:1px solid var(--border)}.task-metric span{color:#1f2b28;font-weight:850}.task-metric strong{font-size:18px}.task-metric.is-danger strong{color:#ef2929}.task-metric.is-warning strong{color:#f28a00}.progress{position:relative;height:8px;border-radius:999px;background:#d9e0de;overflow:hidden}.progress span{display:block;height:100%;border-radius:inherit;background:var(--primary)}.progress b{position:absolute;right:0;bottom:12px;color:#34403c;font-size:14px}.check-page{display:grid;grid-template-rows:auto auto minmax(0,1fr) 218px;gap:0}.check-layout{min-height:0;display:grid;grid-template-columns:244px minmax(420px,.95fr) minmax(420px,1.05fr) 324px;gap:12px}.checklist-panel,.print-check-panel,.check-preview-panel,.issue-panel{overflow:hidden}.check-group{padding:12px;border-top:1px solid var(--border)}.check-group h3{margin:0 0 8px;color:#1f2b28;font-size:13px}.print-check-panel{display:grid;grid-template-rows:43px minmax(0,1fr)}.check-preview-panel{display:grid;grid-template-rows:43px 42px minmax(0,1fr) 46px}.check-preview-panel.is-expanded{border-color:var(--primary);box-shadow:inset 0 0 0 1px #00796f47}.check-preview-panel.is-expanded .check-mockup-stage{background:radial-gradient(circle at 50% 88%,rgba(16,24,23,.18),transparent 30%),linear-gradient(180deg,#fff,#eef7f6)}.check-mockup-stage .mockup-pair{min-height:420px}.issue{background:#f59e0b}.issue-1{top:48%;left:10%}.issue-2{right:44%;bottom:12%}.issue-3{right:20%;top:50%}.issue-4{right:19%;top:25%}.legend-row{display:flex;align-items:center;justify-content:center;gap:16px;border-top:1px solid var(--border)}.issue-panel{display:flex;flex-direction:column;gap:10px;padding:0 12px 12px}.issue-panel .panel-header{margin:0 -12px}.issue-card{position:relative;display:grid;gap:6px;padding:14px 12px 12px 44px;border:1px solid var(--border);border-radius:7px;background:#fff}.issue-card strong{color:#1f2b28;font-size:14px}.issue-card small{color:var(--muted);font-size:12px}.issue-card b{color:#f28a00}.issue-card>div{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:4px}.issue-card .button{height:30px;padding:0 8px}.issue-number{position:absolute;top:14px;left:14px;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;color:#fff;background:#f59e0b;font-size:12px;font-weight:900}.issue-card:first-of-type .issue-number{background:#ef4444}.check-bottom{min-height:0;display:grid;grid-template-columns:260px minmax(380px,.9fr) minmax(520px,1.1fr);gap:12px;margin-top:12px}.result-summary{display:grid;gap:10px;padding:0 14px 14px}.result-summary .panel-header{margin:0 -14px}.status-tile{min-height:42px;display:flex;align-items:center;gap:12px;padding:0 16px;border:1px solid var(--border);border-radius:6px;font-weight:850}.tile-success{color:var(--primary);background:var(--primary-soft);border-color:#9ed0c9}.tile-warning{color:#f28a00;background:var(--orange-soft);border-color:#ffd798}.tile-danger{color:#ef2929;background:var(--red-soft);border-color:#ffb9b9}.fix-log,.check-flow{overflow:hidden}.workflow-line{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));align-items:start;gap:12px;padding:18px}.workflow-line>div{display:grid;justify-items:center;gap:6px;color:var(--muted);text-align:center}.workflow-line span{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:#e6ecea}.workflow-line .is-done span{color:#fff;background:var(--primary)}.workflow-line .is-active span{color:#fff;background:#f59e0b}.workflow-line strong{color:#1f2b28;font-size:12px}.check-flow .comment-box{width:calc(100% - 36px);min-height:58px}.check-flow .button{width:220px;justify-self:end;margin:8px 18px}.mapping-page{display:grid;grid-template-rows:auto auto auto minmax(0,1fr) 160px;gap:0}.mapping-layout{min-height:0;display:grid;grid-template-columns:264px minmax(480px,.95fr) minmax(480px,1.05fr) 246px;gap:12px}.mapping-parts,.uv-panel,.model-panel,.map-params{overflow:hidden}.mapping-parts{display:flex;flex-direction:column}.uv-part-row{grid-template-columns:14px 1fr 16px 16px 16px 48px;min-height:40px;margin:0 10px 7px}.uv-part-row:first-of-type{margin-top:10px}.uv-part-row small{color:var(--primary);font-size:11px}.mapping-parts .section-title{padding:0 12px}.mapping-parts .asset-row{margin:0 10px 7px}.uv-panel{display:grid;grid-template-rows:43px minmax(0,1fr)}.model-panel{display:grid;grid-template-rows:43px 42px minmax(0,1fr)}.model-stage{position:relative;display:grid;place-items:center;background:linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px),linear-gradient(0deg,rgba(0,0,0,.04) 1px,transparent 1px),radial-gradient(circle at 50% 48%,#fff 0,#f1f4f5 72%);background-size:28px 28px,28px 28px,auto;overflow:hidden}.model-overlay-panel{position:absolute;right:14px;bottom:14px;width:min(260px,calc(100% - 28px));display:grid;gap:4px;padding:10px;border:1px solid #bfe0dc;border-radius:7px;background:#fffffff0;box-shadow:var(--shadow-light)}.model-overlay-panel strong,.model-overlay-panel span{display:block}.model-overlay-panel strong{color:var(--text);font-size:13px}.model-overlay-panel span{color:var(--muted);font-size:12px;line-height:1.4}.model-callout{position:absolute;min-width:54px;height:30px;display:inline-grid;place-items:center;padding:0 10px;border:1px solid var(--border);border-radius:5px;background:#fff;box-shadow:0 3px 9px #1018171f;font-size:13px;font-weight:800}.model-callout.collar{top:9%;right:34%}.model-callout.placket{top:29%;right:26%}.model-callout.sleeve-left{top:43%;left:6%}.model-callout.sleeve-right{top:38%;right:7%}.back-preview-card{position:absolute;right:16px;bottom:16px;width:124px;min-height:150px;display:grid;place-items:center;padding:10px;border-radius:7px;background:#ffffffdb;box-shadow:0 8px 24px #1018171f}.back-preview-card span{justify-self:start;color:#34403c;font-size:12px;font-weight:800}.map-params{display:grid;align-content:start;gap:10px;padding-bottom:14px}.map-params .select-box,.map-params .parameter-row,.map-params .range-row,.map-params .status-line,.map-params .section-title{padding:0 14px}.map-params .select-box{display:grid;grid-template-columns:72px minmax(0,1fr)}.map-params .select-box button{width:100%}.mapping-bottom{display:grid;grid-template-columns:210px 150px 170px repeat(4,minmax(120px,1fr)) 306px;align-items:center;gap:14px;margin-top:12px;padding:12px 14px}.preview-thumb{height:134px;display:grid;grid-template-rows:minmax(0,1fr) 24px;gap:6px;margin:0;text-align:center}.preview-thumb>*:first-child{min-height:0}.preview-thumb figcaption{color:#1f2b28;font-size:12px}.mapping-actions{display:grid;gap:10px}.mini-polo,.mini-polo-pair{display:inline-block}.mini-polo{position:relative;width:58px;height:78px;border-radius:12px 12px 10px 10px;clip-path:polygon(16% 0,84% 0,100% 16%,92% 100%,8% 100%,0 16%);background:radial-gradient(circle at 35% 64%,#fff 0 12%,#151515 13% 16%,transparent 17%),linear-gradient(135deg,#057a31 0 34%,#f5c91c 34% 70%,#151515 70% 77%,#f5c91c 77% 100%);box-shadow:inset 0 0 18px #00000029}.mini-polo.is-design-thumb{overflow:hidden;clip-path:none;background:transparent;box-shadow:none}.mini-polo.is-design-thumb img{width:100%;height:100%;display:block;object-fit:contain}.mini-polo:after{position:absolute;right:16%;top:46%;color:#fff;font-family:Impact,sans-serif;font-size:19px;line-height:1;text-shadow:1px 0 #057a31,-1px 0 #057a31,0 1px #057a31,0 -1px #057a31;content:"08"}.mini-polo.is-design-thumb:after{display:none}.mini-polo.mini-back:after{right:19%;top:36%;font-size:28px}.mini-polo.mini-pink{background:linear-gradient(135deg,#f7cad6 0 40%,#008f86 40% 62%,#fff 62% 70%,#f7cad6 70% 100%)}.mini-polo.mini-blue,.mini-polo.mini-cyan{background:linear-gradient(135deg,#67b7e8 0 42%,#f5d23e 42% 56%,#0d4b78 56% 72%,#67b7e8 72% 100%)}.mini-polo.mini-black{background:linear-gradient(135deg,#161a1c 0 48%,#c31229 48% 57%,#f2f2f2 57% 66%,#161a1c 66% 100%)}.mini-polo-pair{display:flex;align-items:center;justify-content:center;gap:18px;background:#fafcfc}.mini-polo-pair.is-design-pair{overflow:hidden}.mini-polo-pair.is-design-pair img{width:100%;height:100%;display:block;object-fit:contain}.mini-polo-pair .mini-polo{width:78px;height:110px}.template-mini-strip{height:100%;min-height:142px;display:grid;grid-template-columns:1.1fr 1.1fr .7fr .7fr 1fr .28fr;align-items:center;gap:18px;padding:22px 34px 30px;overflow:hidden}.mini-cut{position:relative;min-height:112px;border:1px dashed #ff6b6b;background:#fff;clip-path:polygon(12% 12%,34% 0,66% 0,88% 12%,100% 30%,86% 42%,80% 100%,20% 100%,14% 42%,0 30%)}.template-mini-strip.is-filled .mini-cut,.mini-cut span{background:linear-gradient(135deg,#f5c91c 0 44%,#057a31 44% 64%,#151515 64% 72%,#f5c91c 72% 100%)}.mini-cut-2,.mini-cut-3{min-height:76px}.mini-cut-4{min-height:42px;clip-path:none}.mini-cut-5{min-height:122px;clip-path:none}.mini-cut small{position:absolute;right:8px;bottom:7px;left:8px;width:auto;color:var(--muted);font-size:12px;font-weight:750;text-align:center;background:#ffffffb8}.mini-cut span{position:absolute;right:8%;bottom:46%;left:8%;transform:translateY(50%);padding:4px 7px;border:1px dashed #2166e8;color:#2166e8;background:#ffffffd6;font-size:11px;font-weight:900;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.zoom-bar{position:absolute;right:50%;bottom:18px;transform:translate(50%);height:34px;display:inline-flex;align-items:center;gap:10px;padding:0 12px;border:1px solid var(--border);border-radius:6px;background:#ffffffeb;color:#34403c;box-shadow:0 4px 12px #10181714;font-size:13px}.zoom-bar button{border:0;background:transparent;color:#34403c;font-size:16px}.hidden-measure{display:none}.preview-modal-backdrop{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:28px;background:#0a171885;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.preview-modal{width:min(1280px,calc(100vw - 56px));max-height:calc(100vh - 56px);display:grid;grid-template-rows:auto minmax(0,1fr) auto;border:1px solid rgba(203,218,216,.9);border-radius:8px;background:#f7faf9;box-shadow:0 24px 70px #02111247;overflow:hidden}.preview-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:20px 22px 16px;border-bottom:1px solid var(--border);background:#fff}.preview-modal-header h2{margin:8px 0 4px;color:var(--text);font-size:22px;letter-spacing:0}.preview-modal-header p{margin:0;color:var(--muted);font-size:13px}.preview-modal-body{min-height:0;display:grid;grid-template-columns:minmax(620px,1fr) 336px;gap:14px;padding:14px;overflow:auto}.preview-modal-canvas,.preview-modal-side{min-width:0;border:1px solid var(--border);border-radius:8px;background:#fff}.preview-modal-canvas{min-height:560px;display:grid;grid-template-rows:auto minmax(0,1fr)}.preview-modal-toolbar{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}.preview-modal-tools{display:inline-flex;gap:8px}.preview-modal-stage{min-height:0;display:grid;place-items:center;padding:18px;background:linear-gradient(180deg,#ffffffdb,#f4f8f7eb),radial-gradient(circle at 50% 82%,rgba(0,0,0,.1),transparent 24%)}.preview-modal-stage .mockup-pair{width:min(780px,100%);min-height:500px}.preview-modal-stage .design-product-pair{max-height:520px;object-fit:contain}.preview-modal-side{display:grid;align-content:start;gap:12px;padding:12px;overflow:auto}.preview-summary{min-width:0;padding:12px;border:1px solid var(--border);border-radius:7px;background:#fbfcfc}.preview-summary h3{margin:0 0 10px;color:var(--text);font-size:13px}.preview-roster-row{display:grid;grid-template-columns:minmax(0,1fr) 56px 44px;align-items:center;gap:8px;min-height:34px;border-bottom:1px solid #e5eeec;color:var(--text);font-size:12px}.preview-roster-row:last-child{border-bottom:0}.preview-roster-row strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-roster-row span{color:var(--primary);font-weight:900}.preview-roster-row small{color:var(--muted);font-weight:800}.preview-modal-files{display:grid;gap:8px}.preview-file-row{min-width:0;display:grid;grid-template-columns:40px minmax(0,1fr) auto;align-items:center;gap:9px;padding:8px;border:1px solid #e5eeec;border-radius:7px;background:#fff}.preview-file-row strong,.preview-file-row small{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-file-row strong{color:var(--text);font-size:12px}.preview-file-row small{color:var(--muted);font-size:11px}.preview-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:12px 14px;border-top:1px solid var(--border);background:#fff}@media(max-width:1520px){.order-strip{display:none}}.command-toast{position:fixed;right:18px;bottom:88px;z-index:120;width:min(420px,calc(100vw - 36px));display:grid;grid-template-columns:24px minmax(0,1fr) 30px;align-items:start;gap:10px;padding:14px;border:1px solid #bfe0dc;border-radius:8px;background:#fffffff5;box-shadow:0 16px 42px #1018172e;pointer-events:none}.command-toast>svg{margin-top:2px;color:var(--primary)}.command-toast strong,.command-toast span{display:block;min-width:0}.command-toast strong{color:var(--text);font-size:13px}.command-toast span{margin-top:3px;color:var(--muted);font-size:12px;line-height:1.45}.toast-warning{border-color:#ffd798}.toast-warning>svg{color:var(--orange)}.toast-info{border-color:#bcd2ff}.toast-info>svg{color:var(--blue)}.toast-close{width:26px;height:26px;display:grid;place-items:center;border:1px solid var(--border);border-radius:6px;color:#34403c;background:#fff;pointer-events:auto}@media(max-width:1380px){body{min-width:1180px}.topbar{grid-template-columns:240px minmax(380px,1fr) auto}.order-strip{display:none}.workbench-layout{grid-template-columns:46px 236px minmax(0,1fr) 286px}.file-strip{grid-template-columns:repeat(3,minmax(150px,1fr))}.orders-layout,.approval-layout,.export-layout,.check-layout,.mapping-layout,.template-layout,.names-page{transform-origin:top left}}@media(max-width:1180px){body{min-width:0;overflow-x:hidden}html,body,#root,.app-shell{max-width:100vw;overflow-x:hidden}.app-shell{grid-template-rows:auto minmax(0,1fr)}.topbar{position:sticky;top:0;z-index:40;height:auto;min-height:58px;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"brand tools" "nav nav";gap:8px 10px;padding:8px 10px 0}.brand-group{grid-area:brand}.brand-title{font-size:18px}.nav-tabs{grid-area:nav;height:42px;gap:18px;overflow-x:auto;scrollbar-width:none}.nav-tabs::-webkit-scrollbar{display:none}.top-tools{grid-area:tools;gap:6px}.top-icon-button{width:32px;height:32px}.user-menu{max-width:78px;overflow:hidden}.order-strip{display:none}.page-body{width:100vw;max-width:100vw;height:auto;min-height:calc(100vh - 108px);padding:10px;overflow:visible}.app-page,.split-page,.workbench-layout{max-width:100%;height:auto;overflow:visible}.workbench-layout,.home-page,.access-page,.orders-page,.names-page,.templates-page,.approval-page,.export-page,.check-page,.mapping-page{display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:none;gap:10px}.module-rail{flex-direction:row;min-width:0;overflow-x:auto}.rail-spacer{display:none}.rail-button{min-width:42px}.left-panel,.right-panel,.roster-panel,.style-panel,.order-detail-panel,.approval-left,.approval-side,.export-settings,.mapping-parts,.map-params,.issue-panel{overflow:visible}.stage-topline,.page-command-bar,.preview-modal-toolbar{width:100%;align-items:flex-start;flex-direction:column}.stage-actions,.command-actions,.toolbar-controls,.mockup-tabs,.model-tabs,.approval-tabs>div,.preview-modal-tools{width:100%;justify-content:flex-start;overflow-x:auto}.stage-content,.workbench-stage,.home-hero,.home-main-grid,.home-bottom-grid,.home-stats-grid,.access-stats-grid,.access-layout,.access-side-column,.access-editor-body,.access-form-grid,.access-filter-row,.shortcut-grid,.panel,.output-tray,.stage-actions,.canvas-tools,.module-rail,.nav-tabs,.orders-layout,.template-layout,.approval-layout,.export-layout,.check-layout,.check-bottom,.mapping-layout,.mapping-bottom,.generation-queue,.export-taskbar,.template-info-column{grid-template-columns:minmax(0,1fr);grid-template-rows:none}.workbench-stage,.home-page,.home-hero,.home-main-grid,.home-bottom-grid,.home-stats-grid,.access-page,.access-stats-grid,.access-layout,.access-side-column,.access-editor-body,.access-form-grid,.access-filter-row,.shortcut-grid,.stage-content,.stage-actions,.canvas-tools,.module-rail,.nav-tabs,.panel,.output-tray{min-width:0;max-width:100%}.home-page{overflow:visible}.home-hero{padding:18px 14px}.home-hero-copy h1{font-size:27px}.home-hero-actions,.home-hero-actions .button{width:100%}.home-hero-preview{min-height:220px}.home-hero-preview .design-product-pair{max-height:190px}.home-hero-status{position:static;min-width:0;width:calc(100% - 20px);margin:0 10px 10px}.home-stat-card{grid-template-columns:46px minmax(0,1fr)}.shortcut-card{grid-template-columns:40px minmax(0,1fr)}.shortcut-card .status-badge{grid-column:2;grid-row:auto;justify-self:start}.home-flow-card .workflow-line{align-items:start}.access-page,.role-panel,.user-table-panel,.application-panel,.registration-settings,.access-editor-panel,.access-side-column,.role-list,.application-list{overflow:visible}.user-table-panel{overflow-x:auto}.access-user-table{min-width:980px}.access-editor-body{align-items:stretch}.application-actions,.editor-actions,.filter-row,.filter-row.compact{grid-template-columns:minmax(0,1fr)}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:6px}.metric-card{min-height:78px;gap:10px;padding:14px}.metric-card>span{width:40px;height:40px}.metric-card small{font-size:12px}.metric-card strong{font-size:24px}.data-table,.mini-table{min-width:760px;table-layout:auto}.order-table-panel,.export-list,.fix-log,.version-table,.roster-panel{overflow-x:auto}.canvas-tools{flex-wrap:wrap;overflow-x:visible}.canvas-panel-inner{grid-template-rows:auto minmax(0,1fr);min-height:560px}.tool-button,.canvas-sync{flex:0 0 auto}.canvas-sync{min-height:32px;margin-left:0}.canvas-frame{min-height:468px;margin:8px;padding-left:28px}.mockup-panel,.big-preview-panel,.approval-preview,.check-preview-panel,.model-panel{min-height:560px}.mockup-pair{gap:14px;padding:12px}.polo{width:min(46%,178px)}.file-strip,.queue-cards,.drawer-actions,.template-actions{grid-template-columns:minmax(0,1fr)}.original-template-preview{grid-template-columns:minmax(0,1fr);grid-template-rows:none;overflow:visible}.original-template-frame{min-height:520px}.original-template-audit{grid-template-columns:minmax(0,1fr)}.original-template-audit section:last-child{grid-column:auto}.tray-title,.export-taskbar>div:first-child,.field-map-grid,.roster-settings,.color-control,.file-row{grid-template-columns:minmax(0,1fr)}.file-row{align-items:start;gap:6px;padding:10px 12px}.approval-tabs{min-height:auto;display:grid;gap:8px}.approval-mockup-canvas .mockup-pair,.check-mockup-stage .mockup-pair,.preview-modal-stage .mockup-pair{min-height:360px}.workflow-bar,.workflow-line{grid-template-columns:minmax(0,1fr)}.workflow-step:after{display:none}.preview-modal-backdrop{place-items:start;padding:8px;overflow:auto}.preview-modal{width:100%;max-height:none}.preview-modal-body{grid-template-columns:minmax(0,1fr);padding:8px}.preview-modal-canvas{min-height:440px}.preview-modal-actions{flex-wrap:wrap}.preview-modal-actions .button{flex:1 1 160px}.command-toast{right:10px;bottom:12px;width:calc(100vw - 20px)}}
