:root{--bg:#f5f6f8;--white:#fff;--text:#1a1a1a;--dim:#999;--blue:#0770e3;--blue2:#e8f4fd;--orange:#ff6b00;--border:#eee;--card-r:16px;--shadow:0 2px 12px rgba(0,0,0,.06);--tw:#ef4444;--tw2:#fbbf24;--jp:#3b82f6;--jp2:#8b5cf6}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;font-family:'Noto Sans KR',sans-serif}
body{background:#0a0a0a;color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;display:flex;justify-content:center}

/* ══════════════════════════
   GLOBAL MOBILE CONTAINER
   everything max 420px centered
   ══════════════════════════ */

/* ═══ HOME SCREEN ═══ */
.home-screen{display:none;width:100%;max-width:420px;min-height:100vh;position:relative;overflow:hidden;margin:0 auto}
.home-screen.on{display:block}
#particles{position:fixed;inset:0;z-index:0;pointer-events:none}
.home-content{position:relative;z-index:1;padding:0 0 32px}
.home-logo{text-align:center;padding:48px 0 0;font-size:32px;font-weight:900;color:#fff;letter-spacing:6px;text-shadow:0 0 40px rgba(255,255,255,.12)}
.home-logo span{color:#f97316;font-size:24px}
.home-tagline{text-align:center;font-size:10px;letter-spacing:6px;color:#64748b;margin-top:4px;font-weight:700}
.home-mission{text-align:center;font-size:20px;font-weight:900;color:#e2e8f0;margin-top:20px;letter-spacing:2px;animation:glowPulse 2s infinite}
.home-sub{text-align:center;font-size:12px;color:#475569;margin-top:4px}
.home-hint{text-align:center;font-size:10px;color:#334155;padding:16px;animation:blink 2s infinite}

.choice-cards{padding:16px 14px;display:flex;flex-direction:column;gap:0;align-items:center}
.choice-vs{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#1e293b,#334155);display:flex;align-items:center;justify-content:center;margin:-8px auto;z-index:2;position:relative;border:2px solid #475569}
.choice-vs span{font-size:14px;font-weight:900;color:#94a3b8;letter-spacing:2px}
.choice-card{width:100%;border-radius:18px;overflow:hidden;cursor:pointer;transition:transform .2s}
.choice-card:active{transform:scale(.97)}
.choice-card.theme-tw{background:#1c1017;border:1px solid rgba(239,68,68,.25)}
.choice-card.theme-jp{background:#0f172a;border:1px solid rgba(59,130,246,.25)}
.choice-img-wrap{position:relative;height:140px;overflow:hidden}
.choice-img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.choice-card:active .choice-img{transform:scale(1.03)}
.choice-gradient{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.75) 0%,transparent 50%)}
.choice-overlay{position:absolute;bottom:0;left:0;padding:12px 14px}
.choice-flag{font-size:20px}
.choice-city{font-size:20px;font-weight:900;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.choice-country{font-size:11px;color:rgba(255,255,255,.65)}
.choice-badge{position:absolute;top:10px;right:10px;font-size:9px;font-weight:800;padding:3px 8px;border-radius:16px;color:#fff}
.theme-tw .choice-badge{background:rgba(239,68,68,.8)}
.theme-jp .choice-badge{background:rgba(59,130,246,.8)}
.choice-body{padding:10px 14px 12px}
.choice-date{font-size:12px;font-weight:700;margin-bottom:3px}
.theme-tw .choice-date{color:#fbbf24}
.theme-jp .choice-date{color:#93c5fd}
.choice-flight-mini{font-size:10px;color:#64748b;margin-bottom:6px;display:flex;gap:4px}
.choice-tags{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:6px}
.choice-tag{font-size:9px;padding:2px 7px;border-radius:4px;font-weight:600}
.theme-tw .choice-tag{background:rgba(239,68,68,.1);color:#fca5a5}
.theme-jp .choice-tag{background:rgba(59,130,246,.1);color:#93c5fd}
.choice-bottom{display:flex;align-items:baseline;gap:2px}
.choice-price{font-size:20px;font-weight:900}
.theme-tw .choice-price{color:#f87171}
.theme-jp .choice-price{color:#60a5fa}
.choice-pax{font-size:10px;color:#64748b}

/* ═══ APRIL POPUP ═══ */
.april-overlay{position:fixed;inset:0;z-index:500;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.85);backdrop-filter:blur(6px)}
.april-overlay.on{display:flex}
.april-popup{position:relative;width:92%;max-width:360px;border-radius:22px;padding:24px 16px;overflow:hidden;animation:popIn .4s both}
.april-popup.theme-tw{background:linear-gradient(160deg,#1c1017,#2d1520,#1a0a10);border:1px solid rgba(239,68,68,.25)}
.april-popup.theme-jp{background:linear-gradient(160deg,#0f172a,#1a1040,#0a0e20);border:1px solid rgba(59,130,246,.25)}
.april-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.confetti{position:absolute;top:-20px;border-radius:2px;animation:confettiFall linear infinite}
.april-badge{text-align:center;font-size:9px;letter-spacing:3px;font-weight:800;margin-bottom:10px}
.theme-tw .april-badge{color:#f87171}
.theme-jp .april-badge{color:#60a5fa}
.april-city{text-align:center;font-size:24px;font-weight:900;color:#fff}
.april-date{text-align:center;font-size:12px;color:#94a3b8;margin:3px 0 14px}
.april-benefits{display:grid;gap:6px}
.ab-item{display:flex;gap:8px;padding:8px 10px;border-radius:10px}
.theme-tw .ab-item{background:rgba(239,68,68,.07);border:1px solid rgba(239,68,68,.12)}
.theme-jp .ab-item{background:rgba(59,130,246,.07);border:1px solid rgba(59,130,246,.12)}
.ab-icon{font-size:18px;flex-shrink:0;width:28px;text-align:center}
.ab-title{font-size:12px;font-weight:800;color:#e2e8f0}
.ab-desc{font-size:10px;color:#94a3b8;line-height:1.4;margin-top:1px}
.april-go{display:block;width:100%;margin-top:14px;padding:12px;border-radius:12px;font-size:15px;font-weight:900;color:#fff;border:none;cursor:pointer;letter-spacing:1px}
.april-go:active{transform:scale(.97)}
.theme-tw .april-go{background:linear-gradient(135deg,#ef4444,#f97316)}
.theme-jp .april-go{background:linear-gradient(135deg,#3b82f6,#8b5cf6)}

/* ═══ BOTTOM SHEET (trip.com) ═══ */
.bs-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;display:none;opacity:0;transition:opacity .3s}
.bs-overlay.on{display:block;opacity:1}
.bs{position:fixed;left:50%;bottom:0;z-index:201;width:100%;max-width:420px;transform:translateX(-50%) translateY(100%);background:#fff;border-radius:20px 20px 0 0;max-height:90vh;overflow-y:auto;transition:transform .4s cubic-bezier(.32,1,.23,1);-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.bs.on{transform:translateX(-50%) translateY(0)}
.bs-handle{display:flex;justify-content:center;padding:10px 0 4px;cursor:pointer}
.bs-bar{width:36px;height:4px;border-radius:2px;background:#ddd}
.bs-header{padding:0 14px 10px;border-bottom:1px solid var(--border)}
.bs-top{padding:0}
.bs-city{font-size:18px;font-weight:900}
.bs-flight{font-size:10px;color:var(--text);margin-top:6px;line-height:1.8}
.bs-fl-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.bs-fl-badge{font-size:8px;font-weight:800;color:#fff;padding:1px 5px;border-radius:3px;flex-shrink:0}
.theme-tw .bs-fl-badge{background:var(--tw)}
.theme-jp .bs-fl-badge{background:var(--jp)}
.bs-fl-ret{opacity:.6}
.bs-fl-route{font-weight:700}
.theme-tw .bs-fl-route{color:var(--tw)}
.theme-jp .bs-fl-route{color:var(--jp)}
.bs-fl-air{font-size:9px;color:var(--dim);margin-left:2px}
.bs-price{text-align:right;font-size:17px;font-weight:900;margin-top:4px}
.theme-tw .bs-price{color:var(--tw)}
.theme-jp .bs-price{color:var(--jp)}
.bs-price span{font-size:10px;color:var(--dim);font-weight:500}

.bs-nav{display:flex;gap:5px;padding:8px 14px;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;background:#fff}
.bs-nav::-webkit-scrollbar{display:none}
.bs-pill{flex-shrink:0;padding:5px 12px;border-radius:18px;font-size:11px;font-weight:700;background:var(--bg);color:var(--dim);border:1px solid var(--border);cursor:pointer;transition:.2s;white-space:nowrap}
.theme-tw .bs-pill.on{background:var(--tw);color:#fff;border-color:var(--tw)}
.theme-jp .bs-pill.on{background:var(--jp);color:#fff;border-color:var(--jp)}
.bs-body{padding:12px 14px 40px}
.bs-section-title{font-size:14px;font-weight:800;margin:12px 0 8px}

/* ═══ SPOT CARDS ═══ */
.sp-card{display:flex;gap:10px;padding:10px;background:#fff;border-radius:12px;margin-bottom:6px;cursor:pointer;box-shadow:var(--shadow);transition:.15s}
.sp-card:active{background:#f0f0f5;transform:scale(.98)}
.sp-img{width:68px;height:56px;border-radius:8px;flex-shrink:0;background:var(--border)}
.sp-info{flex:1;min-width:0}
.sp-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-tw{font-size:10px;color:var(--dim)}
.sp-tags{display:flex;gap:2px;margin-top:2px;flex-wrap:wrap}
.sp-tag{font-size:8px;padding:1px 5px;border-radius:3px;font-weight:600;background:var(--blue2);color:var(--blue)}
.sp-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;flex-shrink:0}
.sp-score{font-size:10px;font-weight:700;padding:2px 5px;border-radius:4px;background:var(--blue2);color:var(--blue)}
.sp-price{font-size:13px;font-weight:800;color:var(--orange)}

/* ═══ MOMENTS ═══ */
.moments-title{font-size:14px;font-weight:800;padding:2px 0 6px}
.moments{display:flex;gap:8px;padding-bottom:12px;overflow-x:auto;scrollbar-width:none;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.moments::-webkit-scrollbar{display:none}
.moment-card{flex-shrink:0;width:170px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);cursor:pointer;scroll-snap-align:start}
.moment-card:active{transform:scale(.97)}
.moment-img{width:170px;height:90px}
.moment-body{padding:8px}
.moment-text{font-size:11px;font-weight:600;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.moment-author{display:flex;align-items:center;gap:4px;margin-top:4px}
.moment-avatar{width:16px;height:16px;border-radius:50%}
.moment-name,.moment-likes{font-size:9px;color:var(--dim)}
.moment-likes{margin-left:auto}

/* ═══ SLIDE POPUP ═══ */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:300;display:none;opacity:0;transition:opacity .3s}
.popup-overlay.on{display:block;opacity:1}
.popup{position:fixed;left:50%;bottom:0;z-index:301;width:100%;max-width:420px;transform:translateX(-50%) translateY(100%);background:#fff;border-radius:20px 20px 0 0;height:88vh;display:flex;flex-direction:column;overflow:hidden;transition:transform .4s cubic-bezier(.32,1,.23,1)}
.popup.on{transform:translateX(-50%) translateY(0)}
.popup-handle{display:flex;justify-content:center;padding:8px 0 4px;cursor:grab}
.popup-bar{width:36px;height:4px;border-radius:2px;background:#ddd}
.popup-header{display:flex;align-items:center;padding:4px 12px 6px;border-bottom:1px solid var(--border);gap:4px}
.popup-tabs{flex:1;display:flex;gap:3px;overflow-x:auto;scrollbar-width:none}
.popup-tabs::-webkit-scrollbar{display:none}
.pop-title{font-size:15px;font-weight:800;color:var(--text)}
.popup-tab{flex-shrink:0;padding:5px 12px;border-radius:18px;font-size:11px;font-weight:700;background:var(--bg);color:var(--dim);border:none;cursor:pointer;transition:.2s}
.popup-tab.on{background:var(--blue);color:#fff}
.popup-header button{font-size:18px;color:var(--dim);width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.popup-body{flex:1;overflow-y:auto;padding:12px 14px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}

/* DETAIL CARD */
.detail-card{background:#fff;border-radius:12px;border:1px solid var(--border);overflow:hidden;margin-bottom:12px}
.detail-gallery{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;scroll-snap-type:x mandatory}
.detail-gallery::-webkit-scrollbar{display:none}
.detail-gallery img{flex-shrink:0;width:88%;height:160px;object-fit:cover;scroll-snap-align:start;border-radius:0;background:var(--border)}
.detail-img{width:100%;height:160px;background:var(--border)}
.detail-body{padding:12px}
.detail-name{font-size:16px;font-weight:800}
.detail-tw{font-size:12px;color:var(--dim)}
.detail-score{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:5px;margin-top:4px;background:var(--blue2);color:var(--blue)}
.detail-desc{font-size:12px;color:#555;line-height:1.7;margin-top:8px}
.detail-warn{font-size:11px;background:#fef2f2;color:#b91c1c;border-radius:10px;padding:8px 10px;margin-top:6px;line-height:1.5;border:1px solid #fecaca}
.detail-local{font-size:11px;background:var(--blue2);color:#1e3a5f;border-radius:10px;padding:8px 10px;margin-top:6px;line-height:1.5}
.detail-reviews{margin-top:8px}
.detail-review{font-size:11px;color:#666;padding:4px 0;border-bottom:1px solid #f5f5f5;line-height:1.4}
.detail-map{display:block;text-align:center;font-size:13px;font-weight:700;background:var(--blue);color:#fff;padding:10px;border-radius:10px;margin-top:10px}

/* MENU TABLE */
.menu-table{margin-top:10px;background:#fafbfc;border-radius:10px;border:1px solid var(--border);overflow:hidden}
.menu-title{font-size:12px;font-weight:800;padding:8px 10px 5px;color:#1e3a5f;border-bottom:1px solid var(--border)}
.menu-row{padding:6px 10px;border-bottom:1px solid #f0f0f0;display:flex;flex-wrap:wrap;align-items:center;gap:3px}
.menu-row:last-child{border-bottom:none}
.menu-row.menu-highlight{background:#eff6ff}
.menu-item{font-size:11px;font-weight:600;flex:1;min-width:100px}
.menu-prices{display:flex;gap:6px;flex-shrink:0}
.menu-ntd{font-size:11px;font-weight:700;color:var(--blue)}
.menu-krw{font-size:10px;font-weight:600;color:var(--orange)}
.menu-note{font-size:9px;color:var(--dim);width:100%;margin-top:1px}

/* HOTEL DETAILS */
.hotel-details{margin-top:6px;display:grid;gap:3px}
.hotel-opt-card{padding:6px 10px;border-radius:7px;border:1px solid #bae6fd;background:#f0f9ff}
.hotel-opt-head{display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:700}
.hotel-opt-price{color:var(--blue);font-weight:800}
.hotel-opt-note{font-size:9px;color:var(--dim);margin-top:1px}

/* LANG/SIGN/PREP */
.lang-row{padding:8px 10px;background:var(--bg);border-radius:8px;margin-bottom:4px}
.lang-ko{font-size:13px;font-weight:600}.lang-tw{font-size:14px;font-weight:800;color:#1e3a5f}
.lang-py{font-size:10px;color:var(--dim);margin-top:1px}.lang-kr{font-size:11px;color:var(--blue);font-weight:700;margin-top:1px}
.sign-card{background:var(--bg);border-radius:10px;padding:10px;margin-bottom:6px}
.sign-vis{height:48px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;font-family:'Noto Sans TC','Noto Sans JP',sans-serif;letter-spacing:2px;color:#fff;margin-bottom:4px}
.sign-m{font-size:13px;font-weight:800}.sign-kr{font-size:11px;color:var(--blue);font-weight:700}
.sign-r{font-size:10px;color:var(--dim)}.sign-d{font-size:11px;color:var(--dim);line-height:1.4;margin-top:2px}
.prep-sec{margin-bottom:12px}
.prep-h{font-size:13px;font-weight:800;color:#1e3a5f;margin-bottom:4px;padding-bottom:3px;border-bottom:2px solid var(--blue2)}
.prep-item{font-size:12px;color:#555;line-height:1.9}
.prep-em{background:#fef2f2;border-radius:8px;padding:8px;font-size:11px;color:#b91c1c;line-height:1.6;border:1px solid #fecaca;margin-top:8px}

/* ═══ STAGE GAME ═══ */
.stage-line{width:3px;height:24px;background:var(--blue);margin:0 auto;opacity:.3;transition:.3s}
.stage-line.on{opacity:1}
.stage{position:relative;padding:12px;margin:0 4px;border-radius:14px;border:2px solid var(--border);background:#fff;transition:.3s}
.stage.active{border-color:var(--blue);box-shadow:0 4px 16px rgba(7,112,227,.1)}
.stage.done{border-color:#22c55e;background:#f0fdf4}
.stage.skipped{opacity:.4}
.stage-num{position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;color:#fff;background:#ccc;transition:.3s}
.stage.active .stage-num{background:var(--blue);animation:pulse .8s infinite}
.stage.done .stage-num{background:#22c55e}
.stage-time{font-size:10px;font-weight:700;color:var(--blue);margin-bottom:3px}
.stage-label{font-size:14px;font-weight:800;margin-bottom:6px}
.stage-opts{display:grid;gap:5px}
.stage-opt{display:flex;gap:8px;padding:8px 10px;border-radius:10px;border:2px solid var(--border);background:#fff;cursor:pointer;transition:.2s;position:relative;overflow:hidden}
.stage-opt:active{transform:scale(.97)}
.stage-opt.picked{border-color:var(--blue);background:var(--blue2)}
.stage-opt.rejected{opacity:.3;text-decoration:line-through}
.stage-opt.rejected::after{content:'PASS';position:absolute;right:6px;top:50%;transform:translateY(-50%) rotate(-12deg);font-size:9px;font-weight:900;color:#ef4444;opacity:.5}
.stage-opt-img{width:48px;height:48px;border-radius:7px;flex-shrink:0;object-fit:cover;background:var(--border)}
.stage-opt-info{flex:1;min-width:0}
.stage-opt-name{font-size:12px;font-weight:700}
.stage-opt-desc{font-size:10px;color:var(--dim);margin-top:1px}
.stage-opt-cost{font-size:12px;font-weight:800;color:var(--blue);margin-top:1px}
.stage-gallery{display:flex;gap:4px;margin-top:6px;overflow-x:auto;scrollbar-width:none;scroll-snap-type:x mandatory}
.stage-gallery::-webkit-scrollbar{display:none}
.stage-gallery img{width:90px;height:60px;border-radius:6px;flex-shrink:0;object-fit:cover;scroll-snap-align:start;background:var(--border)}
.stage-total{text-align:center;padding:16px;margin:8px 4px;background:var(--blue2);border-radius:14px;border:2px solid #c7d2fe}
.stage-total-val{font-size:26px;font-weight:900;color:var(--blue)}
.stage-total-label{font-size:11px;color:var(--dim);margin-top:3px}
.stage-route{display:block;text-align:center;font-size:13px;font-weight:700;background:var(--blue);color:#fff;padding:10px;border-radius:10px;margin:8px 4px}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes cardReveal{from{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes glowPulse{0%,100%{text-shadow:0 0 8px rgba(255,255,255,.08)}50%{text-shadow:0 0 24px rgba(255,255,255,.2)}}
@keyframes blink{0%,100%{opacity:.3}50%{opacity:.7}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(7,112,227,.3)}50%{box-shadow:0 0 0 6px rgba(7,112,227,0)}}
@keyframes popIn{from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}
@keyframes slideIn{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}
@keyframes confettiFall{0%{transform:translateY(-20px) rotate(0deg);opacity:1}100%{transform:translateY(400px) rotate(720deg);opacity:0}}
