:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;background:#f4f6f9;font-family:Inter,PingFang SC,Microsoft YaHei,Arial,sans-serif}*{box-sizing:border-box}body{background:#f4f6f9;min-width:320px;min-height:100vh;margin:0}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.6}button:focus-visible,input:focus-visible,textarea:focus-visible{outline-offset:2px;outline:3px solid #14b8a633}.boot-screen,.login-page{place-items:center;min-height:100vh;padding:24px;display:grid}.boot-screen{color:#475569;gap:10px}.login-page{background:linear-gradient(#0f172ae6,#0f172ad1),#111827}.login-panel{background:#fff;border:1px solid #dbe3ef;border-radius:8px;width:min(420px,100%);padding:28px;box-shadow:0 24px 70px #0f172a47}.login-brand,.brand{align-items:center;gap:12px;display:flex}.login-brand{margin-bottom:28px}.brand-mark{color:#fff;background:#0f766e;border-radius:8px;place-items:center;width:38px;height:38px;font-weight:800;display:grid}.login-brand strong,.login-brand small,.brand strong,.brand small{display:block}.login-brand strong,.brand strong{letter-spacing:0}.login-brand small,.brand small{color:#94a3b8;margin-top:3px;font-size:12px}.login-title{margin-bottom:20px}.login-title h1{margin:0;font-size:24px;line-height:1.25}.login-title p{color:#64748b;margin:8px 0 0}.app-shell{grid-template-columns:232px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{color:#f8fafc;background:#111827;height:100vh;padding:22px 16px;position:sticky;top:0}.brand{margin-bottom:28px}.nav-item{color:#cbd5e1;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;width:100%;min-height:42px;margin-bottom:8px;padding:0 12px;transition:background .18s,color .18s;display:flex}.nav-item:hover,.nav-item.active{color:#fff;background:#1f2937}.main-panel{min-width:0;padding:22px}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.page-heading{min-width:0}.topbar h1{margin:0;font-size:25px;line-height:1.2}.topbar p,.panel-head p,.modal-head p{color:#64748b;margin:5px 0 0;font-size:13px}.top-actions,.panel-actions,.row-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.admin-chip{color:#172033;background:#fff;border:1px solid #dbe3ef;border-radius:8px;align-items:center;gap:7px;min-height:38px;padding:0 10px;display:flex}.admin-chip small{color:#64748b}.icon-button{color:#243043;background:#fff;border:1px solid #dbe3ef;border-radius:8px;place-items:center;width:38px;height:38px;transition:border-color .18s,color .18s,transform .18s;display:inline-grid}.icon-button:hover{color:#0f766e;border-color:#0f766e}.icon-button:active,.text-button:active,.primary-button:active,.ghost-button:active,.top-button:active{transform:translateY(1px)}.alert,.success-alert,.loading-panel{border-radius:8px;align-items:center;gap:10px;min-height:46px;margin-bottom:14px;padding:0 14px;display:flex}.alert{color:#be123c;background:#fff1f2;border:1px solid #fecdd3}.success-alert{color:#0f766e;background:#f0fdfa;border:1px solid #99f6e4}.loading-panel{color:#475569;background:#fff;border:1px solid #dbe3ef}.inline-loading{margin:14px}.spinning{animation:1s linear infinite spin}.view-stack{gap:16px;display:grid}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.kpi-card,.panel{background:#fff;border:1px solid #dbe3ef;border-radius:8px}.kpi-card{grid-template-columns:42px 1fr;align-items:center;gap:3px 12px;min-height:88px;padding:14px;display:grid}.kpi-card span{color:#64748b;font-size:13px}.kpi-card strong{font-size:24px}.kpi-icon{border-radius:8px;grid-row:span 2;place-items:center;width:40px;height:40px;display:grid}.kpi-icon.teal{color:#0f766e;background:#ccfbf1}.kpi-icon.blue{color:#2563eb;background:#dbeafe}.kpi-icon.amber{color:#b45309;background:#fef3c7}.kpi-icon.rose{color:#be123c;background:#ffe4e6}.content-grid{grid-template-columns:minmax(0,1.5fr) minmax(280px,.8fr);gap:16px;display:grid}.panel{overflow:hidden}.panel-head{border-bottom:1px solid #e5eaf2;justify-content:space-between;align-items:center;gap:12px;min-height:54px;padding:0 14px;display:flex}.panel-head h2{margin:0;font-size:16px}.panel-meta{color:#64748b;font-size:13px}.compact-table,.data-table{width:100%}.table-row,.data-row{border-bottom:1px solid #edf1f7;align-items:center;gap:12px;min-height:48px;padding:0 14px;display:grid}.table-row{grid-template-columns:minmax(170px,1fr) 90px 80px 80px}.products-grid{grid-template-columns:minmax(260px,1fr) 100px 90px 80px 80px 96px}.users-grid,.shipments-grid{grid-template-columns:minmax(220px,1fr) repeat(4,minmax(86px,120px))}.table-head,.data-head{color:#64748b;background:#f8fafc;min-height:40px;font-size:13px;font-weight:700}.table-row:last-child,.data-row:last-child{border-bottom:0}.data-row:hover:not(.data-head),.table-row:hover:not(.table-head),.native-table tbody tr:hover{background:#fbfcfe}.strong{font-weight:700}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.product-cell{align-items:center;gap:10px;min-width:0;display:flex}.product-cell img{object-fit:cover;background:#e5e7eb;border-radius:8px;flex:none;width:38px;height:38px}.product-cell strong,.product-cell small{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.product-cell small{color:#64748b;margin-top:2px;font-size:12px}.status-pill{color:#64748b;background:#f1f5f9;border-radius:999px;justify-content:center;align-items:center;min-height:24px;padding:0 8px;font-size:12px;font-weight:700;display:inline-flex}.status-pill.on{color:#0f766e;background:#ccfbf1}.text-button,.primary-button,.ghost-button,.top-button{border-radius:8px;justify-content:center;align-items:center;gap:6px;min-height:36px;padding:0 12px;transition:border-color .18s,background .18s,color .18s,transform .18s;display:inline-flex}.text-button{color:#0f766e;background:#fff;border:1px solid #dbe3ef}.text-button:hover,.ghost-button:hover,.top-button:hover{color:#0f766e;border-color:#0f766e}.text-button.danger,.top-button.danger{color:#be123c}.text-button.danger:hover,.top-button.danger:hover{color:#be123c;border-color:#fb7185}.primary-button{color:#fff;background:#0f766e;border:0}.primary-button:hover:not(:disabled){background:#115e59}.ghost-button,.top-button{color:#334155;background:#fff;border:1px solid #dbe3ef}.wide-button{width:100%}.shipment-list{padding:8px 14px}.shipment-row{color:#475569;justify-content:space-between;align-items:center;min-height:38px;display:flex}.shipment-row strong{color:#0f766e}.empty-state{color:#94a3b8;place-items:center;min-height:150px;display:grid}.compact-empty{min-height:100px}.service-form{grid-template-columns:repeat(3,minmax(0,1fr)) 160px;align-items:end;gap:12px;padding:14px;display:grid}.config-layout{grid-template-columns:210px minmax(0,1fr);gap:16px;display:grid}.config-tabs{align-content:start;gap:8px;display:grid}.config-tab{color:#334155;text-align:left;background:#fff;border:1px solid #dbe3ef;border-radius:8px;justify-content:space-between;align-items:center;min-height:42px;padding:0 12px;display:flex}.config-tab:hover,.config-tab.active{color:#0f766e;background:#f0fdfa;border-color:#0f766e}.config-tab small{color:#64748b}.config-panel{min-width:0}.native-table-wrap{width:100%;overflow-x:auto}.native-table{border-collapse:collapse;width:100%;min-width:760px}.native-table th,.native-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #edf1f7;height:48px;padding:0 12px}.native-table th{color:#64748b;background:#f8fafc;font-size:13px;font-weight:700}.native-table td{color:#243043;max-width:220px}.action-col{width:196px}.native-table td.row-actions{flex-wrap:nowrap;min-width:172px;max-width:none}.native-table .row-actions .text-button{flex:none}.image-value{align-items:center;gap:8px;min-width:0;display:flex}.image-value img{object-fit:cover;background:#e5e7eb;border-radius:8px;flex:none;width:34px;height:34px}.image-value span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.modal-mask{z-index:20;background:#0f172a6b;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal{background:#fff;border-radius:8px;width:min(580px,100%);max-height:calc(100vh - 36px);padding:18px;overflow-y:auto;box-shadow:0 24px 60px #0f172a38}.small-modal{width:min(460px,100%)}.product-modal{width:min(860px,100%)}.config-modal{width:min(780px,100%)}.modal-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.modal-head h2{margin:0;font-size:18px}.form-field{color:#475569;gap:7px;margin-bottom:12px;font-size:13px;font-weight:700;display:grid}.form-field input,.form-field textarea{color:#172033;background:#fff;border:1px solid #dbe3ef;border-radius:8px;width:100%;min-height:38px;padding:0 10px}.form-field textarea{resize:vertical;min-height:82px;padding:9px 10px}.form-field input:focus,.form-field textarea:focus{border-color:#14b8a6;outline:3px solid #14b8a629}.form-field.invalid input,.form-field.invalid textarea{background:#fff7f7;border-color:#fb7185}.form-field.invalid input:focus,.form-field.invalid textarea:focus{border-color:#e11d48;outline-color:#e11d4829}.field-error{color:#e11d48;margin-top:-2px;font-size:12px;font-weight:600;line-height:1.35;display:block}.field-grid,.config-form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.prize-editor{border-top:1px solid #edf1f7;gap:10px;margin-top:14px;padding-top:14px;display:grid}.prize-editor-head,.prize-row{gap:10px;display:grid}.prize-editor-head{grid-template-columns:minmax(0,1fr) auto;align-items:center}.prize-row{background:#fbfcfe;border:1px solid #edf1f7;border-radius:8px;grid-template-columns:88px minmax(140px,1fr) minmax(150px,1fr) 82px 82px 40px;align-items:end;padding:10px}.prize-row .form-field{margin-bottom:0}.config-form-grid .wide{grid-column:1/-1}.switch-field{color:#334155;align-items:center;gap:10px;min-height:38px;font-size:13px;font-weight:700;display:flex}.inline-switch{margin-top:0}.switch-field input{accent-color:#0f766e;width:18px;height:18px}.form-error{color:#be123c;background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;margin:0 0 12px;padding:9px 10px;font-size:13px}.modal-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=1120px){.topbar{flex-direction:column;align-items:flex-start}.top-actions{width:100%}.service-form{grid-template-columns:1fr 1fr}}@media (width<=980px){.app-shell{grid-template-columns:1fr}.sidebar{flex-wrap:wrap;align-items:center;gap:8px;height:auto;display:flex;position:static}.brand{width:100%;margin-bottom:8px}.nav-item{width:auto;margin-bottom:0}.kpi-grid,.content-grid,.config-layout{grid-template-columns:1fr 1fr}}@media (width<=760px){.main-panel{padding:16px}.kpi-grid,.content-grid,.field-grid,.config-form-grid,.config-layout,.service-form{grid-template-columns:1fr}.config-tabs{grid-template-columns:1fr 1fr}.data-table,.compact-table{overflow-x:auto}.products-grid{min-width:760px}.users-grid,.shipments-grid{min-width:640px}.prize-row{grid-template-columns:1fr}.table-row{min-width:560px}.top-actions{align-items:stretch}.admin-chip,.top-button{width:100%}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}
