:root{--bg-primary: #0a0e1a;--bg-secondary: #121829;--bg-tertiary: #1a2038;--bg-card: rgba(26, 32, 56, .6);--bg-card-hover: rgba(30, 40, 70, .75);--bg-glass: rgba(255, 255, 255, .03);--bg-glass-hover: rgba(255, 255, 255, .06);--accent-cyan: #00f5d4;--accent-purple: #7b2ff7;--accent-pink: #f72585;--accent-blue: #4361ee;--accent-orange: #ff6d00;--accent-yellow: #ffd60a;--accent-green: #06d6a0;--accent-red: #ef476f;--gradient-cyan-purple: linear-gradient(135deg, #00f5d4, #7b2ff7);--gradient-pink-orange: linear-gradient(135deg, #f72585, #ff6d00);--gradient-blue-cyan: linear-gradient(135deg, #4361ee, #00f5d4);--gradient-purple-pink: linear-gradient(135deg, #7b2ff7, #f72585);--gradient-bg: linear-gradient(135deg, #0a0e1a 0%, #121829 50%, #0f1525 100%);--text-primary: #e8ecf4;--text-secondary: rgba(232, 236, 244, .65);--text-tertiary: rgba(232, 236, 244, .4);--text-accent: #00f5d4;--border-subtle: rgba(255, 255, 255, .06);--border-glow: rgba(0, 245, 212, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 24px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 48px rgba(0, 0, 0, .5);--shadow-glow-cyan: 0 0 20px rgba(0, 245, 212, .15), 0 0 60px rgba(0, 245, 212, .05);--shadow-glow-purple: 0 0 20px rgba(123, 47, 247, .15), 0 0 60px rgba(123, 47, 247, .05);--shadow-glow-pink: 0 0 20px rgba(247, 37, 133, .15), 0 0 60px rgba(247, 37, 133, .05);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--sidebar-width: 260px;--sidebar-collapsed: 72px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--gradient-bg);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}img{max-width:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:var(--space-xl) var(--space-2xl);min-height:100vh;position:relative;overflow-x:hidden;max-width:calc(100vw - var(--sidebar-width))}.main-content:before{content:"";position:fixed;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(123,47,247,.08) 0%,transparent 70%);pointer-events:none;z-index:0}.main-content:after{content:"";position:fixed;bottom:-200px;left:200px;width:500px;height:500px;background:radial-gradient(circle,rgba(0,245,212,.06) 0%,transparent 70%);pointer-events:none;z-index:0}.page-content{position:relative;z-index:1}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;background:#0a0e1af2;border-right:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;flex-direction:column;z-index:100;padding:var(--space-lg) 0}.sidebar-logo{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-xl)}.sidebar-logo-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--gradient-cyan-purple);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow-cyan)}.sidebar-logo-icon svg{color:var(--bg-primary)}.sidebar-logo-text{font-size:1.15rem;font-weight:700;letter-spacing:-.02em}.sidebar-logo-text span{background:var(--gradient-cyan-purple);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:var(--space-xs);padding:0 var(--space-md)}.sidebar-link{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-md);border-radius:var(--radius-md);font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.sidebar-link:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--accent-cyan);border-radius:var(--radius-full);transition:height .25s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px var(--accent-cyan)}.sidebar-link:hover{color:var(--text-primary);background:var(--bg-glass-hover)}.sidebar-link.active{color:var(--text-primary);background:#00f5d40f}.sidebar-link.active:before{height:60%}.sidebar-link.active svg{color:var(--accent-cyan)}.sidebar-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-subtle)}.sidebar-upload-btn{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md);border-radius:var(--radius-md);background:#00f5d414;border:1px solid rgba(0,245,212,.2);color:var(--accent-cyan);font-size:.85rem;font-weight:600;transition:all .25s ease}.sidebar-upload-btn:hover{background:#00f5d424;border-color:#00f5d459;box-shadow:var(--shadow-glow-cyan)}.glass-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:var(--space-lg);transition:all .35s cubic-bezier(.4,0,.2,1)}.glass-card:hover{background:var(--bg-card-hover);border-color:#ffffff1a;transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg);margin-bottom:var(--space-xl)}.kpi-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:var(--space-lg);position:relative;overflow:hidden;transition:all .35s cubic-bezier(.4,0,.2,1)}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.kpi-card.cyan:before{background:var(--gradient-blue-cyan);box-shadow:0 0 15px #00f5d44d}.kpi-card.purple:before{background:var(--gradient-purple-pink);box-shadow:0 0 15px #7b2ff74d}.kpi-card.pink:before{background:var(--gradient-pink-orange);box-shadow:0 0 15px #f725854d}.kpi-card.blue:before{background:var(--gradient-cyan-purple);box-shadow:0 0 15px #4361ee4d}.kpi-card.orange:before{background:linear-gradient(135deg,#ff6d00,#ffd60a);box-shadow:0 0 15px #ff6d004d}.kpi-card.green:before{background:linear-gradient(135deg,#06d6a0,#00f5d4);box-shadow:0 0 15px #06d6a04d}.kpi-card.red:before{background:linear-gradient(135deg,#ef476f,#f72585);box-shadow:0 0 15px #ef476f4d}.kpi-card.yellow:before{background:linear-gradient(135deg,#ffd60a,#ff6d00);box-shadow:0 0 15px #ffd60a4d}.kpi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#ffffff1a}.kpi-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.kpi-card-icon{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.kpi-card.cyan .kpi-card-icon{background:#00f5d41a;color:var(--accent-cyan)}.kpi-card.purple .kpi-card-icon{background:#7b2ff71a;color:var(--accent-purple)}.kpi-card.pink .kpi-card-icon{background:#f725851a;color:var(--accent-pink)}.kpi-card.blue .kpi-card-icon{background:#4361ee1a;color:var(--accent-blue)}.kpi-card.orange .kpi-card-icon{background:#ff6d001a;color:var(--accent-orange)}.kpi-card.green .kpi-card-icon{background:#06d6a01a;color:var(--accent-green)}.kpi-card.red .kpi-card-icon{background:#ef476f1a;color:var(--accent-red)}.kpi-card.yellow .kpi-card-icon{background:#ffd60a1a;color:var(--accent-yellow)}.kpi-card-label{font-size:.78rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.kpi-card-value{font-family:var(--font-mono);font-size:1.8rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:var(--space-xs)}.kpi-card-sub{font-size:.78rem;color:var(--text-tertiary)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.section-title{font-size:1.1rem;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:var(--space-sm)}.section-title svg{color:var(--accent-cyan)}.page-header{margin-bottom:var(--space-2xl)}.page-title{font-size:1.75rem;font-weight:800;letter-spacing:-.03em;margin-bottom:var(--space-xs)}.page-subtitle{font-size:.9rem;color:var(--text-secondary)}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}.chart-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:var(--space-lg)}.chart-title{font-size:.9rem;font-weight:600;margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary)}.secondary-kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.secondary-kpi{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);text-align:center;transition:all .25s ease}.secondary-kpi:hover{border-color:#ffffff1a;transform:translateY(-2px)}.secondary-kpi-value{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;margin-bottom:var(--space-xs)}.secondary-kpi-label{font-size:.72rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.upload-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-2xl)}.upload-container{max-width:640px;width:100%;text-align:center}.upload-logo{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-3xl)}.upload-logo-icon{width:56px;height:56px;border-radius:var(--radius-lg);background:var(--gradient-cyan-purple);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow-cyan)}.upload-logo-icon svg{color:var(--bg-primary);width:28px;height:28px}.upload-logo-text{font-size:2rem;font-weight:800;letter-spacing:-.03em}.upload-logo-text span{background:var(--gradient-cyan-purple);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.upload-dropzone{border:2px dashed rgba(0,245,212,.25);border-radius:var(--radius-xl);padding:var(--space-3xl) var(--space-2xl);background:#00f5d405;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.upload-dropzone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(0,245,212,.04) 0%,transparent 70%);opacity:0;transition:opacity .35s ease}.upload-dropzone:hover,.upload-dropzone.drag-over{border-color:#00f5d480;background:#00f5d40d;box-shadow:var(--shadow-glow-cyan)}.upload-dropzone:hover:before,.upload-dropzone.drag-over:before{opacity:1}.upload-dropzone-icon{width:72px;height:72px;margin:0 auto var(--space-lg);border-radius:50%;background:#00f5d414;display:flex;align-items:center;justify-content:center;color:var(--accent-cyan);position:relative;z-index:1}.upload-dropzone-text{position:relative;z-index:1}.upload-dropzone-text h3{font-size:1.15rem;font-weight:600;margin-bottom:var(--space-sm)}.upload-dropzone-text p{font-size:.85rem;color:var(--text-secondary)}.upload-dropzone-text .accent{color:var(--accent-cyan);font-weight:600}.upload-file-input{display:none}.upload-or{margin:var(--space-lg) 0;font-size:.8rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em}.upload-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);border-radius:var(--radius-full);background:var(--gradient-cyan-purple);color:var(--bg-primary);font-weight:700;font-size:.9rem;transition:all .25s ease;box-shadow:var(--shadow-glow-cyan)}.upload-btn:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 0 30px #00f5d440}.upload-error{margin-top:var(--space-lg);padding:var(--space-md);border-radius:var(--radius-md);background:#ef476f1a;border:1px solid rgba(239,71,111,.3);color:var(--accent-red);font-size:.85rem}.funnel-container{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md) 0}.funnel-step{display:flex;align-items:center;gap:var(--space-md)}.funnel-bar-wrapper{flex:1;position:relative;height:32px;background:#ffffff08;border-radius:var(--radius-sm);overflow:hidden}.funnel-bar{height:100%;border-radius:var(--radius-sm);transition:width 1.2s cubic-bezier(.25,.46,.45,.94);position:relative}.funnel-bar:after{content:"";position:absolute;right:0;top:0;bottom:0;width:2px;background:#ffffff4d;box-shadow:0 0 6px currentColor}.funnel-label{font-size:.78rem;font-weight:600;color:var(--text-secondary);width:40px;text-align:right;flex-shrink:0}.funnel-value{font-family:var(--font-mono);font-size:.82rem;font-weight:600;width:70px;text-align:right;flex-shrink:0}.campaigns-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--space-lg);min-height:calc(100vh - 140px);overflow:hidden}.campaign-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:calc(100vh - 180px);overflow-y:auto;padding-right:var(--space-sm)}.campaign-item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;transition:all .25s ease}.campaign-item:hover{background:var(--bg-card-hover);border-color:#ffffff1a}.campaign-item.active{border-color:#00f5d459;background:#00f5d40d;box-shadow:var(--shadow-glow-cyan)}.campaign-item-name{font-size:.85rem;font-weight:600;margin-bottom:var(--space-xs);line-height:1.3}.campaign-item-spend{font-family:var(--font-mono);font-size:.9rem;font-weight:700;color:var(--accent-cyan)}.campaign-item-meta{font-size:.72rem;color:var(--text-tertiary);margin-top:var(--space-xs)}.campaign-detail{display:flex;flex-direction:column;gap:var(--space-lg);min-width:0;overflow:hidden}.campaign-detail-header{display:flex;align-items:flex-start;justify-content:space-between}.campaign-detail-title{font-size:1.3rem;font-weight:700;margin-bottom:var(--space-xs)}.campaign-detail-date{font-size:.82rem;color:var(--text-tertiary)}.data-table-wrapper{overflow-x:auto;border-radius:var(--radius-lg)}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.82rem}.data-table thead th{background:#00f5d40d;padding:var(--space-md);text-align:left;font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);white-space:nowrap}.data-table tbody td{padding:var(--space-md);border-bottom:1px solid var(--border-subtle);font-family:var(--font-mono);font-size:.8rem;white-space:nowrap}.data-table tbody tr{transition:all .2s ease}.data-table tbody tr:hover{background:var(--bg-glass-hover)}.data-table tbody tr:last-child td{border-bottom:none}.export-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);background:#7b2ff71f;border:1px solid rgba(123,47,247,.25);color:var(--accent-purple);font-size:.82rem;font-weight:600;transition:all .25s ease}.export-btn:hover{background:#7b2ff733;border-color:#7b2ff766;box-shadow:var(--shadow-glow-purple);transform:translateY(-1px)}.export-btn.loading{opacity:.6;pointer-events:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #00f5d433}50%{box-shadow:0 0 25px #00f5d466}}@keyframes border-flow{0%{border-color:#00f5d440}50%{border-color:#7b2ff759}to{border-color:#00f5d440}}.animate-fade-in-up{animation:fadeInUp .6s cubic-bezier(.16,1,.3,1) both}.animate-fade-in{animation:fadeIn .5s ease both}.stagger-children>*:nth-child(1){animation-delay:.05s}.stagger-children>*:nth-child(2){animation-delay:.1s}.stagger-children>*:nth-child(3){animation-delay:.15s}.stagger-children>*:nth-child(4){animation-delay:.2s}.stagger-children>*:nth-child(5){animation-delay:.25s}.stagger-children>*:nth-child(6){animation-delay:.3s}.stagger-children>*:nth-child(7){animation-delay:.35s}.stagger-children>*:nth-child(8){animation-delay:.4s}.month-filter{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xl);padding:var(--space-xs);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-full);width:fit-content}.month-filter-icon{display:flex;align-items:center;justify-content:center;padding:0 var(--space-sm) 0 var(--space-md);color:var(--text-tertiary)}.month-filter-btn{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);font-size:.82rem;font-weight:600;color:var(--text-secondary);transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap}.month-filter-btn:hover{color:var(--text-primary);background:#ffffff0d}.month-filter-btn.active{background:#00f5d41f;color:var(--accent-cyan);box-shadow:0 0 12px #00f5d426}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-full);font-size:.68rem;font-weight:600;letter-spacing:.02em;border:1px solid;white-space:nowrap;flex-shrink:0}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:1600px){.main-content{padding:var(--space-lg) var(--space-xl)}.campaigns-layout{grid-template-columns:260px 1fr}.campaign-detail .kpi-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:1400px){.campaign-detail .kpi-grid{grid-template-columns:repeat(2,1fr)}.kpi-card-value{font-size:1.5rem}}@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.secondary-kpi-grid{grid-template-columns:repeat(3,1fr)}.charts-grid{grid-template-columns:1fr}.campaigns-layout{grid-template-columns:240px 1fr}}@media(max-width:900px){.sidebar{display:none}.main-content{margin-left:0;max-width:100vw}.campaigns-layout{grid-template-columns:1fr}}@media(max-width:600px){.kpi-grid{grid-template-columns:1fr}.secondary-kpi-grid{grid-template-columns:repeat(2,1fr)}.main-content{padding:var(--space-md)}}
