.empty-state-container{display:flex;align-items:center;justify-content:center;min-height:50vh;padding:32px 16px}.empty-state-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:48px 40px;max-width:560px;width:100%;text-align:center;transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.empty-state-card.dragging{border-color:#3b82f6;background:#f0f9ff;transform:scale(1.01)}.empty-state-icon{margin:0 auto 32px;color:#6b7280;display:flex;justify-content:center;align-items:center}.empty-state-content{margin-bottom:32px}.empty-state-headline{font-size:24px;font-weight:600;color:#111827;margin:0 0 24px;line-height:1.3;letter-spacing:-.01em}.upload-info-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:0}.upload-info-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:16px;text-align:left}.upload-info-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.upload-info-value{font-size:14px;color:#374151;font-weight:500}.empty-state-actions{margin-bottom:24px}.empty-state-button{padding:14px 32px;font-size:15px;font-weight:600;border-radius:10px;cursor:pointer;transition:all .2s ease;border:none;min-width:200px}.empty-state-button.primary{background:#111827;color:#fff}.empty-state-button.primary:hover{background:#000;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.empty-state-button.primary:active{transform:translateY(0)}.privacy-badge-row{display:flex;justify-content:center;gap:24px;flex-wrap:wrap}.privacy-badge-item{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280;font-weight:500}.privacy-badge-item svg{color:#10b981;flex-shrink:0}@media (max-width: 768px){.empty-state-container{min-height:40vh;padding:24px 16px}.empty-state-card{padding:32px 24px}.empty-state-headline{font-size:20px;margin-bottom:20px}.upload-info-cards{grid-template-columns:1fr;gap:10px}.empty-state-button{width:100%}.privacy-badge-row{flex-direction:column;gap:12px;align-items:center}}.data-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.data-modal{background:#fff;border:1px solid #ccc;border-radius:4px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 4px 12px #00000026}.data-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.data-modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#333}.data-modal-close{background:none;border:none;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#666;line-height:1}.data-modal-close:hover{color:#333}.data-modal-content{padding:1.5rem}.data-explanation h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#333}.data-explanation p{margin:0 0 1.5rem;color:#666;line-height:1.6}.process-steps{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}.process-step{display:flex;gap:1rem;align-items:flex-start}.step-number{width:32px;height:32px;border-radius:50%;background:#4a90e2;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.step-content{flex:1}.step-content strong{display:block;margin-bottom:.5rem;color:#333;font-size:1rem}.step-content p{margin:0 0 .5rem;color:#666;font-size:.875rem}.step-content ul{margin:.5rem 0 0 1.5rem;padding:0;color:#666;font-size:.875rem}.step-content li{margin:.25rem 0}.data-tabs{display:flex;gap:.5rem;margin:2rem 0 1rem;border-bottom:1px solid #e0e0e0}.data-tab{padding:.75rem 1rem;background:none;border:none;border-bottom:2px solid transparent;font-weight:500;cursor:pointer;font-size:.875rem;color:#666;transition:all .2s}.data-tab:hover{color:#333}.data-tab.active{color:#4a90e2;border-bottom-color:#4a90e2}.data-preview{margin-top:1rem}.data-preview-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f5f5f5;border:1px solid #e0e0e0;border-bottom:none;font-weight:600;font-size:.875rem;color:#333}.copy-button{padding:.25rem .75rem;background:#fff;color:#4a90e2;border:1px solid #4a90e2;border-radius:4px;font-weight:500;cursor:pointer;font-size:.75rem;transition:all .2s}.copy-button:hover{background:#4a90e2;color:#fff}.data-preview-content{background:#fafafa;border:1px solid #e0e0e0;padding:1rem;overflow-x:auto;font-size:.75rem;line-height:1.5;font-family:Courier New,monospace;max-height:400px;overflow-y:auto;margin:0;color:#333}.data-preview-empty{padding:2rem;text-align:center;color:#999;font-style:italic}.data-preview-summary{padding:1rem;background:#f9f9f9;border:1px solid #e0e0e0;border-top:none;font-size:.875rem}.data-preview-summary h4{margin:1rem 0 .5rem;font-size:.875rem;font-weight:600;color:#333}.data-preview-summary h4:first-child{margin-top:0}.data-preview-summary ul{margin:.5rem 0 1rem 1.5rem;padding:0}.data-preview-summary li{margin:.25rem 0;color:#666}.data-preview-summary p{margin:0;color:#666}.data-modal-footer{margin-top:2rem;padding:1rem;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:4px;font-size:.875rem;color:#666}.data-modal-footer code{background:#fff;padding:.125rem .25rem;border:1px solid #e0e0e0;border-radius:4px;font-family:Courier New,monospace;font-size:.8125rem}@media (max-width: 768px){.data-modal{max-width:100%;max-height:95vh}.data-modal-header{padding:1rem}.data-modal-header h2{font-size:1.25rem}.data-modal-content{padding:1rem}.process-steps{gap:1rem}.data-preview-content{font-size:.625rem;max-height:300px}.data-tabs{flex-direction:column}.data-tab{width:100%;text-align:left}}.chat-section{margin:0 0 1.5rem;padding:1.5rem;background:#fff;border:2px solid #000000;border-radius:12px;box-shadow:0 4px 15px #0000001a;display:flex;flex-direction:column;height:100%;max-height:700px;width:100%}.chat-section h2{margin:0 0 1rem;font-size:1.5rem;font-weight:700;color:#111827;letter-spacing:-.02em}.chat-privacy-banner{padding:.5rem .75rem;background:#f5f5f5;border:1px solid #e0e0e0;border-left:3px solid #4a90e2;font-size:.75rem;margin-bottom:1rem;color:#666;border-radius:4px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.privacy-banner-content{line-height:1.4;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.privacy-banner-content strong{font-weight:600;color:#333}.privacy-verify-link{font-weight:600;color:#4a90e2;background:none;border:none;text-decoration:underline;cursor:pointer;padding:0;font-size:.75rem;white-space:nowrap}.privacy-verify-link:hover{color:#357abd}.super-prompts-container{margin-bottom:1.5rem}.super-prompts-label{font-size:.875rem;font-weight:600;margin-bottom:.75rem;color:#666}.super-prompts-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.super-prompt-button{padding:.625rem 1rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:20px;color:#333;font-weight:500;cursor:pointer;font-size:.8125rem;text-align:center;transition:all .2s;white-space:nowrap}.super-prompt-button:hover:not(:disabled){background:#e8f0fe;border-color:#4a90e2;color:#4a90e2;transform:translateY(-1px)}.super-prompt-button:disabled{opacity:.5;cursor:not-allowed}.chat-placeholder{padding:3rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.chat-placeholder-icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#111827,#1f2937);color:#10b981;display:flex;align-items:center;justify-content:center;border:2px solid #000000;filter:drop-shadow(0 0 8px rgba(16,185,129,.4))}.chat-placeholder-text{font-size:1.125rem;font-weight:600;color:#111827;margin:0}.chat-privacy-note{font-size:.875rem;color:#6b7280;margin-top:.5rem;padding:1rem;background:#f9fafb;border:2px solid #000000;border-radius:8px;max-width:600px;line-height:1.6}.chat-privacy-note strong{color:#111827;font-weight:700}.chat-messages{flex:1;overflow-y:auto;border:1px solid #e0e0e0;border-radius:4px;padding:1rem;margin-bottom:1rem;background:#fafafa;display:flex;flex-direction:column;gap:1rem;min-height:200px}.chat-message{display:flex;flex-direction:column;gap:.5rem}.chat-message.user{align-items:flex-end}.chat-message.assistant{align-items:flex-start}.message-role-label{font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.chat-message.user .message-role-label{text-align:right}.message-content{max-width:80%;padding:1rem 1.25rem;border:1px solid #e0e0e0;background:#fff;border-radius:4px;font-size:.875rem;line-height:1.7;word-wrap:break-word}.message-content strong{font-weight:700}.message-content .message-list-item{margin:.5rem 0;padding-left:.5rem}.message-content>div:first-child{margin-top:0}.message-content>div:last-child{margin-bottom:0}.chat-message.user .message-content{background:#4a90e2;color:#fff;border-color:#4a90e2}.chat-message.assistant .message-content{background:#fff;color:#333;border-color:#e0e0e0}.loading-dots{display:inline-flex;gap:.25rem}.loading-dots span{animation:blink 1.4s infinite;animation-fill-mode:both}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.3}40%{opacity:1}}.chat-input-container{display:flex;gap:.5rem;align-items:flex-end;position:sticky;bottom:0;background:#fff;padding-top:.5rem;border-top:1px solid #e0e0e0;margin-top:auto}.chat-input{flex:1;padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:.875rem;resize:none;min-height:50px;max-height:120px;transition:all .2s;line-height:1.5}.chat-input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.chat-input::placeholder{color:#999}.chat-send-button{padding:.875rem 1.5rem;background:#4a90e2;color:#fff;border:2px solid #4a90e2;border-radius:8px;font-weight:600;cursor:pointer;font-size:.875rem;white-space:nowrap;transition:all .2s;min-height:50px;display:flex;align-items:center;justify-content:center}.chat-send-button:hover:not(:disabled){background:#357abd;border-color:#357abd;transform:translateY(-1px);box-shadow:0 2px 4px #4a90e233}.chat-send-button:active:not(:disabled){transform:translateY(0)}.chat-send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.chat-section{padding:1rem}.chat-messages{max-height:300px}.message-content{max-width:85%;font-size:.8125rem}.chat-input-container{flex-direction:column}.chat-send-button{width:100%}}.category-trends-section{margin:0 0 1.5rem;padding:1.5rem;border:2px solid #000;background:#fff}.category-trends-section h2{margin:0 0 1rem;font-size:1.25rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding-bottom:.75rem;border-bottom:2px solid #000}@media (min-width: 768px){.category-trends-section{padding:2rem;margin-bottom:2rem}.category-trends-section h2{font-size:1.5rem;margin-bottom:1.25rem;padding-bottom:1rem}}.trends-subtitle{margin:0 0 1rem;font-size:.875rem;color:#666}.trends-chart{width:100%;margin-top:1rem}@media (max-width: 768px){.category-trends-section{padding:1rem}.trends-chart{height:250px}}.spending-velocity-section{background:#fff;border:2px solid #000000;border-radius:12px;padding:24px;margin-bottom:24px}.spending-velocity-title{font-size:18px;font-weight:600;color:#111827;margin:0 0 20px;letter-spacing:-.01em}.velocity-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}.velocity-card{grid-column:span 1}@media (max-width: 1024px){.velocity-grid{grid-template-columns:repeat(2,1fr)}}.velocity-card{background:#fff;border:2px solid #000000;border-radius:10px;padding:20px;text-align:center;transition:all .2s ease}.velocity-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.velocity-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.velocity-value{font-size:24px;font-weight:700;color:#111827;font-variant-numeric:tabular-nums}.velocity-note{font-size:13px;color:#6b7280;text-align:center;font-weight:500}@media (max-width: 768px){.spending-velocity-section{padding:20px}.velocity-grid{grid-template-columns:1fr}.velocity-card{padding:16px}.velocity-value{font-size:20px}}.top-merchants-section{background:transparent;border:none;border-radius:0;padding:0;margin-bottom:0;width:100%}.top-merchants-title{font-size:18px;font-weight:600;color:#111827;margin:0 0 20px;letter-spacing:-.01em}.top-merchants-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;width:100%}@media (max-width: 1024px){.top-merchants-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.top-merchants-grid{grid-template-columns:1fr}}.top-merchant-card{background:#fff;border:2px solid #000000;border-radius:10px;padding:16px;display:flex;align-items:flex-start;gap:16px;transition:all .2s ease}.top-merchant-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.top-merchant-rank{flex-shrink:0}.top-merchant-rank-number{width:40px;height:40px;background:#111827;color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.top-merchant-content{flex:1;min-width:0}.top-merchant-name{font-size:15px;font-weight:600;color:#111827;margin-bottom:8px;word-break:break-word}.top-merchant-details{display:flex;flex-direction:column;gap:4px}.top-merchant-amount{font-size:18px;font-weight:700;color:#111827;font-variant-numeric:tabular-nums}.top-merchant-count{font-size:12px;color:#6b7280;font-weight:500}@media (max-width: 768px){.top-merchants-section{padding:20px}.top-merchants-grid{grid-template-columns:1fr}.top-merchant-card{padding:14px}}.monthly-comparison-section{background:#fff;border:2px solid #000000;border-radius:12px;padding:24px;margin-bottom:24px}.monthly-comparison-title{font-size:18px;font-weight:600;color:#111827;margin:0 0 20px;letter-spacing:-.01em}.monthly-comparison-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-bottom:20px}.monthly-comparison-card{background:#fff;border:2px solid #000000;border-radius:10px;padding:20px;transition:all .2s ease}.monthly-comparison-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.monthly-comparison-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.monthly-comparison-month{font-size:16px;font-weight:600;color:#111827}.monthly-comparison-details{display:flex;flex-direction:column;gap:12px}.monthly-comparison-row{display:flex;justify-content:space-between;align-items:center}.monthly-comparison-row.net{padding-top:12px;border-top:2px solid #000000;margin-top:4px}.monthly-comparison-label{font-size:13px;font-weight:500;color:#6b7280}.monthly-comparison-value{font-size:15px;font-weight:600;font-variant-numeric:tabular-nums}.monthly-comparison-value.income{color:#10b981}.monthly-comparison-value.expense{color:#ef4444}.monthly-comparison-value.net{font-size:18px;font-weight:700}.monthly-comparison-value.net.positive{color:#10b981}.monthly-comparison-value.net.negative{color:#ef4444}.monthly-comparison-total-card{background:#111827;border:2px solid #000000;border-radius:10px;padding:20px;color:#fff}.monthly-comparison-total-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.2)}.monthly-comparison-total-label{font-size:18px;font-weight:700;color:#fff}.monthly-comparison-total-details{display:flex;flex-direction:column;gap:12px}.monthly-comparison-total-card .monthly-comparison-label{color:#ffffffb3}.monthly-comparison-total-card .monthly-comparison-value.income{color:#34d399}.monthly-comparison-total-card .monthly-comparison-value.expense{color:#f87171}.monthly-comparison-total-card .monthly-comparison-value.net.positive{color:#34d399}.monthly-comparison-total-card .monthly-comparison-value.net.negative{color:#f87171}.monthly-comparison-total-card .monthly-comparison-row.net{border-top-color:#fff3}@media (max-width: 768px){.monthly-comparison-section{padding:20px}.monthly-comparison-grid{grid-template-columns:1fr}.monthly-comparison-card{padding:16px}}.chart-container{background:transparent;border-radius:0;border:none;padding:0;margin-bottom:0;box-shadow:none;display:flex;flex-direction:column}.chart-title{font-size:13px;margin:0 0 8px;color:#111827;font-weight:600;letter-spacing:-.01em;padding-bottom:8px;border-bottom:1px solid #e5e7eb}@media (min-width: 768px){.chart-container{padding:24px;margin-bottom:24px}.chart-title{font-size:16px;margin-bottom:20px;padding-bottom:16px}}@media (max-width: 768px){.chart-container{padding:16px;margin-bottom:16px}.chart-title{font-size:14px;margin-bottom:16px;padding-bottom:12px}}.data-inspection-container{background:#fff;border:2px solid #000000;border-radius:12px;overflow:hidden}.data-inspection-header{padding:20px 24px;border-bottom:2px solid #000000;background:#fff}.data-inspection-header-content{display:flex;align-items:center;gap:12px}.data-inspection-icon{color:#111827;flex-shrink:0;display:flex;align-items:center}.data-inspection-title{font-size:18px;font-weight:600;color:#111827;margin:0;letter-spacing:-.01em}.data-inspection-tabs{display:flex;border-bottom:2px solid #000000;background:#fff}.data-inspection-tab{flex:1;padding:14px 20px;background:#fff;border:none;border-right:2px solid #000000;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}.data-inspection-tab:last-child{border-right:none}.data-inspection-tab:hover{background:#f9fafb;color:#374151}.data-inspection-tab.active{background:#111827;color:#fff}.data-inspection-tab.active:hover{background:#000}.data-inspection-tab svg{flex-shrink:0}.data-inspection-content-area{padding:24px;background:#fff}.data-inspection-banner{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;border:2px solid #000000;border-radius:10px;margin-bottom:20px}.data-inspection-banner.success{background:#f0fdf4;border-left:4px solid #10b981}.data-inspection-banner.warning{background:#fffbeb;border-left:4px solid #f59e0b}.data-inspection-banner-icon{flex-shrink:0;margin-top:2px}.data-inspection-banner.success .data-inspection-banner-icon{color:#10b981}.data-inspection-banner.warning .data-inspection-banner-icon{color:#f59e0b}.data-inspection-banner-content{flex:1}.data-inspection-banner-title{font-size:14px;font-weight:600;color:#111827;margin-bottom:4px}.data-inspection-banner-text{font-size:13px;color:#374151;line-height:1.5}.data-inspection-json-section{border:2px solid #000000;border-radius:10px;margin-bottom:20px;overflow:hidden}.data-inspection-json-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#111827;color:#fff;border-bottom:2px solid #000000}.data-inspection-json-label{font-size:14px;font-weight:600}.data-inspection-copy-button{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;color:#111827;border:1px solid #ffffff;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.data-inspection-copy-button:hover{background:#f9fafb;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.data-inspection-copy-button svg{flex-shrink:0}.data-inspection-json-code{padding:20px;margin:0;background:#f9fafb;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;line-height:1.6;color:#111827;overflow-x:auto;overflow-y:auto;max-height:400px}.data-inspection-lists-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}.data-inspection-list-card{border:2px solid #000000;border-radius:10px;padding:20px;background:#fff}.data-inspection-list-card.included{border-left:4px solid #10b981}.data-inspection-list-card.excluded{border-left:4px solid #ef4444}.data-inspection-list-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.data-inspection-list-card.included .data-inspection-list-header{color:#10b981}.data-inspection-list-card.excluded .data-inspection-list-header{color:#ef4444}.data-inspection-list-header svg{flex-shrink:0}.data-inspection-list-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.data-inspection-list{list-style:none;padding:0;margin:0}.data-inspection-list li{font-size:13px;color:#374151;padding:8px 0 8px 24px;position:relative;line-height:1.5}.data-inspection-list-card.included .data-inspection-list li:before{content:"✅";position:absolute;left:0}.data-inspection-list-card.excluded .data-inspection-list li:before{content:"❌";position:absolute;left:0}.data-inspection-notice{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;background:#f9fafb;border:2px solid #000000;border-radius:10px;border-left:4px solid #111827}.data-inspection-notice-icon{color:#111827;flex-shrink:0;margin-top:2px}.data-inspection-notice-text{font-size:13px;color:#374151;line-height:1.5}.data-inspection-notice-text strong{color:#111827;font-weight:600}.data-inspection-footer{display:flex;align-items:flex-start;gap:12px;padding:20px 24px;background:#f9fafb;border-top:2px solid #000000;border-left:4px solid #111827}.data-inspection-footer-icon{color:#111827;flex-shrink:0;margin-top:2px}.data-inspection-footer-content{flex:1}.data-inspection-footer-title{font-size:14px;font-weight:600;color:#111827;margin-bottom:6px}.data-inspection-footer-text{font-size:13px;color:#374151;line-height:1.5}.data-inspection-code{background:#fff;border:1px solid #d1d5db;border-radius:4px;padding:2px 6px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;color:#111827}@media (max-width: 768px){.data-inspection-header{padding:16px 20px}.data-inspection-title{font-size:16px}.data-inspection-tabs{flex-direction:column}.data-inspection-tab{border-right:none;border-bottom:2px solid #000000}.data-inspection-tab:last-child{border-bottom:none}.data-inspection-content-area{padding:20px}.data-inspection-lists-grid{grid-template-columns:1fr}.data-inspection-json-code{font-size:11px;padding:16px;max-height:300px}.data-inspection-footer{padding:16px 20px}}.api-key-toggle-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000a}.api-key-toggle-button:hover{border-color:#9ca3af;background:#f9fafb;transform:translateY(-1px);box-shadow:0 2px 4px #0000000f}.api-key-toggle-button svg{flex-shrink:0;color:#6b7280}.api-key-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.api-key-modal{background:#fff;border:2px solid #000000;border-radius:12px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column}.api-key-modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:2px solid #000000}.api-key-modal-title{font-size:20px;font-weight:600;color:#111827;margin:0;letter-spacing:-.01em}.api-key-modal-close{width:32px;height:32px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s ease;flex-shrink:0}.api-key-modal-close:hover{border-color:#9ca3af;background:#f9fafb;color:#374151}.api-key-privacy-section{padding:24px;border-bottom:2px solid #000000}.privacy-card-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.privacy-card-icon{color:#10b981;flex-shrink:0;display:flex;align-items:center}.privacy-card-title{font-size:16px;font-weight:600;color:#111827}.privacy-points-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.privacy-point-card{background:#f9fafb;border:2px solid #000000;border-radius:10px;padding:16px;display:flex;align-items:flex-start;gap:12px;transition:all .2s ease}.privacy-point-card:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000a}.privacy-point-icon{color:#10b981;flex-shrink:0;margin-top:2px}.privacy-point-content{flex:1}.privacy-point-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.privacy-point-value{font-size:13px;color:#374151;line-height:1.4}.api-key-input-section{padding:24px;border-bottom:2px solid #000000}.api-key-input-card{background:#fff;border:2px solid #000000;border-radius:10px;padding:20px}.api-key-label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:12px}.api-key-optional{font-weight:400;color:#6b7280}.api-key-input-wrapper{display:flex;align-items:center;gap:8px;margin-bottom:12px}.api-key-input{flex:1;padding:12px 16px;border:2px solid #000000;border-radius:8px;font-size:14px;color:#111827;background:#fff;font-family:Monaco,Menlo,Ubuntu Mono,monospace;transition:all .2s ease}.api-key-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.api-key-input::placeholder{color:#9ca3af}.api-key-toggle-visibility{width:40px;height:40px;border:2px solid #000000;border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s ease;flex-shrink:0}.api-key-toggle-visibility:hover{border-color:#9ca3af;background:#f9fafb;color:#374151}.api-key-help{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280}.api-key-help svg{flex-shrink:0;color:#9ca3af}.api-key-help a{color:#3b82f6;text-decoration:none;font-weight:500}.api-key-help a:hover{text-decoration:underline}.api-key-data-inspection{padding:24px;border-bottom:2px solid #000000}.data-inspection-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:#fff;border:2px solid #000000;border-radius:10px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease}.data-inspection-toggle:hover{border-color:#9ca3af;background:#f9fafb}.data-inspection-toggle svg:first-child{flex-shrink:0;color:#6b7280}.data-inspection-toggle svg:last-child{flex-shrink:0;color:#6b7280;transition:transform .2s ease}.data-inspection-toggle svg.rotated{transform:rotate(180deg)}.data-inspection-content{margin-top:16px;padding:0;background:transparent;border:none;border-radius:0}.api-key-modal-actions{display:flex;justify-content:flex-end;gap:12px;padding:24px}.api-key-button{padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;min-width:100px}.api-key-button.cancel{background:#fff;color:#374151;border:2px solid #000000}.api-key-button.cancel:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px);box-shadow:0 2px 4px #0000000a}.api-key-button.save{background:#111827;color:#fff}.api-key-button.save:hover{background:#000;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.api-key-button:active{transform:translateY(0)}@media (max-width: 768px){.api-key-modal{max-width:100%;max-height:100vh;border-radius:0}.api-key-modal-header{padding:20px}.api-key-modal-title{font-size:18px}.api-key-privacy-section{padding:20px}.privacy-points-grid{grid-template-columns:1fr}.api-key-input-section,.api-key-data-inspection{padding:20px}.api-key-modal-actions{padding:20px;flex-direction:column-reverse}.api-key-button{width:100%}}.dashboard-container{width:100%;max-width:1400px;margin:0 auto;padding:32px;background:#f9fafb;box-sizing:border-box;overflow-x:hidden}@media (max-width: 768px){.dashboard-container{padding:16px}}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px;padding:20px 24px;background:linear-gradient(135deg,#111827,#1f2937);border:2px solid #000000;border-radius:12px;box-shadow:0 4px 12px #0000001f;position:relative;overflow:hidden}.dashboard-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6)}.dashboard-header-left{display:flex;align-items:center;gap:16px}.dashboard-header-right{display:flex;align-items:center;gap:12px}.advanced-mode-toggle{padding:10px 16px;border:2px solid rgba(255,255,255,.3);border-radius:10px;background:#ffffff1a;font-size:14px;cursor:pointer;color:#e5e7eb;transition:all .2s ease;font-weight:500;display:flex;align-items:center;gap:8px;box-shadow:0 2px 4px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.advanced-mode-toggle:hover{border-color:#ffffff80;background:#ffffff26;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.advanced-mode-toggle.active{background:#10b98133;color:#10b981;border-color:#10b981;box-shadow:0 0 12px #10b9814d}.advanced-mode-toggle.active:hover{background:#10b9814d;border-color:#10b981}.advanced-mode-toggle svg{flex-shrink:0}.parsing-badge{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:12px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 4px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.parsing-badge-icon{color:#10b981;flex-shrink:0;display:flex;align-items:center;filter:drop-shadow(0 0 4px rgba(16,185,129,.5))}.parsing-badge-content{flex:1}.parsing-badge-label{font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.parsing-badge-value{font-size:13px;font-weight:500;color:#e5e7eb}.time-range-filter{display:flex;justify-content:flex-end}.time-range-select{padding:10px 16px;border:2px solid rgba(255,255,255,.3);border-radius:10px;background:#ffffff1a;font-size:14px;cursor:pointer;color:#e5e7eb;transition:all .2s ease;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 4px #0000001a}.time-range-select:hover{border-color:#ffffff80;background:#ffffff26}.time-range-select:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b98133}.time-range-select option{background:#111827;color:#e5e7eb}.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.info-button{width:32px;height:32px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s ease;flex-shrink:0}.info-button:hover{border-color:#9ca3af;background:#f9fafb;color:#374151}.category-badge.clickable{cursor:pointer;transition:background-color .2s;padding:4px 8px;border-radius:6px}.category-badge.clickable:hover{background-color:#f3f4f6}.category-select{padding:4px 8px;border:1px solid #3b82f6;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.category-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #3b82f61a}.api-key-toggle{margin-bottom:16px}section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #0000000d}.section-title{font-size:16px;font-weight:600;color:#111827;margin:0 0 20px;letter-spacing:-.01em}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.kpi-section{padding:24px;background:linear-gradient(135deg,#111827,#1f2937);border:2px solid #000000;border-radius:12px;margin-bottom:24px;box-shadow:0 4px 12px #0000001f;position:relative;overflow:hidden}.kpi-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6)}.kpi-section .section-title{margin-bottom:20px;color:#fff}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;width:100%;min-width:0}@media (max-width: 1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:#fff;border:2px solid #000000;border-radius:10px;padding:20px;text-align:center;transition:all .2s ease;min-width:0;box-shadow:0 2px 4px #0000000f}.kpi-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.kpi-card.income-card{border-left:4px solid #10b981}.kpi-card.spending-card{border-left:4px solid #ef4444}.kpi-card.net-card{border-left:4px solid #6366f1}.kpi-label{font-size:12px;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-weight:600}.kpi-section .kpi-label{color:#9ca3af}.kpi-value{font-size:32px;font-weight:700;color:#111827;line-height:1.2;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.kpi-card.income-card .kpi-value{color:#10b981}.kpi-card.spending-card .kpi-value{color:#ef4444}.kpi-value.positive{color:#10b981}.kpi-value.negative{color:#ef4444}.kpi-value-small{font-size:14px;color:#6b7280;font-weight:400}.charts-row{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px;width:100%}@media (max-width: 1024px){.charts-row{grid-template-columns:1fr;gap:20px}}.charts-row .chart-section{min-width:0;flex:1 1 50%}.charts-row .chart-section.full-width{grid-column:1 / -1}@media (min-width: 769px){.charts-row{grid-template-columns:repeat(2,1fr)}}.chart-section{min-height:280px;padding:0;background:#fff;border:2px solid #000000;border-radius:12px;box-shadow:0 1px 2px #0000000a;overflow:hidden;display:flex;flex-direction:column;transition:all .2s ease}.chart-section.full-width{grid-column:1 / -1;min-height:320px}.chart-section:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000f}.chart-section .section-title-row,.chart-section .section-title-with-info,.chart-section .section-title{padding:12px 16px 8px;margin-bottom:0;border-bottom:1px solid #e5e7eb}.chart-section .section-title{font-size:14px;font-weight:600;color:#111827;margin:0}.chart-container{margin-top:0;width:100%;padding:8px 12px;display:flex;justify-content:flex-start;align-items:flex-start;flex:1;min-height:0}.chart-container>div{width:100%!important;margin-left:0;height:100%!important;min-height:350px}.filter-badge-card{display:flex;align-items:center;justify-content:space-between;margin-top:16px;margin-left:24px;margin-right:24px;padding:12px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;box-shadow:0 1px 2px #0000000a}.filter-badge-content{flex:1}.filter-badge-label{font-size:11px;font-weight:600;color:#1e40af;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.filter-badge-value{font-size:14px;font-weight:600;color:#1e40af}.filter-badge-close{background:none;border:none;cursor:pointer;color:#1e40af;padding:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease;flex-shrink:0}.filter-badge-close:hover{background:#dbeafe}.table-section{background:#fff;border:2px solid #000000;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 4px 12px #00000014;overflow-x:auto}.recurring-expenses-section{background:#fff;border:2px solid #000000;border-radius:12px;padding:24px;margin-bottom:24px}.recurring-expenses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.recurring-expense-card{background:#fff;border:2px solid #000000;border-radius:10px;padding:20px;transition:all .2s ease}.recurring-expense-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.recurring-expense-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.recurring-expense-icon{color:#111827;flex-shrink:0;display:flex;align-items:center}.recurring-expense-merchant{font-size:16px;font-weight:600;color:#111827;flex:1;word-break:break-word}.recurring-expense-details{display:flex;flex-direction:column;gap:12px}.recurring-expense-row{display:flex;justify-content:space-between;align-items:center}.recurring-expense-label{font-size:13px;font-weight:500;color:#6b7280}.recurring-expense-amount{font-size:18px;font-weight:700;color:#111827;font-variant-numeric:tabular-nums}.recurring-expense-date{font-size:14px;font-weight:500;color:#374151}@media (max-width: 768px){.recurring-expenses-section{padding:20px}.recurring-expenses-grid{grid-template-columns:1fr}.recurring-expense-card{padding:16px}}.table-filters{display:flex;gap:12px;align-items:center;margin-bottom:16px}.filter-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background:#fff;color:#374151;cursor:pointer;transition:all .2s ease}.filter-select:hover{border-color:#9ca3af}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-input{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;min-width:200px;transition:all .2s ease}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.table-container{margin-top:16px;overflow-x:auto;border:2px solid #000000;border-radius:10px;background:#fff}.data-table{width:100%;border-collapse:collapse;font-size:14px;background:#fff}.data-table thead{background:#111827;color:#fff;border-bottom:2px solid #000000}.data-table th{padding:14px 16px;text-align:left;font-weight:600;color:#fff;font-size:12px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-bottom:2px solid #000000}.data-table th.text-right{text-align:right}.data-table td{padding:14px 16px;border-bottom:1px solid #e5e7eb;color:#374151}.data-table td.text-right{text-align:right}.data-table tbody tr{transition:background .15s ease;border-bottom:1px solid #f3f4f6}.data-table tbody tr:hover{background:#f9fafb}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:last-child td{border-bottom:none}.description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-badge{display:inline-block;padding:4px 10px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;font-size:12px;color:#374151;font-weight:500}.amount-cell{font-weight:600;font-variant-numeric:tabular-nums}.amount-cell.positive{color:#10b981;font-weight:600}.amount-cell.negative{color:#ef4444;font-weight:600}.amount-cell.income{color:#10b981;font-weight:600}.amount-cell.expense{color:#ef4444;font-weight:600}.empty-state{text-align:center;padding:48px 24px;color:#9ca3af;font-size:14px}.advanced-charts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px;width:100%;min-width:0}@media (max-width: 1400px){.advanced-charts-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1024px){.advanced-charts-grid{grid-template-columns:repeat(2,1fr);gap:12px}}@media (max-width: 768px){.advanced-charts-grid{grid-template-columns:1fr;gap:16px}}.advanced-charts-grid .chart-section.full-width{grid-column:1 / -1}.chat-section-below-hero{margin-bottom:32px;width:100%;display:block;visibility:visible}.settings-section-top{margin-bottom:24px;width:100%}.settings-section{margin:24px 0;padding:0;background:transparent;border:none;box-shadow:none}@media (max-width: 1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-row{grid-template-columns:1fr}}@media (max-width: 768px){.dashboard-container{padding:16px}.kpi-grid{grid-template-columns:1fr;gap:16px}.kpi-value{font-size:24px}.charts-row{grid-template-columns:1fr;gap:16px;margin-left:0;margin-right:0}.charts-row .chart-section{width:100%}.chart-section{min-height:350px;width:100%;margin-left:0;margin-right:0;padding:0}.chart-section .section-title-with-info,.chart-section .section-title{padding:16px 16px 12px;font-size:14px}.chart-container{width:100%;margin-left:0;margin-right:0;padding:8px;overflow-x:auto}.chart-container>div{width:100%!important;min-width:100%!important;min-height:300px!important}.section-header{flex-direction:column;align-items:flex-start;gap:16px}.table-filters{flex-direction:column;width:100%}.filter-select,.search-input{width:100%}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{font-size:13px;min-width:600px}.data-table th,.data-table td{padding:10px 12px}.description-cell{max-width:200px}.advanced-charts-grid{grid-template-columns:1fr;gap:16px;width:100%;margin-top:20px}.dashboard-header-right{flex-direction:column;align-items:flex-end;width:100%}.advanced-mode-toggle{width:100%;text-align:center}}.privacy-policy-page{min-height:100vh;padding:2rem 1rem;background:#f9fafb}.privacy-policy-container{max-width:800px;margin:0 auto;padding:2rem;border:2px solid #000000;background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a}.privacy-close-btn{margin-bottom:2rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#111827,#1f2937);color:#fff;border:2px solid #000000;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}.privacy-close-btn:hover{background:linear-gradient(135deg,#1f2937,#374151);transform:translateY(-2px);box-shadow:0 4px 8px #0003}.privacy-policy-container h1{font-size:2.5rem;font-weight:800;color:#111827;margin:0 0 .5rem;letter-spacing:-.03em}.privacy-section{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid #e5e7eb}.privacy-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.privacy-section h2{font-size:1.75rem;font-weight:700;color:#111827;margin:0 0 1rem;letter-spacing:-.02em}.privacy-section h3{font-size:1.25rem;font-weight:600;color:#111827;margin:1.5rem 0 .75rem}.privacy-section p{font-size:1rem;line-height:1.7;color:#374151;margin:0 0 1rem}.privacy-section ul{margin:1rem 0;padding-left:1.5rem}.privacy-section li{font-size:1rem;line-height:1.7;color:#374151;margin-bottom:.75rem}.privacy-section a{color:#3b82f6;text-decoration:underline;font-weight:600}.privacy-section a:hover{color:#2563eb}@media (max-width: 640px){.privacy-policy-container{padding:1.5rem}.privacy-policy-container h1{font-size:2rem}.privacy-section h2{font-size:1.5rem}.privacy-section h3{font-size:1.1rem}.privacy-section p,.privacy-section li{font-size:.95rem}}.how-it-works-page{min-height:100vh;padding:2rem 1rem;background:#f9fafb}.how-it-works-container{max-width:800px;margin:0 auto;padding:2rem;border:2px solid #000000;background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a}.how-it-works-back-btn{margin-bottom:2rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#111827,#1f2937);color:#fff;border:2px solid #000000;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}.how-it-works-back-btn:hover{background:linear-gradient(135deg,#1f2937,#374151);transform:translateY(-2px);box-shadow:0 4px 8px #0003}.how-it-works-container h1{font-size:2.5rem;font-weight:800;color:#111827;margin:0 0 .5rem;letter-spacing:-.03em}.last-updated{color:#6b7280;font-size:1rem;margin:0 0 2.5rem;font-weight:500}.how-it-works-section{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid #e5e7eb}.how-it-works-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.how-it-works-icon{width:64px;height:64px;border-radius:12px;background:linear-gradient(135deg,#111827,#1f2937);color:#10b981;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;border:2px solid #000000}.how-it-works-section h2{font-size:1.75rem;font-weight:700;color:#111827;margin:0 0 1rem;letter-spacing:-.02em}.how-it-works-section p{font-size:1rem;line-height:1.7;color:#374151;margin:0 0 1rem}.how-it-works-section ul,.how-it-works-section ol{margin:1rem 0;padding-left:1.5rem}.how-it-works-section li{font-size:1rem;line-height:1.7;color:#374151;margin-bottom:.75rem}.how-it-works-section li strong{color:#111827;font-weight:600}.how-it-works-section a{color:#3b82f6;text-decoration:underline;font-weight:600}.how-it-works-section a:hover{color:#2563eb}@media (max-width: 640px){.how-it-works-container{padding:1.5rem}.how-it-works-container h1{font-size:2rem}.how-it-works-section h2{font-size:1.5rem}.how-it-works-icon{width:56px;height:56px}.how-it-works-section p,.how-it-works-section li{font-size:.95rem}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;color:#1a1a1a;line-height:1.5;font-size:14px}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#111827,#1f2937);border-bottom:4px solid;border-image:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6) 1;padding:32px;text-align:center;box-shadow:0 4px 12px #0000001a}.app-header h1{font-size:36px;font-weight:800;color:#fff;margin:0;letter-spacing:-.03em;text-shadow:0 2px 4px rgba(0,0,0,.2)}.app-main{flex:1;padding:40px 32px;background:#fff}.hero-section{max-width:900px;margin:0 auto 48px;padding:0}.hero-content{background:linear-gradient(135deg,#111827,#1f2937);border:2px solid #000000;border-radius:16px;padding:48px 40px;text-align:center;box-shadow:0 8px 24px #0000001f;position:relative;overflow:hidden}.hero-content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6)}.hero-brand{font-size:14px;font-weight:700;color:#10b981;text-transform:uppercase;letter-spacing:.15em;margin-bottom:16px;display:inline-block;padding:6px 16px;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:8px}.hero-title{font-size:42px;font-weight:800;color:#fff;margin:0 0 12px;letter-spacing:-.03em;line-height:1.2;text-shadow:0 2px 4px rgba(0,0,0,.2)}.hero-subtitle{font-size:24px;font-weight:600;color:#e5e7eb;margin:0 0 8px;letter-spacing:-.02em;line-height:1.3}.hero-tagline{font-size:16px;color:#9ca3af;margin:0 0 32px;font-weight:400}.hero-button-container{display:flex;justify-content:center;align-items:center;padding:24px;background:#fff;border:2px solid #000000;border-radius:12px;margin-top:24px}.hero-upload-button{display:flex;align-items:center;gap:12px;padding:16px 32px;background:#111827;color:#fff;border:2px solid #111827;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #00000026}.hero-upload-button:hover{background:#000;border-color:#000;transform:translateY(-2px);box-shadow:0 6px 16px #0003}.hero-upload-button:active{transform:translateY(0)}.hero-upload-button svg{flex-shrink:0}.intro-section{max-width:900px;margin:0 auto 64px}.intro-card{background:linear-gradient(135deg,#111827,#1f2937);border:2px solid #000000;border-radius:16px;padding:48px 40px;margin-bottom:24px;text-align:center;box-shadow:0 8px 24px #0000001f;position:relative;overflow:hidden}.intro-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6)}.intro-headline{font-size:36px;font-weight:700;color:#fff;margin:0;letter-spacing:-.03em;line-height:1.2;text-shadow:0 2px 4px rgba(0,0,0,.2)}.trust-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.trust-card{background:#fff;border:2px solid #000000;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 2px 4px #0000000f}.trust-card:hover{border-color:#10b981;box-shadow:0 8px 16px #10b98126;transform:translateY(-2px)}.trust-card-icon{flex-shrink:0;color:#10b981;display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#f0fdf4;border-radius:12px;border:2px solid #10b981}.trust-card-content{flex:1}.trust-card-title{font-size:14px;font-weight:600;color:#374151;line-height:1.4}.privacy-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #10b981;border-radius:12px;padding:24px 28px;box-shadow:0 4px 12px #10b9811a}.privacy-card-content{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.privacy-card-title{font-size:16px;font-weight:700;color:#166534;letter-spacing:-.01em}.privacy-card-badges{display:flex;gap:8px;flex-wrap:wrap}.privacy-badge{background:#fff;border:2px solid #10b981;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:700;color:#166534;box-shadow:0 2px 4px #10b9811a}.processing-section{display:flex;align-items:center;justify-content:center;min-height:50vh;padding:32px}.processing-card{background:#fff;border:2px solid #000000;border-radius:12px;padding:48px 40px;text-align:center;box-shadow:0 1px 3px #0000000d;max-width:400px;width:100%}.processing-spinner{margin-bottom:24px}.spinner{width:48px;height:48px;border:3px solid #f3f4f6;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.processing-label{font-size:16px;font-weight:600;color:#111827;margin-bottom:8px}.processing-subtext{font-size:14px;color:#6b7280}.error-section{display:flex;align-items:center;justify-content:center;min-height:50vh;padding:32px}.error-card{background:#fff;border:2px solid #fecaca;border-radius:12px;padding:32px;text-align:center;box-shadow:0 1px 3px #0000000d;max-width:500px;width:100%}.error-label{font-size:14px;font-weight:600;color:#991b1b;margin-bottom:12px;text-transform:uppercase;letter-spacing:.05em}.error-message{font-size:15px;color:#991b1b;margin-bottom:24px;line-height:1.5}.retry-button{padding:12px 24px;background:#3b82f6;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-button:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px #3b82f633}.retry-button:active{transform:translateY(0)}.app-footer{background:linear-gradient(135deg,#111827,#1f2937);border-top:4px solid;border-image:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6) 1;padding:48px 32px;margin-top:auto;position:relative;overflow:hidden}.footer-content{max-width:900px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:32px}.footer-privacy-section{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:700px}.footer-privacy-icon{width:56px;height:56px;border-radius:50%;background:#10b98133;border:2px solid rgba(16,185,129,.5);color:#10b981;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 0 8px rgba(16,185,129,.4))}.footer-privacy-title{font-size:20px;font-weight:700;color:#fff;margin:0;letter-spacing:-.02em}.footer-privacy-text{font-size:15px;color:#d1d5db;line-height:1.6;margin:0;max-width:600px}.footer-links{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.footer-link{color:#9ca3af;text-decoration:none;font-size:14px;transition:color .2s ease;font-weight:500}.footer-link:hover{color:#fff}.footer-separator{color:#4b5563;font-size:14px}.footer-copyright{font-size:13px;color:#6b7280;margin:0;font-weight:500}@media (max-width: 768px){.app-header{padding:24px 16px}.app-footer{padding:40px 24px}.footer-content{gap:24px}.footer-privacy-section{gap:12px}.footer-privacy-icon{width:48px;height:48px}.footer-privacy-title{font-size:18px}.footer-privacy-text{font-size:14px}.footer-links{flex-direction:column;gap:8px}.footer-separator{display:none}.app-header h1{font-size:28px}.app-main{padding:24px 16px}.hero-section{margin-bottom:32px}.hero-content{padding:32px 24px}.hero-title{font-size:32px}.hero-subtitle{font-size:20px}.hero-tagline{font-size:14px}.hero-button-container{padding:20px}.hero-upload-button{padding:14px 24px;font-size:15px;width:100%;justify-content:center}.intro-section{margin-bottom:48px}.intro-card{padding:32px 24px}.intro-headline{font-size:28px}.trust-cards-grid{grid-template-columns:1fr;gap:16px}.trust-card{padding:20px}.trust-card-icon{width:40px;height:40px}.privacy-card{padding:20px}.privacy-card-content{flex-direction:column;align-items:flex-start}.privacy-card-title{font-size:15px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f9fafb;color:#1a1a1a;line-height:1.5;font-size:14px}#root{min-height:100vh}
