*,:before,:after{box-sizing:border-box}:root{--brand-primary:#ff8c00;--brand-primary-hover:#f07e00;--brand-primary-pressed:#db7300;--brand-secondary:#7043c2;--brand-accent:#14b8a6;--brand-text:#904d00;--brand-gradient:linear-gradient(90deg, #ff8c00 0%, #ffb77d 100%);--brand-gradient-soft:linear-gradient(135deg, #ff8c0014 0%, #ffb77d14 100%);--brand-tint:#ff8c001a;--brand-tint-strong:#ff8c0029;--secondary-fixed:#ebddff;--on-secondary-fixed:#250059;--primary-fixed:#ffdcc3;--on-primary-fixed:#2f1500;--tertiary-fixed:#71f8e4;--on-tertiary-fixed:#00201c;--accent-lime:#dcfce7;--accent-yellow:#fef08a;--accent-peach:#ffdcc3;--accent-mint:#71f8e4;--bg:#f8f9fa;--surface:#fff;--surface-elevated:#fff;--surface-pressed:#edeeef;--surface-tint:#fff6ec;--text-primary:#191c1d;--text-secondary:#4e5968;--text-tertiary:#8b95a1;--text-on-brand:#fff;--ink:var(--text-primary);--ink-soft:var(--text-secondary);--ink-mute:var(--text-tertiary);--border-subtle:#edeeef;--border-default:#e1e3e4;--border-strong:#d9dadb;--line:var(--border-default);--line-strong:var(--border-strong);--success:#006b5f;--success-bg:#d6f5f0;--warning:#f59e0b;--warning-bg:#fff7e5;--danger:#ba1a1a;--danger-bg:#ffdad6;--info:#3182f6;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-pill:999px;--shadow-card:0px 4px 20px #0000000d;--shadow-card-hover:0 4px 8px #0000000f, 0 12px 32px #0000001a;--shadow-modal:0 -4px 24px #0000001f;--shadow-popover:0 8px 24px #00000014;--shadow-brand:0 4px 16px #ff8c0052;--shadow-sm:var(--shadow-card);--shadow-md:var(--shadow-card-hover);--shadow-lg:var(--shadow-card-hover);--shadow-pop:var(--shadow-brand);--brand-glow:var(--shadow-brand);--brand-from:var(--brand-primary);--brand-to:#ffb77d;--brand-mid:var(--brand-primary);--bg-card:var(--surface);--bg-soft:var(--surface-tint);--font-display:"Anybody", "Plus Jakarta Sans", "Pretendard Variable", Pretendard, sans-serif;--font-body:"Plus Jakarta Sans", "Pretendard Variable", Pretendard, -apple-system, "Apple SD Gothic Neo", system-ui, sans-serif;font-family:var(--font-body);letter-spacing:-.02em;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:15px;line-height:1.5}body{overscroll-behavior:none;background-color:var(--bg);background-image:radial-gradient(#e1e3e4 1px,#0000 1px);background-size:20px 20px;margin:0}#root{min-height:100svh}button{cursor:pointer;color:inherit;-webkit-tap-highlight-color:transparent;letter-spacing:-.02em;background:0 0;border:none;outline:none;font-family:inherit}input,textarea,select{color:var(--text-primary);letter-spacing:-.02em;appearance:none;font-family:inherit;font-size:15px}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.app{background:0 0;flex-direction:column;max-width:480px;min-height:100svh;margin:0 auto;display:flex;position:relative;overflow-x:hidden}@media (width>=481px){.app{border-left:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);box-shadow:0 0 60px #0000000a}}.header{z-index:100;-webkit-backdrop-filter:blur(12px);background:#fffc;justify-content:space-between;align-items:center;padding:14px 20px;display:flex;position:sticky;top:0;box-shadow:0 1px 2px #0000000a}.header-brand{align-items:center;gap:8px;display:flex}.header-logo{flex-shrink:0;width:28px;height:28px}.header-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--brand-primary);text-transform:uppercase;font-size:22px;font-style:italic;font-weight:900}.header-chip{border-radius:var(--r-sm);background:var(--brand-secondary);color:#fff;letter-spacing:.2px;padding:3px 8px;font-size:10px;font-weight:700}.bubble-label{background:var(--brand-secondary);color:#fff;border-radius:var(--r-sm);margin-bottom:10px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-block;position:relative}.bubble-label:after{content:"";border-left:6px solid #0000;border-right:6px solid #0000;border-top:6px solid var(--brand-secondary);width:0;height:0;position:absolute;bottom:-6px;left:20px}.main{flex:1;padding:20px 16px 100px}.footer{text-align:center;color:var(--text-tertiary);padding:16px;font-size:11px}.hero{margin-bottom:20px;padding:4px 4px 12px}.hero-eyebrow{color:var(--brand-text);background:var(--brand-tint);border-radius:var(--r-pill);align-items:center;gap:6px;margin-bottom:10px;padding:5px 10px;font-size:12px;font-weight:600;display:inline-flex}.hero-title{letter-spacing:-.03em;color:var(--text-primary);margin:0;font-size:22px;font-weight:700;line-height:1.35}.hero-title em{color:var(--brand-text);font-style:normal}.hero-sub{color:var(--text-secondary);margin:6px 0 0;font-size:14px;line-height:1.5}.card{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--shadow-card);border:1px solid var(--border-default)}.panel-card{background:var(--surface);border-radius:var(--r-xl);border:1px solid var(--border-default);box-shadow:var(--shadow-card);margin-bottom:24px;padding:24px 20px 20px;position:relative}.panel-card>.bubble-label{margin-bottom:0;position:absolute;top:-12px;left:24px}.panel-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);align-items:center;gap:6px;margin:8px 0 2px;font-size:26px;font-style:italic;font-weight:900;display:flex}.panel-title .sparkle{color:#facc15;font-size:22px;font-style:normal}.panel-sub{color:var(--text-tertiary);margin:0 0 18px;font-size:13px}.seg-control{grid-auto-columns:1fr;grid-auto-flow:column;gap:12px;margin-bottom:20px;display:grid}.seg-btn{border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--border-default);color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:16px 4px;font-size:12px;font-weight:700;transition:all .15s cubic-bezier(.2,.8,.2,1);display:flex}.seg-btn:active{transform:scale(.95)}.seg-btn.active{border-color:var(--brand-primary);color:var(--brand-primary);background:var(--surface)}.seg-emoji{font-size:22px;line-height:1}.field{margin-bottom:14px}.field-label{color:var(--text-primary);align-items:center;gap:6px;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.field-label .optional{color:var(--text-tertiary);font-size:11px;font-weight:500}.field input,.field textarea{border:1.5px solid var(--border-default);border-radius:var(--r-md);background:var(--surface);width:100%;padding:14px 16px;font-size:14px;transition:border-color .15s,box-shadow .15s}.field input::placeholder,.field textarea::placeholder{color:var(--text-tertiary)}.field input:focus,.field textarea:focus{border-color:var(--brand-text);box-shadow:0 0 0 3px var(--brand-tint);outline:none}.field textarea{resize:none;min-height:88px;line-height:1.5}.url-row{gap:8px;display:flex}.url-row input{flex:1}.fetch-btn{background:var(--text-primary);color:#fff;border-radius:var(--r-pill);white-space:nowrap;padding:0 18px;font-size:13px;font-weight:700;transition:transform .1s,opacity .15s}.fetch-btn:active{transform:scale(.96)}.fetch-btn:disabled{opacity:.4}.product-chip{background:var(--surface-tint);border-radius:var(--r-md);border:1px solid var(--brand-tint-strong);align-items:flex-start;gap:10px;margin-bottom:14px;padding:12px 14px;display:flex}.product-chip .chip-icon{flex-shrink:0;font-size:20px}.product-chip .chip-name{color:var(--text-primary);margin-bottom:2px;font-size:13px;font-weight:700;line-height:1.4}.product-chip .chip-meta{color:var(--text-secondary);font-size:11px}.upload-zone{border:2px dashed var(--border-default);border-radius:var(--r-lg);text-align:center;cursor:pointer;background:var(--surface);padding:36px 20px;transition:all .2s}.upload-zone:active{border-color:var(--brand-text);background:var(--surface-tint);transform:scale(.99)}.upload-zone input[type=file]{display:none}.upload-zone .upload-icon{margin-bottom:10px;font-size:32px;display:block}.upload-zone .upload-title{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:700}.upload-zone .upload-hint{color:var(--text-tertiary);font-size:12px}.preview-images{scroll-snap-type:x mandatory;gap:8px;padding:12px 0;display:flex;overflow-x:auto}.preview-img{object-fit:cover;border-radius:var(--r-md);border:1px solid var(--border-default);scroll-snap-align:start;flex-shrink:0;width:80px;height:80px}.options-section{margin-top:24px;padding:0 4px}.option-row{margin-bottom:16px}.option-row-label{color:var(--text-primary);margin-bottom:8px;font-size:13px;font-weight:600}.chip-group{flex-wrap:wrap;gap:6px;display:flex}.chip{border-radius:var(--r-pill);background:var(--surface);border:1px solid var(--border-default);color:var(--text-primary);align-items:center;gap:4px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.chip:active{transform:scale(.96)}.chip.active{background:var(--text-primary);color:#fff;border-color:var(--text-primary);font-weight:700}.chip-emoji{font-size:14px}.rating-stars{justify-content:center;gap:6px;padding:8px 0;display:flex}.star-btn{filter:grayscale();opacity:.25;padding:4px;font-size:30px;line-height:1;transition:all .15s}.star-btn.on{filter:none;opacity:1}.rating-label{text-align:center;color:var(--text-secondary);margin-top:4px;font-size:12px;font-weight:600}.cta-wrap{z-index:50;background:linear-gradient(#f8f9fa00 0%,#f8f9faeb 30% 100%);margin-top:8px;padding:16px 0 8px;position:sticky;bottom:0}.cta{background:var(--brand-gradient);color:#fff;border-radius:var(--r-pill);letter-spacing:-.02em;width:100%;box-shadow:var(--shadow-brand);justify-content:center;align-items:center;gap:8px;padding:17px;font-size:16px;font-weight:700;transition:transform .12s,filter .15s;display:flex}.cta:hover{filter:brightness(1.04)}.cta:active{filter:brightness(.96);transform:scale(.98);box-shadow:0 2px 8px #ff8c0033}.cta:disabled{opacity:.4;background:var(--border-default);color:var(--text-tertiary);box-shadow:none;cursor:not-allowed}.error-msg{background:var(--danger-bg);color:#b91c1c;border-radius:var(--r-md);border:1px solid #fecaca;align-items:flex-start;gap:8px;margin:12px 0;padding:12px 14px;font-size:13px;display:flex}.loading-bar-wrap{z-index:200;pointer-events:none;background:0 0;width:100%;max-width:480px;height:3px;position:fixed;top:0;left:50%;transform:translate(-50%)}.loading-bar{background:var(--brand-primary);border-radius:0 0 var(--r-pill) var(--r-pill);width:30%;height:100%;animation:1.4s ease-in-out infinite loadingSlide}@keyframes loadingSlide{0%{width:30%;transform:translate(-100%)}50%{width:50%}to{width:30%;transform:translate(400%)}}.loading-toast{background:var(--text-primary);color:#fff;border-radius:var(--r-pill);z-index:210;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:600;animation:.3s cubic-bezier(.2,.8,.2,1) toastIn;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0003}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.loading-toast-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.skeleton-card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-card);margin-bottom:14px;padding:18px}.skeleton-line{border-radius:var(--r-sm);background:linear-gradient(90deg, var(--surface-pressed) 0%, var(--border-subtle) 50%, var(--surface-pressed) 100%);background-size:200% 100%;height:12px;margin-bottom:10px;animation:1.4s linear infinite shimmer}.skeleton-line:last-child{margin-bottom:0}.skeleton-line.short{width:30%;height:10px}.skeleton-line.medium{width:70%}.skeleton-line.full{width:100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.result-head{margin-bottom:16px}.result-back-btn{color:var(--text-secondary);border-radius:var(--r-pill);align-items:center;gap:4px;margin-bottom:12px;margin-left:-12px;padding:8px 12px;font-size:13px;font-weight:600;transition:background .15s;display:inline-flex}.result-back-btn:active{background:var(--surface-pressed)}.result-title{letter-spacing:-.03em;color:var(--text-primary);margin:0 0 4px;font-size:20px;font-weight:700}.result-title em{color:var(--brand-text);font-style:normal}.result-sub{color:var(--text-secondary);font-size:13px}.review-card{background:var(--surface);border-radius:var(--r-xl);border:1px solid var(--border-default);box-shadow:var(--shadow-card);margin-bottom:14px;transition:all .2s cubic-bezier(.2,.8,.2,1);animation:.35s cubic-bezier(.2,.8,.2,1) both slideUp;position:relative;overflow:hidden}.review-card:first-child{animation-delay:0s}.review-card:nth-child(2){animation-delay:60ms}.review-card:nth-child(3){animation-delay:.12s}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.review-card:active{transform:scale(.995)}.review-card.selected{border-color:var(--brand-text);box-shadow:var(--shadow-brand)}.review-card-head{background:var(--surface-tint);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.review-badge{letter-spacing:.2px;border-radius:var(--r-sm);background:var(--brand-secondary);color:#fff;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.review-len{color:var(--text-tertiary);font-size:11px;font-weight:600}.review-body{padding:16px 18px 18px}.review-text{color:var(--text-primary);white-space:pre-wrap;letter-spacing:-.02em;margin:0 0 14px;font-size:14px;line-height:1.7}.review-tags{border-top:1px dashed var(--border-default);flex-wrap:wrap;gap:5px;padding-top:12px;display:flex}.tag{color:var(--brand-secondary);letter-spacing:-.01em;padding:4px 2px;font-size:12px;font-weight:700}.copy-btn{background:var(--brand-gradient);color:#fff;border-radius:var(--r-pill);justify-content:center;align-items:center;gap:6px;width:100%;margin-top:14px;padding:13px;font-size:13px;font-weight:700;transition:all .15s;display:flex;box-shadow:0 2px 8px #ff8c0040}.copy-btn:active{transform:scale(.98)}.copy-btn.copied{background:var(--success);box-shadow:none}.header-actions{align-items:center;gap:8px;display:flex}.header-icon-btn{border-radius:var(--r-pill);background:var(--surface-pressed);width:36px;height:36px;color:var(--text-secondary);border:none;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.header-icon-btn:active{background:var(--border-default);transform:scale(.94)}.mode-toggle{grid-template-columns:1fr 1fr;gap:10px;margin:0 0 16px;display:grid}.mode-btn{background:var(--surface);border:1.5px solid var(--border-default);border-radius:var(--r-lg);text-align:left;align-items:center;gap:10px;padding:14px;transition:all .15s;display:flex}.mode-btn .mode-emoji{font-size:22px;line-height:1}.mode-btn .mode-text{flex-direction:column;gap:2px;display:flex}.mode-btn .mode-label{color:var(--text-primary);letter-spacing:-.02em;font-size:13px;font-weight:700}.mode-btn .mode-sub{color:var(--text-tertiary);font-size:10.5px}.mode-btn.active{border-color:var(--brand-primary);background:var(--surface-tint);box-shadow:0 0 0 3px var(--brand-tint)}.mode-btn.active .mode-label{color:var(--brand-text)}.mode-btn:active{transform:scale(.98)}.deeplink-btn{border-radius:var(--r-md);background:var(--brand-primary);color:#fff;letter-spacing:-.02em;width:100%;box-shadow:var(--shadow-brand);justify-content:center;align-items:center;gap:6px;margin-top:8px;padding:12px;font-size:13px;font-weight:700;transition:background .15s,transform .12s;animation:.25s cubic-bezier(.2,.8,.2,1) slideUp;display:flex}.deeplink-btn:hover{background:var(--brand-primary-hover)}.deeplink-btn:active{background:var(--brand-primary-pressed);transform:scale(.98)}.confirm-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f0f1273;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.confirm-modal{background:var(--surface);border-radius:var(--r-xl);text-align:center;width:100%;max-width:340px;padding:24px 22px 18px;animation:.2s cubic-bezier(.2,.8,.2,1) slideUp;overflow:hidden;box-shadow:0 20px 60px #00000040}.confirm-emoji{margin-bottom:10px;font-size:36px;line-height:1}.confirm-title{color:var(--text-primary);letter-spacing:-.03em;margin:0 0 6px;font-size:17px;font-weight:700}.confirm-text{color:var(--text-secondary);margin:0 0 18px;font-size:14px;line-height:1.5}.confirm-actions{gap:8px;display:flex}.confirm-btn{border-radius:var(--r-md);letter-spacing:-.02em;flex:1;padding:13px;font-size:14px;font-weight:700;transition:transform .1s,background .15s}.confirm-btn:active{transform:scale(.98)}.confirm-cancel{background:var(--surface-pressed);color:var(--text-secondary)}.confirm-cancel:hover{background:var(--border-default)}.confirm-go{background:var(--brand-primary);color:#fff}.confirm-go:hover{background:var(--brand-primary-hover)}.confirm-progress{background:var(--surface-pressed);border-radius:999px;height:3px;margin-top:14px;overflow:hidden}.confirm-progress-bar{background:var(--brand-primary);border-radius:999px;height:100%;transition:width 1s linear}.drawer-backdrop{z-index:200;background:#0f0f1273;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.drawer{background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:480px;max-height:85vh;box-shadow:var(--shadow-modal);flex-direction:column;animation:.3s cubic-bezier(.2,.8,.2,1) drawerUp;display:flex;overflow:hidden}@keyframes drawerUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.drawer-handle{background:var(--border-default);border-radius:var(--r-pill);width:32px;height:4px;margin:8px auto 0}.drawer-head{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:14px 20px 12px;display:flex;position:relative}.drawer-title{letter-spacing:-.03em;color:var(--text-primary);font-size:17px;font-weight:700}.drawer-close{border-radius:var(--r-pill);width:32px;height:32px;color:var(--text-secondary);background:var(--surface-pressed);justify-content:center;align-items:center;font-size:14px;display:flex}.drawer-close:hover{background:var(--border-default)}.drawer-clear{color:var(--danger);border-radius:var(--r-pill);padding:6px 10px;font-size:12px;font-weight:600}.drawer-clear:active{background:#ef444414}.drawer-empty{text-align:center;padding:60px 20px}.drawer-empty-emoji{margin-bottom:12px;font-size:44px}.drawer-empty-title{color:var(--text-primary);margin-bottom:4px;font-size:15px;font-weight:700}.drawer-empty-sub{color:var(--text-tertiary);font-size:12px}.drawer-list{flex-direction:column;flex:1;gap:10px;padding:12px 16px 24px;display:flex;overflow-y:auto}.history-card{text-align:left;background:var(--surface);border:1px solid var(--border-default);border-radius:var(--r-xl);box-shadow:var(--shadow-card);flex-direction:column;gap:6px;padding:16px;transition:all .15s;display:flex;position:relative}.history-card:hover{transform:translateY(-2px)}.history-card:active{border-color:var(--brand-primary);background:var(--surface-tint);transform:scale(.99)}.history-card-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.history-kind{color:var(--on-primary-fixed);background:var(--primary-fixed);border-radius:var(--r-pill);padding:4px 10px;font-size:11px;font-weight:700}.history-time{color:var(--text-tertiary);font-size:11px}.history-product{color:var(--text-primary);letter-spacing:-.02em;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:700;overflow:hidden}.history-preview{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:1.45;display:-webkit-box;overflow:hidden}.history-del{border-radius:var(--r-pill);opacity:.5;cursor:pointer;padding:4px 6px;font-size:14px;transition:opacity .15s;position:absolute;top:10px;right:12px}.history-del:hover,.history-del:active{opacity:1;background:#ef44441a}.auth-overlay{z-index:1100;background:#0f0f1273;justify-content:center;align-items:flex-end;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.auth-modal{background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:480px;box-shadow:var(--shadow-modal);max-height:92vh;padding:8px 24px 28px;animation:.3s cubic-bezier(.2,.8,.2,1) drawerUp;position:relative;overflow-y:auto}.auth-modal:before{content:"";background:var(--border-default);border-radius:var(--r-pill);width:32px;height:4px;margin:0 auto 16px;display:block}.auth-close{width:32px;height:32px;color:var(--text-tertiary);border-radius:var(--r-pill);background:var(--surface-pressed);justify-content:center;align-items:center;font-size:18px;display:flex;position:absolute;top:16px;right:18px}.auth-close:hover{background:var(--border-default);color:var(--text-primary)}.auth-head{text-align:center;margin-bottom:20px}.auth-emoji{font-size:32px;line-height:1}.auth-title{color:var(--text-primary);letter-spacing:-.03em;margin:8px 0 4px;font-size:20px;font-weight:700}.auth-sub{color:var(--text-secondary);margin:0;font-size:13px}.auth-naver-btn{color:#fff;border-radius:var(--r-md);background:#03c75a;justify-content:center;align-items:center;gap:10px;width:100%;padding:14px 12px;font-size:14px;font-weight:700;transition:transform .1s,filter .15s;display:flex}.auth-naver-btn:hover{filter:brightness(1.05)}.auth-naver-btn:active{transform:scale(.98)}.naver-mark{color:#03c75a;background:#fff;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;font-weight:900;display:inline-flex}.auth-divider{text-align:center;color:var(--text-tertiary);margin:18px 0;font-size:11px;position:relative}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-subtle);width:calc(50% - 24px);height:1px;position:absolute;top:50%}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--text-secondary);letter-spacing:-.02em;font-size:12px;font-weight:600}.auth-field input,.auth-field textarea{border:1.5px solid var(--border-default);border-radius:var(--r-md);color:var(--text-primary);background:var(--surface);padding:14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.auth-field input:focus,.auth-field textarea:focus{border-color:var(--brand-text);box-shadow:0 0 0 3px var(--brand-tint);outline:none}.auth-field textarea{resize:vertical;min-height:56px;font-family:inherit}.auth-error{color:#b91c1c;background:var(--danger-bg);border-radius:var(--r-md);margin-top:4px;padding:10px 12px;font-size:13px}.auth-submit{background:var(--brand-primary);color:#fff;border-radius:var(--r-md);letter-spacing:-.02em;box-shadow:var(--shadow-brand);margin-top:6px;padding:14px;font-size:14px;font-weight:700;transition:transform .1s,background .15s}.auth-submit:hover{background:var(--brand-primary-hover)}.auth-submit:active{background:var(--brand-primary-pressed);transform:scale(.98)}.auth-submit:disabled{opacity:.4;cursor:not-allowed;background:var(--border-default);color:var(--text-tertiary);box-shadow:none}.auth-toggle{text-align:center;color:var(--text-secondary);margin-top:14px;font-size:13px}.auth-toggle button{color:var(--brand-text);padding:4px 6px;font-weight:600}.auth-toggle button:hover{text-underline-offset:2px;text-decoration:underline}.profile-modal{max-width:480px}.profile-form{gap:14px}.profile-row{gap:12px;display:flex}.profile-col{flex:1}.profile-label{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:600;display:block}.profile-chips{flex-wrap:wrap;gap:6px}.profile-actions{gap:8px;margin-top:10px;display:flex}.profile-skip{background:var(--surface-pressed);color:var(--text-secondary);border-radius:var(--r-md);flex:1;padding:14px;font-size:14px;font-weight:700}.profile-skip:hover{background:var(--border-default)}.profile-save{flex:1.4}.header-login-btn{background:var(--brand-primary);color:#fff;border-radius:var(--r-pill);padding:8px 14px;font-size:12px;font-weight:700;transition:background .15s}.header-login-btn:hover{background:var(--brand-primary-hover)}.user-menu-wrap{position:relative}.user-avatar-btn{background:var(--brand-primary);color:#fff;border-radius:999px;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:inline-flex;overflow:hidden}.user-avatar-img{object-fit:cover;width:100%;height:100%}.user-avatar-fallback{padding-top:1px}.user-menu{background:var(--surface);border-radius:var(--r-lg);width:220px;box-shadow:var(--shadow-popover);z-index:200;border:1px solid var(--border-subtle);padding:6px;animation:.15s cubic-bezier(.2,.8,.2,1) slideUp;position:absolute;top:calc(100% + 8px);right:0}.user-menu-head{border-bottom:1px solid var(--border-subtle);margin-bottom:4px;padding:10px 12px 8px}.user-menu-name{color:var(--text-primary);font-size:14px;font-weight:700}.user-menu-email{color:var(--text-tertiary);word-break:break-all;margin-top:2px;font-size:11px}.user-menu-item{text-align:left;border-radius:var(--r-sm);width:100%;color:var(--text-primary);align-items:center;gap:10px;padding:10px 12px;font-size:13px;transition:background .12s;display:flex;position:relative}.user-menu-item:hover{background:var(--surface-pressed)}.user-menu-badge{background:var(--brand-accent);color:#fff;letter-spacing:.3px;border-radius:999px;margin-left:auto;padding:2px 7px;font-size:9px;font-weight:700}.drawer-sync-badge{color:#0369a1;vertical-align:middle;background:#e0f2fe;border-radius:999px;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.search-fallback{background:var(--surface-tint);border:1px solid var(--brand-tint-strong);border-radius:var(--r-md);margin-top:10px;padding:14px 14px 12px;animation:.2s cubic-bezier(.2,.8,.2,1) slideUp}.food-hint{border-radius:var(--r-md);background:#fff7ed;border:1px solid #fed7aa;gap:12px;margin-bottom:14px;padding:14px;animation:.2s cubic-bezier(.2,.8,.2,1) slideUp;display:flex}.food-hint strong{color:#9a3412;margin-bottom:4px;font-size:14px;font-weight:700;display:block}.food-hint p{color:#7c2d12;margin:0;font-size:13px}.search-fallback-title{color:var(--brand-text);margin-bottom:4px;font-size:13px;font-weight:700}.search-fallback-desc{color:var(--text-secondary);margin:0 0 10px;font-size:12px;line-height:1.4}.search-fallback-alts{border-top:1px dashed var(--border-subtle);gap:8px;margin-top:10px;padding-top:10px;display:flex}.alt-btn{border-radius:var(--r-sm);background:var(--surface-elevated);border:1px solid var(--border-default);height:38px;color:var(--text-primary);cursor:pointer;flex:1;justify-content:center;align-items:center;gap:6px;padding:0 12px;font-size:13px;font-weight:600;transition:background .12s,border-color .12s;display:inline-flex}.alt-btn:hover{background:var(--surface-pressed);border-color:var(--brand-text)}.welcome-screen{z-index:200;background:var(--surface);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);flex-direction:column;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.welcome-inner{flex-direction:column;flex:1;justify-content:center;width:100%;max-width:480px;margin:0 auto;padding:32px 28px 24px;display:flex}.welcome-brand{justify-content:center;align-items:center;gap:12px;margin-bottom:56px;display:flex}.welcome-logo{width:56px;height:56px;display:block}.welcome-wordmark{color:var(--text-primary);letter-spacing:-.03em;margin:0;font-size:36px;font-weight:800;line-height:1}.welcome-features{flex-direction:column;gap:28px;margin:0;padding:0;list-style:none;display:flex}.welcome-feature{align-items:flex-start;gap:16px;display:flex}.welcome-feature-icon{border-radius:var(--r-md);background:var(--surface-tint);width:44px;height:44px;color:var(--brand-text);flex-shrink:0;justify-content:center;align-items:center;display:flex}.welcome-feature-text{flex:1;padding-top:2px}.welcome-feature-title{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:4px;font-size:17px;font-weight:700;line-height:1.35}.welcome-feature-desc{color:var(--text-tertiary);letter-spacing:-.01em;font-size:14px;font-weight:500;line-height:1.5}.welcome-cta-wrap{padding:16px 20px calc(20px + env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border-subtle)}.welcome-cta{border-radius:var(--r-lg);background:var(--brand-primary);color:#fff;letter-spacing:-.02em;cursor:pointer;border:none;width:100%;height:56px;font-size:17px;font-weight:700;transition:background .12s,transform 80ms}.welcome-cta:hover{background:var(--brand-primary-hover)}.welcome-cta:active{background:var(--brand-primary-pressed);transform:scale(.98)}@media (width<=380px){.welcome-wordmark{font-size:32px}.welcome-logo{width:48px;height:48px}.welcome-features{gap:24px}.welcome-feature-title{font-size:16px}.welcome-feature-desc{font-size:13px}}.bottom-tabbar{z-index:90;background:var(--surface);border-top:1px solid var(--border-default);border-radius:var(--r-lg) var(--r-lg) 0 0;width:100%;max-width:480px;padding-bottom:env(safe-area-inset-bottom);display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -4px 10px #00000005}.bottom-tab{cursor:pointer;color:var(--text-tertiary);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;min-height:56px;padding:10px 0;transition:color .12s;display:flex}.bottom-tab:active{background:var(--surface-pressed)}.bottom-tab.active{color:var(--brand-primary)}.bottom-tab.active .bottom-tab-icon svg{stroke-width:2.5px}.bottom-tab.active .bottom-tab-label{font-weight:700}.bottom-tab-icon{justify-content:center;align-items:center;height:22px;display:flex}.bottom-tab-label{letter-spacing:-.01em;font-size:11px;font-weight:600}.main-with-tabbar{padding-bottom:calc(72px + env(safe-area-inset-bottom))}.page{padding:8px 4px 24px}.page-head{justify-content:space-between;align-items:flex-end;gap:12px;padding:12px 4px 16px;display:flex}.page-title{letter-spacing:-.03em;color:var(--text-primary);margin:0;font-size:24px;font-weight:800;line-height:1.3}.page-count{color:var(--text-tertiary);margin-left:6px;font-size:14px;font-weight:400}.page-sub{color:var(--text-tertiary);margin:4px 0 0;font-size:12px;font-weight:500}.page-action{border-radius:var(--r-pill);background:var(--surface-elevated);border:1px solid var(--border-default);height:32px;color:var(--text-secondary);cursor:pointer;padding:0 12px;font-size:12px;font-weight:600}.page-action:hover{background:var(--surface-pressed)}.page-empty{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:60px 24px;display:flex}.page-empty-icon{margin-bottom:8px;font-size:48px}.page-empty-title{color:var(--text-primary);letter-spacing:-.02em;font-size:16px;font-weight:700}.page-empty-sub{color:var(--text-tertiary);max-width:280px;font-size:13px;line-height:1.5}.page-empty-cta{border-radius:var(--r-md);background:var(--brand-primary);color:#fff;letter-spacing:-.02em;cursor:pointer;border:none;height:44px;margin-top:20px;padding:0 24px;font-size:14px;font-weight:700;transition:background .12s}.page-empty-cta:hover{background:var(--brand-primary-hover)}.history-page-list{flex-direction:column;gap:10px;padding:0 4px;display:flex}.my-guest-card{background:var(--surface-tint);border-radius:var(--r-xl);text-align:center;margin:8px 4px 0;padding:32px 24px 24px}.my-guest-emoji{margin-bottom:8px;font-size:48px}.my-guest-title{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:20px;font-size:18px;font-weight:800}.my-guest-list{text-align:left;background:var(--surface);border-radius:var(--r-md);flex-direction:column;gap:10px;margin:0 0 24px;padding:16px;list-style:none;display:flex}.my-guest-list li{color:var(--text-secondary);letter-spacing:-.01em;align-items:center;gap:10px;font-size:14px;font-weight:500;display:flex}.my-guest-list li span{justify-content:center;width:24px;font-size:16px;display:inline-flex}.my-guest-cta{border-radius:var(--r-md);color:#fff;letter-spacing:-.02em;cursor:pointer;background:#03c75a;border:none;width:100%;height:52px;font-size:15px;font-weight:700;transition:filter .12s}.my-guest-cta:hover{filter:brightness(.95)}.my-profile-card{background:var(--surface-elevated);border:1px solid var(--border-default);border-radius:var(--r-xl);box-shadow:var(--shadow-card);align-items:center;gap:14px;margin:4px 4px 16px;padding:20px 18px;display:flex}.my-avatar{border:4px solid var(--brand-primary);background:var(--brand-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:22px;font-weight:700;display:flex;overflow:hidden}.my-avatar img{object-fit:cover;width:100%;height:100%}.my-profile-info{flex:1;min-width:0}.my-profile-name{color:var(--text-primary);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:17px;font-weight:700;line-height:1.2;overflow:hidden}.my-profile-email{color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.my-menu{background:var(--surface-elevated);border:1px solid var(--border-default);border-radius:var(--r-xl);box-shadow:var(--shadow-card);margin:0 4px;overflow:hidden}.my-menu-item:nth-child(2n) .my-menu-icon{background:var(--secondary-fixed)}.my-menu-item:nth-child(3n) .my-menu-icon{background:var(--tertiary-fixed)}.my-menu-item{border:none;border-bottom:1px solid var(--border-subtle);width:100%;height:56px;color:var(--text-primary);text-align:left;cursor:pointer;letter-spacing:-.01em;background:0 0;align-items:center;gap:12px;padding:0 18px;font-size:15px;font-weight:500;transition:background .12s;display:flex}.my-menu-item:last-child{border-bottom:none}.my-menu-item:active{background:var(--surface-pressed)}.my-menu-icon{background:var(--primary-fixed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:inline-flex}.my-menu-label{flex:1}.my-menu-arrow{color:var(--text-tertiary);font-size:20px;font-weight:400}.my-menu-badge{background:var(--brand-primary);color:#fff;border-radius:var(--r-pill);letter-spacing:0;padding:2px 6px;font-size:10px;font-weight:700}.my-footer{text-align:center;color:var(--text-tertiary);padding:32px 0 8px;font-size:11px;font-weight:500}.ai-disclaimer{background:var(--surface-tint);color:var(--text-secondary);letter-spacing:-.01em;border-radius:var(--r-pill);align-items:center;gap:6px;margin-top:12px;padding:6px 12px;font-size:12px;font-weight:500;display:inline-flex}.review-actions{gap:8px;margin-top:12px;display:flex}.review-actions .copy-btn{flex:1}.share-btn{border-radius:var(--r-md);background:var(--surface-elevated);border:1px solid var(--border-default);height:44px;color:var(--text-primary);letter-spacing:-.01em;cursor:pointer;flex-shrink:0;padding:0 16px;font-size:14px;font-weight:600;transition:background .12s,border-color .12s}.share-btn:hover{background:var(--surface-pressed);border-color:var(--brand-text)}.share-btn.shared{background:var(--brand-primary);color:#fff;border-color:var(--brand-text)}.welcome-legal-note{color:var(--text-tertiary);text-align:center;letter-spacing:-.01em;margin:12px 0 0;font-size:11px;line-height:1.5}.welcome-legal-link{font:inherit;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline}.legal-page{max-width:720px;margin:0 auto}.legal-back-btn{color:var(--text-secondary);cursor:pointer;letter-spacing:-.01em;background:0 0;border:none;padding:0 0 8px;font-size:14px;font-weight:600}.legal-back-btn:hover{color:var(--text-primary)}.legal-content{background:var(--surface-elevated);border:1px solid var(--border-subtle);border-radius:var(--r-xl);color:var(--text-secondary);letter-spacing:-.01em;margin:0 4px;padding:24px 20px;font-size:14px;line-height:1.7}.legal-content h3{color:var(--text-primary);letter-spacing:-.02em;margin:24px 0 8px;font-size:15px;font-weight:700}.legal-content h3:first-child{margin-top:0}.legal-content p{margin:0 0 12px}.legal-content ul{margin:0 0 12px;padding-left:20px}.legal-content li{margin-bottom:6px}.legal-content strong{color:var(--text-primary);font-weight:600}.legal-content .legal-meta{border-top:1px solid var(--border-subtle);color:var(--text-tertiary);margin-top:24px;padding-top:16px;font-size:12px}.error-boundary{background:var(--surface);justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.error-boundary-card{text-align:center;background:var(--surface-elevated);border:1px solid var(--border-subtle);border-radius:var(--r-xl);width:100%;max-width:360px;box-shadow:var(--shadow-card);padding:40px 28px}.error-boundary-emoji{margin-bottom:16px;font-size:56px}.error-boundary-title{color:var(--text-primary);letter-spacing:-.02em;margin:0 0 12px;font-size:18px;font-weight:800}.error-boundary-sub{color:var(--text-secondary);letter-spacing:-.01em;margin:0 0 24px;font-size:14px;line-height:1.6}.error-boundary-cta{border-radius:var(--r-md);background:var(--brand-primary);color:#fff;letter-spacing:-.02em;cursor:pointer;border:none;width:100%;height:48px;font-size:15px;font-weight:700;transition:background .12s}.error-boundary-cta:hover{background:var(--brand-primary-hover)}
