@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg: #f7fef9;--bg2: #f0fdf4;--bg3: #dcfce7;--surface: #ffffff;--surface2: #f7fef9;--border: #d1fae5;--border2: #a7f3d0;--text: #052e16;--text2: #14532d;--text3: #4b7a5e;--primary: #16a34a;--primary-d: #15803d;--primary-s: #dcfce7;--primary-g: linear-gradient(135deg, #16a34a 0%, #15803d 100%);--accent: #ea580c;--accent-d: #c2410c;--accent-s: #ffedd5;--green: #16a34a;--green-bg: #dcfce7;--amber: #d97706;--amber-bg: #fef3c7;--red: #dc2626;--red-bg: #fee2e2;--blue: #2563eb;--blue-bg: #dbeafe;--violet: #7c3aed;--violet-bg: #ede9fe;--cyan: #0891b2;--cyan-bg: #cffafe;--orange: #ea580c;--orange-bg: #ffedd5;--sidebar-w: 252px;--sidebar-c: 64px;--radius: 12px;--radius-lg: 16px;--shadow: 0 2px 16px rgba(5,46,22,.09);--shadow-sm: 0 1px 4px rgba(5,46,22,.06);--shadow-lg: 0 8px 32px rgba(5,46,22,.14);--transition: .16s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;transition:grid-template-columns var(--transition)}.app.sidebar-collapsed{grid-template-columns:var(--sidebar-c) 1fr}.sidebar{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;flex-direction:column;background:linear-gradient(175deg,#052e16,#14532d 45%,#166534);border-right:none;z-index:100;width:var(--sidebar-w);transition:width var(--transition);--text: rgba(220, 252, 231, .92);--text2: rgba(220, 252, 231, .65);--text3: rgba(220, 252, 231, .42);--border: rgba(255, 255, 255, .1);--border2: rgba(255, 255, 255, .18);--bg: rgba(255, 255, 255, .07);--bg2: rgba(255, 255, 255, .04);--surface: rgba(255, 255, 255, .1);--primary: #4ade80;--primary-s: rgba(255, 255, 255, .12);--red-bg: rgba(239, 68, 68, .18);--red: #fca5a5}.app.sidebar-collapsed .sidebar{width:var(--sidebar-c)}.brand{display:flex;align-items:center;gap:10px;padding:16px 14px;border-bottom:1px solid var(--border);min-height:64px;overflow:hidden}.brand-icon{flex-shrink:0;width:36px;height:36px;background:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 2px 8px #0000002e}.brand-icon-img{width:34px;height:34px;object-fit:contain;border-radius:9px}.brand-text{flex:1;overflow:hidden;min-width:0}.brand-name{font-size:15px;font-weight:800;color:var(--text);letter-spacing:-.3px;white-space:nowrap}.brand-sub{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.7px;white-space:nowrap;margin-top:1px}.brand-toggle{flex-shrink:0;background:var(--bg);border:1px solid var(--border);border-radius:7px;color:var(--text3);width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.brand-toggle:hover{background:var(--primary-s);color:var(--primary);border-color:var(--border2)}.app.sidebar-collapsed .brand{flex-direction:column;gap:10px;justify-content:center;padding:14px 0;overflow:visible}.nav-wrapper{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.nav-section-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;padding:10px 8px 4px;white-space:nowrap}.nav-divider{height:1px;background:var(--border);margin:8px 0}.nav-link{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:9px;color:var(--text2);text-decoration:none;font-size:13.5px;font-weight:600;transition:var(--transition);white-space:nowrap;overflow:hidden}.nav-link:hover{background:var(--primary-s);color:var(--text)}.nav-link.active{background:var(--primary-s);color:var(--primary);font-weight:700;position:relative}.nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--primary);border-radius:0 3px 3px 0}.nav-link.active .nav-icon{color:var(--primary)}.nav-icon{flex-shrink:0;width:16px;height:16px}.nav-badge{margin-left:auto;background:var(--primary);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:20px;min-width:18px;text-align:center}.nav-badge.red{background:var(--red)}.nav-badge.amber{background:var(--amber)}.app.sidebar-collapsed .nav-link{justify-content:center;padding:10px}.app.sidebar-collapsed .nav-link span,.app.sidebar-collapsed .nav-badge,.app.sidebar-collapsed .nav-section-label,.app.sidebar-collapsed .brand-text{display:none}.sidebar-footer{padding:10px;border-top:1px solid var(--border)}.user-card{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;overflow:hidden;margin-bottom:4px}.avatar{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:var(--primary-g);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}.user-info{flex:1;overflow:hidden;min-width:0}.user-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.user-role{font-size:10px;color:var(--text3)}.signout-btn{width:100%;display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:9px;background:transparent;border:none;color:var(--text3);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);font-family:inherit}.signout-btn:hover{background:var(--red-bg);color:var(--red)}.main{display:flex;flex-direction:column;min-height:100vh}.topbar{position:sticky;top:0;z-index:50;background:#f7fef9eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-title{font-size:17px;font-weight:800;letter-spacing:-.4px;color:var(--text)}.topbar-sub{font-size:11px;color:var(--text3);margin-top:1px}.mobile-menu-btn{display:none;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text2);width:36px;height:36px;align-items:center;justify-content:center;cursor:pointer}.topbar-actions{display:flex;align-items:center;gap:8px}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:7px 12px;color:var(--text3);font-size:13px;min-width:200px;cursor:pointer;transition:var(--transition)}.topbar-search:hover{border-color:var(--border2)}.kbd{margin-left:auto;background:var(--bg);border:1px solid var(--border2);border-radius:4px;font-size:10px;padding:1px 5px;color:var(--text3)}.content{flex:1;padding:24px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition)}.card:hover{box-shadow:var(--shadow)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:relative;overflow:hidden;transition:var(--transition);box-shadow:var(--shadow-sm)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:3px 3px 0 0}.stat-card.green:before{background:var(--green)}.stat-card.blue:before{background:var(--blue)}.stat-card.amber:before{background:var(--amber)}.stat-card.violet:before{background:var(--violet)}.stat-card.red:before{background:var(--red)}.stat-card.cyan:before{background:var(--cyan)}.stat-card.slate:before{background:#94a3b8}.stat-card.primary:before{background:var(--primary)}.stat-card:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.stat-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}.stat-icon.green{background:var(--green-bg);color:var(--green)}.stat-icon.blue{background:var(--blue-bg);color:var(--blue)}.stat-icon.amber{background:var(--amber-bg);color:var(--amber)}.stat-icon.violet{background:var(--violet-bg);color:var(--violet)}.stat-icon.red{background:var(--red-bg);color:var(--red)}.stat-icon.cyan{background:var(--cyan-bg);color:var(--cyan)}.stat-icon.primary{background:var(--primary-s);color:var(--primary)}.stat-value{font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1;color:var(--text)}.stat-label{font-size:12px;color:var(--text3);margin-top:4px;font-weight:500}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:18px}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.panel-title{font-size:14px;font-weight:700;color:var(--text)}.panel-sub{font-size:12px;color:var(--text3);margin-top:2px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;padding:10px 16px;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg)}td{padding:13px 16px;font-size:13px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg2)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.badge.green{background:var(--green-bg);color:var(--green)}.badge.amber{background:var(--amber-bg);color:var(--amber)}.badge.red{background:var(--red-bg);color:var(--red)}.badge.blue{background:var(--blue-bg);color:var(--blue)}.badge.violet{background:var(--violet-bg);color:var(--violet)}.badge.slate{background:#f1f5f9;color:#64748b}.badge.cyan{background:var(--cyan-bg);color:var(--cyan)}.badge.primary{background:var(--primary-s);color:var(--primary)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;border:1px solid var(--border2);background:var(--surface);color:var(--text2);transition:var(--transition);text-decoration:none;white-space:nowrap;font-family:inherit}.btn:hover{background:var(--bg2);border-color:var(--border2);color:var(--primary)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--primary-g);border-color:transparent;color:#fff;box-shadow:0 3px 12px #0d94884d}.btn.primary:hover{opacity:.92;box-shadow:0 5px 18px #0d948866;color:#fff}.btn.danger{background:var(--red-bg);border-color:#dc262633;color:var(--red)}.btn.danger:hover{background:var(--red);color:#fff;border-color:transparent}.btn.success{background:var(--green-bg);border-color:#05966933;color:var(--green)}.btn.success:hover{background:var(--green);color:#fff;border-color:transparent}.btn.sm{padding:5px 11px;font-size:12px;border-radius:7px}.btn.icon-only{padding:8px}.btn-group{display:flex;gap:6px;flex-wrap:wrap}.field{display:flex;flex-direction:column;gap:5px}.label{font-size:12px;font-weight:700;color:var(--text2)}.input,.select,textarea{background:var(--surface);border:1.5px solid var(--border);border-radius:9px;padding:9px 12px;color:var(--text);font-size:13.5px;font-family:inherit;outline:none;transition:var(--transition);width:100%}.input:focus,.select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0d94881f}.input::placeholder{color:var(--text3)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237BA5A2' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}textarea{resize:vertical;min-height:80px}.input-with-icon{position:relative}.input-with-icon .icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}.input-with-icon .input{padding-left:36px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid.three{grid-template-columns:1fr 1fr 1fr}.field.span2{grid-column:span 2}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}.toggle-row:last-child{border-bottom:none}.toggle-info .toggle-label{font-size:13.5px;font-weight:700;color:var(--text)}.toggle-info .toggle-desc{font-size:12px;color:var(--text3);margin-top:2px}.toggle{position:relative;display:inline-block;width:42px;height:24px;border-radius:20px;border:none;cursor:pointer;flex-shrink:0}.toggle input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;z-index:1}.toggle input:disabled{cursor:not-allowed}.toggle input:disabled~.slider{opacity:.5;cursor:not-allowed}.toggle .slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border2);border-radius:20px;transition:var(--transition);pointer-events:none}.toggle .slider:after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:var(--transition);box-shadow:0 1px 3px #00000026}.toggle input:checked~.slider{background:var(--primary)}.toggle input:checked~.slider:after{left:21px}.toggle.on{background:var(--primary)}.toggle.on:after{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;right:3px;box-shadow:0 1px 3px #00000026}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d262273;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:0 20px 60px #0d26222e;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;animation:modal-in .2s ease}.modal.lg{max-width:720px}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.modal-title{font-size:15px;font-weight:800;color:var(--text)}.modal-close{background:var(--bg);border:1px solid var(--border);border-radius:7px;color:var(--text3);cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.modal-close:hover{background:var(--red-bg);color:var(--red);border-color:transparent}.modal-body{flex:1;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:14px}.modal-foot{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 22px;border-top:1px solid var(--border)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text3);gap:12px;text-align:center}.empty-state svg{opacity:.4}.empty-state p{font-size:14px;font-weight:500}.center-spin{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text3);font-size:13px;gap:10px}.spinner{width:18px;height:18px;border:2px solid var(--border2);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);font-size:13px;font-weight:600;animation:toast-in .2s ease;min-width:240px;max-width:360px;color:var(--text)}.toast.success{border-left:3px solid var(--green)}.toast.error{border-left:3px solid var(--red)}.toast.info{border-left:3px solid var(--primary)}@keyframes toast-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}.error-banner{background:var(--red-bg);border:1px solid rgba(220,38,38,.2);border-radius:9px;padding:10px 14px;font-size:13px;color:var(--red);display:flex;align-items:center;gap:8px;font-weight:600}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden}.login-wrap:before{content:"";position:absolute;width:700px;height:700px;background:radial-gradient(circle,rgba(22,163,74,.1) 0%,transparent 65%);top:-200px;right:-100px;pointer-events:none}.login-wrap:after{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(234,88,12,.08) 0%,transparent 65%);bottom:-100px;left:-100px;pointer-events:none}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px;width:100%;max-width:420px;box-shadow:0 16px 48px #0d26221f;position:relative;z-index:1}.login-logo{width:72px;height:72px;background:#fff;border-radius:20px;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:20px;box-shadow:0 4px 18px #052e1624}.login-logo-img{width:68px;height:68px;object-fit:contain}.login-title{font-size:22px;font-weight:800;letter-spacing:-.5px;margin-bottom:4px;color:var(--text)}.login-sub{font-size:13px;color:var(--text3);margin-bottom:28px}.dev-hint{background:var(--accent-s);border:1px solid rgba(217,119,6,.2);border-radius:9px;padding:10px 14px;font-size:12px;color:var(--accent);margin-bottom:14px;font-weight:600}.dev-hint b{font-size:20px;letter-spacing:4px;display:block;margin-top:4px;font-family:monospace}.progress-bar{height:5px;background:var(--bg3);border-radius:5px;overflow:hidden}.progress-fill{height:100%;border-radius:5px;transition:width .4s ease}.tabs{display:flex;gap:4px;background:var(--bg);border-radius:10px;padding:3px;margin-bottom:20px;width:fit-content;border:1px solid var(--border)}.tab{padding:7px 16px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;background:transparent;border:none;color:var(--text3);transition:var(--transition);font-family:inherit}.tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg)}.search-input{display:flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--border);border-radius:9px;padding:7px 12px;flex:1;min-width:200px;max-width:360px;transition:var(--transition)}.search-input:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #0d94881a}.search-input input{background:transparent;border:none;color:var(--text);font-size:13px;outline:none;width:100%;font-family:inherit}.search-input input::placeholder{color:var(--text3)}.order-timeline{display:flex;margin:8px 0}.timeline-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;gap:6px}.timeline-step:before{content:"";position:absolute;top:12px;left:50%;right:-50%;height:2px;background:var(--border)}.timeline-step:last-child:before{display:none}.timeline-step.done:before{background:var(--green)}.timeline-dot{width:24px;height:24px;border-radius:50%;border:2px solid var(--border2);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:10px;position:relative;z-index:1;transition:var(--transition)}.timeline-step.done .timeline-dot{background:var(--green);border-color:var(--green);color:#fff}.timeline-step.active .timeline-dot{border-color:var(--primary);background:var(--primary-s);color:var(--primary)}.timeline-label{font-size:10px;color:var(--text3);text-align:center;white-space:nowrap;font-weight:500}.timeline-step.done .timeline-label{color:var(--green);font-weight:600}.timeline-step.active .timeline-label{color:var(--primary);font-weight:700}.prod-img{width:40px;height:40px;border-radius:9px;object-fit:cover;border:1px solid var(--border);background:var(--bg);flex-shrink:0}.prod-name{font-weight:700;font-size:13px;color:var(--text)}.prod-brand{font-size:11px;color:var(--text3)}.drawer-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0d262266;z-index:90;border:none;cursor:pointer}.catalog-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}.catalog-stats{display:flex;gap:10px;flex-wrap:wrap}.catalog-stat{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:9px 14px 9px 10px;box-shadow:var(--shadow-sm);transition:var(--transition)}.catalog-stat:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.catalog-stat-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.catalog-stat-icon.c1{background:var(--primary-s);color:var(--primary)}.catalog-stat-icon.c2{background:var(--blue-bg);color:var(--blue)}.catalog-stat-icon.c3{background:var(--orange-bg);color:var(--orange)}.catalog-stat-num{font-size:19px;font-weight:800;letter-spacing:-.5px;line-height:1;color:var(--text)}.catalog-stat-label{font-size:10.5px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.4px;margin-top:3px}.catalog-layout{display:grid;grid-template-columns:264px 1fr;gap:16px;min-height:520px;align-items:start}.catalog-rail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:10px;position:sticky;top:88px}.catalog-rail-head{display:flex;align-items:center;justify-content:space-between;font-size:10.5px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;padding:6px 8px 10px}.catalog-rail-head span{display:inline-flex;align-items:center;gap:6px}.catalog-c1{display:flex;align-items:center;gap:11px;width:100%;padding:9px 10px;border-radius:11px;border:1px solid transparent;background:transparent;cursor:pointer;text-align:left;transition:var(--transition);margin-bottom:3px;font-family:inherit}.catalog-c1:hover{background:var(--bg2)}.catalog-c1.active{background:var(--primary-s);border-color:var(--border2)}.catalog-c1-icon{width:38px;height:38px;border-radius:10px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;overflow:hidden;transition:var(--transition)}.catalog-c1.active .catalog-c1-icon{background:#fff;box-shadow:var(--shadow-sm)}.catalog-c1-icon img{width:100%;height:100%;object-fit:cover}.catalog-c1-body{flex:1;min-width:0;display:flex;flex-direction:column}.catalog-c1-name{display:block;font-size:13.5px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.catalog-c1.active .catalog-c1-name{color:var(--primary-d)}.catalog-c1-sub{display:block;font-size:11px;color:var(--text3);margin-top:1px}.catalog-c1-chev{color:var(--text3);flex-shrink:0;opacity:0;transition:var(--transition)}.catalog-c1:hover .catalog-c1-chev,.catalog-c1.active .catalog-c1-chev{opacity:1}.count-pill{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:20px;padding:0 7px;border-radius:20px;font-size:11px;font-weight:700;background:var(--bg3);color:var(--text2);flex-shrink:0}.catalog-c1.active .count-pill{background:#fff;color:var(--primary-d)}.catalog-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.catalog-hero{display:flex;align-items:center;gap:14px;padding-bottom:18px;margin-bottom:18px;border-bottom:1px solid var(--border)}.catalog-hero-icon{width:56px;height:56px;border-radius:14px;background:var(--primary-g);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;overflow:hidden;box-shadow:var(--shadow-sm)}.catalog-hero-icon img{width:100%;height:100%;object-fit:cover}.catalog-hero-body{flex:1;min-width:0}.catalog-hero-title{font-size:19px;font-weight:800;letter-spacing:-.4px;color:var(--text)}.catalog-hero-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text3);margin-top:3px}.catalog-hero-meta code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;background:var(--bg3);color:var(--text2);padding:1px 7px;border-radius:5px}.catalog-sec-label{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}.catalog-sec-label .count-pill{background:var(--bg3)}.catalog-c2-row{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:26px}.catalog-c2-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 13px;border-radius:10px;border:1.5px solid var(--border);background:var(--surface);color:var(--text2);font-size:13px;font-weight:700;cursor:pointer;transition:var(--transition);font-family:inherit}.catalog-c2-chip:hover{border-color:var(--border2);background:var(--bg2);color:var(--text)}.catalog-c2-chip .c2-emoji{font-size:15px}.catalog-c2-chip.active{border-color:var(--primary);background:var(--primary-s);color:var(--primary-d)}.catalog-c2-chip .count-pill{min-width:18px;height:17px;font-size:10px}.catalog-c2-chip.active .count-pill{background:var(--primary);color:#fff}.catalog-c3-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(212px,1fr));gap:12px}.catalog-c3-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:13px;transition:var(--transition);position:relative;overflow:hidden}.catalog-c3-card:hover{box-shadow:var(--shadow);border-color:var(--border2);transform:translateY(-2px)}.catalog-c3-top{display:flex;gap:11px;align-items:center}.catalog-c3-avatar{width:46px;height:46px;border-radius:11px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:23px;flex-shrink:0;overflow:hidden}.catalog-c3-avatar img{width:100%;height:100%;object-fit:cover}.catalog-c3-body{flex:1;min-width:0}.catalog-c3-name{font-weight:700;font-size:13.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.catalog-c3-id{font-size:10px;color:var(--text3);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.catalog-c3-promo{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:var(--accent);background:var(--accent-s);padding:2px 7px;border-radius:20px;margin-top:7px}.catalog-c3-actions{display:flex;gap:6px;margin-top:12px;padding-top:11px;border-top:1px dashed var(--border)}.catalog-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 24px;gap:12px;color:var(--text3);border:1.5px dashed var(--border2);border-radius:var(--radius);background:var(--bg2)}.catalog-empty-icon{width:52px;height:52px;border-radius:14px;background:var(--bg3);display:flex;align-items:center;justify-content:center;color:var(--text3)}.catalog-empty p{font-size:13.5px;font-weight:600;color:var(--text2)}.catalog-empty span{font-size:12px;color:var(--text3);max-width:320px}.catalog-c3-grid .catalog-empty{grid-column:1 / -1}.level-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.3px}.level-pill.c1{background:var(--primary-s);color:var(--primary-d)}.level-pill.c2{background:var(--blue-bg);color:var(--blue)}.level-pill.c3{background:var(--orange-bg);color:var(--orange)}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:6px;margin-top:8px}.emoji-opt{aspect-ratio:1;border:1px solid var(--border);border-radius:9px;background:var(--surface);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.emoji-opt:hover{background:var(--bg2);border-color:var(--border2);transform:scale(1.06)}.emoji-opt.active{border-color:var(--primary);background:var(--primary-s);box-shadow:0 0 0 2px #16a34a26}@media (max-width: 980px){.catalog-layout{grid-template-columns:1fr}.catalog-rail{position:static}}.cust-row{transition:var(--transition)}.cust-row:hover{background:var(--bg2)}.ovr-pill{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;line-height:1;padding:3px 7px;border-radius:6px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.ovr-pill.on{background:var(--green-bg);color:var(--green)}.ovr-pill.off{background:var(--red-bg);color:var(--red)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d262273;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:250;display:flex;justify-content:flex-end;animation:drawer-fade .18s ease}@keyframes drawer-fade{0%{opacity:0}to{opacity:1}}.drawer{width:100%;max-width:480px;height:100%;background:var(--surface);border-left:1px solid var(--border);box-shadow:-12px 0 48px #0d26222e;display:flex;flex-direction:column;animation:drawer-slide .24s cubic-bezier(.22,1,.36,1)}@keyframes drawer-slide{0%{transform:translate(100%)}to{transform:none}}.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.drawer-avatar{width:44px;height:44px;border-radius:50%;background:var(--primary-g);color:#fff;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;flex-shrink:0}.drawer-name{font-size:16px;font-weight:800;color:var(--text);letter-spacing:-.3px}.drawer-sub{font-size:12.5px;color:var(--text3);margin-top:2px;display:flex;align-items:center;gap:5px}.drawer-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:22px}.drawer-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--text3)}.drawer-meta-item{display:inline-flex;align-items:center;gap:5px}.drawer-meta-id{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;background:var(--bg3);color:var(--text2);padding:1px 7px;border-radius:5px;margin-left:auto}.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.kpi-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px}.kpi-icon{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}.kpi-icon.green{background:var(--green-bg);color:var(--green)}.kpi-icon.blue{background:var(--blue-bg);color:var(--blue)}.kpi-icon.amber{background:var(--amber-bg);color:var(--amber)}.kpi-icon.violet{background:var(--violet-bg);color:var(--violet)}.kpi-value{font-size:19px;font-weight:800;letter-spacing:-.5px;line-height:1.1;color:var(--text)}.kpi-label{font-size:11px;color:var(--text3);font-weight:600;margin-top:4px}.drawer-section-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px;display:flex;align-items:center;gap:8px}.perm-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--border)}.perm-row.col{flex-direction:column;align-items:stretch;gap:10px}.perm-row:last-child{border-bottom:none}.perm-label{font-size:13.5px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:7px}.perm-desc{font-size:12px;color:var(--text3);margin-top:3px}.override-seg{display:inline-flex;gap:3px;padding:3px;background:var(--bg3);border-radius:9px;width:100%}.override-seg.is-disabled{opacity:.6;pointer-events:none}.override-seg-btn{flex:1;padding:7px 10px;border:none;cursor:pointer;border-radius:7px;font-family:inherit;font-size:12px;font-weight:600;background:transparent;color:var(--text3);transition:var(--transition)}.override-seg-btn:hover{color:var(--text2)}.override-seg-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.override-seg-btn.on.active{background:var(--green);color:#fff}.override-seg-btn.off.active{background:var(--red);color:#fff}.order-mini-list{display:flex;flex-direction:column;gap:8px}.order-mini{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 13px;background:var(--surface2);border:1px solid var(--border);border-radius:10px}.order-mini.clickable{width:100%;text-align:left;cursor:pointer;font:inherit;transition:var(--transition)}.order-mini.clickable:hover{border-color:var(--primary);background:var(--primary-s);box-shadow:var(--shadow-sm)}.order-mini-main{min-width:0}.order-mini-id{font-size:12.5px;font-weight:700;color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.order-mini-sub{font-size:11px;color:var(--text3);margin-top:2px}.order-mini-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.order-mini-total{font-size:13px;font-weight:800;color:var(--text)}.drawer-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:30px;color:var(--text3);font-size:13px}.drawer-backdrop.nested{z-index:260}.order-detail-drawer{max-width:520px}.kpi-grid.od-dates{grid-template-columns:repeat(3,1fr)}.kpi-value.sm{font-size:12.5px;font-weight:700;line-height:1.3}.od-timeline{display:flex;align-items:flex-start}.od-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}.od-step:before{content:"";position:absolute;top:10px;left:50%;right:-50%;height:2px;background:var(--border2)}.od-step:last-child:before{display:none}.od-step.done:before{background:var(--green)}.od-step-icon{color:var(--border2);background:var(--surface);position:relative;z-index:1;display:flex}.od-step.done .od-step-icon{color:var(--green)}.od-step-label{font-size:9.5px;font-weight:600;color:var(--text3);text-align:center}.od-step.done .od-step-label{color:var(--green)}.od-cancelled{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--red);background:var(--red-bg);padding:11px 13px;border-radius:10px}.od-items{display:flex;flex-direction:column;gap:9px}.od-item{display:flex;align-items:center;gap:11px;padding:9px;border:1px solid var(--border);border-radius:10px;background:var(--surface2)}.od-item-img{width:42px;height:42px;border-radius:9px;flex-shrink:0;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text3);overflow:hidden}.od-item-img img{width:100%;height:100%;object-fit:cover}.od-item-main{flex:1;min-width:0}.od-item-name{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.od-item-sub{font-size:11px;color:var(--text3);margin-top:2px}.od-item-right{text-align:right;flex-shrink:0}.od-item-qty{font-size:11px;color:var(--text3)}.od-item-total{font-size:13px;font-weight:800;color:var(--text);margin-top:2px}.od-bill{display:flex;flex-direction:column;gap:8px}.od-bill-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text2)}.od-bill-row .free{font-style:normal;font-weight:700;color:var(--green)}.od-bill-row.total{border-top:1px dashed var(--border2);padding-top:9px;margin-top:3px;font-size:15px;font-weight:800;color:var(--text)}.od-kv{display:flex;flex-direction:column;gap:10px}.od-kv-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.od-kv-k{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text3);font-weight:600}.od-kv-v{font-size:13px;font-weight:700;color:var(--text)}.od-kv-v.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11.5px}.od-address{display:flex;gap:11px;padding:13px;border:1px solid var(--border);border-radius:10px;background:var(--surface2)}.od-address-pin{color:var(--primary);flex-shrink:0;margin-top:1px}.od-address-name{font-size:13.5px;font-weight:700;color:var(--text)}.od-address-line{font-size:12.5px;color:var(--text2);margin-top:3px;line-height:1.5}.od-address-phone{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--text3);margin-top:5px}.od-notes{font-size:12.5px;color:var(--text2);font-style:italic;margin-top:10px;padding:9px 12px;background:var(--amber-bg);border-radius:8px}.cust-detail-head{display:flex;align-items:center;gap:16px;padding:18px 20px;margin-bottom:18px}.drawer-avatar.lg{width:56px;height:56px;font-size:22px}.cust-detail-name{font-size:20px;font-weight:800;letter-spacing:-.4px;color:var(--text)}.cust-detail-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:12.5px;color:var(--text3);margin-top:5px}.cust-detail-kpis{margin-bottom:18px;grid-template-columns:repeat(4,1fr)}.cust-detail-grid{align-items:start}.order-filter-tabs{display:flex;gap:4px;overflow-x:auto;padding:14px 16px 0;border-bottom:1px solid var(--border)}.order-filter-tab{padding:8px 14px;border:none;background:transparent;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;white-space:nowrap;color:var(--text3);border-bottom:2px solid transparent;margin-bottom:-1px;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.order-filter-tab:hover{color:var(--text2)}.order-filter-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.order-filter-count{background:var(--bg3);color:var(--text3);border-radius:20px;font-size:10px;padding:1px 6px;font-weight:700}.order-filter-tab.active .order-filter-count{background:var(--primary);color:#fff}@media (max-width: 980px){.cust-detail-kpis{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.app,.app.sidebar-collapsed{grid-template-columns:1fr}.sidebar{position:fixed;left:-100%;top:0;height:100%;width:var(--sidebar-w)!important;z-index:100;transition:left var(--transition)}.sidebar.mobile-open{left:0}.mobile-menu-btn{display:flex}.grid-2,.grid-3,.grid-2-1,.form-grid,.form-grid.three{grid-template-columns:1fr}.field.span2{grid-column:span 1}.stat-grid{grid-template-columns:repeat(2,1fr)}.topbar-search{display:none}.content{padding:16px}.drawer{max-width:100%}}.modal.xl{max-width:980px}.modal-subtitle{font-size:12px;color:var(--text3);margin-top:3px;font-weight:500}.editor2{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start}.editor2 .form-col{display:flex;flex-direction:column;gap:20px;min-width:0}.editor2 .preview-col{position:sticky;top:4px;display:flex;flex-direction:column;gap:12px}@media (max-width: 820px){.editor2{grid-template-columns:1fr}.editor2 .preview-col{position:static;order:-1}}.form-section{display:flex;flex-direction:column;gap:12px}.form-section+.form-section{padding-top:18px;border-top:1px solid var(--border)}.form-section-head{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--text3)}.form-section-head svg{color:var(--primary)}.field-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.field{display:flex;flex-direction:column;gap:6px}.hint{font-size:11px;color:var(--text3);line-height:1.5}.preset-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.preset{position:relative;border:1.5px solid var(--border);border-radius:12px;padding:0;overflow:hidden;cursor:pointer;background:var(--surface);transition:var(--transition);text-align:left}.preset:hover{border-color:var(--border2);transform:translateY(-1px)}.preset.active{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-s)}.preset-swatch{height:34px;display:flex;align-items:center;justify-content:center;font-size:16px}.preset-name{font-size:11px;font-weight:700;padding:5px 8px;color:var(--text2);text-transform:capitalize}.preset .preset-check{position:absolute;top:4px;right:4px;color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.color-field{display:flex;flex-direction:column;gap:6px}.color-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:38px;padding:0;border:1px solid var(--border);border-radius:9px;background:var(--surface);cursor:pointer}.color-input::-webkit-color-swatch-wrapper{padding:4px}.color-input::-webkit-color-swatch{border:none;border-radius:6px}.seg{display:inline-flex;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px;flex-wrap:wrap}.seg button{border:none;background:transparent;cursor:pointer;font-size:12px;font-weight:600;color:var(--text2);padding:6px 12px;border-radius:7px;transition:var(--transition)}.seg button:hover{color:var(--primary)}.seg button.active{background:var(--surface);color:var(--primary);box-shadow:0 1px 3px #00000014}.sched-summary{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;padding:9px 12px;border-radius:10px;background:var(--bg2);border:1px solid var(--border);color:var(--text2)}.sched-summary.live{background:var(--green-bg);border-color:transparent;color:var(--green)}.sched-summary.future{background:var(--amber-bg);border-color:transparent;color:var(--amber)}.sched-summary.off{background:var(--bg3);color:var(--text3)}.tile-list{display:flex;flex-direction:column;gap:10px}.tile-card{border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:10px;background:var(--bg2)}.tile-card-head{display:flex;align-items:center;gap:8px}.tile-swatch{width:26px;height:26px;border-radius:7px;flex-shrink:0;border:1px solid var(--border)}.tile-card-head .tile-idx{font-size:11px;font-weight:800;color:var(--text3)}.tile-del{margin-left:auto;background:transparent;border:none;cursor:pointer;color:var(--text3);padding:4px;border-radius:6px;transition:var(--transition);display:flex;align-items:center;justify-content:center}.tile-del:hover{color:var(--red);background:var(--red-bg)}.tile-add{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:11px;border:1.5px dashed var(--border2);border-radius:11px;background:transparent;color:var(--text3);cursor:pointer;font-weight:700;font-size:13px;transition:var(--transition)}.tile-add:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-s)}.app-preview-label{font-size:10px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:var(--text3);display:flex;align-items:center;gap:6px}.app-frame{border-radius:18px;overflow:hidden;border:1px solid var(--border);background:var(--surface);box-shadow:0 8px 24px #0d26221a}.app-hero{padding:16px 14px 18px}.app-hero-row{display:flex;align-items:center;gap:8px}.app-hero-emoji{font-size:24px}.app-hero-title{font-size:19px;font-weight:900;letter-spacing:-.3px;line-height:1.15}.app-hero-sub{font-size:12px;font-weight:600;margin-top:3px;opacity:.9}.app-tiles{display:flex;gap:8px;margin-top:14px;overflow-x:auto;padding-bottom:2px}.app-tiles::-webkit-scrollbar{height:0}.app-tile{flex:0 0 46%;border-radius:12px;padding:9px;min-height:116px;display:flex;flex-direction:column;gap:6px;overflow:hidden}.app-tile-pill{align-self:flex-start;font-size:9px;font-weight:800;letter-spacing:.3px;color:#fff;background:var(--primary);padding:2px 7px;border-radius:99px}.app-tile-title{font-size:12px;font-weight:800;color:#14112b;line-height:1.25}.app-tile-img{width:100%;height:56px;border-radius:6px;object-fit:cover;margin-top:auto;background:#0000000f}.app-tiles-empty{font-size:11px;color:var(--text3);padding:12px 0 2px;font-style:italic}
