:root{--bg:#fbf7f2;--bg-card:#fff;--bg-warm:#f5ede3;--text:#1a1714;--text-secondary:#6b635a;--text-muted:#9c948a;--accent:#c4642d;--accent-hover:#a8532b;--accent-light:#f8e8dd;--sage:#7a8c6e;--sage-light:#e8ede4;--border:#e8e0d6;--shadow:0 2px 12px rgba(26,23,20,.06);--shadow-lg:0 8px 32px rgba(26,23,20,.1);--radius:16px;--radius-sm:10px;--font-display:"DM Serif Display",Georgia,serif;--font-body:"DM Sans",-apple-system,sans-serif}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.landing,body{min-height:100dvh}.landing{display:flex;flex-direction:column}.landing-nav{justify-content:space-between;padding:20px 24px;max-width:1100px;width:100%;margin:0 auto}.landing-nav,.logo{display:flex;align-items:center}.logo{font-family:var(--font-display);font-size:26px;color:var(--accent);gap:8px}.logo-dot{width:8px;height:8px;background:var(--sage);border-radius:50%;display:inline-block}.landing-hero{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px 60px;text-align:center;max-width:640px;margin:0 auto}.landing-hero h1{font-family:var(--font-display);font-size:clamp(36px,8vw,56px);line-height:1.1;margin-bottom:20px;color:var(--text)}.landing-hero h1 em{color:var(--accent);font-style:normal}.landing-hero p{font-size:17px;color:var(--text-secondary);line-height:1.6;margin-bottom:36px;max-width:440px}.landing-steps{display:flex;gap:24px;margin-bottom:40px;width:100%;max-width:480px}.landing-step{flex:1 1;text-align:center;padding:20px 12px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border)}.landing-step-num{width:28px;height:28px;background:var(--accent-light);color:var(--accent);font-weight:700;font-size:13px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin-bottom:8px}.landing-step-title{font-weight:600;font-size:14px;margin-bottom:4px}.landing-step-desc{font-size:12px;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:50px;font-family:var(--font-body);font-size:15px;font-weight:600;cursor:pointer;border:none;transition:all .2s;text-decoration:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--text-secondary);border:1.5px solid var(--border)}.btn-outline:hover{border-color:var(--text-muted);background:var(--bg-card)}.btn-google{background:#fff;color:#333;border:1.5px solid #ddd;box-shadow:0 1px 4px rgba(0,0,0,.08)}.btn-google:hover{background:#f8f8f8;box-shadow:var(--shadow)}.landing-btns{display:flex;flex-direction:column;gap:12px;align-items:center}.dashboard{max-width:640px;margin:0 auto;padding:0 20px 40px}.dash-header{justify-content:space-between;padding:20px 0}.dash-header,.dash-user{display:flex;align-items:center}.dash-user{gap:10px}.dash-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.dash-avatar-placeholder{width:36px;height:36px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.btn-sm{padding:8px 16px;font-size:13px;border-radius:50px}.greeting{font-family:var(--font-display);font-size:28px;margin-bottom:4px}.greeting-sub{color:var(--text-secondary);font-size:15px;margin-bottom:28px}.upload-section{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px;margin-bottom:36px}.upload-card{background:var(--bg-card);border:2px dashed var(--border);border-radius:var(--radius);padding:28px 16px;text-align:center;cursor:pointer;transition:all .25s;display:flex;flex-direction:column;align-items:center;gap:10px}.upload-card:hover{border-color:var(--accent);background:var(--accent-light);transform:translateY(-2px);box-shadow:var(--shadow)}.upload-card svg{width:44px;height:44px;color:var(--accent)}.upload-card-title{font-weight:600;font-size:15px}.upload-card-desc{font-size:12px;color:var(--text-muted)}.section-title{font-family:var(--font-display);font-size:22px;margin-bottom:16px}.past-scans{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.scan-thumb{background:var(--bg-card);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:all .2s;border:1px solid var(--border)}.scan-thumb:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.scan-thumb-img{width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--bg-warm);display:block}.scan-thumb-img-placeholder{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--accent-light),var(--sage-light));display:flex;align-items:center;justify-content:center;font-size:28px}.scan-thumb-info{padding:10px 12px}.scan-thumb-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scan-thumb-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.scan-view{max-width:640px;margin:0 auto;padding:0 20px 40px}.scan-view-header{gap:12px;padding:20px 0}.btn-back,.scan-view-header{display:flex;align-items:center}.btn-back{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);background:var(--bg-card);cursor:pointer;justify-content:center;transition:all .2s;flex-shrink:0}.btn-back:hover{background:var(--bg-warm)}.scan-view-title{font-family:var(--font-display);font-size:24px}.category-group{margin-bottom:28px}.category-label{font-family:var(--font-display);font-size:20px;color:var(--accent);margin-bottom:12px;padding-bottom:6px;border-bottom:2px solid var(--accent-light)}.menu-item-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;margin-bottom:12px;display:flex;gap:0;transition:box-shadow .2s}.menu-item-card:hover{box-shadow:var(--shadow)}.menu-item-img-wrap{width:110px;min-height:110px;flex-shrink:0;background:var(--bg-warm);position:relative;overflow:hidden}.menu-item-img{width:100%;height:100%;object-fit:cover;display:block}.menu-item-img-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-light) 0,var(--bg-warm) 100%)}.shimmer{background:linear-gradient(90deg,var(--bg-warm) 25%,var(--accent-light) 50%,var(--bg-warm) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner-sm{width:22px;height:22px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.menu-item-info{padding:14px 16px;flex:1 1;display:flex;flex-direction:column;justify-content:center;min-width:0}.menu-item-name{font-weight:600;font-size:15px;margin-bottom:4px}.menu-item-desc{font-size:13px;color:var(--text-secondary);line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.menu-item-price{font-weight:700;color:var(--accent);font-size:15px}.progress-bar-wrap{background:var(--bg-warm);border-radius:20px;height:8px;margin:16px 0;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--sage));border-radius:20px;transition:width .4s ease}.progress-text{text-align:center;font-size:14px;color:var(--text-secondary);margin-bottom:20px}.processing-overlay{position:fixed;inset:0;background:hsla(33,53%,97%,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;padding:24px;text-align:center}.processing-spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:20px}.processing-title{font-family:var(--font-display);font-size:22px;margin-bottom:6px}.processing-sub{color:var(--text-secondary);font-size:14px}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}.empty-state-icon{font-size:40px;margin-bottom:10px}input[type=file]{display:none}@media (max-width:420px){.landing-steps{flex-direction:column;gap:12px}.upload-section{gap:10px}.menu-item-img-wrap{width:90px;min-height:90px}}