*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f14;--bg-secondary: #1a1a24;--bg-tertiary: #22222e;--bg-hover: #2a2a38;--border: #2e2e3e;--text-primary: #e8e8ed;--text-secondary: #9898a8;--text-muted: #6a6a7a;--accent: #6c5ce7;--accent-hover: #7d6ff0;--success: #2ecc71;--warning: #f39c12;--danger: #e74c3c;--info: #3498db;--purple: #6c5ce7;--purple-bg: rgba(108,92,231,.15);--blue: #3498db;--blue-bg: rgba(52,152,219,.15);--green: #2ecc71;--green-bg: rgba(46,204,113,.15);--orange: #f39c12;--orange-bg: rgba(243,156,18,.15)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);height:100vh;overflow:hidden}#root{height:100vh}.app{display:flex;height:100vh}.sidebar{width:240px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:20px;border-bottom:1px solid var(--border)}.logo{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:700;background:linear-gradient(135deg,#6c5ce7,#a29bfe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo svg{color:var(--accent);-webkit-text-fill-color:initial}.sidebar-nav{flex:1;padding:12px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;color:var(--text-secondary);font-size:14px;transition:all .15s;border:none;background:none;width:100%;text-align:left;font-family:inherit}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent);color:#fff}.sidebar-footer{padding:12px;border-top:1px solid var(--border)}.config-btn{margin-bottom:8px}.connection-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);padding:4px 12px}.status-icon.connected{color:var(--success)}.status-icon.disconnected{color:var(--danger)}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.page{flex:1;overflow-y:auto;padding:28px 32px}.page::-webkit-scrollbar{width:6px}.page::-webkit-scrollbar-track{background:transparent}.page::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.page-title{font-size:24px;font-weight:700;margin-bottom:24px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header .page-title{margin-bottom:0}.page-actions{display:flex;gap:10px}.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.dash-card{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:border-color .2s}.dash-card:hover{border-color:var(--accent)}.dash-card-icon{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dash-card-info{display:flex;flex-direction:column}.dash-card-value{font-size:22px;font-weight:700}.dash-card-label{font-size:12px;color:var(--text-muted);margin-top:2px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.dash-section{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:20px}.dash-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.dash-section-header h2{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;display:flex;align-items:center;gap:4px;font-family:inherit}.link-btn:hover{text-decoration:underline}.chart-container{margin:0 -8px}.empty-state{text-align:center;color:var(--text-muted);padding:32px 16px;font-size:14px}.alerts-section{margin-top:0}.alerts-grid{display:flex;gap:12px}.alert-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:8px;cursor:pointer;font-size:14px;flex:1;transition:opacity .2s}.alert-item:hover{opacity:.8}.alert-danger{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);color:var(--danger)}.alert-warning{background:#f39c121a;border:1px solid rgba(243,156,18,.3);color:var(--warning)}.filters-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.search-box{display:flex;align-items:center;gap:8px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:0 12px;flex:1;max-width:300px}.search-box input{flex:1;padding:10px 0;background:none;border:none;color:var(--text-primary);font-size:14px;outline:none;font-family:inherit}.search-box input::placeholder{color:var(--text-muted)}.search-box svg{color:var(--text-muted);flex-shrink:0}.filters-bar select,.date-filter input{padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px;outline:none;font-family:inherit;cursor:pointer}.filters-bar select:focus,.date-filter input:focus{border-color:var(--accent)}.date-filter{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.table-wrapper{overflow-x:auto;border-radius:10px;border:1px solid var(--border)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{background:var(--bg-primary);padding:10px 14px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;font-size:12px;text-transform:uppercase;letter-spacing:.3px}.data-table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-primary)}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover td{background:var(--bg-hover)}.data-table tbody tr.selected td{background:#6c5ce71a}.data-table tbody tr:last-child td{border-bottom:none}.data-table input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent)}.product-name{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inline-edit{display:flex;align-items:center;gap:4px}.inline-edit input{width:90px;padding:4px 8px;background:var(--bg-primary);border:1px solid var(--accent);border-radius:4px;color:var(--text-primary);font-size:13px;outline:none;font-family:inherit}.editable{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .15s}.editable:hover{background:var(--bg-hover)}.icon-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:all .15s}.icon-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.stock-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600}.stock-badge.ok{background:#2ecc7126;color:var(--success)}.stock-badge.low{background:#f39c1226;color:var(--warning)}.stock-badge.out{background:#e74c3c26;color:var(--danger)}.status-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.active{background:#2ecc7126;color:var(--success)}.status-badge.inactive{background:#6a6a7a26;color:var(--text-muted)}.order-status{display:inline-block;padding:2px 10px;border:1px solid;border-radius:12px;font-size:12px;font-weight:500}.mass-action-bar{display:flex;align-items:center;gap:16px;padding:10px 16px;background:#6c5ce71a;border:1px solid rgba(108,92,231,.3);border-radius:8px;margin-bottom:16px;font-size:14px}.mass-action-buttons{display:flex;gap:8px}.mass-action-form{display:flex;align-items:center;gap:8px}.mass-input{padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:13px;width:120px;outline:none;font-family:inherit}.pagination{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding:8px 0}.pagination-info{font-size:13px;color:var(--text-muted)}.pagination-controls{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text-secondary)}.pagination-controls button{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer;padding:6px 10px;display:flex;align-items:center;transition:all .15s}.pagination-controls button:hover:not(:disabled){background:var(--bg-hover)}.pagination-controls button:disabled{opacity:.3;cursor:not-allowed}.btn{padding:8px 16px;border-radius:6px;border:none;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit;display:flex;align-items:center;gap:6px}.btn-sm{padding:6px 12px;font-size:12px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover)}.btn-confirm{background:var(--success);color:#fff}.btn-confirm:hover{background:#27ae60}.btn-cancel{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.btn-cancel:hover{background:var(--bg-hover)}.tab-bar{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:0}.tab{padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;gap:6px;font-family:inherit;transition:all .15s}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-actions{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:14px;color:var(--text-secondary)}.period-select{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px;outline:none;font-family:inherit;cursor:pointer}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.analytics-grid .dash-section{margin-bottom:0}.chat-page{flex:1;display:flex;overflow:hidden}.chat-history-panel{width:240px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;padding:12px}.new-chat-btn{width:100%;justify-content:center;margin-bottom:12px;padding:10px}.conv-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.conv-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text-secondary);transition:all .15s}.conv-item:hover{background:var(--bg-hover);color:var(--text-primary)}.conv-item.active{background:#6c5ce726;color:var(--text-primary)}.conv-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;opacity:0;transition:all .15s}.conv-item:hover .conv-delete{opacity:1}.conv-delete:hover{color:var(--danger)}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.message{max-width:85%;padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.6;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message.assistant{align-self:flex-start;background:var(--bg-tertiary);border:1px solid var(--border);border-bottom-left-radius:4px}.message-content p{margin-bottom:8px}.message-content p:last-child{margin-bottom:0}.confirmation-box{background:var(--bg-primary);border:1px solid var(--warning);border-radius:8px;padding:12px 16px;margin-top:10px}.confirmation-box p{color:var(--warning);font-weight:500;margin-bottom:10px;font-size:13px}.confirmation-buttons{display:flex;gap:8px}.dismissed-box{margin-top:10px;padding:8px 14px;border-radius:6px;background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);color:var(--danger);font-size:13px}.chat-input-area{padding:16px 24px 20px;border-top:1px solid var(--border);background:var(--bg-secondary)}.quick-commands{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.quick-cmd{padding:6px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:16px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s;font-family:inherit}.quick-cmd:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.input-row{display:flex;gap:10px}.chat-input{flex:1;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-muted)}.send-btn{padding:12px 20px;background:var(--accent);color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:500;transition:all .15s;font-family:inherit;display:flex;align-items:center;gap:6px}.send-btn:hover{background:var(--accent-hover)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.upload-btn{padding:8px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.upload-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.upload-input{display:none}.welcome{text-align:center;padding:60px 20px;color:var(--text-muted)}.welcome h2{font-size:24px;color:var(--text-primary);margin-bottom:8px}.welcome p{font-size:14px;max-width:400px;margin:0 auto;line-height:1.6}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:32px;width:480px;max-width:90vw;max-height:85vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal h2{font-size:20px;margin-bottom:8px}.modal p{color:var(--text-secondary);font-size:14px;margin-bottom:24px}.detail-modal{width:600px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.detail-item{font-size:14px;padding:8px 0;border-bottom:1px solid var(--border)}.detail-item span:first-child{color:var(--text-muted);margin-right:8px}.detail-modal h3{font-size:15px;margin-bottom:12px;margin-top:8px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-group input{width:100%;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s}.form-group input:focus{border-color:var(--accent)}.form-group input::placeholder{color:var(--text-muted)}.modal-actions{display:flex;gap:10px;margin-top:24px}.error-text{color:var(--danger);font-size:13px;margin-top:8px}.loading{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:13px}.spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}.skeleton-card{height:88px}.skeleton-table{display:flex;flex-direction:column;gap:2px}.skeleton-header{height:42px;border-radius:8px 8px 0 0}.skeleton-row{height:44px;border-radius:0}.skeleton-row:last-child{border-radius:0 0 8px 8px}.skeleton-chart{height:300px;margin-bottom:20px}.toast-container{position:fixed;top:20px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px}.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:10px;font-size:14px;animation:toastIn .3s ease,toastOut .3s ease 3.7s forwards;box-shadow:0 4px 20px #0006}@keyframes toastIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}.toast-success{background:var(--bg-secondary);border:1px solid var(--success);color:var(--success)}.toast-error{background:var(--bg-secondary);border:1px solid var(--danger);color:var(--danger)}.toast-warning{background:var(--bg-secondary);border:1px solid var(--warning);color:var(--warning)}.toast-info{background:var(--bg-secondary);border:1px solid var(--info);color:var(--info)}.stats-panel{width:280px;background:var(--bg-secondary);border-left:1px solid var(--border);padding:20px;overflow-y:auto;flex-shrink:0}.scheduler-layout{display:grid;grid-template-columns:380px 1fr;gap:20px}.scheduler-calendar{margin-bottom:0}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.cal-header h2{font-size:16px;font-weight:600}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-day-label{text-align:center;font-size:11px;color:var(--text-muted);padding:6px 0;text-transform:uppercase;letter-spacing:.5px}.cal-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;cursor:pointer;transition:all .15s;position:relative;gap:3px}.cal-cell:hover:not(.empty){background:var(--bg-hover)}.cal-cell.today{background:#6c5ce726}.cal-cell.today .cal-day-num{color:var(--accent);font-weight:700}.cal-cell.selected{background:var(--accent)}.cal-cell.selected .cal-day-num{color:#fff}.cal-cell.empty{cursor:default}.cal-day-num{font-size:13px;color:var(--text-primary)}.cal-dots{display:flex;gap:3px}.cal-dot{width:5px;height:5px;border-radius:50%}.cal-day-detail{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.cal-day-detail h3{font-size:14px;margin-bottom:10px}.cal-task-item{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;margin-bottom:4px;transition:background .15s}.cal-task-item:hover{background:var(--bg-hover)}.cal-task-item strong{display:block;font-size:13px}.cal-task-meta{font-size:11px;color:var(--text-muted)}.scheduler-list{margin-bottom:0}.scheduler-filters{display:flex;gap:6px;margin-bottom:16px}.task-list{display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 280px);overflow-y:auto}.task-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;padding:14px;transition:border-color .15s}.task-card:hover{border-color:var(--accent)}.task-card-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.task-card-header strong{flex:1;font-size:14px}.task-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.task-status-label{font-size:12px;font-weight:500}.task-card-body{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.task-meta{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.task-result{font-size:12px;color:var(--text-muted);padding:6px 10px;background:var(--bg-tertiary);border-radius:6px;margin-top:4px}.task-card-actions{display:flex;gap:6px;justify-content:flex-end}.form-row{display:flex;gap:12px}.form-row-align{align-items:flex-end}.form-row-align .form-group label{min-height:2.8em;display:flex;align-items:flex-end}.mode-tabs{display:flex;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden}.mode-tab{flex:1;padding:8px 12px;background:var(--bg-tertiary);border:none;color:var(--text-secondary);font-size:13px;cursor:pointer;font-family:inherit;transition:all .15s}.mode-tab:not(:last-child){border-right:1px solid var(--border)}.mode-tab:hover{background:var(--bg-hover)}.mode-tab.active{background:var(--accent);color:#fff}.category-picker{margin-top:10px;border:1px solid var(--border);border-radius:8px;max-height:280px;overflow-y:auto}.category-picker::-webkit-scrollbar{width:5px}.category-picker::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.tree-row{display:flex;align-items:center;gap:6px;padding:7px 10px;transition:background .1s;border-radius:6px;margin:1px 4px}.tree-row:hover{background:var(--bg-hover)}.tree-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:18px;height:18px;border-radius:4px;transition:color .15s}.tree-toggle:hover{color:var(--text-primary)}.tree-toggle-placeholder{width:18px;flex-shrink:0}.tree-check-label{display:inline-flex;align-items:center;gap:12px;cursor:pointer;font-size:13px;flex:1}.tree-check-label input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;min-width:18px;max-height:18px;border:1.5px solid #555;border-radius:3px;background:transparent;cursor:pointer;flex-shrink:0;position:relative;transition:all .15s;margin:0 6px 0 0;padding:0;vertical-align:middle}.tree-check-label input[type=checkbox]:hover{border-color:var(--accent)}.tree-check-label input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.tree-check-label input[type=checkbox]:checked:after{content:"✓";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;line-height:1}.cat-count{font-size:11px;color:var(--text-muted);background:var(--bg-tertiary);padding:1px 6px;border-radius:8px;flex-shrink:0}.cat-summary{padding:10px 12px;background:#6c5ce71a;font-size:13px;color:var(--accent);border-top:1px solid var(--border)}.pp-overlay{z-index:150!important}.pp-modal{width:95vw!important;max-width:1400px!important;height:92vh;display:flex;flex-direction:column}.pp-modal .modal-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.pp-header-right{display:flex;align-items:center;gap:12px}.pp-selected-count{font-size:13px;color:var(--accent);font-weight:600}.pp-body{display:flex;flex:1;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.pp-sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;padding:8px 0}.pp-sidebar-title{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:8px 12px 4px;font-weight:600}.pp-cat-btn{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text-secondary);font-size:13px;padding:6px 12px;cursor:pointer;transition:all .15s}.pp-cat-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.pp-cat-btn.active{background:var(--purple-bg);color:var(--accent);font-weight:600}.pp-cat-count{color:var(--text-muted);font-weight:400;font-size:12px}.pp-cat-row{display:flex;align-items:center;gap:2px}.pp-cat-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;flex-shrink:0}.pp-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.pp-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.pp-search{display:flex;align-items:center;gap:8px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:7px 12px;flex:1;min-width:200px}.pp-search input{background:none;border:none;color:var(--text-primary);font-size:13px;width:100%;outline:none}.pp-search svg{color:var(--text-muted);flex-shrink:0}.pp-toolbar-actions{display:flex;align-items:center;gap:8px}.pp-view-toggle{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:6px;padding:2px}.pp-view-toggle .icon-btn{padding:5px;border-radius:4px}.pp-view-toggle .icon-btn.active{background:var(--accent);color:#fff}.pp-loading,.pp-empty{display:flex;align-items:center;justify-content:center;flex:1;color:var(--text-muted);font-size:14px;padding:40px}.pp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding:16px;overflow-y:auto;flex:1;align-content:start}.pp-card{background:var(--bg-tertiary);border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden}.pp-card:hover{border-color:var(--border);background:var(--bg-hover)}.pp-card.selected{border-color:var(--accent);background:var(--purple-bg)}.pp-card-check{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;border:2px solid var(--border);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;z-index:2;transition:all .15s}.pp-card.selected .pp-card-check{background:var(--accent);border-color:var(--accent);color:#fff}.pp-img{width:100%;aspect-ratio:1;object-fit:cover;display:block;background:var(--bg-secondary)}.pp-img-placeholder{display:flex;align-items:center;justify-content:center;aspect-ratio:1;color:var(--text-muted);background:var(--bg-secondary)}.pp-img-loading{aspect-ratio:1;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pp-card-info{padding:8px 10px}.pp-card-name{font-size:12px;font-weight:500;color:var(--text-primary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.8em}.pp-card-meta{display:flex;gap:6px;font-size:11px;color:var(--text-muted);margin-top:2px;flex-wrap:wrap}.pp-list{overflow-y:auto;flex:1}.pp-list-row{display:flex;align-items:center;gap:12px;padding:8px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:all .15s}.pp-list-row:hover{background:var(--bg-hover)}.pp-list-row.selected{background:var(--purple-bg)}.pp-list-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.pp-list-row.selected .pp-list-check{background:var(--accent);border-color:var(--accent);color:#fff}.pp-list-row .pp-img{width:48px;height:48px;border-radius:6px;flex-shrink:0;aspect-ratio:auto}.pp-list-row .pp-img-placeholder,.pp-list-row .pp-img-loading{width:48px;height:48px;border-radius:6px;aspect-ratio:auto}.pp-list-info{flex:1;min-width:0}.pp-list-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pp-list-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.pp-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;flex-shrink:0}.pp-footer-info{font-size:13px;color:var(--text-secondary)}.pp-footer-actions{display:flex;gap:10px}.btn-product-picker{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;background:var(--bg-tertiary);border:1.5px dashed var(--border);border-radius:8px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .15s}.btn-product-picker:hover{border-color:var(--accent);color:var(--accent);background:var(--purple-bg)}.pp-selected-summary{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.pp-selected-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;font-size:11px;color:var(--text-secondary)}.pp-selected-tag button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;display:flex;line-height:1}.pp-selected-tag button:hover{color:var(--danger)}.pp-selected-tag.pp-more{background:var(--purple-bg);color:var(--accent);border-color:transparent}.round-toggle{display:flex;flex-direction:row;align-items:center;gap:16px;cursor:pointer;padding:14px 18px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;transition:all .15s;-webkit-user-select:none;user-select:none}.round-toggle:hover{border-color:var(--accent)}.round-switch{width:44px;height:24px;min-width:44px;background:var(--bg-hover);border-radius:12px;position:relative;transition:background .2s;flex-shrink:0}.round-switch.on{background:var(--accent)}.round-switch-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--text-muted);transition:all .2s}.round-switch.on .round-switch-knob{left:23px;background:#fff}.round-toggle-label{font-size:14px;font-weight:500;color:var(--text-primary);line-height:24px}.round-description{margin-top:8px;padding:10px 14px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border)}.round-description p{font-size:12px;color:var(--text-secondary);line-height:1.5;margin-bottom:4px}.round-description p:last-child{margin-bottom:0}.round-example{color:var(--text-muted)!important;font-style:italic;margin-top:4px!important}.round-example strong{color:var(--accent)}.coupons-layout{display:grid;grid-template-columns:420px 1fr;gap:20px}.coupons-form-section{align-self:start}.coupons-form{padding:16px 20px 20px;display:flex;flex-direction:column;gap:14px}.coupon-info-box{display:flex;gap:12px;padding:14px 16px;background:var(--blue-bg);border:1px solid rgba(52,152,219,.2);border-radius:10px;color:var(--text-secondary);font-size:13px;line-height:1.5}.coupon-info-box svg{color:var(--blue);flex-shrink:0;margin-top:2px}.coupon-info-box p{margin-bottom:2px}.coupon-info-box p:last-child{margin-bottom:0}.form-hint{display:block;font-size:11px;color:var(--text-muted);margin-top:4px}.form-select{width:100%;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px}.form-divider{height:1px;background:var(--border);margin:4px 0}.coupon-preview{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-tertiary);border-radius:8px;border:1px dashed var(--border)}.coupon-preview-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.coupon-preview-code{font-size:15px;font-weight:700;color:var(--accent);letter-spacing:1.5px;font-family:Consolas,Monaco,monospace}.coupon-toggle-row{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;color:var(--text-primary);transition:border-color .15s}.coupon-toggle-row:hover{border-color:var(--accent)}.btn-generate{width:100%;padding:14px;font-size:15px;font-weight:600;gap:8px;justify-content:center}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}.coupons-results-section{align-self:start}.coupons-results-section .dash-section-header{flex-wrap:wrap;gap:10px}.coupons-result-actions{display:flex;gap:8px}.coupons-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px;text-align:center;color:var(--text-muted)}.coupons-empty svg{margin-bottom:16px;opacity:.3}.coupons-empty h3{font-size:16px;color:var(--text-secondary);margin-bottom:8px;font-weight:600}.coupons-empty p{font-size:13px;line-height:1.6;max-width:320px}.coupons-result-content{padding:0}.coupons-summary{display:flex;align-items:center;gap:16px;padding:14px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap}.coupons-summary-stat{display:flex;align-items:center;gap:6px;font-size:14px;padding:6px 14px;border-radius:20px}.coupons-summary-stat.success{background:var(--green-bg);color:var(--green)}.coupons-summary-stat.error{background:#e74c3c26;color:var(--danger)}.coupons-summary-info{font-size:13px;color:var(--text-muted);margin-left:auto}.coupons-code-list{max-height:500px;overflow-y:auto}.coupon-code-row{display:flex;align-items:center;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border);transition:background .1s}.coupon-code-row:last-child{border-bottom:none}.coupon-code-row:hover{background:var(--bg-hover)}.coupon-code-num{font-size:12px;color:var(--text-muted);min-width:28px;text-align:right}.coupon-code-value{font-size:14px;font-weight:600;color:var(--text-primary);letter-spacing:1px;font-family:Consolas,Monaco,monospace;flex:1}.coupon-copy-btn{opacity:0;transition:opacity .15s}.coupon-code-row:hover .coupon-copy-btn{opacity:1}.coupons-errors{padding:14px 20px;border-top:1px solid var(--border);background:#e74c3c0d}.coupons-errors h4{font-size:13px;color:var(--danger);display:flex;align-items:center;gap:6px;margin-bottom:8px}.coupon-error-row{display:flex;gap:12px;font-size:12px;color:var(--text-muted);padding:4px 0}.coupon-error-row code{color:var(--text-secondary);font-family:monospace}.coupon-error-more{font-size:12px;color:var(--text-muted);margin-top:4px}.profit-loading{display:flex;align-items:center;justify-content:center;padding:80px;color:var(--text-muted);font-size:15px}.profit-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:20px}.profit-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:18px 20px;display:flex;align-items:center;gap:16px}.profit-card-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profit-card-data{display:flex;flex-direction:column;gap:2px;min-width:0}.profit-card-value{font-size:18px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profit-card-label{font-size:12px;color:var(--text-muted)}.profit-insights{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px;margin-bottom:20px}.profit-insight-card{padding:0}.profit-insight-card h3{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-secondary);padding:14px 18px;border-bottom:1px solid var(--border)}.profit-insight-list{padding:6px 0}.profit-insight-row{display:flex;align-items:center;justify-content:space-between;padding:8px 18px;font-size:13px}.profit-insight-row:hover{background:var(--bg-hover)}.profit-insight-name{color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:12px}.profit-insight-badge{font-weight:700;font-size:13px;flex-shrink:0}.scatter-legend{display:flex;justify-content:center;gap:20px;margin-top:8px;font-size:12px;color:var(--text-muted)}.scatter-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;vertical-align:middle}.profit-table-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex:1;justify-content:flex-end}.profit-search{display:flex;align-items:center;gap:6px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:6px 10px;min-width:200px}.profit-search input{background:none;border:none;color:var(--text-primary);font-size:13px;outline:none;width:100%}.profit-search svg{color:var(--text-muted);flex-shrink:0}.profit-filter-pills{display:flex;gap:4px;flex-wrap:wrap}.table-wrapper{overflow:auto}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sortable:hover{color:var(--accent)}.sort-icon-inactive{opacity:.3}.margin-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-weight:700;font-size:12px}.row-warning{background:#f39c120d}.row-danger{background:#e74c3c0d}.td-mono{font-family:Consolas,Monaco,monospace;font-size:12px;color:var(--text-muted)}.td-muted{color:var(--text-muted);font-size:12px}.inline-warn{color:var(--warning);margin-left:6px;vertical-align:middle}.profit-product-name{display:flex;align-items:center;max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profit-suggestions-modal{width:900px!important;max-width:95vw!important;max-height:85vh;display:flex;flex-direction:column}.profit-suggest-controls{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--border);font-size:14px;color:var(--text-secondary)}.profit-suggest-controls input{text-align:center}.profit-suggest-info{padding:10px 20px;font-size:13px;color:var(--text-muted);background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.profit-suggest-list{overflow-y:auto;flex:1}.profit-suggest-list .data-table th,.profit-suggest-list .data-table td{font-size:12px;padding:8px 10px}.inv-dropzone{border:2px dashed var(--border);border-radius:12px;padding:64px 40px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-tertiary)}.inv-dropzone:hover,.inv-dropzone-active{border-color:var(--accent);background:var(--purple-bg)}.inv-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted)}.inv-dropzone-title{font-size:16px;font-weight:600;color:var(--text-primary)}.inv-dropzone-sub{font-size:13px;color:var(--text-muted)}.inv-spinner{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.inv-badge{font-size:10px;padding:3px 10px;border-radius:10px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;margin-left:6px}.inv-badge-high{background:var(--green-bg);color:var(--green)}.inv-badge-medium{background:var(--orange-bg);color:var(--orange)}.inv-badge-low{background:#e74c3c26;color:var(--danger)}.inv-info-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:14px 16px;background:var(--bg-primary);border-radius:8px;margin-bottom:16px;border:1px solid var(--border)}.inv-info-chip{display:flex;gap:5px;align-items:center;font-size:13px;padding:4px 12px;background:var(--bg-tertiary);border-radius:6px;border:1px solid var(--border)}.inv-info-label{color:var(--text-muted);font-size:12px}.inv-info-value{color:var(--text-primary);font-weight:600;font-size:13px}.inv-info-detected{color:var(--text-muted);font-weight:400;font-size:12px}.inv-col-input{width:56px;padding:3px 8px;background:var(--bg-secondary);border:1px solid var(--accent);border-radius:5px;color:var(--text-primary);font-size:13px;text-align:center}.inv-preview-section{margin-top:4px}.inv-preview-title{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:10px}.inv-col-idx{background:#6c5ce714!important}.inv-col-name{background:#3498db0f!important}.inv-col-tag{display:inline-block;font-size:9px;font-weight:700;padding:1px 6px;border-radius:4px;margin-left:6px;letter-spacing:.5px;vertical-align:middle}.inv-col-tag-idx{background:var(--purple-bg);color:var(--accent)}.inv-col-tag-name{background:var(--blue-bg);color:var(--blue)}.inv-action-bar{margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}.inv-tabs-bar{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}.inv-tabs{display:flex;gap:4px}.inv-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;border:none;background:none;color:var(--text-muted);font-size:13px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s;font-family:inherit}.inv-tab:hover{background:var(--bg-hover);color:var(--text-secondary)}.inv-tab.active{background:var(--purple-bg);color:var(--accent)}.inv-tab-count{background:var(--bg-tertiary);padding:1px 7px;border-radius:10px;font-size:11px;font-weight:600;color:var(--text-secondary)}.inv-tab.active .inv-tab-count{background:#6c5ce740;color:var(--accent)}.inv-tabs-right{display:flex;gap:8px;align-items:center}.inv-tabs-right .search-box{min-width:220px}.inv-tab-hint{display:flex;align-items:center;gap:8px;padding:8px 20px;font-size:12px;border-bottom:1px solid var(--border)}.inv-tab-hint-missing{background:#e74c3c0f;color:var(--danger)}.inv-tab-hint-extra{background:#f39c120f;color:var(--warning)}.inv-tab-hint-matched{background:#2ecc710f;color:var(--green)}.inv-ref{font-size:12px;background:var(--bg-primary);padding:3px 8px;border-radius:4px;font-family:JetBrains Mono,Fira Code,monospace;border:1px solid var(--border);white-space:nowrap}.inv-type-badge{font-size:11px;padding:2px 10px;border-radius:10px;font-weight:500;white-space:nowrap}.inv-type-product{background:var(--purple-bg);color:var(--accent)}.inv-type-combo{background:var(--blue-bg);color:var(--blue)}.inv-table-footer{padding:10px 20px;font-size:12px;color:var(--text-muted);border-top:1px solid var(--border)}.inv-bottom-actions{display:flex;gap:10px;margin-top:16px}.img-stepper{display:flex;align-items:center;gap:8px;padding:16px 20px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;margin-bottom:20px}.img-step{display:flex;align-items:center;gap:8px;cursor:default;opacity:.4;transition:opacity .2s}.img-step.active{opacity:1}.img-step.done{opacity:.8;cursor:pointer}.img-step.done:hover{opacity:1}.img-step-num{width:28px;height:28px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}.img-step.active .img-step-num{background:var(--accent);border-color:var(--accent);color:#fff}.img-step.done .img-step-num{background:var(--green-bg);border-color:var(--success);color:var(--success)}.img-step-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.img-step.active .img-step-label{color:var(--text-primary)}.img-step-arrow{color:var(--text-muted);flex-shrink:0}.img-search-box{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;margin-bottom:12px}.img-search-box svg{color:var(--text-muted);flex-shrink:0}.img-search-box input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:14px}.img-search-loading{display:flex;align-items:center;gap:8px;padding:12px;color:var(--text-secondary);font-size:13px}.img-product-list{display:flex;flex-direction:column;gap:2px;max-height:500px;overflow-y:auto}.img-product-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;cursor:pointer;transition:background .15s}.img-product-item:hover{background:var(--bg-hover)}.img-product-thumb{width:44px;height:44px;border-radius:6px;object-fit:cover;background:var(--bg-tertiary);flex-shrink:0}.img-product-info{flex:1;min-width:0}.img-product-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.img-product-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.img-product-arrow{color:var(--text-muted);flex-shrink:0}.img-selected-product{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;margin-bottom:16px}.img-selected-thumb{width:40px;height:40px;border-radius:6px;object-fit:cover;background:var(--bg-tertiary);flex-shrink:0}.img-template-result{display:flex;gap:24px;padding:0 4px}.img-template-preview{flex-shrink:0}.img-template-preview img{max-width:220px;max-height:220px;border-radius:8px;border:1px solid var(--border);object-fit:contain;background:var(--bg-tertiary)}.img-template-params{flex:1}.img-template-params h3{font-size:15px;font-weight:600;margin-bottom:14px}.img-param-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.img-param{display:flex;flex-direction:column;gap:6px}.img-param-label{font-size:12px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.3px}.img-param-value{display:flex;align-items:center;gap:6px;font-size:14px}.img-param-value input,.img-param-value select{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);padding:6px 8px;font-size:13px;outline:none}.img-param-value input:focus,.img-param-value select:focus{border-color:var(--accent)}.img-color-swatch{width:24px;height:24px;border-radius:6px;border:2px solid var(--border);flex-shrink:0}.img-progress-card{padding:24px;display:flex;flex-direction:column;gap:14px;align-items:center;text-align:center}.img-progress-bar-wrap{width:100%;height:8px;background:var(--bg-tertiary);border-radius:8px;overflow:hidden}.img-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--success));border-radius:8px;transition:width .4s ease}.img-progress-info{display:flex;align-items:center;gap:16px;font-size:14px;color:var(--text-secondary)}.img-progress-file{font-size:12px;color:var(--text-muted);font-style:italic}.img-progress-errors{width:100%;display:flex;flex-direction:column;gap:4px;margin-top:8px}.img-error-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--danger);padding:6px 10px;background:#e74c3c1a;border-radius:6px}.img-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;padding:20px}.img-preview-card{background:var(--bg-tertiary);border:2px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .2s}.img-preview-card.approved{border-color:var(--success)}.img-preview-card.rejected{border-color:var(--border);opacity:.55}.img-preview-card.rejected:hover{opacity:.85}.img-preview-card.dragging{opacity:.35;transform:scale(.95)}.img-preview-card.drag-over{border-color:var(--accent);box-shadow:0 0 0 2px #6c5ce74d}.img-preview-drag-handle{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;cursor:grab;color:var(--text-muted);border-bottom:1px solid var(--border);font-size:12px}.img-preview-drag-handle:active{cursor:grabbing}.img-cover-badge{display:flex;align-items:center;gap:4px;color:var(--warning);font-weight:600;font-size:11px}.img-preview-image{position:relative;aspect-ratio:1;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden}.img-preview-image img{width:100%;height:100%;object-fit:contain}.img-preview-badge{position:absolute;top:8px;left:8px;background:#000000a6;color:var(--warning);padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.img-preview-badge-after{color:var(--success)}.img-preview-footer{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}.img-preview-name{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.img-deploy-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;border-top:1px solid var(--border);font-size:14px;color:var(--text-secondary)}.img-deploy-success{background:var(--green-bg);color:var(--success);gap:10px;justify-content:center}.login-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary)}.login-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:40px 36px;width:100%;max-width:420px}.login-logo{text-align:center;margin-bottom:28px}.login-logo svg{color:var(--accent);margin-bottom:8px}.login-logo h1{font-size:22px;font-weight:700;color:var(--text-primary)}.login-tabs{display:flex;gap:4px;background:var(--bg-tertiary);border-radius:10px;padding:4px;margin-bottom:24px}.login-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 0;border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s}.login-tab:hover{color:var(--text-secondary)}.login-tab.active{background:var(--bg-secondary);color:var(--text-primary);box-shadow:0 1px 3px #0003}.login-form{display:flex;flex-direction:column;gap:12px}.login-field{display:flex;align-items:center;gap:10px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:10px;padding:0 14px;transition:border-color .2s}.login-field:focus-within{border-color:var(--accent)}.login-field svg{color:var(--text-muted);flex-shrink:0}.login-field input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:14px;padding:12px 0;font-family:inherit}.login-field input::placeholder{color:var(--text-muted)}.login-error{background:#e74c3c1f;color:var(--danger);padding:10px 14px;border-radius:8px;font-size:13px;border:1px solid rgba(231,76,60,.2)}.login-submit{margin-top:8px;padding:12px;font-size:14px;font-weight:600;border-radius:10px;display:flex;align-items:center;justify-content:center;gap:8px}.onboarding-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:40px 36px;width:100%;max-width:520px}.onboarding-step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}.onboarding-step h2{font-size:18px;font-weight:600;color:var(--text-primary)}.onboarding-step p{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.onboarding-step .login-field{width:100%}.onboarding-step .btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px}.onboarding-icon{width:64px;height:64px;border-radius:16px;background:var(--purple-bg);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:8px}.sidebar-user{padding:4px 12px 8px}.sidebar-user-email{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}@media(max-width:1200px){.cards-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.analytics-grid{grid-template-columns:1fr}}@media(max-width:900px){.sidebar{width:60px}.sidebar-header,.nav-item span,.connection-status .status-text,.config-btn span{display:none}.nav-item{justify-content:center;padding:12px}.connection-status{justify-content:center}.chat-history-panel{width:60px}.conv-title,.new-chat-btn span{display:none}}
