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