:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden;width:100%}#root{width:100%;overflow-x:hidden;padding:0 2%}:root{--primary: #C5F82A;--primary-dark: #A8D922;--accent-blue: #1E3A5F;--accent-pink: #FFE8E8;--accent-yellow: #FFF4D6;--accent-green: #E8F8E8;--bg-primary: #FAF9F6;--bg-white: #FFFFFF;--bg-card: #FFFFFF;--text-primary: #1a1a1a;--text-secondary: #666666;--text-muted: #999999;--border-color: #E5E5E5;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .16)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans KR,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;margin:0;padding:0;overflow-x:hidden}.app{min-height:100vh;display:flex;flex-direction:column;width:100%;margin:0 auto}.header{background:var(--bg-white);border-bottom:1px solid var(--border-color);width:100%}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:100%;margin:0;padding:1.5rem 2%}.landing-logo{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.landing-logo-icon{width:32px;height:32px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center}.landing-nav{display:flex;align-items:center;gap:1rem}.btn-primary{padding:.75rem 1.75rem;background:var(--primary);color:var(--text-primary);border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:var(--primary-dark)}.btn-secondary{padding:.75rem 1.75rem;background:transparent;color:var(--text-primary);border:1.5px solid var(--primary);border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#c5f82a1a}.landing-main{flex:1;width:100%}.landing-content{max-width:100%;margin:0;padding:4rem 2%}.hero{display:grid;grid-template-columns:1fr 1fr;gap:8%;align-items:center;margin-bottom:6rem;width:100%}.hero-left h2{font-size:3rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem;letter-spacing:-.02em;color:var(--text-primary)}.hero-left h2 .accent{color:var(--primary);display:block}.hero-subtitle{font-size:1.15rem;color:var(--text-secondary);margin-bottom:2.5rem;line-height:1.7}.hero-cta{display:flex;gap:1rem;margin-bottom:2rem}.hero-badges{display:flex;gap:2rem;margin-top:2rem}.badge-item{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.95rem}.badge-item svg{color:var(--primary)}.dashboard-preview{border-radius:20px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;width:100%;background:transparent}.dashboard-image{width:100%;height:auto;border-radius:20px;display:block}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.preview-header span{color:#fffc;font-size:.9rem;font-weight:500}.real-time-badge{background:var(--primary);color:var(--text-primary);padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:600}.preview-content{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.metric-card{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1.5rem;color:#fff}.metric-card.large{grid-column:1 / -1}.metric-label{font-size:.85rem;color:#ffffffb3;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:.25rem}.metric-trend{font-size:.9rem;color:var(--primary);display:flex;align-items:center;gap:.25rem}.chart-placeholder{height:120px;background:linear-gradient(135deg,#c5f82a33,#a8d9221a);border-radius:8px;margin-top:1rem;position:relative;overflow:hidden}.chart-line{position:absolute;bottom:0;left:0;right:0;height:80%;background:linear-gradient(to top,var(--primary),transparent);clip-path:polygon(0% 80%,10% 60%,20% 70%,30% 40%,40% 50%,50% 30%,60% 45%,70% 25%,80% 35%,90% 20%,100% 30%,100% 100%,0% 100%)}.pain-points{margin-bottom:4rem;text-align:center}.pain-points h3{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary)}.section-subtitle{color:var(--text-secondary);font-size:1.1rem;margin-bottom:3rem}.features{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2rem}.feature-card{background:var(--bg-card);border-radius:20px;padding:2.5rem 2rem;text-align:center;transition:all .3s;box-shadow:var(--shadow-sm)}.feature-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.feature-icon-circle{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;transition:transform .3s}.feature-card:hover .feature-icon-circle{transform:scale(1.1)}.feature-icon-circle.red{background:var(--accent-pink);color:#dc2626}.feature-icon-circle.yellow{background:var(--accent-yellow);color:#d97706}.feature-icon-circle.blue{background:var(--accent-green);color:#059669}.feature-card h3{font-size:1.25rem;margin-bottom:.75rem;font-weight:600}.feature-card p{color:var(--text-secondary);line-height:1.6;font-size:.95rem}.solution-section{margin-bottom:6rem;text-align:center}.solution-section h3{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary)}.solution-container{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:3rem;align-items:center}.solution-visual{background:linear-gradient(135deg,#e0f7fa,#b2ebf2);border-radius:20px;padding:3rem 2rem;box-shadow:var(--shadow-md)}.data-flow{display:flex;align-items:center;justify-content:center;gap:1rem}.flow-step{display:flex;flex-direction:column;align-items:center;gap:.75rem}.step-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a}.step-icon.upload{background:linear-gradient(135deg,#4fc3f7,#03a9f4);color:#fff}.step-icon.process{background:linear-gradient(135deg,#81c784,#66bb6a);color:#fff}.step-icon.analyze{background:linear-gradient(135deg,#ffb74d,#ffa726);color:#fff}.flow-arrow{font-size:2rem;color:var(--text-secondary);font-weight:300}.flow-step span{font-size:.9rem;font-weight:600;color:var(--text-primary)}.solution-features{display:flex;flex-direction:column;gap:2rem;text-align:left}.solution-item{display:flex;gap:1.5rem;align-items:flex-start}.solution-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.solution-icon.green{background:var(--accent-green);color:#059669}.solution-item h4{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.solution-item p{font-size:.95rem;color:var(--text-secondary);line-height:1.6}.app.dashboard{background:#f8f9fa;min-height:100vh}.dashboard-header{background:var(--bg-white);border-bottom:1px solid var(--border-color);box-shadow:0 2px 4px #00000014}.dashboard-logo{display:flex;align-items:center;gap:1rem}.logo-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #c5f82a4d;transition:transform .3s}.logo-icon:hover{transform:scale(1.05)}.logo-icon svg{color:var(--text-primary)}.header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.subtitle{color:var(--text-secondary);font-size:.9rem;margin:0}.user-menu{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-color)}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:var(--text-primary);box-shadow:0 2px 8px #c5f82a4d}.user-name{font-weight:500;color:var(--text-primary);font-size:.95rem}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid #DC3545;border-radius:6px;color:#dc3545;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;font-size:.9rem}.logout-btn:hover{background:#dc3545;border-color:#dc3545;color:#fff;box-shadow:0 2px 4px #dc354540}.logout-btn svg{transition:transform .2s}.logout-btn:hover svg{transform:translate(2px)}main.dashboard-content{max-width:1200px;margin:0 auto;padding:2.5rem 2%}.dashboard-nav{display:flex;gap:.5rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.nav-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;position:relative;top:2px}.nav-btn:hover{color:var(--text-primary);background:#c5f82a0d}.nav-btn.active{color:var(--text-primary);border-bottom-color:var(--primary);font-weight:600}.nav-btn svg{color:currentColor}.dashboard-welcome{background:linear-gradient(135deg,#d4f4dd,#e8f8ec);border-radius:16px;padding:2rem;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;border:2px solid #A8E6CF;box-shadow:0 2px 8px #a8e6cf33}.welcome-text h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.welcome-text p{color:var(--text-secondary);font-size:1rem;line-height:1.6}.quick-stats{display:flex;gap:1.5rem}.stat-item{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;min-width:160px;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014;border:1px solid #E9ECEF;transition:all .2s}.stat-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.blue{background:linear-gradient(135deg,#e0f7fa,#b2ebf2);color:#0288d1}.stat-icon.green{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1}.stat-label{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.card{background:var(--bg-white);border-radius:12px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014;border:1px solid #DEE2E6;transition:all .3s}.card:hover{box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;transform:translateY(-2px)}.card.upload-card{border-left:4px solid #0D6EFD}.card.history-card{border-left:4px solid #6C757D;background:#f8f9fa}.card.powerbi-card{border-left:4px solid #FFC107;background:linear-gradient(135deg,#fff9e6,#fffdf5)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.card-header-left{display:flex;gap:1rem;flex:1}.card-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#c5f82a26,#a8d9221a);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-dark);transition:all .3s}.card-icon.gradient-blue{background:linear-gradient(135deg,#e0f7fa,#b2ebf2);color:#0288d1}.card:hover .card-icon{transform:scale(1.1)}.card h2{font-size:1.5rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.description{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.description.secondary{color:var(--text-muted);font-size:.9rem}.drop-zone{border:2px dashed var(--border-color);border-radius:16px;padding:3rem 2rem;text-align:center;background:var(--bg-primary);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden}.drop-zone:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center,rgba(197,248,42,.1),transparent 70%);opacity:0;transition:opacity .3s}.drop-zone:hover:before,.drop-zone.dragging:before{opacity:1}.drop-zone:hover,.drop-zone.dragging{border-color:var(--primary);background:#c5f82a0d;transform:scale(1.01);box-shadow:0 4px 16px #c5f82a26}.drop-label{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon-wrapper{width:96px;height:96px;background:linear-gradient(135deg,#c5f82a26,#a8d9221a);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:.5rem;transition:all .3s;color:var(--primary-dark)}.drop-zone:hover .upload-icon-wrapper{transform:scale(1.1) translateY(-4px);background:linear-gradient(135deg,#c5f82a40,#a8d92226)}.drop-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:0}.file-types{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem;padding:.5rem 1rem;background:#00000008;border-radius:8px}.file-types svg{color:var(--primary-dark)}.files-list{display:flex;flex-direction:column;gap:.75rem}.file-preview{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-white);border:1px solid var(--border-color);border-radius:12px;transition:all .3s}.file-preview:hover{border-color:var(--primary);box-shadow:0 2px 8px #c5f82a26;transform:translate(4px)}.file-preview.success{background:#10b9810d;border-color:#059669}.file-preview.error{background:#ef44440d;border-color:#dc2626}.file-icon{width:40px;height:40px;background:linear-gradient(135deg,#c5f82a26,#a8d9221a);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-dark)}.file-details{flex:1;min-width:0}.file-name{font-weight:600;color:var(--text-primary);margin:0 0 .25rem;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:var(--text-secondary);font-size:.85rem;margin:0}.upload-status{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.upload-status.success{background:#10b98126;color:#059669}.upload-status.error{background:#ef444426;color:#dc2626}.remove-file{width:32px;height:32px;border-radius:8px;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.remove-file:hover{background:#ef44441a;border-color:#dc2626;color:#dc2626;transform:scale(1.1)}.remove-file:disabled{opacity:.5;cursor:not-allowed}.add-more-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background:#f8f9fa;border:2px dashed #6C757D;border-radius:8px;color:#495057;font-weight:600;cursor:pointer;transition:all .2s}.add-more-btn:hover{border-color:#0d6efd;border-style:solid;background:#e7f1ff;color:#0d6efd}.upload-actions{display:flex;gap:1rem;margin-top:1.5rem}.upload-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 2rem;background:linear-gradient(180deg,#0d6efd,#0b5ed7);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0d6efd40;text-shadow:0 1px 2px rgba(0,0,0,.1)}.upload-btn:hover:not(:disabled){background:linear-gradient(180deg,#0b5ed7,#0a58ca);transform:translateY(-1px);box-shadow:0 4px 8px #0d6efd59}.upload-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0d6efd40}.upload-btn:disabled{background:#adb5bd;opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.clear-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:#fff;border:1px solid #DC3545;border-radius:8px;color:#dc3545;font-weight:600;cursor:pointer;transition:all .2s}.clear-btn:hover{background:#dc3545;border-color:#dc3545;color:#fff;box-shadow:0 2px 4px #dc354540}.clear-btn:active{transform:translateY(0);box-shadow:0 1px 2px #dc354540}.message{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;border-radius:12px;margin-top:1.5rem;font-size:.95rem;line-height:1.5}.message-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.message p{margin:0;flex:1}.message.success{background:#d1e7dd;border:1px solid #BADBCC;color:#0f5132}.message.warning{background:#fff3cd;border:1px solid #FFECB5;color:#664d03}.message.error{background:#f8d7da;border:1px solid #F5C2C7;color:#842029}.table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid var(--border-color)}.history-table{width:100%;border-collapse:collapse}.history-table th{text-align:left;padding:1rem 1.25rem;background:var(--bg-primary);font-weight:600;color:var(--text-primary);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border-color)}.history-table td{padding:1rem 1.25rem;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.history-table tbody tr{transition:background .2s}.history-table tbody tr:hover{background:#c5f82a08}.history-table tbody tr:last-child td{border-bottom:none}.filename-cell{display:flex;align-items:center;gap:.75rem;font-weight:500}.filename-cell svg{color:var(--primary-dark);flex-shrink:0}.timestamp{color:var(--text-secondary);font-size:.9rem}.numeric{font-variant-numeric:tabular-nums;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.9rem}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .85rem;border-radius:8px;font-size:.85rem;font-weight:600;transition:all .2s}.status-badge.completed{background:#d1e7dd;color:#0f5132;border:1px solid #BADBCC}.status-badge.failed{background:#f8d7da;color:#842029;border:1px solid #F5C2C7}.status-badge.processing{background:#fff3cd;color:#664d03;border:1px solid #FFECB5}.empty-state{text-align:center;padding:3rem 2rem}.empty-icon{width:96px;height:96px;margin:0 auto 1.5rem;background:linear-gradient(135deg,#c5f82a1a,#a8d9220d);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.empty-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.empty-description{color:var(--text-secondary);font-size:.95rem;margin:0}.refresh-btn{width:40px;height:40px;border-radius:6px;background:#fff;border:1px solid #6C757D;color:#6c757d;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.refresh-btn:hover{background:#6c757d;border-color:#6c757d;color:#fff;transform:rotate(90deg);box-shadow:0 2px 4px #6c757d40}.powerbi-features{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:1.5rem}.feature-item{display:flex;gap:1rem;padding:1.5rem;background:var(--bg-primary);border-radius:16px;border:1px solid var(--border-color);transition:all .3s}.feature-item:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000014;border-color:var(--primary)}.feature-icon-small{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-icon-small.blue{background:linear-gradient(135deg,#e0f7fa,#b2ebf2);color:#0288d1}.feature-icon-small.green{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32}.feature-item h4{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.feature-item p{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner,.spinner-small{animation:spin 1s linear infinite}.footer{padding:2rem;text-align:center;color:var(--text-muted);background:var(--bg-white);border-top:1px solid var(--border-color);margin-top:auto}@media(max-width:1200px){.landing-header{padding:1.5rem 3%}.landing-main{padding:3rem 3%}.features{grid-template-columns:repeat(2,1fr);gap:1.5rem}.solution-container{gap:2rem}}@media(max-width:768px){.landing-header{padding:1rem 4%}.landing-header-content{flex-direction:row;flex-wrap:wrap}.landing-logo{font-size:1.25rem}.landing-nav{flex-wrap:wrap}.hero{grid-template-columns:1fr;gap:2rem;text-align:center}.hero-left h2{font-size:2.5rem}.hero-subtitle{font-size:1rem}.hero-cta{flex-direction:column;align-items:stretch}.hero-cta .btn-primary,.hero-cta .btn-secondary{width:100%;text-align:center;justify-content:center}.hero-badges{flex-direction:column;gap:1rem;align-items:center}.dashboard-preview{margin-top:2rem}.preview-content{grid-template-columns:1fr}.metric-value,.pain-points h3{font-size:2rem}.features{grid-template-columns:1fr}.landing-main{padding:2rem 4%}.solution-container{grid-template-columns:1fr;gap:2rem}.data-flow{flex-direction:column}.flow-arrow{transform:rotate(90deg)}}@media(max-width:480px){.landing-header{padding:1rem 4%}.hero-left h2{font-size:2rem}.btn-primary,.btn-secondary{padding:.65rem 1.25rem;font-size:.95rem}.feature-icon-circle{width:64px;height:64px}.feature-card{padding:2rem 1.5rem}}@media(max-width:1024px){main.dashboard-content{padding:2rem 3%}.dashboard-welcome{flex-direction:column;align-items:stretch}.quick-stats{flex-direction:row;justify-content:space-between}.stat-item{flex:1;min-width:0}.powerbi-features{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-logo{gap:.75rem}.logo-icon{width:40px;height:40px}.header h1{font-size:1.5rem}.subtitle{font-size:.85rem}.user-info{padding:.4rem .75rem}.user-avatar{width:32px;height:32px;font-size:.9rem}.user-name{display:none}.logout-btn{padding:.5rem 1rem;font-size:.9rem}main.dashboard-content{padding:1.5rem 4%}.dashboard-welcome{padding:1.5rem}.welcome-text h2{font-size:1.5rem}.welcome-text p{font-size:.95rem}.quick-stats{flex-direction:column;gap:1rem}.stat-item{min-width:0}.stat-value{font-size:1.75rem}.card{padding:1.5rem;border-radius:16px}.card-header{flex-direction:column;gap:1rem}.card-header-left{flex-direction:column}.card h2{font-size:1.35rem}.drop-zone{padding:2rem 1.5rem}.upload-icon-wrapper{width:80px;height:80px}.upload-icon-wrapper svg{width:48px;height:48px}.drop-title{font-size:1rem}.file-types{font-size:.85rem;text-align:center}.file-preview{padding:1rem}.upload-actions{flex-direction:column}.upload-btn,.clear-btn{width:100%}.table-wrapper{overflow-x:scroll}.history-table{min-width:600px}.history-table th,.history-table td{padding:.75rem 1rem;font-size:.85rem}.powerbi-features{gap:1rem}.feature-item{padding:1.25rem}}@media(max-width:480px){.header-content{flex-wrap:wrap;gap:1rem}.dashboard-logo{flex-direction:row}.logo-icon{width:36px;height:36px}.header h1{font-size:1.25rem}.subtitle{display:none}.user-menu{width:100%;justify-content:space-between}.logout-btn span{display:none}.logout-btn{padding:.5rem .75rem}main.dashboard-content{padding:1.25rem 4%}.dashboard-welcome{padding:1.25rem}.welcome-text h2{font-size:1.35rem}.welcome-text p{font-size:.9rem}.stat-item{padding:1.25rem}.stat-value{font-size:1.5rem}.card{padding:1.25rem}.card h2{font-size:1.25rem}.description{font-size:.9rem}.drop-zone{padding:1.5rem 1rem}.upload-icon-wrapper{width:64px;height:64px}.upload-icon-wrapper svg{width:40px;height:40px}.drop-title{font-size:.95rem}.file-preview{padding:.85rem;gap:.75rem}.file-icon{width:36px;height:36px}.file-icon svg{width:24px;height:24px}.file-name{font-size:.9rem}.file-size{font-size:.8rem}.upload-btn{padding:.875rem 1.5rem;font-size:.95rem}.history-table th,.history-table td{padding:.65rem .75rem;font-size:.8rem}.status-badge{padding:.35rem .65rem;font-size:.8rem}.status-badge svg{width:12px;height:12px}.empty-icon{width:80px;height:80px}.empty-icon svg{width:48px;height:48px}.empty-title{font-size:1.05rem}.empty-description{font-size:.9rem}.feature-item{flex-direction:column;padding:1rem}.feature-item h4{font-size:1rem}.feature-item p{font-size:.85rem}}.auth-container{position:relative}.auth-toggle-btn{padding:.75rem 1.75rem;background:var(--primary);color:var(--text-primary);border:none;border-radius:12px;font-weight:600;cursor:pointer}.auth-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--bg-white);border:1px solid var(--border-color);border-radius:12px;padding:1rem;min-width:300px;box-shadow:var(--shadow-lg);z-index:1000}.auth-provider-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;margin-bottom:.5rem;cursor:pointer;transition:all .2s;text-decoration:none;color:var(--text-primary);font-weight:500}.auth-provider-btn:hover{background:var(--bg-primary);transform:translate(4px)}.auth-provider-btn.microsoft{border-color:#00a4ef}.auth-provider-btn.google{border-color:#db4437}.auth-provider-btn.facebook{border-color:#1877f2}.cta-section{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#faf9f6,#f0f0e8);border-radius:24px;margin-top:4rem}.cta-section h3{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.cta-description{font-size:1.1rem;color:var(--text-secondary);margin-bottom:3rem}.auth-buttons{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:400px;margin:0 auto}.auth-button{display:flex;align-items:center;justify-content:center;gap:1rem;width:100%;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #00000014;position:relative;overflow:hidden}.auth-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.auth-button:hover:before{left:100%}.auth-button:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.auth-button:active{transform:translateY(0)}.auth-button.email{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);color:#fff;border:2px solid transparent}.auth-button.email:hover{background:linear-gradient(135deg,#2d2d2d,#404040)}.auth-button.google{background:#fff;color:#1a1a1a;border:2px solid #e0e0e0}.auth-button.google:hover{border-color:#4285f4;background:#f8f9fa}.auth-button.facebook{background:linear-gradient(135deg,#1877f2,#0c63d4);color:#fff;border:2px solid transparent}.auth-button.facebook:hover{background:linear-gradient(135deg,#0c63d4,#084a9e)}.auth-button svg{flex-shrink:0}@media(max-width:768px){.cta-section{padding:3rem 1.5rem}.cta-section h3{font-size:2rem}.auth-buttons{max-width:100%}.auth-button{padding:.875rem 1.5rem;font-size:.95rem}}.reports-container{width:100%;max-width:1400px;margin:2rem auto;padding:0 1rem}.reports-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.reports-header h2{font-size:1.75rem;font-weight:700;color:#58a6ff;margin:0;text-shadow:0 0 20px rgba(88,166,255,.3)}.refresh-btn-reports{padding:.5rem;background:#21262d;border:1px solid #30363d;border-radius:6px;color:#7d8590;cursor:pointer;transition:all .2s}.refresh-btn-reports:hover{background:#30363d;color:#e6edf3;border-color:#58a6ff}.reports-tabs{display:flex;gap:.5rem;border-bottom:1px solid #30363d;margin-bottom:2rem}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:none;border-bottom:2px solid transparent;color:#7d8590;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.tab-btn:hover{color:#e6edf3;background:#58a6ff0d}.tab-btn.active{color:#58a6ff;border-bottom-color:#58a6ff}.tab-btn svg{color:currentColor}.reports-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.reports-loading p{color:#7d8590;font-size:.95rem}.spinner-large{width:48px;height:48px;border:4px solid #30363d;border-top-color:#58a6ff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.reports-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem;text-align:center}.reports-error svg{color:#f85149}.reports-error h3{color:#e6edf3;font-size:1.25rem;margin:0}.reports-error p{color:#7d8590;margin:0}.retry-btn{margin-top:1rem;padding:.75rem 1.5rem;background:#238636;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.retry-btn:hover{background:#2ea043}.overview-tab{display:flex;flex-direction:column;gap:2rem}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.kpi-grid{grid-template-columns:1fr}}.kpi-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#161b22,#1c2128);border:1px solid #30363d;border-radius:12px;transition:all .3s}.kpi-card:hover{transform:translateY(-2px);border-color:#58a6ff;box-shadow:0 8px 24px #58a6ff1a}.kpi-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:10px;background:linear-gradient(135deg,#58a6ff,#1f6feb);color:#fff}.kpi-card.revenue .kpi-icon{background:linear-gradient(135deg,#3fb950,#238636)}.kpi-card.orders .kpi-icon{background:linear-gradient(135deg,#a371f7,#8957e5)}.kpi-card.aov .kpi-icon{background:linear-gradient(135deg,#f778ba,#db61a2)}.kpi-card.uploads .kpi-icon{background:linear-gradient(135deg,#f5a623,#e09500)}.kpi-content{flex:1}.kpi-label{font-size:.85rem;color:#7d8590;margin-bottom:.25rem}.kpi-value{font-size:1.75rem;font-weight:700;color:#e6edf3}.chart-card{padding:1.5rem;background:#0d1117;border:1px solid #30363d;border-radius:12px}.chart-card h3{font-size:1.1rem;color:#e6edf3;margin:0 0 1.5rem;font-weight:600}.chart-with-controls{display:flex;flex-direction:column;gap:1rem}.chart-controls{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#161b22;border:1px solid #30363d;border-radius:8px}.chart-info{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.date-range{font-size:.9rem;color:#e6edf3;font-weight:500}.page-indicator{font-size:.85rem;color:#7d8590;padding:.25rem .75rem;background:#0d1117;border-radius:4px;font-family:Monaco,Courier New,monospace}.chart-nav-buttons{display:flex;gap:.25rem}.chart-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#21262d;border:1px solid #30363d;border-radius:6px;color:#7d8590;cursor:pointer;transition:all .2s}.chart-nav-btn:hover:not(:disabled){background:#30363d;border-color:#58a6ff;color:#58a6ff}.chart-nav-btn:active:not(:disabled){background:#0d1117;transform:scale(.95)}.chart-nav-btn:disabled{opacity:.4;cursor:not-allowed}.chart-nav-btn svg{display:block}.line-chart-container{width:100%;min-height:300px;background:#0d1117;border-radius:8px;padding:1rem}.line-chart{width:100%;height:auto}.chart-point{cursor:pointer;transition:all .2s}.chart-point:hover{r:6;filter:drop-shadow(0 0 4px #58a6ff)}.simple-chart{height:200px;display:flex;align-items:flex-end}.chart-bars{display:flex;align-items:flex-end;gap:.5rem;width:100%;height:100%}.chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}.chart-bar{width:100%;background:linear-gradient(180deg,#58a6ff,#1f6feb);border-radius:4px 4px 0 0;min-height:4px;transition:all .3s;cursor:pointer;position:relative;display:flex;align-items:flex-start;justify-content:center;padding-top:4px}.chart-bar:hover{background:linear-gradient(180deg,#79c0ff,#58a6ff)}.chart-bar.highlight{background:linear-gradient(180deg,#f78166,#ea6045)}.chart-bar.highlight:hover{background:linear-gradient(180deg,#ff9580,#f78166)}.bar-value{font-size:.65rem;color:#fff;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3);white-space:nowrap;opacity:0;transition:opacity .3s}.chart-bar:hover .bar-value{opacity:1}.chart-label{font-size:.75rem;color:#7d8590}.chart-empty{display:flex;align-items:center;justify-content:center;height:200px;color:#7d8590;font-style:italic}.upload-trends{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.trend-item{text-align:center;padding:1rem;background:#161b22;border-radius:8px;border:1px solid #30363d}.trend-label{font-size:.85rem;color:#7d8590;margin-bottom:.5rem}.trend-value{font-size:1.5rem;font-weight:700;color:#e6edf3}.trend-value.unique{color:#3fb950}.trend-value.duplicate{color:#f85149}.trend-value.rate{color:#d29922}.products-tab{background:#0d1117;border:1px solid #30363d;border-radius:12px;padding:1.5rem}.products-header{margin-bottom:1.5rem}.products-header h3{font-size:1.25rem;color:#e6edf3;margin:0 0 .5rem}.products-subtitle{color:#7d8590;font-size:.9rem;margin:0}.products-table-wrapper{overflow-x:auto}.products-table{width:100%;border-collapse:collapse}.products-table thead{background:#161b22;border-bottom:2px solid #30363d}.products-table th{padding:.75rem 1rem;text-align:left;font-size:.85rem;font-weight:600;color:#7d8590;text-transform:uppercase;letter-spacing:.5px}.products-table th.align-right{text-align:right}.products-table tbody tr{border-bottom:1px solid #30363d;transition:background .2s}.products-table tbody tr:hover{background:#161b22}.products-table td{padding:1rem;color:#e6edf3}.products-table td.align-right{text-align:right}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-weight:700;font-size:.9rem}.rank-badge.rank-1{background:linear-gradient(135deg,gold,#f1c40f);color:#1c1e26}.rank-badge.rank-2{background:linear-gradient(135deg,silver,#95a5a6);color:#1c1e26}.rank-badge.rank-3{background:linear-gradient(135deg,#cd7f32,sienna);color:#fff}.rank-badge:not(.rank-1):not(.rank-2):not(.rank-3){background:#30363d;color:#7d8590}.product-name{font-weight:500;color:#e6edf3}.sku{font-family:Monaco,Courier New,monospace;font-size:.85rem;color:#7d8590}.revenue-cell{color:#3fb950;font-weight:600}.margin-cell{color:#58a6ff;font-weight:500}.quality-tab{display:flex;flex-direction:column;gap:2rem}.quality-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.quality-card{padding:1.5rem;background:linear-gradient(135deg,#0d1117,#161b22);border:1px solid #30363d;border-radius:12px;text-align:center}.quality-card h4{font-size:.9rem;color:#7d8590;margin:0 0 1rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.quality-value{font-size:2.5rem;font-weight:700;color:#3fb950;margin-bottom:.5rem}.quality-detail{font-size:.85rem;color:#7d8590}.issues-section{padding:1.5rem;background:#0d1117;border:1px solid #30363d;border-radius:12px}.issues-section h3{font-size:1.1rem;color:#e6edf3;margin:0 0 1.5rem}.no-issues{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.no-issues p{color:#3fb950;font-size:1.1rem;font-weight:500;margin-top:1rem}.issues-table{width:100%;border-collapse:collapse}.issues-table thead{background:#161b22;border-bottom:2px solid #30363d}.issues-table th{padding:.75rem 1rem;text-align:left;font-size:.85rem;font-weight:600;color:#7d8590;text-transform:uppercase}.issues-table tbody tr{border-bottom:1px solid #30363d}.issues-table td{padding:1rem;color:#e6edf3}.severity-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.severity-badge.low{background:#3fb95026;color:#3fb950}.severity-badge.medium{background:#d2992226;color:#d29922}.severity-badge.high{background:#f8514926;color:#f85149}.severity-badge.none{background:#7d859026;color:#7d8590}@media(max-width:768px){.reports-header h2{font-size:1.5rem}.kpi-grid{grid-template-columns:1fr}.kpi-value{font-size:1.5rem}.products-table{font-size:.85rem}.products-table th,.products-table td{padding:.5rem}.quality-metrics{grid-template-columns:1fr}.upload-trends{grid-template-columns:repeat(2,1fr)}.chart-controls{flex-direction:column;gap:1rem}.chart-info{width:100%;justify-content:space-between}.chart-nav-buttons{width:100%;justify-content:center}.date-range{font-size:.8rem}}.executive-tab{display:flex;flex-direction:column;gap:2rem}.charts-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}@media(max-width:1200px){.charts-grid{grid-template-columns:1fr}}.chart-card.chart-primary,.chart-card.chart-secondary{min-height:350px}.kpi-card.gmv .kpi-icon{background:linear-gradient(135deg,gold,#f1c40f)}.kpi-card.refund-rate .kpi-icon{background:linear-gradient(135deg,#f85149,#da3633)}.kpi-card.profit .kpi-icon{background:linear-gradient(135deg,#3fb950,#238636)}.platform-breakdown{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0}.platform-item{display:flex;flex-direction:column;gap:.5rem}.platform-header{display:flex;justify-content:space-between;align-items:center}.platform-name{font-weight:600;color:#e6edf3;font-size:1rem}.platform-share{color:#58a6ff;font-weight:700;font-size:1.25rem}.platform-bar-wrapper{width:100%;height:24px;background:#161b22;border-radius:12px;overflow:hidden}.platform-bar{height:100%;background:linear-gradient(90deg,#58a6ff,#1f6feb);transition:width .3s}.platform-stats{display:flex;gap:.5rem;font-size:.9rem;color:#7d8590}.platform-stats .separator{color:#30363d}.platforms-tab{background:#0d1117;border:1px solid #30363d;border-radius:12px;padding:1.5rem}.platforms-header{margin-bottom:1.5rem}.platforms-header h3{font-size:1.25rem;color:#e6edf3;margin:0 0 .5rem}.platforms-subtitle{color:#7d8590;font-size:.9rem;margin:0}.platforms-table-wrapper{overflow-x:auto}.platforms-table{width:100%;border-collapse:collapse}.platforms-table thead{background:#161b22;border-bottom:2px solid #30363d}.platforms-table th{padding:.75rem 1rem;text-align:left;font-size:.85rem;font-weight:600;color:#7d8590;text-transform:uppercase}.platforms-table tbody tr{border-bottom:1px solid #30363d;transition:background .2s}.platforms-table tbody tr:hover{background:#161b22}.platforms-table td{padding:1rem;color:#e6edf3}.refund-cell{color:#f85149;font-weight:500}.revenue-tab{display:flex;flex-direction:column;gap:2rem}.revenue-header{margin-bottom:1rem}.revenue-header h3{font-size:1.25rem;color:#e6edf3;margin:0 0 .5rem}.revenue-subtitle{color:#7d8590;font-size:.9rem;margin:0}.waterfall-section,.breakdown-section{padding:1.5rem;background:#0d1117;border:1px solid #30363d;border-radius:12px}.waterfall-section h4,.breakdown-section h4{font-size:1.1rem;color:#e6edf3;margin:0 0 1.5rem}.waterfall-chart{display:flex;align-items:flex-end;gap:1rem;min-height:300px;padding:1rem;background:#161b22;border-radius:8px}.waterfall-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}.waterfall-label{font-size:.75rem;color:#7d8590;text-align:center;min-height:32px}.waterfall-bar{width:100%;border-radius:4px 4px 0 0;display:flex;align-items:flex-start;justify-content:center;padding-top:.5rem;position:relative}.waterfall-bar.positive{background:linear-gradient(180deg,#3fb950,#238636)}.waterfall-bar.negative{background:linear-gradient(180deg,#f85149,#da3633)}.waterfall-bar.total{background:linear-gradient(180deg,#58a6ff,#1f6feb)}.waterfall-value{font-size:.85rem;font-weight:700;color:#fff}.waterfall-value.total{font-size:1rem}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.breakdown-item{padding:1.5rem;background:#161b22;border-radius:8px;border-left:4px solid;text-align:center}.breakdown-item.positive{border-left-color:#3fb950}.breakdown-item.negative{border-left-color:#f85149}.breakdown-item.total{border-left-color:#58a6ff;background:linear-gradient(135deg,#0d1117,#1c2128)}.breakdown-label{font-size:.85rem;color:#7d8590;margin-bottom:.5rem}.breakdown-value{font-size:1.5rem;font-weight:700;color:#e6edf3}.breakdown-margin{margin-top:.5rem;font-size:.9rem;color:#58a6ff;font-weight:600}.operations-tab{display:flex;flex-direction:column;gap:2rem}.status-breakdown{display:flex;flex-direction:column;gap:1rem;padding:1rem 0}.status-item{display:flex;align-items:center;gap:1rem}.status-label{min-width:120px;display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#e6edf3;font-weight:500}.status-dot{width:12px;height:12px;border-radius:50%}.status-dot.delivered{background:#3fb950}.status-dot.shipped{background:#58a6ff}.status-dot.pending{background:#d29922}.status-dot.refunded{background:#f85149}.status-dot.cancelled{background:#7d8590}.status-bar-wrapper{flex:1;height:24px;background:#161b22;border-radius:12px;overflow:hidden}.status-bar{height:100%;background:linear-gradient(90deg,#58a6ff,#1f6feb)}.status-count{min-width:100px;text-align:right;font-size:.9rem;color:#7d8590}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.metric-card{padding:1.5rem;background:linear-gradient(135deg,#0d1117,#1c2128);border:1px solid #30363d;border-radius:12px;text-align:center}.metric-label{font-size:.85rem;color:#7d8590;margin-bottom:.75rem}.metric-value{font-size:2rem;font-weight:700;color:#58a6ff}.geo-table-wrapper{overflow-x:auto}.geo-table{width:100%;border-collapse:collapse}.geo-table thead{background:#161b22;border-bottom:2px solid #30363d}.geo-table th{padding:.75rem 1rem;text-align:left;font-size:.85rem;font-weight:600;color:#7d8590;text-transform:uppercase}.geo-table tbody tr{border-bottom:1px solid #30363d;transition:background .2s}.geo-table tbody tr:hover{background:#161b22}.geo-table td{padding:1rem;color:#e6edf3}.country-name{display:flex;align-items:center;gap:.5rem;font-weight:500}.country-flag{display:inline-block;width:24px;height:16px;background:#30363d;border-radius:2px;text-align:center;font-size:.7rem;line-height:16px;color:#7d8590}@media(max-width:768px){.kpi-grid{grid-template-columns:1fr}.waterfall-chart{flex-direction:column;align-items:stretch}.waterfall-item{flex-direction:row;justify-content:space-between}.waterfall-bar{width:60%;height:40px;border-radius:0 4px 4px 0}.breakdown-grid{grid-template-columns:1fr}.platforms-table,.geo-table{font-size:.85rem}}
