*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#fff;min-height:100vh;padding:20px;color:#333}.container{max-width:1200px;margin:0 auto}header{color:#111827;margin-bottom:26px}.header-row{display:flex;justify-content:space-between;align-items:center}.header-row>div:first-child{text-align:left}header h1{font-size:2.6rem;margin-bottom:6px;letter-spacing:-.5px}header p{font-size:1.05rem;color:#4b5563}.header-user{display:flex;align-items:center;gap:14px}.user-name{font-size:1rem;font-weight:600;opacity:.95}.user-name-btn{background:var(--surface-bg);border:1px solid var(--border-soft);padding:8px 14px;border-radius:999px;cursor:pointer;color:var(--text-primary-neutral);font:inherit;font-weight:600;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease}.user-name-btn:hover{background:var(--surface-muted);border-color:var(--border-strong)}.user-name-btn-active{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}.user-name-btn-active:hover{background:#dbeafe;border-color:#60a5fa;box-shadow:0 0 0 1px #2563eb33}.brand-link{display:flex;align-items:center;gap:10px;background:none;border:none;padding:0;cursor:pointer;text-align:left;color:inherit}.brand-link:hover h1{color:#2563eb}.logout-btn{display:inline-flex;align-items:center;gap:6px;background:#fff;color:#2563eb;border:1px solid #bfdbfe;padding:8px 18px;border-radius:50px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .25s ease}.logout-btn:hover{background:#f4f6ff;border-color:#93c5fd}.theme-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid #bfdbfe;border-radius:50%;background:#fff;color:#64748b;cursor:pointer;transition:all .2s ease}.theme-icon-btn:hover{color:#2563eb;background:#eff6ff;border-color:#bfdbfe}.auth-theme-corner-btn{position:fixed;top:1rem;right:1rem;z-index:1000;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;border:none;border-radius:8px;background:transparent;color:#1e293b;cursor:pointer;transition:background .2s ease,color .2s ease}.auth-theme-corner-btn:hover{background:#0f172a0f}.auth-theme-corner-btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}body.theme-dark .auth-theme-corner-btn{color:#e2e8f0}body.theme-dark .auth-theme-corner-btn:hover{background:#ffffff14}.auth-loading-title{color:#111}body.theme-dark .auth-loading-title{color:#f1f5f9}main{background:#fff;border-radius:16px;padding:32px;box-shadow:0 10px 28px #0f172a0f}section{margin-bottom:40px}h2{color:#111827;margin-bottom:20px;font-size:1.8rem}.profile-section{margin-bottom:28px;max-width:100%}.profile-card{display:flex;align-items:center;gap:24px;background:linear-gradient(135deg,#f7f8ff,#eef1ff);border:1px solid #dbeafe;border-radius:16px;padding:24px;box-shadow:0 4px 14px #2563eb14}.profile-overview{margin-bottom:8px}.profile-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-size:1.5rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-details{flex:1;min-width:0}.profile-name{color:#111827;font-size:1.4rem;font-weight:700;margin-bottom:4px}.profile-email{color:#535774;font-size:.95rem;margin-bottom:16px}.profile-stats{display:flex;gap:24px;flex-wrap:wrap}.profile-stat{display:flex;flex-direction:column;gap:2px}.profile-stat-value{font-size:1.25rem;font-weight:700;color:#2563eb}.profile-stat-label{font-size:.8rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.profile-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:1px solid #e5e7eb}.profile-tab{padding:10px 20px;font-size:.95rem;font-weight:600;color:#6b7280;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;margin-bottom:-1px;transition:color .2s,border-color .2s}.profile-tab:hover{color:#374151}.profile-tab.active{color:#1d4ed8;border-bottom-color:#2563eb}.profile-cards-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}@media (max-width: 768px){.profile-cards-row{grid-template-columns:1fr}}.profile-detail-card{flex-direction:column;align-items:stretch;text-align:left;margin-bottom:0}.profile-form .required{color:#2563eb;font-weight:600}.profile-card-header{margin-bottom:16px}.profile-card-header h3{font-size:1rem;font-weight:700;color:#111827;margin-bottom:4px}.profile-card-subtitle{font-size:.875rem;color:#6b7280;margin:0;font-weight:400}.profile-detail-section{background:linear-gradient(135deg,#f7f8ff,#eef1ff);border:1px solid #dbeafe;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 2px 8px #2563eb0f}.profile-theme-section{border-color:#2563eb40;background:linear-gradient(135deg,#f0f4ff,#e8eeff);box-shadow:0 2px 8px #2563eb14}.profile-theme-toggle-wrap{display:flex;align-items:center}.profile-theme-toggle{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:8px;border:1px solid rgba(37,99,235,.3);background:#ffffffb3;color:#2563eb;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.profile-theme-toggle:hover{background:#2563eb14;border-color:#2563eb80;color:#1d4ed8}.profile-detail-section h3{font-size:.95rem;font-weight:600;color:#111827;margin-bottom:10px}.profile-form{display:flex;flex-direction:column;gap:10px}.profile-form .form-group{margin-bottom:0}.profile-form input{padding:7px 10px;border-radius:6px;font-size:.875rem;min-height:auto}.profile-field-hint{font-size:.8rem;color:#6b7280;margin-top:4px}.profile-form input:disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed}.profile-message{font-size:.9rem;font-weight:500}.profile-message.success{color:#059669}.profile-message.error{color:#dc2626}.profile-danger-zone{border-color:#dc262633;background:linear-gradient(135deg,#fef7f7,#fef2f2);margin-top:0;padding:14px 18px}.profile-danger-zone .profile-danger-header{border-left:3px solid #dc2626;padding-left:14px;margin-bottom:10px}.profile-danger-zone .profile-danger-header h3{color:#dc2626;font-size:.9rem}.profile-danger-body{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.profile-danger-text{color:#6b7280;font-size:.8rem;margin:0;line-height:1.4;flex:1;min-width:120px}.profile-danger-zone .icon-btn.delete-btn{background:#dc2626;color:#fff;border-color:#dc2626;font-size:.8rem;padding:6px 12px;flex-shrink:0}.profile-danger-zone .icon-btn.delete-btn:hover{background:#b91c1c;border-color:#b91c1c}.profile-page{display:flex;flex-direction:column;gap:24px;max-width:900px}.back-to-dashboard-btn{align-self:flex-start;background:none;border:1px solid #bfdbfe;color:#2563eb;padding:10px 20px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.back-to-dashboard-btn:hover{background:#f4f6ff;border-color:#93c5fd}.dashboard-hero{display:grid;grid-template-columns:.9fr 1fr;gap:20px;align-items:stretch;margin-bottom:28px}.hero-upload-pane,.hero-info-pane{background:#fbfcff;border:1px solid #dbeafe;border-radius:16px;padding:18px}.hero-info-pane{background:linear-gradient(135deg,#f7f8ff,#eef1ff)}.hero-info-pane h3{color:#111827;margin-bottom:10px;font-size:1.2rem}.hero-info-pane p{color:#535774;font-size:.92rem;line-height:1.5;margin-bottom:14px}.hero-feature-list{list-style:none;display:grid;gap:8px}.hero-feature-list li{color:#454a68;font-size:.9rem;background:#2563eb14;border:1px solid rgba(37,99,235,.16);border-radius:10px;padding:8px 10px}.upload-section{margin-bottom:0}.upload-area{border:3px dashed #2563eb;border-radius:15px;padding:60px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#f8f9ff}.upload-area:hover{background:#f0f2ff;border-color:#1d4ed8;transform:translateY(-2px)}.upload-area.dragover{background:#e8ebff;border-color:#1d4ed8;transform:scale(1.02)}.upload-area.uploading{pointer-events:none;opacity:1;padding:14px 16px;border-style:solid;background:#f6f8ff}.upload-area.uploading .upload-content svg{width:34px;height:34px;margin-bottom:8px}.upload-area.uploading .upload-content h3{margin-bottom:0;font-size:1.12rem;color:#2563eb}.upload-content svg{color:#2563eb;margin-bottom:15px}.upload-content h3{color:#333;margin-bottom:10px}.upload-content p{color:#666;font-size:.9rem}.progress-bar{width:100%;height:12px;background:#eff6ff;border-radius:999px;margin-top:8px;overflow:hidden;border:1px solid #bfdbfe}.progress-fill{height:100%;background:linear-gradient(90deg,#2563eb,#1d4ed8,#2563eb);background-size:220% 100%;width:0%;transition:width .25s ease;animation:progressShimmer 1.2s linear infinite;box-shadow:0 0 10px #2563eb80}.progress-bar-wrapper{display:flex;align-items:stretch;gap:12px;margin-top:12px}.upload-visuals{margin-top:8px}.scan-preview-card{border:1px solid #dfe4ff;border-radius:14px;background:#f7f9ff;padding:10px;box-shadow:0 6px 22px #2563eb1f}.scan-preview-header{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;font-weight:700;color:#5f69aa;margin-bottom:8px}.scan-preview-frame{position:relative;height:220px;overflow:hidden;border-radius:10px;border:1px solid #d7dcff;background:#f4f6ff;isolation:isolate}.scan-preview-frame:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;background-image:linear-gradient(rgba(91,108,224,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(91,108,224,.08) 1px,transparent 1px);background-size:100% 16px,16px 100%;opacity:.35}.scan-preview-image{width:100%;height:100%;object-fit:contain;object-position:center;display:block;background:#fff}.scan-line{position:absolute;left:0;width:100%;height:3px;background:linear-gradient(90deg,#5b6ce000,#788dff59 20%,#a6c8fffa,#788dff59 80%,#5b6ce000);box-shadow:0 0 14px #6882fff2,0 0 28px #6882ff8c;top:0;transform:translateY(-50%);animation:scanSweep 1.8s linear infinite alternate;z-index:3}.scan-line:after{content:"";position:absolute;top:-8px;right:0;bottom:-2px;left:0;background:linear-gradient(to bottom,#7090ff59,#7090ff00);pointer-events:none}.scan-progress-chip{position:absolute;top:6px;right:8px;padding:3px 8px;border-radius:999px;font-size:.74rem;font-weight:700;color:#fff;background:#4b5bd8e0;border:1px solid rgba(255,255,255,.45);box-shadow:0 4px 12px #4b5bd859}@keyframes scanSweep{0%{top:0%}to{top:100%}}.progress-text{min-width:64px;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#4f5ed6;background:#eef0ff;border:1px solid #d8dcfb;border-radius:10px;padding:0 10px;box-shadow:0 4px 14px #2563eb26}.progress-main{flex:1}.progress-meta{display:flex;justify-content:space-between;align-items:baseline}.progress-title{color:#454a68;font-weight:600;font-size:.9rem}.progress-subtitle{color:#7a7f9f;font-size:.78rem}@keyframes progressShimmer{0%{background-position:0% 0}to{background-position:220% 0}}.summary-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}.summary-header h2{margin-bottom:0}.summary-date-filters{display:flex;gap:10px;flex-wrap:wrap}.summary-date-filter{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary-neutral)}.summary-date-filter input{border:1px solid var(--border-soft);background:var(--surface-bg);color:var(--text-primary-neutral);border-radius:8px;padding:6px 8px;font:inherit}.summary-date-filter input:focus{outline:none;border-color:var(--accent-ui);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-ui) 18%,transparent)}.apply-filter-btn{border:1px solid var(--border-soft);background:var(--surface-bg);color:var(--text-primary-neutral);border-radius:8px;padding:6px 12px;font:inherit;font-weight:600;cursor:pointer}.apply-filter-btn:hover:not(:disabled){background:#eff6ff;border-color:#93c5fd;color:#2563eb;box-shadow:0 0 0 1px #2563eb2e}.apply-filter-btn:disabled{opacity:.5;cursor:not-allowed}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.summary-visual{display:grid;grid-template-columns:170px 1fr;gap:18px;align-items:center;background:#f8f9ff;border:1px solid #e4e8ff;border-radius:14px;padding:14px}.summary-pie{width:160px;height:160px;border-radius:50%;border:6px solid #fff;box-shadow:0 8px 24px #0f172a1f,0 0 0 1px #2563eb14;transition:transform .25s ease,box-shadow .25s ease}.summary-pie-btn:hover .summary-pie{transform:scale(1.04);box-shadow:0 12px 32px #0f172a2e,0 0 0 1px #2563eb26}.summary-pie-btn{border:none;background:transparent;padding:0;cursor:zoom-in}.summary-legend{display:grid;gap:8px;min-width:0;width:100%}.summary-legend-row{display:grid;grid-template-columns:14px minmax(0,1fr) auto;align-items:center;gap:10px}.summary-legend-dot{width:12px;height:12px;border-radius:999px;box-shadow:0 0 0 2px #ffffffd9,0 1px 3px #0000001f;flex-shrink:0}.summary-legend-label{color:#4f5472;font-size:.9rem;font-weight:600}.summary-legend-value{color:#111827;font-size:.85rem;font-weight:700}.summary-legend-percent{margin-left:4px;font-size:.8rem;font-weight:500;color:#6b7280}.category-layout{display:grid;grid-template-columns:340px minmax(0,1fr);align-items:stretch;column-gap:28px;row-gap:0;margin-bottom:24px}.category-layout .summary-visual{margin-bottom:0;display:flex;flex-direction:column;gap:16px;align-items:stretch;min-width:0}.category-layout .summary-pie-btn{align-self:center}.category-right-panel{display:flex;flex-direction:column;gap:20px;min-width:0}.category-layout .category-grid{margin-top:0;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));align-content:start}.category-insights{display:grid;grid-template-columns:minmax(140px,200px) 1fr;gap:20px;align-items:start;flex:1;min-height:0}.insight-total-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#1d4ed8;border-radius:16px;padding:22px 20px;box-shadow:0 4px 16px #2563eb1f;display:flex;flex-direction:column;gap:6px;border:1px solid rgba(37,99,235,.1)}.insight-total-label{font-size:.85rem;font-weight:600;opacity:.85;text-transform:uppercase;letter-spacing:.04em}.insight-total-value{font-size:1.75rem;color:#1d4ed8;font-weight:800;line-height:1.2}.insight-total-meta{font-size:.8rem;opacity:.75;color:#2563eb}.insight-bar-chart{background:var(--surface-muted);border:1px solid var(--border-soft);border-radius:12px;padding:14px 18px;min-width:0}.insight-bar-chart-label{font-size:.8rem;font-weight:600;color:var(--text-secondary-neutral);text-transform:uppercase;letter-spacing:.03em;margin-bottom:12px}.insight-bar-chart-bars{display:flex;flex-direction:column;gap:10px}.insight-bar-row{display:grid;grid-template-columns:80px minmax(0,1fr) auto;align-items:center;gap:14px;background:none;border:none;cursor:pointer;padding:6px 0;font:inherit;text-align:left;width:100%}.insight-bar-track{position:relative;height:14px;background:#0000000f;border-radius:7px;overflow:hidden}body.theme-dark .insight-bar-track{background:#ffffff14}.insight-bar-fill{position:absolute;left:0;top:0;height:100%;width:var(--bar-pct, 0%);background:var(--bar-color);border-radius:7px;opacity:.85;transition:opacity .25s,width .4s ease}.insight-bar-row:hover .insight-bar-fill{opacity:1}.insight-bar-row .insight-bar-label{min-width:0}.insight-bar-row .insight-bar-value{flex-shrink:0}.insight-bar-label{font-size:.9rem;font-weight:600;color:var(--text-primary-neutral)}.insight-bar-value{font-size:.9rem;font-weight:700;color:var(--text-primary-neutral)}.insight-bar-pct{font-weight:500;font-size:.8rem;color:var(--text-secondary-neutral);margin-left:4px}body.theme-dark .insight-total-card{background:linear-gradient(135deg,#2563eb33,#1d4ed82e);color:#93c5fd;box-shadow:0 4px 16px #2563eb33}body.theme-dark .insight-total-value{color:#bfdbfe}body.theme-dark .insight-total-meta{color:#60a5fa}body.theme-dark .insight-bar-chart{background:#162d50;border-color:#2a4674}.chart-modal-content{display:grid;grid-template-columns:minmax(240px,320px) 1fr;align-items:center;gap:20px}.summary-pie-fullscreen{width:280px;height:280px;margin:0 auto}.summary-legend-fullscreen{max-height:300px;overflow:auto;padding-right:6px}.category-card{--cat-accent: #2563eb;container-type:inline-size;container-name:category-card;background:#fff;color:#2f3552;padding:14px 16px;border-radius:15px;cursor:pointer;border:1px solid #e4e8f8;box-shadow:0 4px 12px #0f172a0f;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;position:relative;overflow:hidden}.category-card-body{display:flex;align-items:center;justify-content:space-between;gap:12px}.category-card-left{display:flex;flex-direction:column;gap:4px}.category-card-right{text-align:right}.category-card:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:var(--cat-accent)}.category-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px #0f172a1f;border-color:var(--cat-accent)}.category-card h3{font-size:1.05rem;margin-bottom:4px;color:#111827}.category-card .amount{font-size:1.5rem;font-weight:700;color:#111827}.category-card .count{font-size:.85rem;color:#6f7897}@container category-card (max-width: 180px){.category-card{padding:10px 12px}.category-card-body{gap:6px}.category-card h3{font-size:.9rem}.category-card .amount{font-size:1.15rem}.category-card .count{font-size:.75rem}}.category-card.fruits{--cat-accent: #7301F5}.category-card.vegetables{--cat-accent: #039BE5}.category-card.meat-seafood{--cat-accent: #0D47A1}.category-card.bakery{--cat-accent: #F7B500}.category-card.dairy-eggs{--cat-accent: #64B5F6}.category-card.snacks-beverages{--cat-accent: #03A9F4}.category-card.household-supplies{--cat-accent: #1565C0}.category-card.kitchenware{--cat-accent: #3111F5}.category-card.apparel{--cat-accent: #00ACC1}.category-card.personal-care{--cat-accent: #90CAF9}.category-card.pharmacy{--cat-accent: #0288D1}.category-card.electronics{--cat-accent: #1976D2}.category-card.other{--cat-accent: #2563eb}.store-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}.store-card{--store-accent: #2563eb;color:#2f3552;padding:28px;border-radius:18px;cursor:pointer;border:1px solid #e4e8f8;box-shadow:0 6px 16px #28387014;transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden;background:#fff}.pill-delete-btn{position:absolute;top:10px;right:10px;width:24px;height:24px;border-radius:999px;border:none;background:#eef1ff;color:#5566d8;display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pill-delete-btn:hover{background:#d9def8;color:#4454c2}.store-delete-btn{top:16px;right:16px}.store-card:after{content:"";position:absolute;inset:0 auto 0 0;width:6px;background:var(--store-accent);pointer-events:none}.store-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px #28387024}.store-card h3{font-size:1.3rem;margin-bottom:12px;font-weight:700;color:#111827}.store-card .store-total{font-size:2rem;font-weight:800;margin-bottom:6px;color:#111827}.store-card .store-count{font-size:.9rem;color:#6f7897}.store-card.walmart{--store-accent: #0071ce}.store-card.target{--store-accent: #cc0000}.store-card.costco{--store-accent: #e31837}.store-card.aldi{--store-accent: #f47920}.store-card.sams{--store-accent: #0060a9}.store-card.other-store{--store-accent: #2563eb}.bills-section-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.bills-section-header h2{margin-bottom:0}.back-btn{display:inline-flex;align-items:center;gap:8px;background:#2563eb;color:#fff;border:none;padding:10px 22px;border-radius:50px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .25s ease;white-space:nowrap;box-shadow:0 4px 12px #2563eb59}.back-btn:hover{transform:translateY(-2px);background:#1d4ed8;box-shadow:0 6px 20px #2563eb66}.back-btn:active{transform:translateY(0)}.back-btn svg{flex-shrink:0}.bills-list{display:grid;gap:20px}.address-group{margin-bottom:24px}.address-header{display:flex;align-items:center;gap:10px;font-size:.95rem;font-weight:600;color:var(--text-secondary-neutral);padding:8px 14px;background:var(--surface-muted);border-left:3px solid #2563eb;border-radius:0 10px 10px 0;margin-bottom:15px}.bill-card{background:var(--surface-bg);border:1px solid var(--border-soft);border-radius:12px;padding:18px 20px;transition:all .25s ease;margin-bottom:12px}.bill-card:hover{border-color:var(--border-strong);box-shadow:0 5px 18px #0f172a14;transform:translate(2px)}.bill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.bill-header h3{color:var(--text-primary-neutral);font-size:1.15rem;font-weight:600}.bill-total{font-size:1.4rem;font-weight:700;color:#111827;margin-bottom:6px}.bill-tax{font-size:.85rem;color:var(--text-secondary-neutral);margin-left:10px;font-weight:500}.bill-date{color:var(--text-secondary-neutral);font-size:.85rem;background:#f3f4ff;padding:4px 10px;border-radius:20px}.bill-meta{color:var(--text-secondary-neutral);font-size:.9rem;margin-bottom:14px}.bill-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid #eaedf5}.icon-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .2s ease}.primary-btn{background:#2563eb;color:#fff;border-color:#2563eb}.primary-btn:hover{background:#1d4ed8;color:#fff;border-color:#1d4ed8;box-shadow:0 2px 8px #2563eb59}.view-btn{background:#eff6ff;color:#2563eb;border-color:#bfdbfe}.view-btn:hover{background:#2563eb;color:#fff;border-color:#2563eb}.delete-btn{background:#fef2f2;color:#dc2626;border-color:#fecaca}.delete-btn:hover{background:#dc2626;color:#fff;border-color:#dc2626}.modal-backdrop{position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .25s;display:flex;align-items:flex-start;justify-content:center;padding-top:5vh}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#fff;padding:32px;border-radius:20px;width:90%;max-width:600px;max-height:82vh;overflow-y:auto;animation:slideDown .3s;box-shadow:0 25px 60px #0000004d;position:relative}@keyframes slideDown{0%{transform:translateY(-40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:16px;right:20px;background:none;border:none;font-size:28px;color:#aaa;cursor:pointer;line-height:1;padding:4px 8px;border-radius:8px;transition:all .2s}.modal-close:hover{color:#333;background:#f0f0f0}.modal-title{color:#111827;font-size:1.5rem;margin-bottom:20px;padding-right:40px}.confirm-text{color:#444;font-size:.95rem;line-height:1.5;margin-bottom:18px}.confirm-actions{display:flex;justify-content:flex-end;gap:10px}.bill-detail-meta{margin-bottom:24px;padding:18px 20px;border-radius:16px;background:linear-gradient(135deg,#f7f8ff,#eef0ff);border:1px solid #e1e4ff;display:flex;flex-direction:column;gap:8px;font-size:.9rem}.category-detail-header{margin-bottom:24px}.category-detail-header .sub-text{color:#666;margin-top:5px;font-size:.95rem}.highlight-amount{font-size:1.5rem;color:#2563eb;font-weight:700}.modal-items{margin-top:16px}.meta-row{display:grid;grid-template-columns:110px 1fr;align-items:baseline;column-gap:10px}.meta-label{font-weight:700;color:#4d4f62}.meta-label:after{content:":"}.meta-value{color:#333;font-weight:500;line-height:1.45}.text-input{flex:1;padding:8px 10px;border-radius:10px;border:1px solid #dfe3ff;font-size:.9rem;font-family:inherit;outline:none}.text-input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb2e}.meta-input{width:100%}.bill-image-wrapper{margin-bottom:18px}.bill-image-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.bill-image-label{font-size:.9rem;font-weight:600;color:#555;margin:0}.receipt-view-btn{display:inline-flex;align-items:center;gap:6px;background:#eef0ff;border:1px solid #d9defb;color:#5d6edf;border-radius:8px;padding:6px 10px;font-size:.82rem;font-weight:600;cursor:pointer}.receipt-view-btn:hover{background:#e4e8ff}.receipt-preview-btn{position:relative;width:100%;border:0;background:transparent;padding:0;border-radius:12px;overflow:hidden;cursor:pointer}.bill-image-preview{width:100%;max-height:180px;object-fit:cover;display:block;border:1px solid #e1e4ff;border-radius:12px;background:#fafbff}.bill-image-preview-blur{filter:blur(6px);transform:scale(1.03)}.bill-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#191b2859;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;font-size:.9rem;font-weight:600}.receipt-fullscreen-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#000000b3;display:flex;align-items:center;justify-content:center}.receipt-fullscreen-inner{position:relative;max-width:95vw;max-height:95vh}.receipt-fullscreen-image{max-width:95vw;max-height:95vh;object-fit:contain;border-radius:10px;background:#fafbff;border:1px solid #e1e4ff;box-shadow:0 16px 40px #00000080}.receipt-fullscreen-close{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:999px;border:none;background:#0009;color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer}.receipt-fullscreen-close:hover{background:#000c}.bill-detail-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.secondary-btn{background:#f3f4ff;color:#555;border-color:#dfe3ff}.secondary-btn:hover{background:#e1e4ff;color:#333}.modal-items h3{margin-bottom:15px;font-size:1.1rem;color:#444}.modal-item{display:flex;justify-content:space-between;padding:14px 16px;background:#f8f9ff;border-radius:10px;margin-bottom:8px;align-items:center;transition:background .15s}.modal-item-name-input{flex:2;margin-right:8px}.modal-item-category-input{flex:1;margin:0 8px}.modal-item-amount-input{width:90px;text-align:right}.modal-item:hover{background:#eef0ff}.modal-item-name{flex:1;font-weight:500}.item-sub-info{font-size:.8rem;color:#888;margin-top:2px}.modal-item-category{margin:0 15px}.modal-item-amount{font-weight:700;color:#2563eb;font-size:1.1rem;white-space:nowrap}.category-badge{padding:3px 10px;border-radius:10px;font-size:.75rem;font-weight:700;text-transform:uppercase;border:1px solid transparent}.category-badge.fruits{background:#7301f5;color:#fff}.category-badge.vegetables{background:#039be5;color:#fff}.category-badge.meat-seafood{background:#0d47a1;color:#fff}.category-badge.bakery{background:#f7b500;color:#1a1a1a}.category-badge.dairy-eggs{background:#64b5f6;color:#0a1929}.category-badge.snacks-beverages{background:#03a9f4;color:#fff}.category-badge.household-supplies{background:#1565c0;color:#fff}.category-badge.kitchenware{background:#3111f5;color:#fff}.category-badge.apparel{background:#00acc1;color:#fff}.category-badge.personal-care{background:#90caf9;color:#0a1929}.category-badge.pharmacy{background:#0288d1;color:#fff}.category-badge.electronics{background:#1976d2;color:#fff}.category-badge.other{background:#2563eb;color:#fff}.empty-state{text-align:center;padding:60px 20px;color:#666}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;border-radius:24px;padding:48px 40px;width:100%;max-width:440px;box-shadow:0 25px 60px #0000004d;animation:slideDown .4s ease}.auth-card-stacked{padding-top:40px}.auth-brand-row{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:28px}.auth-brand-logo-sm{width:40px;height:40px}.auth-brand-name{font-size:1.35rem;font-weight:800;color:#111827;letter-spacing:-.03em}.auth-screen-title{font-size:1.5rem;font-weight:700;color:#111827;text-align:center;margin-bottom:8px;letter-spacing:-.02em}.auth-screen-subtitle{text-align:center;font-size:.95rem;color:#6b7280;margin-bottom:28px}.auth-beta-notice{text-align:center;font-size:.8125rem;line-height:1.5;color:#4b5563;margin:-12px 0 24px;padding:10px 14px;background:#fefce8;border:1px solid #fde047;border-radius:10px}.auth-beta-notice strong{color:#854d0e;font-weight:700}.auth-forgot-row{text-align:center;margin-top:14px}.auth-link-btn{background:none;border:none;color:#2563eb;font-weight:600;font-size:.9rem;cursor:pointer;padding:0;font-family:inherit}.auth-link-btn:hover{text-decoration:underline}.auth-footer-cta{text-align:center;margin-top:28px;font-size:.92rem;color:#6b7280}.auth-link-cta{background:none;border:none;color:#2563eb;font-weight:600;font-size:inherit;cursor:pointer;padding:0;font-family:inherit}.auth-link-cta:hover{text-decoration:underline}body.theme-dark .auth-brand-name,body.theme-dark .auth-screen-title{color:#f1f5f9}body.theme-dark .auth-screen-subtitle,body.theme-dark .auth-footer-cta{color:#94a3b8}body.theme-dark .auth-beta-notice{color:#e2e8f0;background:#eab3081f;border-color:#eab30859}body.theme-dark .auth-beta-notice strong{color:#fbbf24}.auth-header{text-align:center;margin-bottom:32px}.auth-header h1{font-size:2.4rem;color:#111827;margin-bottom:6px;letter-spacing:-.5px}.auth-header p{color:#888;font-size:1rem}.auth-tabs{display:flex;background:#f0f2ff;border-radius:12px;padding:4px;margin-bottom:28px}.auth-tab{flex:1;padding:10px;border:none;background:transparent;border-radius:10px;font-size:.95rem;font-weight:600;color:#888;cursor:pointer;transition:all .2s}.auth-tab.active{background:#fff;color:#2563eb;box-shadow:0 2px 8px #2563eb26}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-form-row{display:flex;gap:12px;flex-direction:row}.auth-form-row .form-group-inline{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.auth-form-row .form-group-inline label{font-size:.85rem;font-weight:600;color:#555}.auth-form-row .form-group-inline input{padding:12px 16px;border:2px solid #e8ebf5;border-radius:12px;font-size:1rem}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;font-weight:600;color:#555}.optional-label{font-weight:400;color:#9ca3af;font-size:.8rem}.form-group input{padding:12px 16px;border:2px solid #e8ebf5;border-radius:12px;font-size:1rem;transition:border-color .2s;outline:none;font-family:inherit}.password-input-wrap{position:relative;display:flex;align-items:center}.password-input-wrap input{padding-right:44px;flex:1}.password-toggle-btn{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;background:none;border:none;padding:4px;cursor:pointer;color:#6b7280;border-radius:6px;transition:color .2s}.password-toggle-btn:hover{color:#2563eb}body.theme-dark .password-toggle-btn{color:#94a3b8}body.theme-dark .password-toggle-btn:hover{color:#60a5fa}.form-group input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group input::placeholder{color:#bbb}.auth-error{background:#fff0f0;color:#e74c3c;padding:10px 14px;border-radius:10px;font-size:.9rem}.auth-submit{padding:14px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .25s;margin-top:4px}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0 16px;color:#888;font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#0000001f}body.theme-dark .auth-divider{color:#9ca3af}body.theme-dark .auth-divider:before,body.theme-dark .auth-divider:after{background:#ffffff1f}.auth-google-btn{display:flex;width:100%;align-items:center;justify-content:center;gap:10px;padding:12px 16px;border:1px solid rgba(0,0,0,.15);border-radius:12px;background:#fff;color:#1f2937;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s,box-shadow .2s}.auth-google-btn:hover{background:#f9fafb;box-shadow:0 2px 8px #0000000f}body.theme-dark .auth-google-btn{background:#1f2937;color:#f3f4f6;border-color:#ffffff26}body.theme-dark .auth-google-btn:hover{background:#374151}.auth-google-glyph{width:20px;height:20px;flex-shrink:0}.auth-switch{text-align:center;margin-top:24px;color:#888;font-size:.9rem}.auth-switch button{background:none;border:none;color:#2563eb;font-weight:600;cursor:pointer;font-size:.9rem;padding:0}.auth-switch button:hover{text-decoration:underline}.toast-container{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:2000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast-container>*{pointer-events:auto}.toast{display:flex;align-items:center;gap:14px;padding:16px 20px;border-radius:16px;box-shadow:0 20px 60px #00000040;background:#fff;max-width:420px;animation:toastIn .3s ease;border-left:4px solid #2563eb}.toast-success{border-left-color:#2563eb}.toast-success .toast-icon{color:#2563eb}.toast-error{border-left-color:#e74c3c}.toast-error .toast-icon{color:#e74c3c}.toast-icon{flex-shrink:0}.toast-message{flex:1;margin:0;font-size:.95rem;color:#333;line-height:1.4}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#888;cursor:pointer;padding:4px;border-radius:8px;transition:color .2s,background .2s}.toast-close:hover{color:#333;background:#f0f0f0}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}body.theme-dark{background:radial-gradient(1200px 520px at 20% -10%,rgba(124,146,255,.2),transparent 60%),radial-gradient(920px 440px at 100% 0%,rgba(113,198,255,.12),transparent 65%),#172133;color:#e2e8f0}body.theme-dark header{color:#e2e8f0}body.theme-dark header p,body.theme-dark .user-name-btn:not(.user-name-btn-active){color:#94a3b8}body.theme-dark .user-name-btn{border-color:var(--border-soft);background:var(--surface-bg);color:var(--text-primary-neutral)}body.theme-dark .user-name-btn:hover{background:var(--surface-muted);border-color:var(--border-strong)}body.theme-dark .user-name-btn-active{border:1px solid rgba(96,165,250,.5);background:#2563eb2e;color:#93c5fd}body.theme-dark .user-name-btn-active:hover{background:#2563eb47;border-color:#60a5fab3;box-shadow:0 0 0 1px #2563eb33}body.theme-dark main,body.theme-dark .hero-upload-pane,body.theme-dark .hero-info-pane,body.theme-dark .summary-visual,body.theme-dark .category-card,body.theme-dark .store-card,body.theme-dark .bill-card,body.theme-dark .modal-content,body.theme-dark .auth-card{background:#1b2945;border-color:#364a72;box-shadow:0 10px 28px #0408124d}body.theme-dark main{background:linear-gradient(180deg,#1d2b48,#18253f);border:1px solid #33486f}body.theme-dark .hero-upload-pane,body.theme-dark .hero-info-pane,body.theme-dark .summary-visual{background:linear-gradient(180deg,#213152,#1b2945)}body.theme-dark .category-card,body.theme-dark .store-card,body.theme-dark .bill-card{background:linear-gradient(180deg,#1f2f4f,#1a2945);box-shadow:0 8px 24px #070d1c47,inset 0 1px #d3deff12}body.theme-dark .category-card:hover{border-color:var(--cat-accent);box-shadow:0 12px 26px #080e1e59,0 0 0 1px #93b0ff33,inset 0 1px #d6e1ff12}body.theme-dark .store-card:hover,body.theme-dark .bill-card:hover{border-color:#5a73aa;box-shadow:0 12px 26px #080e1e52,0 0 0 1px #93b0ff3d,inset 0 1px #d6e1ff17}body.theme-dark .hero-info-pane{background:linear-gradient(135deg,#243556,#1c2c4a)}body.theme-dark .profile-card{background:linear-gradient(135deg,#243556,#1c2c4a);border-color:#2a4674}body.theme-dark .profile-name{color:#e2e8f0}body.theme-dark .profile-email{color:#94a3b8}body.theme-dark .profile-stat-value{color:#60a5fa}body.theme-dark .profile-stat-label{color:#94a3b8}body.theme-dark .profile-detail-section{background:linear-gradient(135deg,#243556,#1c2c4a);border-color:#2a4674}body.theme-dark .profile-theme-section{border-color:#3b82f64d;background:linear-gradient(135deg,#1e3a5f,#1a2d4a);box-shadow:0 2px 8px #3b82f61a}body.theme-dark .profile-theme-toggle{background:#3b82f61a;border-color:#3b82f659;color:#60a5fa}body.theme-dark .profile-theme-toggle:hover{background:#3b82f62e;border-color:#3b82f680;color:#93c5fd}body.theme-dark .profile-detail-section h3{color:#e2e8f0}body.theme-dark .profile-detail-section .form-group label,body.theme-dark .profile-detail-section .form-group-inline label{color:#cbd5e1}body.theme-dark .profile-field-hint{color:#94a3b8}body.theme-dark .profile-section h2{color:#e2e8f0}body.theme-dark .profile-message.success{color:#34d399}body.theme-dark .profile-message.error{color:#f87171}body.theme-dark .profile-form input{color:#e2e8f0;border-color:#3a4a6a;background:#1e293b}body.theme-dark .profile-form input::placeholder{color:#64748b}body.theme-dark .profile-form input:disabled{background:#1f2f4f;color:#94a3b8}body.theme-dark .profile-tabs{border-bottom-color:#33486f}body.theme-dark .profile-tab{color:#94a3b8}body.theme-dark .profile-tab:hover{color:#cbd5e1}body.theme-dark .profile-tab.active{color:#60a5fa;border-bottom-color:#60a5fa}body.theme-dark .profile-card-header h3{color:#e2e8f0}body.theme-dark .profile-card-subtitle{color:#94a3b8}body.theme-dark .profile-danger-zone{border-color:#dc262659;background:linear-gradient(135deg,#dc26260f,#dc26260a)}body.theme-dark .profile-danger-zone .profile-danger-header{border-left-color:#f87171}body.theme-dark .profile-danger-zone .profile-danger-header h3{color:#f87171}body.theme-dark .profile-danger-text{color:#94a3b8}body.theme-dark .profile-danger-zone .icon-btn.delete-btn{background:#dc2626;color:#fff;border-color:#dc2626}body.theme-dark .profile-danger-zone .icon-btn.delete-btn:hover{background:#b91c1c;color:#fff;border-color:#b91c1c}body.theme-dark .back-to-dashboard-btn{border-color:#3a4a6a;color:#93b5ff}body.theme-dark .back-to-dashboard-btn:hover{background:#93b5ff1f;border-color:#4a5a7a}body.theme-dark h2,body.theme-dark .modal-title,body.theme-dark .hero-info-pane h3{color:#e2e8f0}body.theme-dark h2{position:relative;padding-bottom:6px}body.theme-dark h2:after{content:"";position:absolute;left:0;bottom:0;width:64px;height:2px;border-radius:999px;background:linear-gradient(90deg,#7d93ff,#4de2ff)}body.theme-dark h2.auth-screen-title{position:static;padding-bottom:0}body.theme-dark h2.auth-screen-title:after{display:none;content:none}body.theme-dark .hero-info-pane p,body.theme-dark .hero-feature-list li,body.theme-dark .summary-legend-label,body.theme-dark .bill-meta,body.theme-dark .bill-tax,body.theme-dark .bill-date,body.theme-dark .progress-subtitle,body.theme-dark .empty-state,body.theme-dark .auth-header p{color:#94a3b8}body.theme-dark .form-group label{color:#cbd5e1}body.theme-dark .optional-label{color:#94a3b8}body.theme-dark .auth-form-row .form-group-inline label,body.theme-dark .confirm-text{color:#cbd5e1}body.theme-dark .hero-feature-list li{background:#93b0ff1c;border-color:#93b0ff3d}body.theme-dark .summary-legend-value{color:#e2e8f0}body.theme-dark .primary-btn{background:#2563eb;color:#fff;border-color:#2563eb}body.theme-dark .primary-btn:hover{background:#3b82f6;color:#fff;border-color:#3b82f6;box-shadow:0 2px 12px #3b82f666}body.theme-dark .logout-btn,body.theme-dark .theme-icon-btn,body.theme-dark .view-btn,body.theme-dark .secondary-btn{background:#22345a;color:#cbd5e1;border-color:#4b6498}body.theme-dark .logout-btn:hover,body.theme-dark .view-btn:hover,body.theme-dark .secondary-btn:hover{background:#2a406b;border-color:#6383be;box-shadow:0 0 0 1px #98b6ff3d}body.theme-dark .theme-icon-btn:hover{color:#60a5fa;background:#2563eb33;border-color:#60a5fa66}body.theme-dark .upload-area,body.theme-dark .upload-area.uploading,body.theme-dark .scan-preview-card{background:#1f3050;border-color:#4a6396}body.theme-dark .upload-area{box-shadow:inset 0 0 0 1px #a0b8ff24}body.theme-dark .upload-area:hover{border-color:#6f91cc;background:#263c63}body.theme-dark .upload-content svg{color:#60a5fa}body.theme-dark .upload-content h3,body.theme-dark .bill-header h3,body.theme-dark .category-card h3,body.theme-dark .store-card h3,body.theme-dark .modal-close{color:#e2e8f0}body.theme-dark .upload-content p,body.theme-dark .category-card .count,body.theme-dark .store-card .store-count{color:#94a3b8}body.theme-dark .category-card .amount,body.theme-dark .store-card .store-total,body.theme-dark .bill-total{color:#e2e8f0}body.theme-dark .summary-pie{border-color:#1b2945;box-shadow:0 8px 24px #02060e73,0 0 0 1px #64a0ff26}body.theme-dark .summary-pie-btn:hover .summary-pie{box-shadow:0 12px 32px #02060e8c,0 0 0 1px #64a0ff40}body.theme-dark .summary-legend-dot{box-shadow:0 0 0 2px #1b2945d9,0 1px 3px #0000004d}body.theme-dark .pill-delete-btn{background:#2a3f69;color:#cbd5e1}body.theme-dark .pill-delete-btn:hover{background:#365487;color:#e2e8f0}body.theme-dark .back-btn{background:#2563eb;color:#fff}body.theme-dark .back-btn:hover{background:#3b82f6;box-shadow:0 6px 20px #60a5fa59}body.theme-dark .bill-actions{border-top-color:#3b4f79}body.theme-dark .modal-backdrop{background-color:#0009}body.theme-dark .modal-close:hover,body.theme-dark .toast-close:hover{background:#2c4471;color:#e2e8f0}body.theme-dark .toast{background:#1d2c4a;border-color:#435a89;color:#e4ebff;box-shadow:0 8px 24px #050a1452}body.theme-dark .toast-message,body.theme-dark .toast-close{color:#cbd5e1}body.theme-dark .auth-tabs{background:#22345a}body.theme-dark .auth-tab{color:#94a3b8}body{--text-primary-neutral: #111827;--text-secondary-neutral: #6b7280;--app-bg: #f6f8fc;--surface-bg: #ffffff;--surface-muted: #f8fafc;--surface-elevated: #f3f6fb;--border-soft: #e5eaf2;--border-strong: #d9e1ed;--accent-ui: #3b82f6;--shadow-soft: 0 8px 24px rgba(15, 23, 42, .06);--shadow-card: 0 4px 16px rgba(15, 23, 42, .05)}body.theme-dark{--text-primary-neutral: #e2e8f0;--text-secondary-neutral: #94a3b8;--app-bg: #08162f;--surface-bg: #0f213f;--surface-muted: #13284a;--surface-elevated: #102443;--border-soft: #223b62;--border-strong: #2a4978;--accent-ui: #7aa8ff;--shadow-soft: 0 12px 30px rgba(2, 8, 20, .35);--shadow-card: 0 8px 24px rgba(2, 8, 20, .3)}body{background:var(--app-bg);color:var(--text-primary-neutral)}.container{max-width:1320px;padding:0 8px}header{margin-bottom:18px}header h1{font-size:2.3rem;font-weight:700;letter-spacing:-.03em}header p{font-size:.95rem}.user-name{opacity:1;font-size:.86rem;border-radius:999px;padding:6px 10px}.header-user .user-name-btn-active{background:#eff6ff;border:1px solid #93c5fd;padding:8px 14px;color:#1d4ed8;font-weight:600}.header-user .user-name-btn-active:hover{background:#dbeafe;border-color:#60a5fa;box-shadow:0 0 0 1px #2563eb33}.logout-btn{background:var(--surface-bg);border-color:var(--border-soft);color:var(--text-primary-neutral);font-size:.85rem;font-weight:600;padding:7px 14px}.theme-icon-btn{background:var(--surface-bg);border-color:var(--border-soft);color:var(--text-primary-neutral)}.logout-btn:hover,.theme-icon-btn:hover{background:var(--surface-muted);border-color:var(--border-strong)}main{background:var(--surface-bg);border:1px solid var(--border-soft);border-radius:12px;box-shadow:var(--shadow-soft);padding:24px}section{margin-bottom:30px}h2{font-size:2rem;font-weight:700;margin-bottom:14px}.dashboard-hero{gap:14px}.hero-upload-pane,.hero-info-pane{background:var(--surface-muted);border:1px solid var(--border-soft);border-radius:12px;padding:14px;box-shadow:var(--shadow-card)}.hero-info-pane{background:var(--surface-elevated)}.hero-feature-list li{background:var(--surface-bg);border:1px solid var(--border-soft);border-radius:8px;padding:7px 10px}.upload-area{background:var(--surface-bg);border-color:var(--border-strong);border-radius:12px;min-height:210px}.upload-area:hover{background:var(--surface-muted);border-color:var(--accent-ui)}.summary-visual{background:var(--surface-muted);border:1px solid var(--border-soft);border-radius:12px;padding:12px;gap:14px}.summary-pie{border-width:6px;box-shadow:0 4px 14px #0f172a1f}.category-grid,.store-grid{gap:14px}.category-card,.store-card{background:var(--surface-bg);border:1px solid var(--border-soft);border-radius:12px;box-shadow:var(--shadow-card)}.store-card{padding:18px}.category-card{padding:14px 16px}.category-card:hover,.store-card:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:0 10px 22px #0f172a1a}.category-card:before,.store-card:after{opacity:.9}.pill-delete-btn{width:22px;height:22px;background:var(--surface-elevated);color:var(--text-secondary-neutral);border:1px solid var(--border-soft)}.pill-delete-btn:hover{background:var(--surface-muted);color:var(--text-primary-neutral)}.bill-card{background:var(--surface-bg);border:1px solid var(--border-soft);border-radius:12px;box-shadow:var(--shadow-card)}.bill-card:hover{border-color:var(--border-strong);transform:translate(2px)}.modal-content{background:var(--surface-bg);border:1px solid var(--border-soft);border-radius:14px;box-shadow:0 20px 48px #0f172a38}.text-input,.form-group input{border-color:var(--border-soft);background:var(--surface-bg);color:var(--text-primary-neutral)}.text-input:focus,.form-group input:focus{border-color:var(--accent-ui);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-ui) 22%,transparent)}body.theme-dark{background:radial-gradient(1000px 380px at 20% -10%,rgba(122,168,255,.12),transparent 58%),var(--app-bg)}body.theme-dark .user-name,body.theme-dark .logout-btn,body.theme-dark .theme-icon-btn,body.theme-dark .hero-upload-pane,body.theme-dark .hero-info-pane,body.theme-dark .profile-card,body.theme-dark .summary-visual,body.theme-dark .category-card,body.theme-dark .store-card,body.theme-dark .bill-card,body.theme-dark .modal-content,body.theme-dark .auth-card{border-color:var(--border-soft)}body.theme-dark .hero-feature-list li{background:#162d50;border-color:#2a4674}body.theme-dark .pill-delete-btn{background:#18305a;border-color:#345486}body.theme-dark .pill-delete-btn:hover{background:#214072}body.theme-dark .summary-pie{box-shadow:0 4px 14px #02081473}header,header h1,h2,.hero-info-pane h3,.summary-legend-value,.category-card h3,.category-card .amount,.store-card h3,.store-card .store-total,.bill-header h3,.bill-total,.highlight-amount,.modal-item-amount,.modal-title,.auth-header h1,.modal-item-name,.meta-value,.field-inline label{color:var(--text-primary-neutral)}header p,.user-name,.hero-info-pane p,.hero-feature-list li,.upload-content p,.progress-subtitle,.summary-legend-label,.category-card .count,.store-card .store-count,.bill-meta,.bill-tax,.bill-date,.empty-state,.auth-header p,.modal-item-category,.modal-item-total,.meta-label,.confirm-text,.upload-hint{color:var(--text-secondary-neutral)}@media (max-width: 768px){header h1{font-size:2rem}.header-row{flex-direction:column;text-align:center;gap:16px}.header-row>div:first-child{text-align:center}.header-user{flex-wrap:wrap;justify-content:center}main{padding:20px}.category-grid,.store-grid{grid-template-columns:1fr}.category-layout .category-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.category-insights{grid-template-columns:1fr}.summary-visual{max-width:100%;grid-template-columns:1fr;justify-items:center}.summary-pie{width:130px;height:130px}.summary-pie-fullscreen{width:240px;height:240px}.chart-modal-content{grid-template-columns:1fr;justify-items:center}.summary-legend{width:100%}.category-layout,.dashboard-hero{grid-template-columns:1fr}.bill-header{flex-direction:column;align-items:flex-start;gap:8px}.bills-section-header{flex-direction:column;align-items:flex-start}.auth-card{padding:32px 24px}}body{--accent-ui: #111111;--app-bg: #ffffff;--surface-bg: #ffffff;--surface-muted: #fafafa;--surface-elevated: #f5f5f5;--border-soft: #e5e7eb;--border-strong: #d1d5db;--text-primary-neutral: #111111;--text-secondary-neutral: #525252;--shadow-soft: 0 8px 24px rgba(0, 0, 0, .06);--shadow-card: 0 4px 14px rgba(0, 0, 0, .05)}body.theme-dark{--accent-ui: #f5f5f5;--app-bg: #0a0a0a;--surface-bg: #121212;--surface-muted: #171717;--surface-elevated: #1f1f1f;--border-soft: #2a2a2a;--border-strong: #3a3a3a;--text-primary-neutral: #e2e8f0;--text-secondary-neutral: #94a3b8;--shadow-soft: 0 10px 28px rgba(0, 0, 0, .4);--shadow-card: 0 8px 20px rgba(0, 0, 0, .3)}body,body.theme-dark{background:var(--app-bg)}body.theme-dark main,body.theme-dark .hero-upload-pane,body.theme-dark .hero-info-pane,body.theme-dark .summary-visual,body.theme-dark .category-card,body.theme-dark .store-card,body.theme-dark .bill-card,body.theme-dark .modal-content,body.theme-dark .auth-card{background:var(--surface-bg);border-color:var(--border-soft)}body.theme-dark .hero-feature-list li{background:var(--surface-elevated);border-color:var(--border-soft)}.logout-btn,.theme-icon-btn,.view-btn,.secondary-btn{color:var(--text-primary-neutral);background:var(--surface-bg);border-color:var(--border-soft)}.logout-btn:hover,.theme-icon-btn:hover,.view-btn:hover,.secondary-btn:hover{background:var(--surface-muted);border-color:var(--border-strong);box-shadow:none}.view-btn:hover{color:var(--text-primary-neutral)}.text-input:focus,.form-group input:focus{border-color:#111;box-shadow:0 0 0 2px #1111111f}body.theme-dark .text-input:focus,body.theme-dark .form-group input:focus{border-color:#f5f5f5;box-shadow:0 0 0 2px #f5f5f533}.highlight-amount,.modal-item-amount,.summary-legend-value,.category-card .amount,.store-card .store-total,.bill-total{color:var(--text-primary-neutral)}body:not(.theme-dark) .modal-content{background:#fff}body:not(.theme-dark) .bill-detail-meta{background:#fff;border:1px solid #e5e7eb}body:not(.theme-dark) .modal-item{background:#fff;border:1px solid #e5e7eb}body:not(.theme-dark) .modal-item:hover{background:#fafafa}body:not(.theme-dark) .receipt-view-btn{background:#fff;border:1px solid #d1d5db;color:#111827}body:not(.theme-dark) .receipt-view-btn:hover{background:#f9fafb}body.theme-dark .bill-detail-meta{background:#1e293b;border-color:#334155}body.theme-dark .meta-label{color:#94a3b8}body.theme-dark .meta-value,body.theme-dark .highlight-amount,body.theme-dark .modal-items h3{color:#e2e8f0}body.theme-dark .modal-item{background:#1e293b;border:1px solid #334155;border-radius:10px}body.theme-dark .modal-item:hover{background:#263548}body.theme-dark .modal-item-name,body.theme-dark .modal-item-amount{color:#e2e8f0}body.theme-dark .item-sub-info,body.theme-dark .bill-image-label{color:#94a3b8}body.theme-dark .receipt-view-btn{background:#2563eb;border-color:#3b82f6;color:#fff}body.theme-dark .receipt-view-btn:hover{background:#3b82f6}body.theme-dark .modal-item .category-badge{background:#334155!important;color:#e2e8f0!important;border-color:#475569!important}body{font-family:Manrope,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}h1,h2,h3,.modal-title,.auth-tab,.auth-submit{font-family:Sora,Manrope,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.brand-block{display:flex;flex-direction:column;gap:4px}.brand-logo{display:inline-flex;width:34px;height:34px;color:#2563eb;flex-shrink:0}.brand-logo svg{width:100%;height:100%;display:block}.brand-title-row{display:flex;align-items:center;gap:10px}.brand-title-row h1{margin:0;letter-spacing:-.03em}.auth-brand-title{justify-content:center;margin-bottom:6px}.auth-brand-logo{width:32px;height:32px}body.theme-dark .brand-logo{color:#60a5fa}.user-name-btn:hover,.logout-btn:hover{color:#2563eb}body.theme-dark .user-name-btn:hover,body.theme-dark .logout-btn:hover{color:#60a5fa}
