:root{--bg: #0a1616;--surface: #122424;--surface-2: #1a3232;--border: #2a4a4a;--text: #f0f5f4;--muted: #8fafab;--accent: #3dd6c6;--accent-dim: #1a8a8a;--warn: #e8b84a;--danger: #e86a6a;--radius: 12px;--nav-h: 64px;font-family:Segoe UI,system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg);line-height:1.45}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100dvh}#root{min-height:100dvh}.app-shell{max-width:520px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom))}.app-header{padding:1rem 1.25rem .5rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.app-header h1{margin:0;font-size:1.25rem;font-weight:600;letter-spacing:-.02em}.app-main{flex:1;padding:0 1.25rem 1.25rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:.75rem}.card-list{padding-top:.25rem;padding-bottom:.25rem}.card-list .list-item-btn{padding-left:0;padding-right:0}.card-highlight{background:linear-gradient(145deg,var(--surface-2),var(--surface));border-color:var(--accent-dim)}.stat-value{font-size:1.75rem;font-weight:700;color:var(--accent);margin:.25rem 0 0}.stat-label{font-size:.85rem;color:var(--muted);margin:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:none;border-radius:10px;padding:.75rem 1rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#042424;width:100%}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border);width:100%}.btn-ghost{background:transparent;color:var(--muted);padding:.35rem .5rem;font-size:.85rem}.input,.textarea,.select{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text);padding:.7rem .85rem;font-size:.95rem;font-family:inherit}.textarea{min-height:88px;resize:vertical}.label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:.35rem}.field,.date-range-picker{margin-bottom:.85rem}.date-range-picker>.label{margin-bottom:.25rem}.date-range-hint{font-size:.8rem;color:var(--muted);margin:0 0 .5rem}.date-range-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.date-range-field{margin-bottom:0}.date-range-presets{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.btn-sm{font-size:.8rem;padding:.35rem .65rem;width:auto}.disclaimer{font-size:.75rem;color:var(--muted);border-left:3px solid var(--warn);padding-left:.65rem;margin:.75rem 0}.error-banner{background:#e86a6a1f;border:1px solid var(--danger);color:#ffc9c9;border-radius:var(--radius);padding:.75rem 1rem;font-size:.9rem;margin-bottom:.75rem}.info-banner{background:#3dd6c614;border:1px solid var(--accent-dim);color:var(--text);border-radius:var(--radius);padding:.75rem 1rem;font-size:.85rem;margin-bottom:.75rem}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:#0a1616eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;justify-content:center}.bottom-nav-inner{max-width:520px;width:100%;display:flex}.nav-btn{flex:1;background:none;border:none;color:var(--muted);font-size:.7rem;padding:.5rem .25rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.2rem}.nav-btn.active{color:var(--accent)}.nav-btn span.icon{font-size:1.25rem}.line-item{border-top:1px solid var(--border);padding-top:.85rem;margin-top:.85rem}.line-item:first-child{border-top:none;padding-top:0;margin-top:0}.line-item-header{display:flex;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.line-item-name{font-weight:600;font-size:.95rem;margin:0}.line-item-price{color:var(--accent);font-weight:600;white-space:nowrap}.checkbox-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem;margin:.35rem 0}.checkbox-row input{width:1.1rem;height:1.1rem;accent-color:var(--accent)}.scan-video-wrap{position:relative;border-radius:var(--radius);overflow:hidden;background:#000;aspect-ratio:1 / 1;max-width:min(100%,420px);margin-left:auto;margin-right:auto;margin-bottom:.75rem}.scan-video-wrap video{width:100%;height:100%;object-fit:cover;object-position:center}.scan-overlay{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:72%;aspect-ratio:1 / 1;border:2px solid var(--accent);border-radius:8px;pointer-events:none;box-shadow:0 0 0 9999px #00000073}.scan-overlay--warn{border-color:var(--danger);animation:scan-shake .45s ease-in-out}@keyframes scan-shake{0%,to{transform:translate(-50%,-50%) translate(0)}20%,60%{transform:translate(-50%,-50%) translate(-4px)}40%,80%{transform:translate(-50%,-50%) translate(4px)}}.scan-toast{position:absolute;left:.5rem;right:.5rem;bottom:5.25rem;z-index:3;display:flex;align-items:flex-start;gap:.5rem;padding:.65rem .75rem;border-radius:10px;background:#280c0ceb;border:1px solid var(--danger);color:#ffc9c9;font-size:.85rem;line-height:1.35;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto}.scan-toast-text{margin:0;flex:1}.scan-toast-close{flex-shrink:0;width:1.75rem;height:1.75rem;padding:0;border:none;border-radius:6px;background:#ffffff1a;color:inherit;font-size:1.25rem;line-height:1;cursor:pointer}.scan-toast-close:active{background:#fff3}.scan-help{margin:0 0 1rem;padding:.65rem .85rem;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);font-size:.85rem;color:var(--muted)}.scan-help summary{cursor:pointer;color:var(--text);font-weight:600;list-style:none}.scan-help summary::-webkit-details-marker{display:none}.scan-help summary:before{content:"▸ ";display:inline-block;transition:transform .15s ease}.scan-help[open] summary:before{transform:rotate(90deg)}.scan-help ul{margin:.65rem 0 0;padding-left:1.15rem}.scan-help li{margin-bottom:.4rem}.scan-help li:last-child{margin-bottom:0}.scan-analyze-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;display:flex;align-items:center;justify-content:center;background:#0a16168c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);pointer-events:none}.scan-spinner{width:2.75rem;height:2.75rem;border:3px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;animation:scan-spin .85s linear infinite}@keyframes scan-spin{to{transform:rotate(360deg)}}.scan-capture-btn{position:absolute;left:50%;bottom:.85rem;z-index:2;transform:translate(-50%);width:4rem;height:4rem;padding:0;border:3px solid rgba(255,255,255,.9);border-radius:50%;background:transparent;cursor:pointer}.scan-capture-btn:disabled{opacity:.5;cursor:not-allowed}.scan-capture-inner{display:block;width:100%;height:100%;border-radius:50%;background:#fff}.scan-capture-btn:active:not(:disabled) .scan-capture-inner{transform:scale(.92)}.scan-controls{position:absolute;right:.65rem;bottom:.85rem;z-index:2;display:flex;gap:.5rem}.scan-control-btn{width:2.75rem;height:2.75rem;border:none;border-radius:50%;background:#0a1616bf;color:var(--text);font-size:1.25rem;line-height:1;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--border)}.scan-control-btn:active{background:var(--surface-2)}.scan-control-btn.active{background:#2dd4bf40;border-color:var(--accent);color:var(--accent)}.empty-state{text-align:center;color:var(--muted);padding:2rem 1rem;font-size:.95rem}.list-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:.65rem 0;border-bottom:1px solid var(--border)}.list-row:last-child{border-bottom:none}.list-row-btn{width:100%;margin:0;border:none;background:transparent;color:inherit;font:inherit;cursor:pointer;text-align:inherit}.list-row-btn:hover{background:#ffffff0a}.list-item-btn{display:block;width:100%;margin:0;padding:.75rem 0;border:none;border-bottom:1px solid var(--border);background:transparent;color:inherit;font:inherit;cursor:pointer;text-align:left}.list-item-btn:last-child{border-bottom:none}.list-item-btn:hover{background:#ffffff0a}.list-item-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.list-item-title{font-weight:600;font-size:.9rem;line-height:1.35;flex:1;min-width:0}.list-item-price{font-weight:600;font-size:.9rem;color:var(--muted);white-space:nowrap;flex-shrink:0}.list-item-price--accent{color:var(--accent)}.list-item-merchant{margin:.35rem 0 0;font-size:.75rem;font-weight:500;letter-spacing:.02em;text-transform:uppercase;color:var(--muted);line-height:1.3}.list-item-meta{margin:.3rem 0 0;font-size:.8rem;color:var(--muted);line-height:1.35}.list-item-badges{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.45rem}.badge{display:inline-block;font-size:.7rem;padding:.15rem .45rem;border-radius:6px;background:var(--surface-2);color:var(--muted)}.badge-warn{background:#e8b84a33;color:var(--warn)}.badge-merchant{text-transform:uppercase;letter-spacing:.02em;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.script-toggle{display:flex;gap:.25rem;background:var(--bg);border-radius:8px;padding:2px;border:1px solid var(--border)}.script-toggle button{border:none;background:transparent;color:var(--muted);font-size:.75rem;padding:.25rem .5rem;border-radius:6px;cursor:pointer}.script-toggle button.active{background:var(--accent-dim);color:var(--text)}.image-file-picker{display:flex;flex-direction:column;gap:.5rem}.image-file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.image-file-picker-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;width:100%;min-height:7rem;padding:1rem;border:2px dashed var(--border);border-radius:var(--radius);background:var(--surface-2);color:var(--muted);font:inherit;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.image-file-picker-btn:hover:not(:disabled){border-color:var(--accent-dim);color:var(--text);background:#3dd6c60f}.image-file-picker-btn:disabled{opacity:.5;cursor:not-allowed}.image-file-picker-icon{color:var(--accent)}.image-file-picker-label{font-size:.9rem;font-weight:500}.image-file-preview{display:flex;gap:.75rem;align-items:flex-start;padding:.75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2)}.image-file-thumb{width:72px;height:72px;object-fit:cover;border-radius:8px;flex-shrink:0;background:var(--bg)}.image-file-meta{flex:1;min-width:0}.image-file-name{margin:0 0 .5rem;font-size:.8rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-file-actions{display:flex;flex-wrap:wrap;gap:.35rem}@media (min-width: 600px){.app-header h1{font-size:1.4rem}}
