body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.landing-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.hero{align-items:center;color:#fff;display:flex;justify-content:center;min-height:90vh;padding:2rem;text-align:center}.hero-content{margin:0 auto;max-width:900px}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#f0f0f0);-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:#ffffffe6;font-size:1.5rem;line-height:1.6;margin-bottom:3rem}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.cta-primary{background:#fff;border:none;border-radius:8px;box-shadow:0 4px 15px #0003;color:#667eea;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2.5rem;transition:all .3s ease}.cta-primary:hover{box-shadow:0 6px 20px #0000004d;transform:translateY(-2px)}.cta-primary.large{font-size:1.25rem;padding:1.25rem 3rem}.cta-secondary{background:#0000;border:2px solid #fff;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2.5rem;transition:all .3s ease}.cta-secondary:hover{background:#fff;color:#667eea;transform:translateY(-2px)}.features-section{background:#fff;padding:5rem 2rem}.container{margin:0 auto;max-width:1200px}.section-title{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-align:center}.section-subtitle{color:#718096;font-size:1.25rem;margin-bottom:4rem;margin-left:auto;margin-right:auto;max-width:700px;text-align:center}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:3rem}.feature-card{background:#f7fafc;border:2px solid #0000;border-radius:12px;padding:2rem;transition:all .3s ease}.feature-card:hover{border-color:#667eea;box-shadow:0 10px 30px #0000001a;transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.feature-card p{color:#4a5568;line-height:1.6;margin-bottom:1rem}.feature-list{list-style:none;margin:1rem 0 0;padding:0}.feature-list li{color:#4a5568;font-size:.95rem;padding:.5rem 0}.how-it-works{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:5rem 2rem}.how-it-works .section-title{color:#fff}.steps-grid{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:3rem}.step{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;border-radius:12px;min-width:200px;padding:2rem;text-align:center}.step-number{align-items:center;background:#fff;border-radius:50%;color:#667eea;display:flex;font-size:1.5rem;font-weight:700;height:50px;justify-content:center;margin:0 auto 1rem;width:50px}.step h3{font-size:1.25rem;margin-bottom:.5rem}.step p{color:#ffffffe6;font-size:.95rem}.step-arrow{color:#fff;font-size:2rem;opacity:.7}.use-cases{background:#f7fafc;padding:5rem 2rem}.use-cases-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:3rem}.use-case{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:2rem;text-align:center;transition:all .3s ease}.use-case:hover{box-shadow:0 10px 20px #0000001a;transform:translateY(-5px)}.use-case h3{color:#2d3748;font-size:1.5rem;margin-bottom:1rem}.use-case p{color:#718096;line-height:1.6}.cta-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:5rem 2rem;text-align:center}.cta-section h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.cta-section p{color:#ffffffe6;font-size:1.25rem;margin-bottom:2rem}.landing-footer{background:#2d3748;color:#fff;padding:3rem 2rem;text-align:center}.footer-links{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin-top:1.5rem}.footer-links a{color:#fffc;text-decoration:none;transition:color .3s ease}.footer-links a:hover{color:#fff}@media (max-width:768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.section-title{font-size:2rem}.features-grid{grid-template-columns:1fr}.steps-grid{flex-direction:column}.step-arrow{transform:rotate(90deg)}.use-cases-grid{grid-template-columns:1fr}}@media (max-width:480px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1.1rem}.hero-buttons{flex-direction:column}.cta-primary,.cta-secondary{width:100%}}.gmail-status-widget{background:#fff;border-radius:1rem;box-shadow:var(--shadow-lg);margin-bottom:2rem;overflow:hidden;transition:all .3s ease}.gmail-status-widget:hover{box-shadow:var(--shadow-xl);transform:translateY(-2px)}.widget-header{background:linear-gradient(135deg,#ea4335,#db4437);color:#fff;padding:1.25rem 1.5rem}.widget-header h3{align-items:center;display:flex;font-size:1.125rem;font-weight:600;gap:.5rem;margin:0}.widget-body{padding:1.5rem}.status-indicator{align-items:center;display:flex;gap:.75rem;margin-bottom:1rem}.status-dot{border-radius:50%;height:12px;position:relative;width:12px}.status-dot.connected{animation:pulse 2s infinite;background:var(--success-color);box-shadow:0 0 0 3px #10b98133}.status-dot.disconnected{background:var(--text-secondary)}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #10b98133}50%{box-shadow:0 0 0 6px #10b9811a}}.status-text{color:var(--text-primary);font-size:1rem;font-weight:600}.status-connected{display:flex;flex-direction:column;gap:1rem}.sync-info{background:var(--light-bg);border-left:3px solid var(--success-color);border-radius:.5rem;padding:.75rem 1rem}.last-sync{color:var(--text-secondary);font-size:.875rem;margin:0}.last-sync strong{color:var(--text-primary)}.status-not-connected{display:flex;flex-direction:column;gap:1rem}.connect-description{color:var(--text-secondary);font-size:.9375rem;line-height:1.6;margin:0}.benefits{background:var(--light-bg);border-radius:.5rem;margin-top:1rem;padding:1rem}.benefits-title{color:var(--text-primary);font-size:.875rem;font-weight:600;margin:0 0 .75rem}.benefits ul{display:flex;flex-direction:column;gap:.5rem;list-style:none;margin:0;padding:0}.benefits li{align-items:center;color:var(--text-secondary);display:flex;font-size:.875rem}.widget-actions{display:flex;flex-wrap:wrap;gap:.75rem}.btn{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#ea4335,#db4437);box-shadow:0 2px 4px #ea43354d;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 4px 8px #ea433566;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-primary svg{height:18px;width:18px}.btn-secondary{background:#fff;border:1.5px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--light-bg);border-color:var(--text-secondary)}.btn-link{background:#0000;border:none;color:var(--primary-color);cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .2s}.btn-link:hover{color:var(--primary-dark);text-decoration:underline}.spinner-small{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;width:14px}.widget-error{background:#fee2e2;border:1px solid #fecaca;border-radius:.5rem;color:#991b1b;font-size:.875rem;margin-top:1rem;padding:.875rem 1rem}.gmail-widget-compact{align-items:center;background:#fff;border:1.5px solid var(--border-color);border-radius:.5rem;display:flex;gap:1rem;padding:.75rem 1rem;transition:all .2s}.gmail-widget-compact:hover{border-color:var(--text-secondary)}.compact-connected,.compact-not-connected{align-items:center;display:flex;gap:.75rem;width:100%}.compact-connected span,.compact-not-connected span{color:var(--text-primary);font-size:.875rem}@media (max-width:768px){.widget-actions{flex-direction:column}.btn{justify-content:center;width:100%}.compact-connected,.compact-not-connected,.gmail-widget-compact{align-items:flex-start;flex-direction:column}}.auth-container{align-items:center;animation:gradientShift 15s ease infinite;background:linear-gradient(135deg,#667eea,#764ba2);background-size:400% 400%;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:1.5rem;position:relative}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.auth-container:after,.auth-container:before{animation:float 20s ease-in-out infinite;border-radius:50%;content:"";filter:blur(80px);opacity:.3;position:absolute}.auth-container:before{animation-delay:-10s;background:#ffffff1a;height:600px;right:-200px;top:-200px;width:600px}.auth-container:after{background:#764ba233;bottom:-100px;height:400px;left:-100px;width:400px}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-30px) rotate(5deg)}}.auth-card{animation:cardSlideIn .6s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffffa;border-radius:1.25rem;box-shadow:0 0 0 1px #ffffff1a,0 20px 70px #0003;max-width:440px;padding:3rem 2.5rem;position:relative;width:100%;z-index:1}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(40px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-header{margin-bottom:2.5rem;text-align:center}.auth-header h1{color:#0f172a;font-size:1.875rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0 0 .75rem}.auth-header p{color:#64748b;font-size:.9375rem;font-weight:400;line-height:1.5;margin:0}.auth-form{gap:1.25rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#1e293b;font-size:.875rem;font-weight:500;letter-spacing:-.01em}.form-group input{-webkit-font-smoothing:antialiased;background:#fff;border:1.5px solid #e2e8f0;border-radius:.625rem;color:#0f172a;font-family:inherit;font-size:.9375rem;padding:.875rem 1rem;transition:all .15s cubic-bezier(.4,0,.2,1)}.form-group input:hover{border-color:#cbd5e1}.form-group input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea14;outline:none}.form-group input:disabled{background-color:#f8fafc;border-color:#e2e8f0;color:#94a3b8;cursor:not-allowed}.form-group input::placeholder{color:#94a3b8;opacity:1}.auth-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.625rem;box-shadow:0 1px 2px #667eea4d,0 0 0 0 #667eea00;color:#fff;cursor:pointer;font-size:.9375rem;font-weight:600;letter-spacing:-.01em;margin-top:.5rem;overflow:hidden;padding:.9375rem 1.5rem;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1)}.auth-button:before{background:linear-gradient(135deg,#fff3,#fff0);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s}.auth-button:hover:not(:disabled){box-shadow:0 4px 12px #667eea66,0 0 0 0 #667eea00;transform:translateY(-1px)}.auth-button:hover:not(:disabled):before{opacity:1}.auth-button:active:not(:disabled){box-shadow:0 1px 3px #667eea4d,0 0 0 0 #667eea00;transform:translateY(0)}.auth-button:focus-visible{box-shadow:0 4px 12px #667eea66,0 0 0 3px #667eea33;outline:none}.auth-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.auth-error{animation:errorSlide .3s cubic-bezier(.16,1,.3,1);background-color:#fef2f2;border:1px solid #fecaca;border-radius:.625rem;color:#991b1b;font-size:.875rem;line-height:1.5;margin-bottom:1rem;padding:.875rem 1rem}@keyframes errorSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.auth-footer{border-top:1px solid #f1f5f9;margin-top:2rem;padding-top:1.75rem;text-align:center}.auth-footer p{color:#64748b;font-size:.875rem;line-height:1.5;margin:0}.auth-link{border-bottom:1px solid #0000;color:#667eea;font-weight:600;text-decoration:none;transition:color .15s ease}.auth-link:hover{border-bottom-color:#5568d3;color:#5568d3}.auth-link:focus-visible{border-radius:2px;outline:2px solid #667eea;outline-offset:2px}.auth-button:disabled:after{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:16px;left:50%;margin-left:-8px;margin-top:-8px;position:absolute;top:50%;width:16px}@media (max-width:480px){.auth-container{padding:1rem}.auth-card{border-radius:1rem;padding:2.5rem 1.75rem}.auth-header h1{font-size:1.625rem}.auth-header p{font-size:.875rem}.form-group input{font-size:1rem;padding:.8125rem .875rem}.auth-button{padding:.875rem 1.25rem}}@media (prefers-contrast:high){.auth-card{border:2px solid #0f172a}.form-group input{border-width:2px}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#4f46e5;--primary-dark:#4338ca;--secondary-color:#06b6d4;--success-color:#10b981;--warning-color:#f59e0b;--danger-color:#ef4444;--dark-bg:#1f2937;--light-bg:#f9fafb;--card-bg:#fff;--text-primary:#111827;--text-secondary:#6b7280;--border-color:#e5e7eb;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App,body{min-height:100vh}.App{display:flex;flex-direction:column}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#111827;color:var(--text-primary);justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.nav-brand,.navbar{align-items:center;display:flex}.nav-brand{gap:.5rem}.nav-brand h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4f46e5,#06b6d4);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin:0}.nav-links{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none}.nav-links li{margin:0}.nav-links a{border-radius:.5rem;color:#111827;color:var(--text-primary);display:block;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.nav-links a:hover{background:#4f46e5;background:var(--primary-color);color:#fff;transform:translateY(-2px)}.nav-logout{background:#0000;border:1.5px solid #e5e7eb;border:1.5px solid var(--border-color);border-radius:.5rem;color:#111827;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.nav-logout:hover{background:#ef4444;background:var(--danger-color);border-color:#ef4444;border-color:var(--danger-color);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff;transform:translateY(-2px)}.container{flex:1 1;margin:2rem auto;max-width:1400px;padding:0 2rem}h1{color:#fff;font-size:2rem;font-weight:700;margin-bottom:2rem;text-shadow:0 2px 4px #0000001a}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:2rem}.stat-card{background:#fff;border:1px solid #fff3;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);overflow:hidden;padding:2rem;position:relative;transition:all .3s ease}.stat-card:before{background:linear-gradient(90deg,#4f46e5,#06b6d4);background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-5px)}.stat-card h3{color:#6b7280;color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.75rem;text-transform:uppercase}.stat-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4f46e5,#06b6d4);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700}.card{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:2rem}.card,.filters{background:#fff;border-radius:1rem;margin-bottom:2rem}.filters{align-items:flex-end;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);display:flex;flex-wrap:wrap;gap:1rem;padding:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:180px}.filter-group label{color:#111827;color:var(--text-primary);font-size:.875rem;font-weight:600}.filter-group input,.filter-group select{background:#fff;border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:.5rem;font-size:.875rem;padding:.625rem .875rem;transition:all .3s ease}.filter-group input:focus,.filter-group select:focus{border-color:#4f46e5;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a;outline:none}.button,button{background:linear-gradient(135deg,#4f46e5,#4338ca);background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border:none;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff;cursor:pointer;display:inline-block;font-size:.875rem;font-weight:600;padding:.625rem 1.5rem;text-decoration:none;transition:all .3s ease}.button:hover,button:hover:not(:disabled){box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}button:active:not(:disabled){transform:translateY(0)}button:disabled{background:#6b7280;background:var(--text-secondary);cursor:not-allowed;opacity:.5}button.secondary{background:#fff;border:2px solid #4f46e5;border:2px solid var(--primary-color);color:#4f46e5;color:var(--primary-color)}.transaction-table{background:#fff;border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);overflow:hidden;width:100%}.transaction-table td,.transaction-table th{padding:1rem;text-align:left}.transaction-table th{background:linear-gradient(135deg,#4f46e5,#4338ca);background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.transaction-table tbody tr{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);transition:all .2s ease}.transaction-table tbody tr:hover{background:#f9fafb;background:var(--light-bg)}.transaction-table tbody tr:last-child{border-bottom:none}.amount{color:#10b981;color:var(--success-color);font-size:1.1rem;font-weight:700}.badge{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:600;padding:.375rem .75rem;text-transform:capitalize}.badge-invoice{background:#4f46e51a;color:#4f46e5;color:var(--primary-color)}.badge-receipt{background:#10b9811a;color:#10b981;color:var(--success-color)}.badge-bank_statement{background:#a855f71a;color:#a855f7}.badge-pending{background:#f59e0b1a;color:#f59e0b;color:var(--warning-color)}.badge-processing{background:#3b82f61a;color:#3b82f6}.badge-completed{background:#10b9811a;color:#10b981;color:var(--success-color)}.badge-failed{background:#ef44441a;color:#ef4444;color:var(--danger-color)}.document-info,.extracted-data,.extracted-text{background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin-bottom:1.5rem;padding:2rem}.document-info h2,.extracted-data h2,.extracted-text h2{color:#111827;color:var(--text-primary);font-size:1.25rem;margin-bottom:1rem}.info-row{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;padding:.75rem 0}.info-row:last-child{border-bottom:none}.info-row strong{color:#6b7280;color:var(--text-secondary);min-width:120px}.data-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:1rem}.data-item{background:#f9fafb;background:var(--light-bg);border-left:4px solid #4f46e5;border-left:4px solid var(--primary-color);border-radius:.5rem;padding:1rem}.data-item strong{color:#6b7280;color:var(--text-secondary);display:block;font-size:.875rem;margin-bottom:.5rem}.extracted-text pre{word-wrap:break-word;background:#f9fafb;background:var(--light-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;line-height:1.6;max-height:500px;overflow-y:auto;padding:1rem;white-space:pre-wrap}.upload-box{background:#fff;border:2px dashed #e5e7eb;border:2px dashed var(--border-color);border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:3rem;text-align:center;transition:all .3s ease}.upload-box:hover{background:#f9fafb;background:var(--light-bg);border-color:#4f46e5;border-color:var(--primary-color)}.file-info,.upload-box input[type=file]{margin:1.5rem 0}.file-info{background:#f9fafb;background:var(--light-bg);border-radius:.5rem;padding:1rem;text-align:left}.upload-help{background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin-top:1.5rem;padding:2rem}.upload-help h3{color:#111827;color:var(--text-primary);margin-bottom:1rem}.upload-help ul{list-style:none;padding:0}.upload-help li{padding:.5rem 0 .5rem 1.5rem;position:relative}.upload-help li:before{color:#10b981;color:var(--success-color);content:"✓";font-weight:700;left:0;position:absolute}.query-form{background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin-bottom:2rem;padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#111827;color:var(--text-primary);display:block;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select{border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:.5rem;font-size:1rem;max-width:500px;padding:.75rem;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#4f46e5;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a;outline:none}.query-result{animation:slideIn .3s ease;background:#fff;border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:2rem}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.query-result h2{color:#111827;color:var(--text-primary);font-size:1.5rem;margin-bottom:1rem}.query-result h3{color:#6b7280;color:var(--text-secondary);font-weight:400;margin-bottom:1.5rem}.query-result table{border-collapse:collapse;margin-top:1rem;width:100%}.query-result table td,.query-result table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:1rem;text-align:left}.query-result table th{background:#f9fafb;background:var(--light-bg);color:#111827;color:var(--text-primary);font-weight:600}.total{color:#10b981;color:var(--success-color);font-size:2rem;font-weight:700;margin-bottom:1.5rem}.connect-box,.sync-box{background:#fff;border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);padding:3rem;text-align:center}.connect-box p,.sync-box p{color:#6b7280;color:var(--text-secondary);font-size:1.125rem;margin-bottom:1.5rem}.connect-button{background:linear-gradient(135deg,#ea4335,#db4437);border:none;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:1rem 2.5rem;transition:all .3s ease}.connect-button:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.info{background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);margin-top:1.5rem;padding:2rem}.info h3{color:#111827;color:var(--text-primary);margin-bottom:1rem}.info ul{list-style:none;padding:0}.info li{color:#6b7280;color:var(--text-secondary);padding:.5rem 0 .5rem 1.5rem;position:relative}.info li:before{color:#4f46e5;color:var(--primary-color);content:"•";font-size:1.5rem;font-weight:700;left:0;position:absolute}.message{animation:slideIn .3s ease;border-radius:.5rem;font-weight:500;margin-top:1rem;padding:1rem 1.5rem}.message.success{background:#10b9811a;border-left:4px solid #10b981;border-left:4px solid var(--success-color);color:#10b981;color:var(--success-color)}.message.error{background:#ef44441a;border-left:4px solid #ef4444;border-left:4px solid var(--danger-color);color:#ef4444;color:var(--danger-color)}.success{color:#10b981;color:var(--success-color);font-weight:600}.loading{color:#fff;font-size:1.25rem;padding:4rem 2rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin:0 auto 1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error{background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#ef4444;color:var(--danger-color);padding:2rem}.error,.no-data{text-align:center}.no-data{color:#6b7280;color:var(--text-secondary);font-size:1.125rem;padding:3rem 2rem}.total-count{color:#fff;font-size:1.125rem;font-weight:500;margin-bottom:1rem}.actions{display:flex;gap:1rem;margin-top:2rem}@media (max-width:768px){.nav-links{gap:.25rem}.nav-links a{font-size:.875rem;padding:.375rem .75rem}.container{padding:0 1rem}h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.filters{flex-direction:column}.filter-group{width:100%}.transaction-table{font-size:.875rem}.transaction-table td,.transaction-table th{padding:.75rem .5rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .5s ease}.graph-container{background:#fff;border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);margin-bottom:2rem;padding:2rem}.graph-canvas{border:2px solid #e5e7eb;border:2px solid var(--border-color);height:600px;width:100%}.graph-canvas,.graph-legend{background:#f9fafb;background:var(--light-bg);border-radius:.5rem}.graph-legend{display:flex;flex-wrap:wrap;gap:2rem;margin-top:1rem;padding:1rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-dot{border-radius:50%;height:12px;width:12px}.graph-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:1rem}.graph-stat-item{background:#f9fafb;background:var(--light-bg);border-radius:.5rem;padding:1rem;text-align:center}.graph-stat-item strong{color:#4f46e5;color:var(--primary-color);display:block;font-size:1.5rem;margin-bottom:.25rem}.graph-stat-item span{color:#6b7280;color:var(--text-secondary);font-size:.875rem}
/*# sourceMappingURL=main.1e177056.css.map*/