@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-card:#111827cc;--bg-card-hover:#182238e6;--bg-glass:#ffffff08;--border-color:#ffffff0f;--border-hover:#ffffff1f;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-green:#2ecc71;--accent-green-dim:#2ecc7126;--accent-blue:#3498db;--accent-blue-dim:#3498db26;--accent-orange:#f39c12;--accent-orange-dim:#f39c1226;--accent-red:#e74c3c;--accent-red-dim:#e74c3c26;--accent-purple:#9b59b6;--accent-purple-dim:#9b59b626;--accent-cyan:#00d2ff;--gradient-green:linear-gradient(135deg,#2ecc71,#27ae60);--gradient-blue:linear-gradient(135deg,#3498db,#2980b9);--gradient-orange:linear-gradient(135deg,#f39c12,#e67e22);--gradient-red:linear-gradient(135deg,#e74c3c,#c0392b);--gap-sm:8px;--gap-md:16px;--gap-lg:24px;--gap-xl:32px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow-green:0 0 20px #2ecc7133;--shadow-glow-blue:0 0 20px #3498db33;--color-critical:#ff6b6b;--color-risk:#f39c12;--color-attention:#f1c40f;--color-normal:#2ecc71;--color-new:#3498db}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.app-layout{width:100vw;max-width:100vw;min-height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);width:260px;padding:var(--gap-lg);z-index:100;flex-direction:column;height:100vh;transition:transform .3s;display:flex;position:fixed;top:0;left:0}.sidebar-logo{align-items:center;gap:var(--gap-md);padding-bottom:var(--gap-lg);border-bottom:1px solid var(--border-color);margin-bottom:var(--gap-lg);display:flex}.sidebar-logo h1{background:linear-gradient(135deg,var(--accent-green),var(--accent-cyan));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.3rem;font-weight:700}.sidebar-logo span{color:var(--text-muted);font-size:.75rem;font-weight:400}.sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex}.nav-item{align-items:center;gap:var(--gap-sm);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;padding:10px 14px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover,.nav-item.active{background:var(--accent-green-dim);color:var(--accent-green)}.nav-item.active{border-left:3px solid var(--accent-green)}.sidebar-footer{border-top:1px solid var(--border-color);padding-top:var(--gap-md);gap:var(--gap-sm);flex-direction:column;display:flex}.user-info{align-items:center;gap:var(--gap-sm);border-radius:var(--radius-sm);padding:8px;display:flex}.user-avatar{background:var(--gradient-green);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex}.user-name{font-size:.85rem;font-weight:600}.user-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem}.main-content{padding:var(--gap-xl);box-sizing:border-box;flex:1;min-width:0;max-width:calc(100vw - 260px);min-height:100vh;margin-left:260px;overflow-x:hidden}.page-header{margin-bottom:var(--gap-xl);justify-content:space-between;align-items:flex-start;display:flex}.page-header h2{letter-spacing:-.5px;font-size:1.8rem;font-weight:800}.page-header p{color:var(--text-secondary);margin-top:4px;font-size:.9rem}.header-actions{gap:var(--gap-sm);flex-wrap:wrap;justify-content:flex-end;align-items:center;display:flex}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--gap-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .3s;position:relative;overflow:hidden}.card:before{content:"";background:linear-gradient(90deg,#0000,#ffffff1a,#0000);height:1px;position:absolute;top:0;left:0;right:0}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--gap-sm);align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:flex}.kpi-grid{gap:var(--gap-md);margin-bottom:var(--gap-lg);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--gap-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transition:all .3s;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--gradient-green);opacity:0;height:2px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.kpi-card:hover:before{opacity:1}.kpi-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-icon{margin-bottom:var(--gap-sm);font-size:1.5rem}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:.75rem;font-weight:600}.kpi-value{color:var(--text-primary);letter-spacing:-1px;font-size:1.8rem;font-weight:800;line-height:1.2}.kpi-delta{border-radius:20px;align-items:center;gap:4px;margin-top:8px;padding:2px 8px;font-size:.8rem;font-weight:600;display:inline-flex}.kpi-delta.positive{color:var(--accent-green);background:var(--accent-green-dim)}.kpi-delta.negative{color:var(--accent-red);background:var(--accent-red-dim)}.kpi-delta.neutral{color:var(--text-muted);background:var(--bg-glass)}.charts-grid{gap:var(--gap-md);margin-bottom:var(--gap-lg);grid-template-columns:3fr 2fr;display:grid}.charts-row{gap:var(--gap-md);margin-bottom:var(--gap-lg);grid-template-columns:1fr 1fr;display:grid}.chart-card{min-height:320px}.data-table-wrapper{margin-bottom:var(--gap-lg)}.data-table{border-collapse:separate;border-spacing:0;width:100%;font-size:.85rem}.data-table thead{z-index:10;position:sticky;top:0}.data-table th{background:var(--bg-secondary);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:1px solid var(--border-color);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;padding:12px 16px;font-size:.75rem;font-weight:600}.data-table th:hover,.data-table th.sorted{color:var(--accent-green)}.data-table td{border-bottom:1px solid var(--border-color);white-space:nowrap;vertical-align:middle;padding:12px 16px}.data-table tr{transition:background .2s}.data-table tbody tr:hover{background:var(--bg-card-hover);cursor:pointer}.status-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.status-badge.normal{background:var(--accent-green-dim);color:var(--accent-green)}.status-badge.attention{background:var(--accent-orange-dim);color:var(--accent-orange)}.status-badge.risk{background:var(--accent-red-dim);color:var(--accent-red)}.status-badge.critical{color:#ff6b6b;background:#e74c3c40;animation:2s ease-in-out infinite pulse-critical}.status-badge.new{background:var(--accent-blue-dim);color:var(--accent-blue)}@keyframes pulse-critical{0%,to{opacity:1}50%{opacity:.7}}.alert-list{gap:var(--gap-sm);flex-direction:column;max-height:300px;display:flex;overflow-y:auto}.alert-item{gap:var(--gap-sm);padding:var(--gap-sm)var(--gap-md);border-radius:var(--radius-sm);background:var(--bg-glass);border-left:3px solid var(--accent-orange);word-break:break-word;font-size:.85rem;transition:background .2s;display:flex;overflow:hidden}.alert-item:hover{background:#ffffff0d}.alert-item.critical{border-left-color:var(--accent-red);background:#e74c3c0d}.alert-item.risk{border-left-color:var(--accent-orange)}.alert-product{color:var(--text-primary);overflow-wrap:break-word;font-size:.82rem;font-weight:600}.alert-message{color:var(--text-secondary);overflow-wrap:break-word;font-size:.8rem}.ai-panel{gap:var(--gap-md);flex-direction:column;display:flex}.ai-insight{padding:var(--gap-md);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-color);transition:all .2s}.ai-insight:hover{border-color:var(--border-hover)}.ai-insight-header{align-items:center;gap:var(--gap-sm);margin-bottom:6px;display:flex}.ai-insight-type{text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:2px 8px;font-size:.7rem;font-weight:700}.ai-insight-type.anomaly{background:var(--accent-orange-dim);color:var(--accent-orange)}.ai-insight-type.risk{background:var(--accent-red-dim);color:var(--accent-red)}.ai-insight-type.recommendation{background:var(--accent-blue-dim);color:var(--accent-blue)}.ai-insight-type.insight{background:var(--accent-purple-dim);color:var(--accent-purple)}.ai-insight-title{color:var(--text-primary);font-size:.9rem;font-weight:600}.ai-insight-body{color:var(--text-secondary);font-size:.82rem;line-height:1.5}.ai-confidence{color:var(--text-muted);margin-top:6px;font-size:.7rem}.ai-chat-input{gap:var(--gap-sm);margin-top:var(--gap-sm);display:flex}.ai-chat-input input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;flex:1;padding:10px 14px;font-family:Inter,sans-serif;font-size:.85rem;transition:border-color .2s}.ai-chat-input input:focus{border-color:var(--accent-green)}.ai-chat-input input::placeholder{color:var(--text-muted)}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:var(--gradient-green);color:#fff}.btn-primary:hover{box-shadow:var(--shadow-glow-green);transform:translateY(-1px)}.btn-secondary{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--border-hover);color:var(--text-primary)}.btn-danger{background:var(--accent-red-dim);color:var(--accent-red)}.btn-sm{padding:5px 10px;font-size:.78rem}.filters-bar{gap:var(--gap-sm);margin-bottom:var(--gap-lg);flex-wrap:wrap;display:flex}.filter-chip{background:var(--bg-glass);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:20px;padding:6px 14px;font-size:.8rem;font-weight:500;transition:all .2s}.filter-chip:hover,.filter-chip.active{background:var(--accent-green-dim);border-color:var(--accent-green);color:var(--accent-green)}.filter-chip:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.table-scroll{max-height:600px;overflow:auto}select.filter-select{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:20px;outline:none;padding:6px 14px;font-family:Inter,sans-serif;font-size:.8rem;font-weight:500}select.filter-select:focus{border-color:var(--accent-green)}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{width:400px;padding:var(--gap-xl);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-lg)}.login-card h1{background:linear-gradient(135deg,var(--accent-green),var(--accent-cyan));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:4px;font-size:1.5rem;font-weight:800}.login-card p{color:var(--text-muted);margin-bottom:var(--gap-lg);font-size:.85rem}.form-group{margin-bottom:var(--gap-md)}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.form-group input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:10px 14px;font-family:Inter,sans-serif;font-size:.9rem;transition:border-color .2s}.form-group input:focus{border-color:var(--accent-green)}.login-btn{width:100%;margin-top:var(--gap-sm);padding:12px}.login-error{color:var(--accent-red);margin-top:var(--gap-sm);text-align:center;font-size:.82rem}.admin-grid{gap:var(--gap-lg);grid-template-columns:1fr 1fr;display:grid}.admin-item{padding:var(--gap-sm)var(--gap-md);border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.admin-item-label{font-size:.85rem;font-weight:500}.admin-item-desc{color:var(--text-muted);font-size:.75rem}.toggle{cursor:pointer;background:#ffffff1a;border:none;border-radius:12px;width:44px;height:24px;transition:background .3s;position:relative}.toggle.active{background:var(--accent-green)}.toggle:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .3s;position:absolute;top:3px;left:3px}.toggle.active:after{transform:translate(20px)}.dev-badge{text-transform:uppercase;letter-spacing:.5px;background:var(--accent-purple-dim);color:var(--accent-purple);border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:.65rem;font-weight:700;display:inline-flex}.loading-spinner{padding:var(--gap-xl);justify-content:center;align-items:center;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--accent-green);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ai-response{margin-top:var(--gap-md);padding:var(--gap-md);background:var(--bg-glass);border:1px solid var(--accent-green-dim);border-radius:var(--radius-md);animation:.3s fadeIn}.ai-response-label{color:var(--accent-green);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:.7rem;font-weight:700}.ai-response-text{color:var(--text-primary);font-size:.85rem;line-height:1.6}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.back-link{color:var(--text-secondary);margin-bottom:var(--gap-lg);align-items:center;gap:6px;font-size:.85rem;font-weight:500;text-decoration:none;transition:color .2s;display:inline-flex}.back-link:hover{color:var(--accent-green)}.product-header{margin-bottom:var(--gap-xl);justify-content:space-between;align-items:flex-start;display:flex}.product-meta{gap:var(--gap-md);margin-top:8px;display:flex}.product-meta-item{color:var(--text-muted);font-size:.8rem}.detail-grid{gap:var(--gap-md);margin-bottom:var(--gap-lg);grid-template-columns:1fr 1fr;display:grid}.bottom-grid{gap:var(--gap-md);margin-bottom:var(--gap-lg);grid-template-columns:2fr 3fr;display:grid}.mobile-header{display:none}.sidebar-overlay{z-index:99;-webkit-backdrop-filter:blur(2px);background:#0009;animation:.2s fadeIn;display:none;position:fixed;inset:0}.sidebar-overlay.visible{display:block}@media (max-width:1400px){.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media (max-width:1024px){.sidebar{box-shadow:none;transform:translate(-280px)}.sidebar.open{transform:translate(0);box-shadow:4px 0 32px #0009}.main-content{padding-top:calc(var(--gap-md) + 56px);box-sizing:border-box;width:100%;max-width:100vw;margin-left:0;overflow-x:hidden}.kpi-grid{grid-template-columns:repeat(3,1fr)}.charts-grid,.charts-row,.bottom-grid,.admin-grid,.detail-grid{grid-template-columns:1fr}.mobile-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);height:56px;padding:0 var(--gap-md);z-index:101;justify-content:space-between;align-items:center;gap:var(--gap-md);display:flex;position:fixed;top:0;left:0;right:0}.mobile-header-logo{background:linear-gradient(135deg,var(--accent-green),var(--accent-cyan));-webkit-text-fill-color:transparent;-webkit-background-clip:text;flex:1;font-size:1rem;font-weight:700}.burger-btn{cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;transition:background .2s;display:flex}.burger-btn:hover{background:var(--bg-glass)}.burger-line{background:var(--text-primary);transform-origin:50%;border-radius:2px;width:20px;height:2px;transition:all .25s;display:block}.burger-btn.open .burger-line:first-child{transform:translateY(7px)rotate(45deg)}.burger-btn.open .burger-line:nth-child(2){opacity:0;transform:scaleX(0)}.burger-btn.open .burger-line:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.nav-item{align-items:center;min-height:44px;display:flex}.btn{min-height:44px;padding:var(--gap-sm)var(--gap-md)}.filter-chip{min-height:40px;padding:8px 16px}}@media (max-width:768px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.page-header{align-items:flex-start;gap:var(--gap-sm);flex-direction:column}.page-header .header-actions{justify-content:flex-start;width:100%}.filters-bar{gap:var(--gap-sm);flex-wrap:wrap}.kpi-card{padding:var(--gap-md)}.kpi-icon,.kpi-value{font-size:1.4rem}}@media (max-width:640px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.main-content{padding:var(--gap-sm);padding-top:calc(var(--gap-sm) + 56px)}.app-layout{overflow-x:hidden}.kpi-value{font-size:clamp(1.1rem,4.5vw,1.4rem)}.kpi-label{font-size:.6rem}.page-header h2{font-size:clamp(1rem,4vw,1.4rem)}.kpi-card{padding:12px}.card{padding:var(--gap-md)}.alert-item{flex-direction:column}.alert-product,.alert-message{font-size:.78rem}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.table-scroll{border-radius:var(--radius-md);overflow-x:auto}.complaints-kpi{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.complaint-severity-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.73rem;font-weight:600;display:inline-flex}.severity-low{color:#94a3b8;background:#64748b26}.severity-medium{background:var(--accent-orange-dim);color:var(--accent-orange)}.severity-high{background:var(--accent-red-dim);color:var(--accent-red);animation:2s ease-in-out infinite pulse-critical}.complaint-status-badge{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.73rem;font-weight:600;display:inline-flex}.status-new{background:var(--accent-blue-dim);color:var(--accent-blue)}.status-investigating{background:var(--accent-orange-dim);color:var(--accent-orange)}.status-resolved{background:var(--accent-green-dim);color:var(--accent-green)}.status-dismissed{color:#64748b;background:#64748b26}.status-select{border-radius:var(--radius-sm);background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;outline:none;padding:4px 8px;font-family:Inter,sans-serif;font-size:.78rem;font-weight:500;transition:border-color .2s}.status-select:focus{border-color:var(--accent-green)}.batch-alerts-card{margin-bottom:var(--gap-lg);background:#ef444408;border-color:#ef44444d}.batch-alerts-list{gap:var(--gap-sm);flex-direction:column;display:flex}.batch-alert-item{padding:var(--gap-md);border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-glass);transition:all .2s}.batch-alert-item:hover{border-color:var(--border-hover)}.batch-alert-item.batch-critical{border-left:4px solid var(--accent-red);background:#e74c3c0d}.batch-alert-item.batch-warning{border-left:4px solid var(--accent-orange);background:#f39c120d}.batch-alert-header{align-items:center;gap:var(--gap-sm);flex-wrap:wrap;margin-bottom:6px;display:flex}.batch-severity-tag{text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:3px 10px;font-size:.72rem;font-weight:700}.batch-severity-tag.critical{background:var(--accent-red-dim);color:var(--accent-red)}.batch-severity-tag.warning{background:var(--accent-orange-dim);color:var(--accent-orange)}.batch-sku{color:var(--text-muted);font-family:monospace;font-size:.75rem}.batch-alert-body{gap:var(--gap-md);color:var(--text-secondary);flex-wrap:wrap;font-size:.82rem;display:flex}.batch-number-tag{color:#60a5fa;background:#3b82f61f;border-radius:6px;align-items:center;gap:4px;padding:2px 8px;font-family:monospace;font-size:.78rem;font-weight:600;display:inline-flex}.complaints-table td{white-space:normal}.btn-xs{padding:3px 8px;font-size:.75rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:560px;max-width:90vw;max-height:90vh;padding:var(--gap-xl);box-shadow:var(--shadow-lg);animation:.3s slideUp;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{margin-bottom:var(--gap-lg);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:1.3rem;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:1.2rem;transition:all .2s}.modal-close:hover{color:var(--text-primary);background:var(--bg-glass)}.complaint-form .form-group{margin-bottom:var(--gap-md)}.complaint-form .form-group select,.complaint-form .form-group textarea{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:10px 14px;font-family:Inter,sans-serif;font-size:.9rem;transition:border-color .2s}.complaint-form .form-group select:focus,.complaint-form .form-group input:focus,.complaint-form .form-group textarea:focus{border-color:var(--accent-green)}.complaint-form .form-group textarea{resize:vertical;min-height:80px}.form-row{gap:var(--gap-md);grid-template-columns:1fr 1fr;display:grid}.form-actions{justify-content:flex-end;gap:var(--gap-sm);margin-top:var(--gap-lg);padding-top:var(--gap-md);border-top:1px solid var(--border-color);display:flex}@media (max-width:1024px){.complaints-kpi{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.complaints-kpi{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.complaints-kpi{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}}.ai-chat-bubble{cursor:pointer;z-index:9999;background:linear-gradient(135deg,#2ecc71,#00c9ff);border:none;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:all .3s;animation:.5s bubbleEntry;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #2ecc7166}.ai-chat-bubble:hover{transform:scale(1.1);box-shadow:0 6px 30px #2ecc7180}.ai-bubble-icon{font-size:1.6rem}.ai-bubble-pulse{border:2px solid #2ecc7166;border-radius:50%;animation:2s ease-in-out infinite bubblePulse;position:absolute;inset:-4px}@keyframes bubbleEntry{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}@keyframes bubblePulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:0;transform:scale(1.15)}}.ai-chat-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);z-index:10000;opacity:0;pointer-events:none;flex-direction:column;width:400px;height:560px;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;bottom:24px;right:24px;overflow:hidden;transform:scale(.8)translateY(30px);box-shadow:0 12px 48px #00000080}.ai-chat-panel.open{opacity:1;pointer-events:all;transform:scale(1)translateY(0)}.ai-chat-panel.fullscreen{border-radius:var(--radius-xl);width:780px;height:85vh;max-height:900px;bottom:50%;right:50%;transform:translate(50%,50%)scale(1)}.ai-chat-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#00000080;position:fixed;inset:0}.ai-chat-header{border-bottom:1px solid var(--border-color);background:#111827f2;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.ai-chat-header-left{align-items:center;gap:10px;display:flex}.ai-chat-avatar{font-size:1.5rem}.ai-chat-title{color:var(--text-primary);font-size:.9rem;font-weight:700}.ai-chat-subtitle{color:var(--text-muted);font-size:.7rem}.ai-chat-header-actions{gap:4px;display:flex}.ai-header-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:1rem;transition:all .2s}.ai-header-btn:hover{background:var(--bg-glass);color:var(--text-primary)}.ai-close-btn{font-size:.9rem}.ai-chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.ai-message{align-items:flex-start;gap:8px;animation:.3s msgFadeIn;display:flex}@keyframes msgFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ai-message-user{flex-direction:row-reverse}.ai-msg-avatar{flex-shrink:0;margin-top:2px;font-size:1.2rem}.ai-msg-content{word-break:break-word;border-radius:16px;max-width:85%;padding:10px 14px;font-size:.88rem;line-height:1.6}.ai-msg-content.user{color:#fff;background:linear-gradient(135deg,#2ecc71,#27ae60);border-bottom-right-radius:4px}.ai-msg-content.assistant{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);border-bottom-left-radius:4px}.ai-msg-content.assistant p{margin:0 0 8px}.ai-msg-content.assistant p:last-child{margin:0}.ai-msg-content.assistant strong{color:var(--accent-green)}.ai-msg-content.assistant ul,.ai-msg-content.assistant ol{margin:6px 0;padding-left:18px}.ai-msg-content.assistant li{margin:2px 0}.ai-msg-content.assistant code{background:#ffffff14;border-radius:4px;padding:1px 5px;font-size:.82rem}.ai-msg-content.assistant pre{background:#0000004d;border-radius:8px;margin:8px 0;padding:10px;overflow-x:auto}.ai-msg-content.assistant table{border-collapse:collapse;width:100%;margin:8px 0;font-size:.82rem}.ai-msg-content.assistant th{text-align:left;border-bottom:1px solid var(--border-color);white-space:nowrap;background:#ffffff0d;padding:6px 10px;font-weight:600}.ai-msg-content.assistant td{border-bottom:1px solid #ffffff08;padding:5px 10px}.ai-msg-content.assistant h1,.ai-msg-content.assistant h2,.ai-msg-content.assistant h3,.ai-msg-content.assistant h4{color:var(--text-primary);margin:12px 0 6px}.ai-msg-content.assistant h3{font-size:1rem}.ai-msg-content.assistant h4{font-size:.9rem}.ai-msg-content.assistant blockquote{border-left:3px solid var(--accent-green);color:var(--text-secondary);margin:8px 0;padding-left:12px}.ai-typing{gap:5px;padding:4px 0;display:flex}.ai-typing-dot{background:var(--text-muted);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite typingDot}.ai-typing-dot:nth-child(2){animation-delay:.2s}.ai-typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}}.ai-tools-used{color:var(--text-muted);text-align:center;padding:2px 12px;font-size:.72rem}.ai-chat-welcome{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:24px;display:flex}.ai-welcome-icon{margin-bottom:8px;font-size:3rem}.ai-chat-welcome h3{color:var(--text-primary);font-size:1.1rem;font-weight:700}.ai-chat-welcome p{color:var(--text-secondary);margin-bottom:12px;font-size:.85rem}.ai-suggestions{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.ai-suggestion-chip{background:var(--bg-glass);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:20px;padding:6px 12px;font-family:Inter,sans-serif;font-size:.78rem;transition:all .2s}.ai-suggestion-chip:hover{background:var(--accent-green-dim);border-color:var(--accent-green);color:var(--accent-green)}.ai-chat-input-bar{border-top:1px solid var(--border-color);background:#111827f2;flex-shrink:0;align-items:flex-end;gap:8px;padding:12px 14px;display:flex}.ai-chat-textarea{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);resize:none;border-radius:12px;outline:none;flex:1;max-height:100px;padding:10px 14px;font-family:Inter,sans-serif;font-size:.88rem;line-height:1.4;transition:border-color .2s}.ai-chat-textarea:focus{border-color:var(--accent-green)}.ai-chat-textarea::placeholder{color:var(--text-muted)}.ai-send-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2ecc71,#27ae60);border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;transition:all .2s;display:flex}.ai-send-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 12px #2ecc7166}.ai-send-btn:disabled{opacity:.5;cursor:not-allowed}.ai-history-panel{border-bottom:1px solid var(--border-color);background:#0a0e1a80;flex-shrink:0;max-height:200px;padding:8px;overflow-y:auto}.ai-history-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;padding:4px 8px;font-size:.72rem;font-weight:600}.ai-history-empty{text-align:center;color:var(--text-muted);padding:12px;font-size:.8rem}.ai-history-item{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:8px 10px;transition:background .2s;display:flex}.ai-history-item:hover{background:var(--bg-glass)}.ai-history-item-title{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.82rem;overflow:hidden}.ai-history-item-date{color:var(--text-muted);flex-shrink:0;font-size:.7rem}.ai-history-delete{cursor:pointer;opacity:0;background:0 0;border:none;padding:2px;font-size:.75rem;transition:opacity .2s}.ai-history-item:hover .ai-history-delete{opacity:.5}.ai-history-delete:hover{opacity:1!important}@media (max-width:640px){.ai-chat-panel.open{border-radius:0;width:100%;height:100vh;bottom:0;left:0;right:0}.ai-chat-panel.fullscreen{border-radius:0;width:100%;height:100vh;bottom:0;right:0;transform:none}.ai-chat-bubble{width:52px;height:52px;bottom:16px;right:16px}}.marketing-kpi{grid-template-columns:repeat(3,1fr)}.marketing-kpi .kpi-value{font-size:1.5rem}.period-selector{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.week-picker-dropdown{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);width:180px;max-height:300px;box-shadow:var(--shadow-lg);z-index:200;padding:4px;animation:.2s fadeSlideDown;position:absolute;top:calc(100% + 6px);right:0;overflow-y:auto}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.week-picker-item{text-align:left;width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 12px;font-family:Inter,sans-serif;font-size:.8rem;transition:all .15s;display:block}.week-picker-item:hover{color:var(--text-primary);background:#ffffff0f}.week-picker-item.active{background:var(--accent-green-dim);color:var(--accent-green);font-weight:600}.marketing-alerts-card{margin-bottom:var(--gap-lg);border-left:3px solid var(--accent-red)}.marketing-alerts-list{gap:var(--gap-sm);flex-direction:column;display:flex}.marketing-alert-item{border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border-color);align-items:flex-start;gap:12px;padding:12px 16px;transition:all .2s;display:flex}.marketing-alert-item:hover{border-color:var(--border-hover);background:#ffffff0a}.marketing-alert-item.critical{background:#e74c3c0d;border-color:#e74c3c4d}.marketing-alert-item.warning{background:#f39c120d;border-color:#f39c124d}.marketing-alert-icon{margin-top:2px;font-size:1.3rem}.marketing-alert-item strong{color:var(--text-primary);margin-bottom:2px;font-size:.88rem;display:block}.marketing-alert-msg{color:var(--text-secondary);font-size:.8rem;line-height:1.5}.sync-result{align-items:center;gap:var(--gap-sm);border-radius:var(--radius-sm);margin-bottom:var(--gap-lg);padding:10px 16px;font-size:.85rem;font-weight:500;animation:.3s slideDown;display:flex}.sync-result.success{background:var(--accent-green-dim);color:var(--accent-green);border:1px solid #2ecc714d}.sync-result.error{background:var(--accent-red-dim);color:var(--accent-red);border:1px solid #e74c3c4d}.marketing-channels-table tfoot td{background:var(--bg-secondary);border-top:2px solid var(--accent-green);padding:12px 16px}.marketing-channels-table .kpi-delta{margin-top:2px;font-size:.7rem;display:block}@media (max-width:1400px){.marketing-kpi{grid-template-columns:repeat(3,1fr)}}@media (max-width:1000px){.marketing-kpi{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.marketing-kpi{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}.period-selector{flex-wrap:wrap}}.notification-bell-wrapper{position:relative}.notification-bell{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;padding:6px 10px;font-size:1.1rem;transition:all .2s;position:relative}.notification-bell:hover{border-color:var(--border-hover);background:#ffffff0f}.notification-badge{background:var(--accent-red);color:#fff;text-align:center;border-radius:10px;min-width:16px;padding:1px 5px;font-size:.6rem;font-weight:700;line-height:1.3;animation:2s ease-in-out infinite pulse-badge;position:absolute;top:-4px;right:-4px}@keyframes pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.notification-dropdown{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:380px;max-height:480px;box-shadow:var(--shadow-lg);z-index:1000;animation:.2s slideDown;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notification-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.notification-header-title{font-size:.9rem;font-weight:700}.notification-mark-all{color:var(--accent-green);cursor:pointer;background:0 0;border:none;font-family:Inter,sans-serif;font-size:.75rem;font-weight:600}.notification-mark-all:hover{text-decoration:underline}.notification-list{max-height:400px;overflow-y:auto}.notification-empty{text-align:center;color:var(--text-muted);padding:32px 16px;font-size:.85rem}.notification-item{cursor:pointer;border-bottom:1px solid #ffffff08;gap:10px;padding:10px 16px;transition:background .2s;display:flex;position:relative}.notification-item:hover{background:#ffffff0a}.notification-item.unread{background:#2ecc710a}.notification-icon{flex-shrink:0;padding-top:2px;font-size:1.2rem}.notification-content{flex:1;min-width:0}.notification-title{color:var(--text-primary);font-size:.82rem;font-weight:600;line-height:1.3}.notification-body{color:var(--text-secondary);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:2px;font-size:.75rem;line-height:1.4;display:-webkit-box;overflow:hidden}.notification-meta{color:var(--text-muted);margin-top:4px;font-size:.68rem}.notification-dot{background:var(--accent-green);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.audit-filters{gap:var(--gap-sm);margin-bottom:var(--gap-md);flex-wrap:wrap;display:flex}.audit-detail{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:300px;font-size:.75rem;overflow:hidden}@media (max-width:768px){.notification-dropdown{width:320px;right:-60px}}.heatmap-grid{padding:8px 0;overflow-x:auto}.heatmap-header,.heatmap-row{align-items:center;gap:2px;display:flex}.heatmap-header{margin-bottom:2px}.heatmap-label{color:#94a3b8;text-align:center;width:32px;min-width:32px;font-size:.7rem}.heatmap-cell-header{color:#64748b;text-align:center;flex:1;min-width:40px;font-size:.65rem}.heatmap-cell{color:#ffffffe6;cursor:default;border-radius:4px;flex:1;justify-content:center;align-items:center;min-width:40px;height:32px;font-size:.7rem;font-weight:600;transition:transform .15s;display:flex}.heatmap-cell:hover{z-index:2;transform:scale(1.15)}.sentiment-bar-container{align-items:center;gap:8px;width:100%;display:flex}.sentiment-bar{border-radius:4px;min-width:4px;height:8px;transition:width .5s}.sentiment-value{min-width:30px;font-size:.8rem;font-weight:600}.expiry-badge{border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.expiry-badge.critical{color:#ef4444;background:#ef444433}.expiry-badge.warning{color:#f59e0b;background:#f59e0b33}.expiry-badge.ok{color:#10b981;background:#10b98133}@media (max-width:768px){.heatmap-cell{min-width:28px;height:24px;font-size:.6rem}.heatmap-cell-header{min-width:28px;font-size:.55rem}.heatmap-label{width:24px;min-width:24px;font-size:.6rem}}.pulse-block{border-radius:var(--radius-xl);padding:var(--gap-lg);margin-bottom:var(--gap-lg);gap:var(--gap-lg);background:linear-gradient(135deg,#2ecc710f,#3498db0f);border:1px solid #2ecc7126;grid-template-columns:1fr auto;animation:.6s ease-out pulseSlideIn;display:grid;position:relative;overflow:hidden}.pulse-block:before{content:"";background:linear-gradient(90deg,var(--accent-green),var(--accent-blue),var(--accent-purple));height:2px;position:absolute;top:0;left:0;right:0}@keyframes pulseSlideIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.pulse-summary{flex-direction:column;gap:4px;display:flex}.pulse-summary-label{text-transform:uppercase;letter-spacing:1px;color:var(--accent-green);align-items:center;gap:6px;margin-bottom:4px;font-size:.7rem;font-weight:700;display:flex}.pulse-summary-label .pulse-dot{background:var(--accent-green);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulseDot}@keyframes pulseDot{0%,to{opacity:1;box-shadow:0 0 4px var(--accent-green)}50%{opacity:.4;box-shadow:0 0 8px var(--accent-green)}}.pulse-summary-text{color:var(--text-secondary);white-space:pre-line;font-size:.88rem;line-height:1.7}.pulse-summary-text .pulse-loading{color:var(--text-muted);font-style:italic}.plan-gauges{gap:var(--gap-lg);align-items:center;display:flex}.plan-gauge{flex-direction:column;align-items:center;gap:4px;min-width:90px;display:flex}.plan-gauge svg{filter:drop-shadow(0 0 6px #2ecc7133)}.plan-gauge-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.68rem;font-weight:600}.plan-gauge-fact{color:var(--text-secondary);font-size:.72rem}.drilldown-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0009;justify-content:center;align-items:flex-start;padding-top:5vh;animation:.2s ease-out ddOverlayIn;display:flex;position:fixed;inset:0}@keyframes ddOverlayIn{0%{opacity:0}to{opacity:1}}.drilldown-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:90%;max-width:720px;max-height:80vh;padding:var(--gap-xl);animation:.3s ease-out ddSlideIn;position:relative;overflow-y:auto;box-shadow:0 20px 60px #00000080}@keyframes ddSlideIn{0%{opacity:0;transform:translateY(-20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.drilldown-modal:before{content:"";background:linear-gradient(90deg,var(--accent-green),var(--accent-blue));height:2px;position:absolute;top:0;left:0;right:0}.drilldown-header{margin-bottom:var(--gap-lg);justify-content:space-between;align-items:center;display:flex}.drilldown-header h3{font-size:1.2rem;font-weight:700}.drilldown-close{background:var(--bg-glass);border:1px solid var(--border-color);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;transition:all .2s;display:flex}.drilldown-close:hover{background:var(--accent-red-dim);color:var(--accent-red);border-color:var(--accent-red)}.drilldown-bar-row{align-items:center;gap:var(--gap-md);border-bottom:1px solid var(--border-color);cursor:pointer;padding:10px 0;transition:all .2s;display:flex}.drilldown-bar-row:hover{background:var(--bg-glass);border-radius:var(--radius-sm);padding-left:8px}.drilldown-bar-name{width:140px;color:var(--text-primary);flex-shrink:0;font-size:.85rem;font-weight:600}.drilldown-bar-track{background:var(--bg-glass);border-radius:12px;flex:1;height:24px;position:relative;overflow:hidden}.drilldown-bar-fill{border-radius:12px;min-width:4px;height:100%;transition:width .6s ease-out}.drilldown-bar-value{text-align:right;width:100px;color:var(--text-primary);flex-shrink:0;font-size:.82rem;font-weight:700}.drilldown-bar-delta{text-align:right;flex-shrink:0;width:65px;font-size:.78rem;font-weight:600}.drilldown-footer{margin-top:var(--gap-lg);padding-top:var(--gap-md);border-top:1px solid var(--border-color);justify-content:center;display:flex}.kpi-card.clickable{cursor:pointer}.kpi-card.clickable:hover{border-color:var(--accent-green);box-shadow:var(--shadow-glow-green)}.kpi-card.clickable:after{content:"↗";color:var(--text-muted);opacity:0;font-size:.7rem;transition:opacity .2s;position:absolute;top:12px;right:14px}.kpi-card.clickable:hover:after{opacity:1;color:var(--accent-green)}.customer-kpi-grid{gap:var(--gap-md);margin-bottom:var(--gap-lg);grid-template-columns:repeat(auto-fill,minmax(190px,1fr));display:grid}.customer-charts-grid{gap:var(--gap-md);margin-bottom:var(--gap-lg);grid-template-columns:2fr 1fr;display:grid}.customer-chart-card{min-height:320px}.channel-legend{margin-top:var(--gap-md);flex-direction:column;gap:8px;display:flex}.channel-legend-item{align-items:center;gap:8px;font-size:.82rem;display:flex}.channel-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.channel-legend-value{color:var(--text-primary);margin-left:auto;font-weight:600}.dual-chart-legend{gap:var(--gap-md);margin-bottom:var(--gap-sm);justify-content:center;display:flex}.dual-chart-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:.75rem;display:flex}.dual-chart-legend-dot{border-radius:2px;width:10px;height:3px}@media (max-width:768px){.pulse-block{grid-template-columns:1fr}.plan-gauges{justify-content:center}.drilldown-modal{width:95%;padding:var(--gap-md);max-height:85vh}.drilldown-bar-name{width:100px;font-size:.78rem}.drilldown-bar-value{width:75px;font-size:.78rem}.drilldown-bar-delta{display:none}.customer-charts-grid{grid-template-columns:1fr}.customer-kpi-grid{grid-template-columns:repeat(2,1fr)}}
