*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #3b82f6;--primary-dark: #2563eb;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--bg-main: #0f172a;--bg-card: #1e293b;--bg-elevated: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--border: #334155;--shadow: 0 1px 3px 0 rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .3)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg-main);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased}.container{max-width:100%;margin:0 auto;padding:12px;display:flex;flex-direction:column;gap:16px}header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:16px;margin-bottom:16px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}header h1{font-size:24px;color:var(--primary);display:flex;align-items:center;gap:8px}.main-grid{display:flex;flex-direction:column;gap:16px}.card{background:var(--bg-card);border-radius:12px;padding:16px;box-shadow:var(--shadow);border:1px solid var(--border)}.card h2{font-size:18px;margin-bottom:16px;color:var(--text-primary);display:flex;align-items:center;gap:8px;font-weight:600}.expense-breakdown{background:var(--bg-elevated);border-radius:8px;padding:16px;margin-top:16px}.expense-category{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--bg-card);border-radius:8px;margin-bottom:8px;border:1px solid var(--border)}.category-label{display:flex;align-items:center;gap:8px;font-weight:500}.category-amount{font-weight:700;font-size:18px;color:var(--success)}.category-amount-neutral{font-weight:700;font-size:18px;color:var(--text-primary)}.expense-total{margin-top:12px;padding-top:12px;border-top:2px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:18px;font-weight:700}.expense-total .amount{color:var(--success);font-size:24px}.transaction-info{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}@media(min-width:768px){.transaction-info{grid-template-columns:repeat(4,1fr)}}.info-item{padding:10px;background:var(--bg-elevated);border-radius:8px;border:1px solid var(--border)}.info-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.info-value{font-size:16px;font-weight:600;color:var(--text-primary);margin-top:4px}.info-value.na{color:var(--text-secondary);font-size:13px;font-style:italic}.expense-business{background:#022c22;color:#34d399;border-color:#064e3b}.expense-personal{background:#450a0a;color:#fca5a5;border-color:#7f1d1d}.chat-container{display:flex;flex-direction:column;height:500px}.chat-messages{flex:1;overflow-y:auto;padding:16px;background:var(--bg-elevated);border-radius:8px;margin-bottom:16px;border:1px solid var(--border)}.chat-message{margin-bottom:16px;display:flex;gap:10px}.message-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:14px}.message-avatar.assistant{background:var(--success)}.message-content{flex:1;background:var(--bg-card);padding:12px 14px;border-radius:12px;box-shadow:var(--shadow);border:1px solid var(--border);font-size:14px;line-height:1.5;word-wrap:break-word}.message-content .chat-receipt-details{background:var(--bg-elevated);border-radius:8px;padding:12px;margin-top:8px;border:1px solid var(--border)}.message-content .chat-receipt-details h3{font-size:16px;color:var(--text-primary);margin-bottom:8px}.message-content .chat-receipt-details p{margin-bottom:4px;color:var(--text-secondary)}.message-content .chat-receipt-details .item{padding-left:16px;font-size:13px}.message-content .chat-receipt-details .item .business{color:var(--success);font-weight:600}.message-content .chat-receipt-details .item .personal{color:var(--warning);font-weight:600}.message-content .chat-receipt-details .chat-breakdown{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.message-content .chat-receipt-details .chat-breakdown-item{display:flex;justify-content:space-between;font-weight:600}.message-content .chat-receipt-details .chat-breakdown-total{margin-top:8px;padding-top:8px;border-top:1px solid var(--text-primary);display:flex;justify-content:space-between;font-size:16px;font-weight:700;color:var(--success)}.message-content.user{background:var(--bg-main)}.chat-input-container{display:flex;gap:8px;align-items:center}.attach-button{background:var(--bg-elevated);border:1px solid var(--border);width:48px;height:48px;border-radius:12px;font-size:20px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-primary)}.attach-button:active{background:var(--bg-card);transform:scale(.95)}.chat-input{flex:1;padding:14px 16px;border:1px solid var(--border);border-radius:12px;font-size:16px;font-family:inherit;background:var(--bg-elevated);color:var(--text-primary)}.chat-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f633}.chat-send{background:var(--primary);color:#fff;border:none;padding:14px 20px;border-radius:12px;cursor:pointer;font-weight:600;transition:background .2s;font-size:16px;font-family:inherit}.chat-send:active{background:var(--primary-dark);transform:scale(.98)}.chat-send:disabled{background:var(--text-secondary);cursor:not-allowed;opacity:.5}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:var(--bg-card)}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.year-selector{display:flex;align-items:center;gap:8px}.year-selector select{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:14px;cursor:pointer;font-family:inherit}.year-selector select:focus{outline:none;border-color:var(--primary)}.historical-badge{background:var(--warning);color:#000;font-size:11px;font-weight:700;padding:3px 8px;border-radius:12px}.export-panel{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.export-btn{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:8px;font-family:inherit}.export-btn:hover:not(:disabled){background:var(--primary);border-color:var(--primary)}.export-btn:disabled{opacity:.4;cursor:not-allowed}.export-error{font-size:12px;color:var(--danger);margin-top:8px}.skeleton{background:var(--bg-elevated);border-radius:8px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton-row{height:52px;margin-bottom:8px;border-radius:8px}.skeleton-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}@media(min-width:768px){.skeleton-grid{grid-template-columns:repeat(4,1fr)}}.skeleton-cell{height:64px;border-radius:8px}.error-text{color:var(--danger);font-size:14px;padding:8px 0}.header-selectors{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.month-selector select{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:14px;cursor:pointer;font-family:inherit}.month-selector select:focus{outline:none;border-color:var(--primary)}.browser-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}.browser-search{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;padding:7px 12px;font-size:14px;font-family:inherit;width:200px}.browser-search:focus{outline:none;border-color:var(--primary)}.filter-tabs{display:flex;gap:4px}.filter-tab{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;padding:5px 12px;font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s}.filter-tab:hover{border-color:var(--primary);color:var(--text-primary)}.filter-tab.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.receipt-count{font-size:13px;color:var(--text-secondary);margin-left:auto}.table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid var(--border)}.receipt-table{width:100%;border-collapse:collapse;font-size:13px}.receipt-table thead tr{background:var(--bg-elevated)}.receipt-table th{text-align:left;padding:10px 12px;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;white-space:nowrap;border-bottom:1px solid var(--border)}.receipt-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.receipt-table th.sortable:hover{color:var(--text-primary)}.receipt-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text-primary);white-space:nowrap}.receipt-row{cursor:pointer;transition:background .12s}.receipt-row:hover{background:var(--bg-elevated)}.receipt-detail-row td{padding:0;background:var(--bg-main)}.receipt-detail-panel{padding:14px 16px;border-bottom:1px solid var(--border)}.line-item-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:8px}.line-item-table th{text-align:left;padding:6px 10px;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.4px;font-weight:600;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.line-item-table td{padding:7px 10px;border-bottom:1px solid var(--border);color:var(--text-primary)}.badge-business{background:#022c22;color:#34d399;border:1px solid #064e3b;font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;white-space:nowrap}.badge-personal{background:#450a0a;color:#fca5a5;border:1px solid #7f1d1d;font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;white-space:nowrap}.delete-btn{background:transparent;border:none;cursor:pointer;font-size:16px;padding:4px 6px;border-radius:6px;transition:background .15s;line-height:1}.delete-btn:hover{background:#ef444426}.spending-chart-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.spending-chart-section h3{font-size:14px;color:var(--text-secondary);margin-bottom:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.receipt-image-wrap{margin-bottom:14px;text-align:center}.receipt-image-preview{max-width:100%;max-height:480px;border-radius:8px;border:1px solid var(--border);object-fit:contain;background:var(--bg-elevated)}
