*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f1a;--bg-secondary: #14142b;--bg-tertiary: #1a1a35;--bg-card: #1e1e3f;--bg-hover: #252550;--glass-bg: rgba(30, 30, 63, .7);--glass-border: rgba(139, 92, 246, .15);--glass-hover: rgba(139, 92, 246, .25);--text-primary: #ffffff;--text-secondary: #a0a0b8;--text-muted: #6b6b8a;--accent-primary: #8b5cf6;--accent-secondary: #a855f7;--accent-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--accent-glow: rgba(139, 92, 246, .4);--success: #22c55e;--success-bg: rgba(34, 197, 94, .12);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .12);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .12);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .12);--kpi-blue: linear-gradient(135deg, rgba(59, 130, 246, .2) 0%, rgba(59, 130, 246, .05) 100%);--kpi-purple: linear-gradient(135deg, rgba(139, 92, 246, .2) 0%, rgba(139, 92, 246, .05) 100%);--kpi-green: linear-gradient(135deg, rgba(34, 197, 94, .2) 0%, rgba(34, 197, 94, .05) 100%);--kpi-gold: linear-gradient(135deg, rgba(251, 191, 36, .2) 0%, rgba(251, 191, 36, .05) 100%);--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 30px var(--accent-glow)}html,body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.dashboard-layout{display:flex;min-height:100vh;background:var(--bg-primary)}.sidebar{position:fixed;left:0;top:0;height:100vh;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;z-index:100;transition:width .3s cubic-bezier(.4,0,.2,1)}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{padding:24px 20px;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:12px}.sidebar-logo{font-size:28px}.sidebar-title{font-size:20px;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.sidebar.collapsed .sidebar-title{display:none}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:var(--radius-md);background:transparent;border:none;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:linear-gradient(135deg,#8b5cf626,#8b5cf60d);color:var(--accent-primary)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent-gradient);border-radius:0 4px 4px 0}.nav-icon{font-size:18px;flex-shrink:0;width:24px;text-align:center}.nav-label{white-space:nowrap;transition:opacity .2s ease}.sidebar.collapsed .nav-label{opacity:0;width:0;overflow:hidden}.sidebar-toggle{padding:16px;border:none;border-top:1px solid var(--glass-border);background:transparent;color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}.sidebar-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.sidebar.collapsed~.main-content{margin-left:var(--sidebar-collapsed)}.top-header{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:16px}.page-title{font-size:18px;font-weight:600;color:var(--text-primary)}.breadcrumb{font-size:14px;color:var(--text-muted)}.header-center{flex:1;max-width:400px;margin:0 40px}.search-wrapper{position:relative}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--text-muted)}.search-input{width:100%;padding:10px 16px 10px 44px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:50px;color:var(--text-primary);font-size:14px}.search-input::-moz-placeholder{color:var(--text-muted)}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf626}.header-right{display:flex;align-items:center;gap:12px}.header-btn{width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--glass-border);color:var(--text-primary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:all .2s ease}.header-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.notification-badge{position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;background:var(--danger);border-radius:50%;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0 4px}.user-menu{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 16px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:50px;cursor:pointer;transition:all .2s ease}.user-menu:hover{border-color:var(--accent-primary)}.user-info{text-align:left}.user-name{font-size:13px;font-weight:500;color:var(--text-primary)}.user-role{font-size:11px;color:var(--accent-primary)}.user-avatar{width:32px;height:32px;background:var(--accent-gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}.page-content{flex:1;padding:24px;overflow-y:auto}.dashboard-overview{display:flex;flex-direction:column;gap:24px}.welcome-banner{position:relative;background:linear-gradient(135deg,#4c1d95,#6d28d9,#7c3aed);border-radius:var(--radius-xl);padding:32px;overflow:hidden}.banner-content{position:relative;z-index:2}.status-badge{display:inline-flex;align-items:center;gap:8px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:6px 14px;border-radius:50px;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:16px}.status-dot{width:8px;height:8px;background:var(--success);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.banner-title{font-size:28px;font-weight:700;margin-bottom:8px}.banner-subtitle{font-size:15px;color:#ffffffd9;margin-bottom:24px}.banner-actions{display:flex;gap:12px}.banner-btn{padding:12px 24px;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.banner-btn.primary{background:#fff;color:#6d28d9;border:none}.banner-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.banner-btn.secondary{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.25)}.banner-btn.secondary:hover{background:#ffffff40}.banner-decoration{position:absolute;right:0;top:0;width:300px;height:100%;pointer-events:none}.circle{position:absolute;border-radius:50%;background:#ffffff14}.circle-1{width:180px;height:180px;right:30px;top:-30px}.circle-2{width:100px;height:100px;right:120px;top:80px}.circle-3{width:60px;height:60px;right:200px;top:20px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.kpi-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px;transition:all .3s ease}.kpi-card:hover{border-color:var(--glass-hover);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.kpi-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.kpi-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px}.kpi-icon.blue{background:var(--kpi-blue)}.kpi-icon.purple{background:var(--kpi-purple)}.kpi-icon.green{background:var(--kpi-green)}.kpi-icon.gold{background:var(--kpi-gold)}.kpi-change{font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px}.kpi-change.positive{background:var(--success-bg);color:var(--success)}.kpi-change.negative{background:var(--danger-bg);color:var(--danger)}.kpi-value{font-size:32px;font-weight:700;margin-bottom:4px}.kpi-label{font-size:14px;color:var(--text-secondary)}.section-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-title{font-size:18px;font-weight:600}.view-all-btn{font-size:13px;color:var(--accent-primary);background:none;border:none;cursor:pointer}.view-all-btn:hover{text-decoration:underline}.jobs-list{display:flex;flex-direction:column;gap:12px}.job-row{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius-md);transition:background .2s ease}.job-row:hover{background:var(--bg-hover)}.job-info{display:flex;align-items:center;gap:14px}.job-icon{width:40px;height:40px;background:var(--kpi-purple);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.job-details h4{font-size:14px;font-weight:500;margin-bottom:2px}.job-meta{font-size:12px;color:var(--text-muted)}.job-status{font-size:11px;font-weight:600;padding:6px 14px;border-radius:20px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;position:relative;z-index:5}.job-status.completed{background:var(--success-bg);color:var(--success)}.job-status.pending{background:var(--warning-bg);color:var(--warning)}.job-status.processing{background:var(--info-bg);color:var(--info)}.job-status.error{background:var(--danger-bg);color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none}.btn-primary{background:var(--accent-gradient);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--accent-glow)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--glass-border)}.btn-secondary:hover{border-color:var(--accent-primary);background:var(--bg-hover)}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px 16px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}.btn-sm{padding:8px 16px;font-size:13px}.btn-icon{padding:8px;min-width:36px}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.form-group label{font-size:13px;font-weight:500;color:var(--text-secondary)}input,select,textarea{padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:all .2s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf626}input::-moz-placeholder,textarea::-moz-placeholder{color:var(--text-muted)}input::placeholder,textarea::placeholder{color:var(--text-muted)}.alert{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:var(--radius-md);font-size:14px;margin-bottom:16px}.alert-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.3);color:var(--danger)}.alert-success{background:var(--success-bg);border:1px solid rgba(34,197,94,.3);color:var(--success)}.alert button{margin-left:auto;background:none;border:none;color:inherit;font-size:18px;cursor:pointer;opacity:.7}.alert button:hover{opacity:1}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary);gap:16px}.spinner{width:40px;height:40px;border:3px solid var(--glass-border);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading,.studio-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:var(--text-secondary);gap:16px}.spinner-large{width:48px;height:48px;border:3px solid var(--glass-border);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.design-studio{display:flex;flex-direction:column;gap:24px}.studio-steps{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.studio-step{display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:50px;font-size:13px;cursor:pointer;transition:all .2s ease}.studio-step.active{background:var(--accent-gradient);border-color:transparent}.studio-step.completed{background:var(--success-bg);border-color:var(--success);color:var(--success)}.step-num{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:50%;font-size:12px;font-weight:600}.step-text{font-weight:500}.studio-section{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:32px}.section-header-row{display:flex;align-items:center;gap:16px;margin-bottom:8px}.section-heading{font-size:22px;font-weight:600}.section-desc{color:var(--text-secondary);margin-bottom:24px}.glass-panel{background:#1e1e3f80;border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px}.customer-select-wrapper{margin-bottom:24px}.customer-dropdown{width:100%;padding:14px 16px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:15px;cursor:pointer}.customer-list{display:grid;gap:12px}.customer-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.customer-card:hover{border-color:var(--accent-primary);background:var(--bg-hover)}.customer-card.selected{border-color:var(--accent-primary);background:#8b5cf61a}.customer-avatar{width:48px;height:48px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600}.customer-info{flex:1;display:flex;flex-direction:column}.customer-name{font-weight:600;font-size:15px}.customer-event{font-size:13px;color:var(--text-secondary)}.customer-arrow{font-size:18px;color:var(--text-muted)}.selected-customer-banner{background:var(--kpi-purple);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:20px;font-size:14px}.upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px;border:2px dashed var(--glass-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease}.upload-area:hover{border-color:var(--accent-primary);background:#8b5cf60d}.upload-icon-large{font-size:56px;margin-bottom:16px}.upload-title{font-size:18px;font-weight:500;margin-bottom:8px}.upload-subtitle{font-size:14px;color:var(--text-secondary)}.upload-area-sm{padding:40px}.zone-editor{display:grid;grid-template-columns:1fr 380px;gap:24px}.zone-canvas-wrapper{display:flex;flex-direction:column;gap:16px}.page-nav{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius-md)}.zone-canvas-container{position:relative;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-lg);background:#fff}.zone-canvas-container img{display:block;width:100%;height:auto;-webkit-user-select:none;-moz-user-select:none;user-select:none}.zone-overlay{position:absolute;inset:0;cursor:crosshair}.zone-rect{position:absolute;border:2px solid;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .15s ease}.zone-rect.selected{border-width:3px;box-shadow:0 0 0 3px #8b5cf64d}.zone-label{background:#000000d9;color:#fff;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600}.zone-mode{padding:1px 6px;border-radius:3px;font-size:8px;font-weight:700}.zone-mode.overlay{background:#f59e0be6;color:#000}.zone-mode.mask{background:#6366f1e6;color:#fff}.zone-drawing-preview{position:absolute;border:2px dashed var(--accent-primary);background:#8b5cf626;pointer-events:none;display:flex;align-items:center;justify-content:center}.zone-drawing-preview span{background:#000000d9;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-family:monospace}.canvas-hint{position:absolute;bottom:8px;left:8px;background:#000000bf;color:#fff;padding:6px 10px;border-radius:6px;font-size:11px}.zone-config-panel{background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:12px;flex:1;min-height:0}.zone-config-panel h3{font-size:16px;font-weight:600;padding-bottom:12px;border-bottom:1px solid var(--glass-border)}.no-zones-msg{color:var(--text-secondary);font-size:14px;text-align:center;padding:20px}.zone-config-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:16px;cursor:pointer;transition:all .2s ease}.zone-config-card:hover{border-color:var(--glass-hover)}.zone-config-card.active{border-color:var(--accent-primary);box-shadow:0 0 0 2px #8b5cf626}.zone-card-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.zone-page-badge{background:var(--accent-gradient);padding:2px 10px;border-radius:6px;font-size:11px;font-weight:600}.zone-name-input{flex:1;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:6px;color:var(--text-primary);font-size:13px}.zone-config-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.config-item{display:flex;flex-direction:column;gap:4px;min-width:0}.config-item label{font-size:10px;color:var(--text-secondary);font-weight:500}.config-item input,.config-item select{padding:6px 8px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:6px;color:var(--text-primary);font-size:12px;width:100%;box-sizing:border-box}.color-picker-row{display:flex;align-items:center;gap:8px}.color-picker-row input[type=color]{width:36px;height:36px;padding:2px;cursor:pointer;border-radius:6px}.color-picker-row span{font-size:12px;color:var(--text-secondary)}.csv-info{background:var(--kpi-green);padding:14px 18px;border-radius:var(--radius-md);margin-bottom:24px;font-size:14px;font-weight:500}.mapping-section h4{font-size:16px;font-weight:600;margin-bottom:16px}.mapping-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.mapping-row{display:grid;grid-template-columns:1fr 40px 1fr;align-items:center;gap:12px}.mapping-zone{background:var(--bg-tertiary);padding:12px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500}.mapping-arrow{text-align:center;font-size:18px;color:var(--accent-primary)}.phone-column-section{background:var(--bg-tertiary);padding:20px;border-radius:var(--radius-md);margin-bottom:24px}.phone-column-section label{display:block;margin-bottom:10px;font-size:14px;font-weight:500}.preview-layout{display:grid;grid-template-columns:1fr 400px;gap:24px}.preview-pdf-panel{background:var(--bg-tertiary);border-radius:var(--radius-lg);overflow:hidden}.preview-iframe{width:100%;height:600px;border:none}.preview-info-panel{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px}.preview-info-panel h4{font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--glass-border)}.preview-data-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--glass-border);font-size:13px}.data-label{color:var(--text-secondary)}.data-value{font-weight:500}.preview-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.output-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.output-card{background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:20px;text-align:center;transition:all .2s ease}.output-card:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.output-icon{font-size:32px;margin-bottom:12px}.output-name{font-size:13px;font-weight:500;margin-bottom:4px;word-break:break-word}.output-phone{font-size:11px;color:var(--text-secondary)}.app{min-height:100vh;background:var(--bg-primary);padding:24px}.app-header{text-align:center;margin-bottom:32px}.app-title{font-size:32px;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{color:var(--text-secondary);font-size:16px}.steps-container{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:32px}.step-indicator{display:flex;align-items:center;gap:8px;padding:10px 18px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:50px;font-size:13px;transition:all .2s ease}.step-indicator.active{background:var(--accent-gradient);border-color:transparent}.step-indicator.completed{background:var(--success-bg);border-color:var(--success);color:var(--success)}.step-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:50%;font-size:12px;font-weight:600}.step-label{font-weight:500}.section{max-width:1200px;margin:0 auto}.section-title{font-size:24px;font-weight:600;margin-bottom:20px}.glass-card{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:32px}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px;border:2px dashed var(--glass-border);border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease}.upload-zone:hover{border-color:var(--accent-primary);background:#8b5cf60d}.upload-icon{font-size:56px;margin-bottom:16px}.upload-text{font-size:18px;font-weight:500;margin-bottom:8px}.upload-hint{font-size:14px;color:var(--text-secondary)}.zone-config-item{background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s ease}.zone-config-item:hover{border-color:var(--glass-hover)}.zone-config-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.zone-config-row label{font-size:11px;color:var(--text-secondary);font-weight:500;display:block;margin-bottom:4px}.preview-container{display:grid;grid-template-columns:1fr 400px;gap:24px}.preview-pdf{background:var(--bg-tertiary);border-radius:var(--radius-lg);overflow:hidden}.preview-info{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px}.whatsapp-section{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:32px}.whatsapp-section h3{font-size:18px;font-weight:600;margin-bottom:20px}.whatsapp-input-group{display:flex;gap:16px;align-items:flex-end}.whatsapp-input-group .form-group{flex:1;margin-bottom:0}.report-card{background:var(--bg-tertiary);border-radius:var(--radius-lg);padding:20px}.report-stats{display:flex;gap:20px}.stat-box{flex:1;text-align:center}.stat-value{font-size:28px;font-weight:700}.stat-value.success{color:var(--success)}.stat-value.danger{color:var(--danger)}.stat-value.neutral{color:var(--text-secondary)}.stat-label{font-size:12px;color:var(--text-secondary)}.output-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.zone-editor,.preview-layout,.preview-container{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.page-content{padding:16px}.kpi-grid{grid-template-columns:1fr}.header-center{display:none}.banner-title{font-size:22px}.banner-actions,.whatsapp-input-group{flex-direction:column}}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease}.modal-content{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--glass-border)}.modal-header h3{font-size:18px;font-weight:600}.modal-close{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-form{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-actions{display:flex;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--glass-border)}.modal-actions .btn{flex:1;padding:14px 24px;font-size:15px;font-weight:600}.modal-actions .btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.modal-actions .btn-secondary:hover{background:#ffffff26;border-color:#ffffff4d}.modal-actions .btn-primary{background:var(--accent-gradient);color:#fff;border:none;box-shadow:0 4px 15px var(--accent-glow)}.modal-actions .btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-glow)}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--glass-border)}.users-table th{background:var(--bg-tertiary);font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.users-table tr:hover{background:var(--bg-hover)}.role-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600}.role-badge.sudo_admin{background:var(--kpi-purple);color:var(--accent-primary)}.role-badge.admin{background:var(--kpi-blue);color:var(--info)}.role-badge.designer{background:var(--kpi-green);color:var(--success)}.settings-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid var(--glass-border);padding-bottom:16px}.settings-tab{padding:10px 20px;background:transparent;border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .2s ease}.settings-tab:hover{border-color:var(--accent-primary);color:var(--text-primary)}.settings-tab.active{background:var(--accent-gradient);border-color:transparent;color:#fff}.settings-section{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}.settings-section h3{font-size:16px;font-weight:600;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--glass-border)}.settings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media(max-width:768px){.settings-grid{grid-template-columns:1fr}}.customers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.customer-card-full{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:20px;transition:all .2s ease}.customer-card-full:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.customer-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}.customer-avatar-lg{width:56px;height:56px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600}.customer-title h3{font-size:16px;font-weight:600;margin-bottom:4px}.customer-title p{font-size:13px;color:var(--text-secondary)}.customer-stats{display:flex;gap:16px;padding-top:16px;border-top:1px solid var(--glass-border)}.customer-stat{flex:1;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.customer-stat-value{font-size:20px;font-weight:600}.customer-stat-label{font-size:11px;color:var(--text-muted)}.preview-layout-enhanced{display:grid;grid-template-columns:1.5fr 1fr .8fr;gap:24px;min-height:500px}.preview-card-container{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:20px}.preview-card-container h4{margin-bottom:16px;font-size:16px}.card-preview-box{background:var(--bg-tertiary);border-radius:var(--radius-md);min-height:300px;display:flex;align-items:center;justify-content:center;overflow:hidden}.preview-image{max-width:100%;max-height:400px;-o-object-fit:contain;object-fit:contain;border-radius:var(--radius-md)}.preview-placeholder{text-align:center;color:var(--text-muted)}.preview-placeholder span{font-size:48px;margin-bottom:12px;display:block}.whatsapp-builder-panel{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:20px}.whatsapp-builder-panel h4{margin-bottom:16px;font-size:16px}.message-template-tabs{display:flex;gap:8px;margin-bottom:16px}.tab-btn{flex:1;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s ease}.tab-btn:hover{border-color:var(--accent-primary)}.tab-btn.active{background:#8b5cf633;border-color:var(--accent-primary);color:var(--accent-primary)}.message-editor{margin-bottom:16px}.message-editor label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:8px}.message-editor textarea{width:100%;min-height:120px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:12px;color:var(--text-primary);font-size:14px;resize:vertical}.message-editor textarea:focus{outline:none;border-color:var(--accent-primary)}.message-editor .hint{font-size:12px;color:var(--text-muted);margin-top:8px}.message-editor .hint code{background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;color:var(--accent-primary)}.whatsapp-preview{background:#0b141a;border-radius:var(--radius-md);overflow:hidden}.wa-header{background:#1f2c34;padding:10px 14px;font-size:13px;color:#8696a0;border-bottom:1px solid #2a3942}.wa-message-bubble{background:#025c4c;margin:12px;padding:8px 12px;border-radius:8px 8px 0;max-width:90%}.wa-pdf-attachment{display:flex;align-items:center;gap:12px;background:#0003;padding:10px;border-radius:6px;margin-bottom:8px}.wa-pdf-icon{font-size:28px}.wa-pdf-info{display:flex;flex-direction:column;gap:2px}.wa-pdf-name{font-size:13px;color:#e9edef}.wa-pdf-size{font-size:11px;color:#8696a0}.wa-text{color:#e9edef;font-size:14px;line-height:1.5;white-space:pre-wrap}.wa-time{text-align:right;font-size:11px;color:#fff9;margin-top:4px}.demo-send-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--glass-border)}.demo-send-section h4{margin-bottom:12px;font-size:14px}.demo-phone-input{width:100%;padding:12px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;margin-bottom:12px}.demo-phone-input:focus{outline:none;border-color:var(--accent-primary)}.btn-lg{padding:16px 24px;font-size:16px}@media(max-width:1200px){.preview-layout-enhanced{grid-template-columns:1fr}}.modal-content .modal-actions{display:flex!important;flex-direction:row!important;gap:12px!important;padding:20px!important;margin-top:20px!important;background:var(--bg-tertiary)!important;border-radius:0 0 var(--radius-lg) var(--radius-lg)!important}.modal-content .modal-actions .btn{flex:1!important;padding:14px 24px!important;font-size:15px!important;font-weight:600!important;border-radius:var(--radius-md)!important;cursor:pointer!important}.modal-content .modal-actions .btn-secondary{background:#6464824d!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important}.modal-content .modal-actions .btn-secondary:hover{background:#64648280!important}.modal-content .modal-actions .btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7)!important;color:#fff!important;border:none!important;box-shadow:0 4px 15px #8b5cf666!important}.modal-content .modal-actions .btn-primary:hover{transform:translateY(-1px)!important;box-shadow:0 6px 20px #8b5cf680!important}.modal-content .modal-actions .btn:disabled{opacity:.6!important;cursor:not-allowed!important}.zone-templates{margin-top:16px;padding:16px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:12px}.zone-templates h4{margin-bottom:12px;font-size:14px;font-weight:600;color:var(--text-primary)}.template-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.template-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:8px;cursor:pointer;transition:all .2s ease}.template-card:hover{background:var(--bg-hover);border-color:var(--accent-primary);transform:translateY(-2px)}.template-icon{font-size:24px}.template-name{font-size:12px;font-weight:500;color:var(--text-primary);text-align:center}.template-zones{font-size:10px;color:var(--text-muted)}.template-confirm-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.template-confirm-modal{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:16px;padding:24px;max-width:400px;width:90%}.template-confirm-modal h4{margin-bottom:12px;font-size:18px;color:var(--text-primary)}.template-confirm-modal p{margin-bottom:20px;color:var(--text-secondary)}.template-confirm-actions{display:flex;gap:12px;justify-content:flex-end}.shortcuts-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.shortcuts-panel{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:16px;padding:24px;min-width:320px;max-width:90%;box-shadow:0 25px 50px #00000080}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.shortcuts-header h3{font-size:18px;font-weight:600;color:var(--text-primary)}.shortcuts-list{display:flex;flex-direction:column;gap:12px}.shortcut-item{display:flex;align-items:center;gap:16px}.shortcut-key{display:inline-flex;align-items:center;justify-content:center;min-width:80px;padding:6px 12px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:6px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;font-weight:500;color:var(--accent-primary)}.shortcut-action{font-size:14px;color:var(--text-secondary)}.shortcuts-hint{margin-top:20px;padding-top:16px;border-top:1px solid var(--glass-border);text-align:center;font-size:12px;color:var(--text-muted)}.shortcuts-hint kbd{padding:2px 6px;background:var(--bg-tertiary);border:1px solid var(--glass-border);border-radius:4px;font-family:inherit;font-size:11px}.skeleton{background:var(--bg-tertiary);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:4px}.skeleton-text{border-radius:4px}.skeleton-rect{border-radius:8px}.skeleton-circle{border-radius:50%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
