:root{color:#273044;background:#fffaf5;font-family:Pretendard Variable,SUIT,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0;background:radial-gradient(circle at 18% 0%,rgba(255,226,207,.7),transparent 32%),radial-gradient(circle at 88% 8%,rgba(235,242,255,.9),transparent 30%),linear-gradient(180deg,#fffaf5,#f7fbff 46%,#fff8fb)}button,input{font:inherit}button{cursor:pointer}.app-shell{width:min(100%,480px);min-height:100vh;margin:0 auto;padding:16px 14px 54px;background:#fffdfaf0}.top-section{display:grid;gap:12px;border:1px solid rgba(255,211,194,.82);border-radius:24px;padding:20px 18px;background:#ffffffeb;box-shadow:0 18px 44px #a4755b1f}.app-label{margin:0 0 8px;color:#f26d5b;font-size:.78rem;font-weight:900;letter-spacing:0}h1,h2,h3,p{margin-top:0}h1{margin-bottom:8px;color:#273044;font-size:1.5rem;line-height:1.25;letter-spacing:0}.description{margin-bottom:0;color:#64748b;font-size:.9rem;line-height:1.58}.location-button{width:100%;min-height:56px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:18px;background:#fff;color:#4d68b3;font-weight:800;box-shadow:0 12px 24px #4d68b324}.location-button:disabled{cursor:progress;opacity:.74}.character-img{display:block;object-fit:contain;flex-shrink:0}.location-card{display:grid;gap:9px;margin:12px 0 14px;border:1px solid #d9e7ff;border-radius:22px;padding:13px;background:radial-gradient(circle at 92% 14%,rgba(232,241,255,.92),transparent 24%),linear-gradient(145deg,#f7fbff,#fff 62%,#f5f8ff);box-shadow:0 12px 26px #6c8ff01a}.location-card-head{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px}.location-card-head h2{margin-bottom:3px;color:#1f2937;font-size:1rem;line-height:1.28}.location-card-head p{margin-bottom:0;color:#64748b;font-size:.8rem;font-weight:800;line-height:1.4}.location-card-character{width:46px;height:46px;border-radius:999px;padding:5px;background:linear-gradient(145deg,#e7f0ff,#fbfdff);box-shadow:inset 0 0 0 6px #ffffff9e}.location-control-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.location-button.compact{flex:0 0 auto;width:auto;min-width:128px;min-height:44px;border:1px solid #d2e0ff;background:#fbfdff;color:#5c7de0;box-shadow:0 8px 16px #6c8ff01a;white-space:nowrap}.compact-location-form{flex:1 1 280px;min-width:0;display:flex;align-items:center;gap:7px;border:0;padding:0;background:transparent}.compact-location-form .manual-location-input{flex:1 1 auto;min-width:0;height:46px}.compact-location-form .manual-location-button{flex:0 0 auto;width:auto;min-width:78px;min-height:46px;border-radius:16px;background:linear-gradient(135deg,#7da2f7,#6c8ff0);box-shadow:0 10px 18px #6c8ff02e;white-space:nowrap}.location-basis{display:flex;align-items:center;gap:7px;border:1px solid #d9e7ff;border-radius:16px;padding:8px 11px;background:#ffffffeb;color:#334155;font-size:.83rem;line-height:1.4}.location-basis span{flex:0 0 auto;color:#6c8ff0;font-weight:900}.location-basis strong{min-width:0;color:#1f2937;overflow-wrap:anywhere}.location-basis.attention{border-color:#f8edd6;background:#fff9ed}.location-help-text{color:#8a5a21;font-size:.82rem;font-weight:800;line-height:1.45}.manual-location-form{display:grid;gap:10px;border:1px solid #f8edd6;border-radius:20px;padding:14px;background:#fff9edf5}.manual-location-form p{margin-bottom:0;color:#5f4b28;font-size:.86rem;font-weight:800;line-height:1.5}.manual-location-input{height:48px;border-color:#d7e6ff;background:#fff}.manual-location-button{width:100%;min-height:46px;border:0;border-radius:16px;padding:0 14px;background:#4f73d9;color:#fff;font-weight:900;box-shadow:0 10px 20px #4f73d924}.manual-location-button:disabled{cursor:progress;opacity:.68}.recommend-card,.restaurant-card{border:1px solid #e4eaf5;border-radius:24px;background:#fff;box-shadow:0 14px 30px #4d68b317}.app-tabs{position:sticky;top:8px;z-index:10;display:grid;grid-template-columns:repeat(4,minmax(66px,1fr));gap:6px;margin:14px 0 16px;padding:0;border:0;border-radius:0;background:transparent;box-shadow:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-tabs button{min-height:46px;border:1px solid transparent;border-radius:20px;padding:0 6px;background:#fff;color:#475569;font-size:12px;font-weight:900;cursor:pointer;box-shadow:0 10px 24px #64748b14;transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease,border-color .16s ease}.app-tabs .tab-recommend{border-color:#ffd5c9;background:#fff7f3;color:#f26d5b}.app-tabs .tab-direct{border-color:#cef1e6;background:#f4fdf9;color:#2fa889}.app-tabs .tab-payer{border-color:#ffe1a8;background:#fff8ea;color:#d98018}.app-tabs .tab-favorites{border-color:#ded6ff;background:#faf8ff;color:#7c65d8}.app-tabs .tab-recommend.active{border-color:#ff9b7a;background:#fff0ea;color:#f26d5b;box-shadow:0 14px 28px #f26d5b2e}.app-tabs .tab-direct.active{border-color:#8dddc3;background:#ecfbf4;color:#2fa889;box-shadow:0 14px 28px #2fa88929}.app-tabs .tab-payer.active{border-color:#ffbd73;background:#fff2d6;color:#c96b12;box-shadow:0 14px 28px #ff9f432b}.app-tabs .tab-favorites.active{border-color:#b8a5ff;background:#f3eeff;color:#7c65d8;box-shadow:0 14px 28px #7c65d829}.app-tabs button:active,.location-button:active,.card-action-button:active{transform:scale(.97)}.recommend-intro{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:13px;border:1px solid #ffd5c9;border-radius:22px;padding:12px;background:linear-gradient(135deg,#fff8ed,#fff0ea)}.recommend-intro h2{margin-bottom:4px;color:#2d3553;font-size:1.05rem;line-height:1.32}.recommend-intro p{margin-bottom:0;color:#8a6358;font-size:.86rem;font-weight:800;line-height:1.5}.recommend-card{display:grid;gap:16px;margin:18px 0 16px;padding:14px;overflow:hidden}.direct-card{border-color:#d9f3e9;background:#fff;box-shadow:0 14px 30px #2fa88914}.direct-card .recommend-intro{border-color:#d9f3e9;background:linear-gradient(135deg,#f6fffb,#ecfbf4)}.direct-card .recommend-intro p{color:#4d7f72}.payer-panel{display:grid;gap:14px;border:1px solid #ffe1a8;border-radius:26px;padding:16px;background:radial-gradient(circle at 92% 4%,rgba(255,213,129,.32),transparent 28%),linear-gradient(145deg,#fffdf7,#fff8ea);box-shadow:0 18px 38px #ff9f431f}.payer-hero{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:13px;border:1px solid #ffe1a8;border-radius:22px;padding:13px;background:#ffffffb8}.payer-hero p,.payer-count-panel p{margin-bottom:4px;color:#d98018;font-size:.78rem;font-weight:900}.payer-hero h2{margin-bottom:5px;color:#1f2937;font-size:1.22rem;line-height:1.25}.payer-hero span,.payer-result-card span{color:#7b6b5a;font-size:.86rem;font-weight:800;line-height:1.45}.payer-mode-toggle{display:grid;grid-template-columns:1fr 1fr;gap:7px;border:1px solid #ffe1a8;border-radius:999px;padding:5px;background:#ffffffb8}.payer-mode-toggle button{min-height:42px;border:0;border-radius:999px;padding:0 10px;background:transparent;color:#8a6a2a;font-size:.84rem;font-weight:900}.payer-mode-toggle button.active{background:#fff2d6;color:#c96b12;box-shadow:0 10px 20px #ff9f4324}.payer-count-panel{display:grid;gap:8px}.payer-count-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.payer-count-head p{margin-bottom:0}.payer-count-head button{min-height:30px;border:1px solid #ffe1a8;border-radius:999px;padding:0 10px;background:#fff;color:#c96b12;font-size:.72rem;font-weight:900}.payer-count-head button:disabled{cursor:progress;opacity:.55}.payer-count-grid{display:flex;flex-wrap:wrap;gap:8px}.payer-count-button{min-height:42px;flex:1 0 calc(25% - 8px);border:1px solid #ffe1a8;border-radius:999px;padding:0 12px;background:#fff;color:#8a6a2a;font-weight:900;box-shadow:0 8px 16px #ff9f4314}.payer-count-button.active{border-color:#ffbd73;background:#fff2d6;color:#c96b12;box-shadow:0 10px 20px #ff9f4329}.payer-character-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.payer-character{display:grid;justify-items:center;align-content:start;gap:8px;border:1px solid rgba(255,225,168,.8);border-radius:20px;padding:10px 6px 9px;background:#ffffffbd;color:#5f4b28;font-size:.78rem;font-weight:900;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,opacity .18s ease}.payer-character.active{transform:translateY(-4px) scale(1.06);border-color:#ffb86b;box-shadow:0 10px 24px #ff9f433d}.payer-character.is-winner{animation:winnerPulse .7s ease both}.payer-character.active .mascot-badge{box-shadow:0 0 0 5px #ffb86b3d,0 12px 24px #ff9f4333}.payer-name-row,.payer-name-editor{width:100%;min-width:0;display:grid;justify-items:center;gap:6px}.payer-name-row strong{max-width:100%;color:#4b3a1f;font-size:.82rem;overflow-wrap:anywhere;text-align:center}.payer-name-row button,.payer-name-editor button{min-height:26px;border:1px solid #ffe1a8;border-radius:999px;padding:0 8px;background:#fff8ea;color:#c96b12;font-size:.68rem;font-weight:900}.payer-name-row button:disabled{cursor:progress;opacity:.55}.payer-name-editor input{width:100%;min-width:0;height:32px;border:1px solid #ffbd73;border-radius:12px;padding:0 8px;background:#fff;color:#1f2937;font-size:.78rem;font-weight:800;text-align:center;outline:0}.payer-pick-button{min-height:50px;border:0;border-radius:999px;background:linear-gradient(135deg,#ffbd73,#ff9f43);color:#fff;font-weight:900;box-shadow:0 14px 26px #ff9f4338}.payer-pick-button:disabled{cursor:progress;opacity:.78}.payer-state-card,.payer-result-card{display:grid;justify-items:center;gap:8px;border:1px solid #ffe1a8;border-radius:24px;padding:16px;background:#fff;text-align:center;box-shadow:0 12px 24px #ff9f431a}.payer-state-card span{color:#d98018;font-size:.86rem;font-weight:900}.payer-state-card strong{color:#1f2937;font-size:1rem}.payer-state-card em{color:#9a6b21;font-size:.82rem;font-style:normal;font-weight:900}.payer-state-card.reveal{border-color:#ffb86b;background:#fff8ea;animation:payerResultPop .48s cubic-bezier(.2,1.4,.4,1) both;box-shadow:0 16px 30px #ff9f4329}.payer-result-card p{margin-bottom:0;color:#d98018;font-size:.9rem;font-weight:900}.payer-result-card h3{margin-bottom:0;color:#1f2937;font-size:1.34rem;line-height:1.25}.payer-result-card small{color:#8a6a2a;font-size:.8rem;font-weight:900;line-height:1.45}.payer-result-card{animation:payerResultPop .48s cubic-bezier(.2,1.4,.4,1) both}.finger-picker-panel{display:grid;gap:14px}.finger-picker-copy{display:grid;gap:5px;border:1px solid #ffe1a8;border-radius:22px;padding:13px;background:#ffffffb8}.finger-picker-copy h3{margin-bottom:0;color:#1f2937;font-size:1.08rem}.finger-picker-copy p,.finger-picker-copy span{margin:0;color:#7b6b5a;font-size:.84rem;font-weight:800;line-height:1.45}.finger-picker-zone{position:relative;min-height:260px;overflow:hidden;border:2px dashed #ffd48b;border-radius:26px;background:radial-gradient(circle at 18% 18%,rgba(255,228,214,.7),transparent 28%),radial-gradient(circle at 82% 72%,rgba(229,240,255,.9),transparent 30%),linear-gradient(145deg,#fffdf7,#fff8ea);touch-action:none;-webkit-user-select:none;user-select:none;box-shadow:inset 0 0 0 7px #ffffff75}.finger-zone-message{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-content:center;justify-items:center;gap:6px;padding:24px;color:#8a6a2a;text-align:center;pointer-events:none}.finger-zone-message strong{color:#1f2937;font-size:1.08rem}.finger-zone-message span,.finger-zone-message em{font-size:.82rem;font-style:normal;font-weight:900;line-height:1.45}.finger-zone-message em{max-width:240px;color:#a47a31}.finger-marker{position:absolute;z-index:2;width:52px;height:52px;display:grid;place-items:center;border:2px solid rgba(255,255,255,.95);border-radius:999px;color:#5f4b28;font-weight:1000;transform:translate(-50%,-50%);box-shadow:0 10px 22px #ff9f4329;animation:fingerFloat 1.4s ease-in-out infinite;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.finger-marker.active{border-color:#ffb86b;transform:translate(-50%,-50%) scale(1.18);box-shadow:0 0 0 7px #ffb86b3d,0 16px 30px #ff9f4347}.finger-marker.is-winner{animation:fingerWinnerPulse .7s ease both}.finger-helper-text{border:1px solid #ffe1a8;border-radius:999px;padding:10px 12px;background:#fff;color:#c96b12;font-size:.84rem;font-weight:900;text-align:center}.finger-result-card{background:radial-gradient(circle at 50% 0%,rgba(255,218,135,.5),transparent 42%),#fff}.finger-result-marker{width:86px;height:86px;display:grid;place-items:center;border:3px solid rgba(255,255,255,.98);border-radius:999px;color:#5f4b28;font-size:1.6rem;font-weight:1000;box-shadow:0 0 0 8px #ffb86b2e,0 18px 34px #ff9f4338}.finger-reset-button{min-height:42px;border:1px solid #ffe1a8;border-radius:999px;padding:0 14px;background:#fff8ea;color:#c96b12;font-weight:900}.touch-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;overflow:hidden;min-height:100vh;height:100dvh;background:radial-gradient(circle at 18% 16%,rgba(255,228,214,.82),transparent 28%),radial-gradient(circle at 82% 72%,rgba(229,240,255,.9),transparent 30%),linear-gradient(145deg,#fffdf7,#fff8ea);touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;overscroll-behavior:contain}.touch-picker-topbar{position:absolute;top:max(14px,env(safe-area-inset-top));left:14px;right:14px;z-index:4;display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid rgba(255,225,168,.9);border-radius:22px;padding:12px;background:#ffffffd1;box-shadow:0 14px 28px #ff9f431f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.touch-picker-topbar div{display:grid;gap:3px}.touch-picker-topbar strong{color:#1f2937;font-size:1rem}.touch-picker-topbar span{color:#8a6a2a;font-size:.8rem;font-weight:900}.touch-picker-topbar button,.touch-result-actions button{min-height:38px;border:1px solid #ffe1a8;border-radius:999px;padding:0 14px;background:#fff;color:#c96b12;font-weight:900}.touch-picker-status{position:absolute;left:18px;right:18px;bottom:max(18px,env(safe-area-inset-bottom));z-index:4;display:grid;justify-items:center;gap:5px;border:1px solid rgba(255,225,168,.9);border-radius:24px;padding:14px;background:#ffffffd6;color:#8a6a2a;text-align:center;box-shadow:0 16px 32px #ff9f431f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.touch-picker-status strong{color:#1f2937;font-size:1.08rem}.touch-picker-status b{width:48px;height:48px;display:grid;place-items:center;border-radius:999px;background:#fff2d6;color:#f97316;font-size:1.6rem;box-shadow:0 10px 20px #ff9f4329}.touch-picker-status span,.touch-picker-status em{font-size:.86rem;font-style:normal;font-weight:900;line-height:1.45}.finger-marker.overlay{z-index:20;width:84px;height:84px;font-size:1.05rem;background:#ffe4d66b;border-width:3px;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.finger-marker.overlay:after{content:"";position:absolute;top:50%;right:50%;bottom:50%;left:50%;width:52px;height:52px;border-radius:999px;transform:translate(-50%,-50%);background:#ffffff9e;box-shadow:inset 0 0 0 999px #ffe4d64d}.finger-marker.overlay span{position:relative;z-index:2;color:#3f2d15;font-size:1.08rem;font-weight:1000}.finger-marker.overlay.active{transform:translate(-50%,-50%) scale(1.14)}.finger-marker.overlay.is-winner{width:104px;height:104px;border-color:#ffb86b;background:#ffb86b59!important;box-shadow:0 0 0 12px #ffb86b38,0 18px 42px #f9731652}.finger-marker.overlay.is-winner:after{width:62px;height:62px;background:#fff2d6eb}.finger-winner-bubble{position:absolute;z-index:40;min-width:118px;display:grid;justify-items:center;gap:2px;transform:translate(-50%,-100%);border:2px solid #ffb86b;border-radius:999px;padding:10px 12px;background:#fff;color:#c96b12;text-align:center;box-shadow:0 18px 34px #ff9f4338;pointer-events:none;animation:winnerBubblePop .52s cubic-bezier(.2,1.4,.4,1) both}.finger-winner-bubble:after{content:"";position:absolute;left:50%;bottom:-8px;width:14px;height:14px;transform:translate(-50%) rotate(45deg);background:#fff;border-right:1px solid #ffb86b;border-bottom:1px solid #ffb86b}.finger-winner-bubble strong{color:#f97316;font-size:.98rem}.finger-winner-bubble span{color:#8a6a2a;font-size:.78rem;font-weight:900}.touch-result-panel{position:absolute;left:18px;right:18px;bottom:max(18px,env(safe-area-inset-bottom));z-index:6;display:grid;justify-items:center;gap:8px;border:1px solid #ffe1a8;border-radius:26px;padding:16px;background:#ffffffeb;color:#1f2937;text-align:center;box-shadow:0 22px 46px #ff9f432e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);animation:payerResultPop .48s cubic-bezier(.2,1.4,.4,1) both}@keyframes winnerBubblePop{0%{opacity:0;transform:translate(-50%,8px) scale(.88)}70%{opacity:1;transform:translate(-50%,-4px) scale(1.06)}to{opacity:1;transform:translate(-50%) scale(1)}}.touch-result-panel p{margin-bottom:0;color:#d98018;font-size:.88rem;font-weight:900}.touch-result-panel h3{margin-bottom:0;color:#1f2937;font-size:1.16rem;line-height:1.25}.touch-result-panel span{color:#8a6a2a;font-size:.82rem;font-weight:900}.touch-result-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px}@keyframes fingerFloat{0%,to{margin-top:0}50%{margin-top:-3px}}@keyframes fingerWinnerPulse{0%{transform:translate(-50%,-50%) scale(1)}45%{transform:translate(-50%,-50%) scale(1.26)}to{transform:translate(-50%,-50%) scale(1.18)}}@keyframes payerResultPop{0%{opacity:0;transform:translateY(12px) scale(.94)}70%{opacity:1;transform:translateY(-3px) scale(1.03)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes winnerPulse{0%{transform:scale(1)}45%{transform:scale(1.08)}to{transform:translateY(-4px) scale(1.06)}}.recommend-mode-panel{display:grid;grid-template-columns:minmax(118px,36%) minmax(0,1fr);align-items:stretch;gap:0;min-height:202px;overflow:hidden;border:1px solid #e4eaf5;border-radius:20px}.direct-mode-panel{display:grid;gap:14px}.recommend-image-wrap{position:relative;min-height:202px;overflow:hidden}.food-visual,.food-visual-image{width:100%;height:100%}.food-visual{display:flex;align-items:center;justify-content:center;overflow:hidden;background:#eef4ff}.food-visual-fallback{width:calc(100% - 18px);min-height:142px;display:grid;place-items:center;gap:8px;border-radius:20px;background:#ffffff94;color:#4d68b3;text-align:center}.food-visual-fallback span{font-size:2.25rem;line-height:1}.food-visual-fallback strong{font-size:1rem}.tone-warm{background:#f8edd6}.tone-gold{background:#fff3c7}.tone-pink{background:#fdecef}.tone-red{background:#ffe8e2}.tone-orange{background:#fff0dc}.tone-brown{background:#f2e4d6}.tone-cream{background:#fff6e8}.tone-blue{background:#eef4ff}.recommend-character{position:absolute;right:8px;bottom:8px;width:50px;height:50px;border-radius:16px;padding:4px;background:#ffffffdb;box-shadow:0 8px 18px #4d68b329}.recommend-content{min-width:0;display:flex;flex-direction:column;justify-content:center;gap:7px;padding:16px 16px 16px 14px}.recommend-content p{margin-bottom:0;color:#6f8edb;font-size:.78rem;font-weight:800}.recommend-content h2{margin-bottom:0;color:#2d3553;font-size:1.18rem;line-height:1.3}.recommend-content span{color:#6f7893;font-size:.84rem;line-height:1.55;word-break:keep-all;overflow-wrap:anywhere}.recommend-actions{display:flex;flex-direction:column;gap:9px;margin-top:8px}.secondary-button,.mini-primary-button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:16px;padding:0 14px;font-size:.84rem;font-weight:800;white-space:nowrap}.secondary-button{width:100%;border:1px solid #ffd5c9;background:#fff7f3;color:#f26d5b}.mini-primary-button{width:100%;border:1px solid #ff9f7a;background:linear-gradient(135deg,#ffb36d,#ff8d79);color:#fff}.search-form{display:grid;grid-template-columns:1fr;gap:10px}.search-box{height:56px;display:flex;align-items:center;gap:10px;border:1px solid #e4eaf5;border-radius:18px;padding:0 16px;background:#f8fbff;color:#4d68b3}.search-box input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:#2d3553}.search-box input::placeholder{color:#94a3b8}.search-submit{width:100%;min-width:0;height:54px;border:0;border-radius:18px;padding:0 14px;background:#ff9f7a;color:#fff;font-weight:800;white-space:nowrap}.search-submit:disabled,.category-chip:disabled{cursor:progress;opacity:.68}.category-chip{flex:0 0 auto;white-space:nowrap;min-height:40px;border:1px solid #dfe7f5;border-radius:999px;padding:0 15px;background:#fff;color:#34405f;font-size:14px;font-weight:700;line-height:1;box-sizing:border-box;cursor:pointer;transition:background-color .18s ease,color .18s ease,border-color .18s ease,transform .18s ease}.category-chip.active{background:#ecfbf4;color:#2fa889;border-color:#8dddc3;box-shadow:0 6px 14px #2fa8891f}.category-chip:active{transform:scale(.96)}.category-grid{display:flex;flex-wrap:wrap;gap:8px;width:100%;margin-top:0}.search-submit:active,.mini-primary-button:active,.secondary-button:active{transform:translateY(1px)}.search-submit:hover,.mini-primary-button:hover{background:#f26d5b;border-color:#ee7f61}.secondary-button:hover{background:#fff0ea;border-color:#ffb199;color:#f26d5b}.list-section{margin-top:26px;padding-bottom:24px}.list-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;border-radius:22px;padding:16px;background:#ffffffe6;border:1px solid #e4eaf5;box-shadow:0 12px 26px #64748b0f}.list-header h2{margin-bottom:0;color:#2d3553;font-size:1.25rem}.list-header p{margin:6px 0 0;color:#6f7893;font-size:.86rem;line-height:1.4}.section-title-row{display:flex;align-items:center;gap:8px}.section-character{width:36px;height:36px}.list-summary{display:grid;justify-items:end;gap:6px;flex:0 0 auto}.list-summary strong{color:#6f7893;font-size:.92rem;font-weight:700;white-space:nowrap}.sort-badge{border-radius:999px;padding:5px 9px;background:#eef4ff;color:#4d68b3;font-size:.72rem;font-weight:800;white-space:nowrap}.sort-toggle{display:grid;grid-template-columns:1fr 1fr;gap:5px;border:1px solid #dbe7ff;border-radius:999px;padding:4px;background:#fff}.sort-toggle button{min-height:32px;border:0;border-radius:999px;padding:0 10px;background:transparent;color:#6f7893;font-size:.76rem;font-weight:900;white-space:nowrap}.sort-toggle button.active{background:#ecfbf4;color:#2fa889;box-shadow:0 6px 14px #2fa8891f}.restaurant-list{display:grid;gap:14px}.load-more-row{display:grid;justify-items:center;margin-top:14px;color:#6f7893;font-size:.88rem;font-weight:900}.load-more-button{width:100%;min-height:48px;border:1px solid #ffd9b8;border-radius:18px;background:#fff7f3;color:#d15e37;font-weight:900;box-shadow:0 10px 20px #e68b461a}.state-message{border:1px solid #e4eaf5;border-radius:22px;padding:20px 18px;background:#f8fbff;color:#6f7893;font-size:.94rem;font-weight:700;line-height:1.5}.state-message.error{border-color:#fecaca;background:#fff7f7;color:#b42318}.state-message.notice{border-color:#dbe7ff;background:#eff6ff;color:#4d68b3}.feedback-message{margin-bottom:14px;border-color:#d9f3e9;background:#ecfbf4;color:#2fa889}.result-pop-card{position:relative;overflow:hidden;display:grid;grid-template-columns:auto 1fr;gap:15px;margin-bottom:14px;border:1px solid #ffbea7;border-radius:30px;padding:19px;background:radial-gradient(circle at 92% 12%,rgba(255,218,135,.58) 0 76px,transparent 77px),radial-gradient(circle at 0% 100%,rgba(255,155,122,.18),transparent 34%),linear-gradient(145deg,#fffdf8,#fff4df 48%,#ffe9df);box-shadow:0 26px 52px #e17d3d3d}.result-character-frame{width:76px;height:76px;display:grid;place-items:center;border-radius:999px;background:linear-gradient(145deg,#fff0cf,#fff8ed);box-shadow:inset 0 0 0 8px #ffffff9e,0 12px 24px #e17d3d1f}.result-character{width:62px;height:62px}.result-pop-content{min-width:0;display:grid;align-content:center;gap:5px}.result-pop-content p{margin-bottom:0;color:#f26d5b;font-size:.94rem;font-weight:900;line-height:1.45}.result-pop-content h3{margin-bottom:0;color:#1f2937;font-size:1.55rem;line-height:1.25}.result-pop-content span,.result-pop-content strong,.result-pop-content em,.result-pop-content b{color:#6f7893;font-size:.84rem;line-height:1.45}.result-pop-content em{font-style:normal;font-weight:800}.result-pop-content b{width:fit-content;border-radius:999px;padding:5px 10px;background:#fff;color:#f26d5b;font-size:.78rem;font-weight:900;box-shadow:0 6px 14px #e68b461f}.result-actions{grid-column:1 / -1;display:grid;grid-template-columns:1fr 1fr;gap:8px}.result-actions .map-link{width:auto}.loading-state,.empty-state{display:grid;justify-items:center;text-align:center;gap:10px}.loading-state{display:flex;align-items:center;justify-content:center;text-align:left}.state-character{width:72px;height:72px;flex:0 0 auto}.loading-character{animation:floaty 1.8s ease-in-out infinite}.empty-character{width:110px;height:110px}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.restaurant-card{min-height:0;overflow:hidden;box-shadow:0 14px 30px #64748b14}.restaurant-info{display:grid;gap:15px;padding:18px}.restaurant-title{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.restaurant-title p{margin-bottom:5px;color:#2fa889;font-size:.76rem;font-weight:800}.restaurant-title h3{margin-bottom:0;color:#2d3553;font-size:1.08rem;line-height:1.32}.distance-badge{min-height:28px;display:inline-flex;align-items:center;justify-content:center;gap:4px;flex:0 0 auto;border-radius:999px;padding:0 10px;border:1px solid #dbe7ff;background:#eef4ff;color:#4b5f8f;font-size:.76rem;font-weight:700;line-height:1}.distance-badge:before{content:"📍";font-size:.75rem;line-height:1}.meta-row{display:flex;flex-wrap:wrap;gap:8px}.meta-row span{display:inline-flex;align-items:center;gap:4px;color:#6f7893;font-size:.82rem;font-weight:700}.meta-row .phone-line{flex-basis:100%}.map-link{width:100%;min-height:48px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:0 14px;background:linear-gradient(135deg,#f98d7f,#ee7f61);color:#fff;font-size:.9rem;font-weight:800;text-decoration:none}.card-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.card-action-button{min-height:44px;border:1px solid #dfe8ff;border-radius:999px;padding:0 10px;background:#fff;color:#3156b7;font-size:.84rem;font-weight:900}.favorite-button{border-color:#ffb199;background:#fff1ea;color:#f26d5b}.favorite-button.is-favorite{border-color:#8dddc3;background:#eafbf5;color:#2fa889}.card-action-button.muted{border-color:#ead7dd;background:#fff6f8;color:#b65b78}.card-actions .map-link{grid-column:1 / -1}.favorites-panel{display:grid;gap:14px;border:1px solid #ded6ff;border-radius:26px;padding:16px;background:#fff;box-shadow:0 16px 34px #7c65d81a}.favorites-panel-header{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:13px;border-radius:22px;padding:12px;background:linear-gradient(135deg,#faf8ff,#f3eeff)}.favorites-panel-header p{margin-bottom:4px;color:#7c65d8;font-size:.78rem;font-weight:900}.favorites-panel-header h2{margin-bottom:0;color:#2d3553;font-size:1.24rem}.favorites-empty{display:grid;justify-items:center;gap:12px;border-radius:22px;padding:22px 16px;background:#faf8ff;color:#6f7893;text-align:center;font-size:.92rem;font-weight:800;line-height:1.55}.favorite-list{display:grid;gap:10px}.favorite-place-card{display:grid;gap:10px;border:1px solid #ede7ff;border-radius:20px;padding:14px;background:#fff}.favorite-place-card h3{margin-bottom:0;color:#2d3553;font-size:1rem}.favorite-place-card p,.favorite-place-card span{margin:0;color:#6f7893;font-size:.82rem;font-weight:700;line-height:1.45}.favorite-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:2px}.favorite-actions .map-link{grid-column:1 / -1;min-height:46px;border-radius:20px;background:linear-gradient(135deg,#7ba0f8,#6f8ff2);font-size:.88rem;box-shadow:0 10px 18px #6f8ff229}.favorite-actions .card-action-button{min-height:42px;border-radius:18px;background:#f8faff;border-color:#d9e2ff;color:#5b6b8c;font-size:.82rem;box-shadow:none}.favorite-actions .card-action-button.muted{border-color:#f2d2da;background:#fff3f5;color:#c56b7a}.toast-message{position:fixed;left:50%;bottom:18px;z-index:30;width:min(calc(100% - 28px),420px);display:flex;align-items:center;gap:10px;transform:translate(-50%);border:1px solid #dbe7ff;border-radius:999px;padding:10px 14px 10px 10px;background:#fff;color:#3156b7;font-size:.86rem;font-weight:900;box-shadow:0 18px 40px #2d35532e}.toast-character{width:38px;height:38px;border-radius:999px;padding:4px;background:#fdecef}.mascot-badge{position:relative;width:52px;height:52px;display:grid;place-items:center;flex:0 0 auto;overflow:hidden;border:2px solid rgba(255,255,255,.95);border-radius:999px;padding:0;background:linear-gradient(135deg,#f7fbff,#eaf3ff);box-shadow:0 8px 20px #4f73d924}.mascot-badge img{width:118%;height:118%;display:block;object-fit:cover;object-position:center}.mascot-badge--xs{width:32px;height:32px}.mascot-badge--sm{width:42px;height:42px}.mascot-badge--md{width:52px;height:52px}.mascot-badge--lg{width:72px;height:72px}.mascot-badge--blue{background:linear-gradient(135deg,#f7fbff,#e5f0ff);box-shadow:0 8px 20px #4f73d924}.mascot-badge--coral{background:linear-gradient(135deg,#fff5ee,#ffe5d8);box-shadow:0 8px 20px #f26d5b24}.mascot-badge--mint{background:linear-gradient(135deg,#f0fff8,#ddf7ec);box-shadow:0 8px 20px #2fa88924}.mascot-badge--lavender{background:linear-gradient(135deg,#f7f3ff,#ece5ff);box-shadow:0 8px 20px #7c65d824}.mascot-badge.recommend-character{position:absolute;right:8px;bottom:8px;border-radius:999px}.footer-copy{margin:34px auto 20px;padding:0 20px;color:#7b8798;font-size:13px;line-height:1.7;text-align:center}.footer-copy span{display:block;margin-top:4px;color:#1f3f95;font-size:12px;font-weight:800;letter-spacing:.02em}@media(max-width:420px){.app-tabs{grid-template-columns:repeat(4,minmax(62px,1fr));gap:5px}.app-tabs button{min-height:42px;border-radius:16px;padding:0 4px;font-size:11px}.location-control-row{display:grid}.location-button.compact{width:100%}.compact-location-form{flex:none;display:grid;grid-template-columns:1fr}.compact-location-form .manual-location-button{width:100%}.category-grid{gap:7px}.category-chip{min-height:38px;padding:0 13px;font-size:13px}.payer-panel{padding:14px}.payer-mode-toggle button{min-height:40px;padding:0 8px;font-size:.78rem}.payer-character-grid{grid-template-columns:repeat(3,1fr)}.payer-count-button{flex-basis:calc(25% - 8px);min-height:40px;padding:0 10px}.finger-picker-zone{min-height:230px}}@media(max-width:374px){.app-shell{padding-right:10px;padding-left:10px}.search-box,.search-submit{border-radius:16px}.recommend-card{gap:14px;padding:12px}.recommend-mode-panel{grid-template-columns:minmax(112px,36%) minmax(0,1fr);min-height:198px}.recommend-image-wrap{min-height:198px}.recommend-content{padding:14px 12px}.recommend-content h2{font-size:1.08rem}.recommend-content span{font-size:.8rem}.secondary-button,.mini-primary-button{min-height:40px;padding:0 10px;font-size:.8rem}.recommend-character{width:48px;height:48px}.payer-character-grid{grid-template-columns:repeat(2,1fr)}.finger-picker-zone{min-height:220px}}@media(min-width:720px){body{padding:28px 0}.app-shell{min-height:calc(100vh - 56px);border:1px solid #dbe3ef;border-radius:34px;padding:20px 18px 88px;box-shadow:0 28px 70px #0f172a29}.top-section{grid-template-columns:1fr;align-items:stretch}.location-button{width:100%;padding:0 18px}.restaurant-list{grid-template-columns:1fr}}
