*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F7F3EE;--surface:#FFFFFF;--surface2:#F0EBE3;--surface3:#EBE5DC;
  --border:rgba(0,0,0,0.06);--border2:rgba(0,0,0,0.11);
  --text:#1A1409;--text2:#3D3629;--muted:#6B5F52;--muted2:#A8998A;
  --accent:#C4682A;--accent-l:#FEF0E6;--accent-d:#9E4F18;--accent-m:rgba(196,104,42,0.1);
  --green:#2A7A5A;--green-l:#E8F5EE;
  --danger:#C42A2A;--danger-l:#FDE8E8;
  --gold:#E8A020;
  --fd:'Playfair Display',Georgia,serif;--fb:'DM Sans',system-ui,sans-serif;
  --r:16px;--rs:10px;--r-xs:6px;--r-sm:10px;--r-md:14px;--r-lg:18px;--r-xl:22px;
  --sh0:none;
  --sh1:0 1px 2px rgba(0,0,0,0.04),0 2px 6px rgba(0,0,0,0.03);
  --sh2:0 1px 4px rgba(0,0,0,0.05),0 4px 14px rgba(0,0,0,0.06);
  --sh3:0 4px 12px rgba(0,0,0,0.07),0 10px 28px rgba(0,0,0,0.07);
  --sh4:0 8px 24px rgba(0,0,0,0.09),0 20px 48px rgba(0,0,0,0.08);
  --sh:var(--sh2);
  --t-spring:cubic-bezier(0.34,1.56,0.64,1);
  --t-smooth:cubic-bezier(0.22,1,0.36,1);
  --t-out:cubic-bezier(0.2,0,0,1);
  --nav-h:52px;--nav-fab:28px;--hdr-h:calc(54px + max(0px, env(safe-area-inset-top) - 14px));
}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--bg);color:var(--text);min-height:100vh;font-size:15px;line-height:1.6;padding-bottom:calc(var(--nav-h) + var(--nav-fab) + env(safe-area-inset-bottom));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
#app{max-width:520px;margin:0 auto;position:relative}
.view{display:none}.view.active{display:block}

/* ══ HEADER ══ */
.hdr{padding:max(14px, env(safe-area-inset-top)) 18px 11px;background:rgba(247,243,238,0.97);backdrop-filter:blur(24px) saturate(1.8);-webkit-backdrop-filter:blur(24px) saturate(1.8);position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(0,0,0,0.05)}
.hdr-row{display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--accent);letter-spacing:-.3px;line-height:1}
.storage-pill{font-size:10px;font-weight:700;color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:4px 9px;letter-spacing:.2px;white-space:nowrap}
.hdr-row .storage-pill{margin-right:4px}
.logo span{color:var(--text)}
.bc{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);margin-top:4px}
.bc button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:12px;font-family:var(--fb);padding:0;text-decoration:underline}
.bc .sep{color:var(--border2)}
.hdr-greeting{font-size:15px;font-weight:400;color:var(--text2);font-family:var(--fd);font-style:italic;letter-spacing:-.01em}
.hdr-search-btn{background:none;border:none;color:var(--text2);cursor:pointer;padding:6px;border-radius:10px;-webkit-tap-highlight-color:transparent;transition:opacity .15s}
.hdr-search-btn:active{opacity:.5}

/* ══ Step 5: Universal search overlay ══ */
.us-overlay{position:fixed;inset:0;z-index:1200;background:var(--bg);display:flex;flex-direction:column;animation:fadeIn .18s ease both}
.us-bar-row{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.us-search-icon{color:var(--muted);flex-shrink:0}
.us-input{flex:1;background:none;border:none;outline:none;font-size:17px;font-family:var(--fb);color:var(--text);caret-color:var(--accent)}
.us-input::placeholder{color:var(--muted2)}
.us-close{background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:10px;-webkit-tap-highlight-color:transparent;flex-shrink:0}
.us-results{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(env(safe-area-inset-bottom,0px)+80px)}
.us-hint{padding:48px 24px;text-align:center;font-size:14px;color:var(--muted);line-height:1.6}
.us-empty{padding:48px 24px;text-align:center;font-size:14px;color:var(--muted);line-height:1.6}
.us-section-label{padding:14px 18px 6px;font-size:11px;font-weight:700;color:var(--muted2);text-transform:uppercase;letter-spacing:.6px}
.us-row{display:flex;align-items:center;gap:12px;padding:12px 18px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .1s;border-bottom:1px solid var(--border)}
.us-row:active{background:var(--surface2)}
.us-row--trip .us-row-ico{font-size:22px;width:44px;height:44px;background:var(--surface2);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.us-row-thumb{width:44px;height:44px;border-radius:12px;overflow:hidden;background:var(--surface2);flex-shrink:0}
.us-row-body{flex:1;min-width:0}
.us-row-title{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.us-row-sub{font-size:12px;color:var(--muted2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.us-row-arr{color:var(--border2);flex-shrink:0}

/* ══ BOTTOM NAV — liquid glass floating pill ══ */
.nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);z-index:200;width:100%;max-width:520px;padding:0 24px calc(14px + env(safe-area-inset-bottom));pointer-events:none;box-sizing:border-box}
.nav-inner{pointer-events:auto;display:flex;align-items:center;gap:0;padding:8px 6px;background:rgba(255,255,255,0.45);backdrop-filter:blur(40px) saturate(2.2) brightness(1.08);-webkit-backdrop-filter:blur(40px) saturate(2.2) brightness(1.08);border:1px solid rgba(255,255,255,0.82);border-radius:28px;box-shadow:0 12px 40px rgba(26,20,9,0.14),0 2px 8px rgba(26,20,9,0.06),inset 0 1px 0 rgba(255,255,255,0.95),inset 0 -1px 0 rgba(0,0,0,0.04)}
.nav-fab-spacer{flex:0 0 56px}
.nav-item{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;padding:10px 6px;border-radius:20px;cursor:pointer;border:none;background:transparent;color:var(--muted2);transition:color .2s,transform .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:44px;position:relative}
.nav-item:active{opacity:.82}
.nav-item.active{color:var(--accent-d)}
.nav-icon{display:flex;align-items:center;justify-content:center;line-height:1;color:inherit}
.nav-icon .ico{display:block;opacity:.75}
.nav-item.active .nav-icon .ico{opacity:1;color:var(--accent)}
.nav-post{pointer-events:auto;position:absolute;left:50%;bottom:calc(10px + env(safe-area-inset-bottom) + 22px);transform:translateX(-50%);padding:0;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;z-index:201}
.nav-post-btn{width:56px;height:56px;border-radius:50%;background:linear-gradient(148deg,#E8884A 0%,#C4682A 52%,#A85420 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(196,104,42,0.45),0 2px 6px rgba(26,20,9,0.12),inset 0 1px 0 rgba(255,255,255,0.28);transition:transform .22s var(--t-spring),box-shadow .2s;color:#fff;border:2.5px solid rgba(255,255,255,0.95);position:relative}
.nav-post-btn::after{content:'';position:absolute;inset:-5px;border-radius:50%;border:2px solid rgba(196,104,42,0.28);animation:fabRing 3s ease-in-out infinite;pointer-events:none}
@keyframes fabRing{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:0}}
.nav-post-btn .ico{color:#fff}
.nav-post:active .nav-post-btn{transform:scale(0.88);box-shadow:0 2px 10px rgba(196,104,42,0.35)}
.nav-post-badge{position:absolute;top:-3px;right:-3px;min-width:18px;height:18px;background:#FF3B30;color:#fff;font-size:10px;font-weight:700;border-radius:9px;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg);font-family:var(--fb);pointer-events:none;padding:0 4px;z-index:202;animation:badgePop .3s cubic-bezier(0.34,1.56,0.64,1) both}
@keyframes badgePop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}

/* ══ GENERIC ══ */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--rs);border:none;cursor:pointer;font-family:var(--fb);font-size:14px;font-weight:600;transition:transform .18s var(--t-spring),background .15s,opacity .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:44px;letter-spacing:.01em}
.btn:active{transform:scale(0.95)}
.btn-primary{background:linear-gradient(148deg,#D4784A 0%,#C4682A 100%);color:#fff;box-shadow:0 3px 12px rgba(196,104,42,0.28),inset 0 1px 0 rgba(255,255,255,0.22)}
.btn-primary:active{background:var(--accent-d);box-shadow:none}
.btn-primary.loading{opacity:.75;pointer-events:none}
.btn-primary.success{background:#2A7A5A;box-shadow:0 2px 12px rgba(42,122,90,0.25);animation:btnSuccess .5s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes btnSuccess{0%{transform:scale(0.93)}60%{transform:scale(1.05)}100%{transform:scale(1)}}
.btn-ghost{background:rgba(255,255,255,0.45);backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border:1px solid rgba(255,255,255,0.75);color:var(--text);box-shadow:0 2px 8px rgba(26,20,9,0.08),inset 0 1px 0 rgba(255,255,255,0.9)}.btn-ghost:active{background:rgba(255,255,255,0.65);transform:scale(0.96)}
.btn-danger{background:rgba(253,232,232,0.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--danger);border:1px solid rgba(196,42,42,0.15)}
.btn-sm{padding:6px 12px;font-size:13px;min-height:36px}
.s0{background:linear-gradient(135deg,#F5E6D3,#D4A87A)}.s1{background:linear-gradient(135deg,#D3E8E0,#7AB8A0)}.s2{background:linear-gradient(135deg,#E8D3F5,#B07ABE)}.s3{background:linear-gradient(135deg,#F5D3D3,#C48080)}.s4{background:linear-gradient(135deg,#D3D8F5,#7A8AC4)}
.empty{text-align:center;padding:48px 24px;color:var(--muted)}.empty p{font-size:14px;margin-bottom:18px;line-height:1.7;max-width:280px;margin-left:auto;margin-right:auto}
.toast{position:fixed;bottom:calc(var(--nav-h) + var(--nav-fab) + env(safe-area-inset-bottom) + 12px);left:50%;transform:translateX(-50%);background:rgba(26,20,9,0.9);color:#fff;padding:11px 22px;border-radius:22px;font-size:14px;font-weight:500;z-index:800;white-space:nowrap;animation:toastIn .32s var(--t-smooth);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);pointer-events:none;box-shadow:0 4px 20px rgba(0,0,0,0.25)}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ══ HOME FEED ══ */
#view-trips{background:#EDEAE5;min-height:100dvh}
/* ── Swipe home layout ────────────────────────────────────────────────── */
.home-sticky{position:sticky;top:var(--hdr-h);z-index:90;background:rgba(237,234,229,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1.5px solid rgba(0,0,0,0.06)}
.home-tab-bar{display:flex;align-items:center;padding:7px 12px 5px}
.home-tab-spacer{flex:0 0 32px}
.home-tab-inner{flex:1;display:flex;position:relative;background:rgba(0,0,0,0.07);border-radius:11px;padding:3px}
.home-tab{flex:1;padding:6px 4px;border:none;background:none;font-family:var(--fb);font-size:12px;font-weight:600;color:var(--muted2);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color .2s;white-space:nowrap;text-align:center;position:relative;z-index:1}
.home-tab.active{color:var(--text)}
.home-tab-ink{position:absolute;top:0;bottom:0;background:var(--surface);border-radius:9px;box-shadow:0 1px 5px rgba(0,0,0,0.13);pointer-events:none;z-index:0;transition:left .38s cubic-bezier(0.25,0.46,0.45,0.94),width .38s cubic-bezier(0.25,0.46,0.45,0.94)}
.home-search-icon-btn{background:none;border:none;cursor:pointer;padding:8px;border-radius:50%;-webkit-tap-highlight-color:transparent;color:var(--text2);display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}
.home-search-icon-btn:active{background:rgba(0,0,0,0.08)}
/* CSS fallback height — JS overrides with exact pixel value after first paint */
.home-panels-outer{overflow:hidden;height:calc(100dvh - var(--hdr-h) - 86px - calc(var(--nav-h) + var(--nav-fab)))}
.home-panels{display:flex;width:300%;height:100%;min-height:inherit;will-change:transform}
.home-panel{flex:0 0 33.333%;height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}
/* Legacy — kept for other views */
.home-tab-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 32px;text-align:center;color:var(--muted);font-size:14px;line-height:1.6;min-height:300px}
.home-tab-empty-ico{font-size:48px;margin-bottom:14px;opacity:.7}
/* Premium empty states */
.home-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 36px 80px;text-align:center;min-height:360px}
.home-empty-art{margin-bottom:24px}
.home-empty-circle{width:88px;height:88px;border-radius:28px;background:linear-gradient(145deg,#FEF4E8,var(--accent-l));display:flex;align-items:center;justify-content:center;margin:0 auto;box-shadow:0 8px 28px rgba(196,104,42,0.16),0 2px 8px rgba(196,104,42,0.08),inset 0 1px 0 rgba(255,255,255,0.7)}
.home-empty-circle .ico{color:var(--accent);opacity:.85}
.home-empty-avatars{display:flex;gap:6px}
.home-empty-avatars span{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px}
.home-empty-title{font-family:var(--fd);font-size:20px;font-weight:700;color:var(--text);margin-bottom:8px}
.home-empty-body{font-size:13.5px;color:var(--muted);line-height:1.65;max-width:240px;margin-bottom:24px}
.home-empty-cta{background:var(--accent);color:#fff;border:none;border-radius:22px;padding:12px 26px;font-family:var(--fb);font-size:14px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s var(--t-spring),background .15s,box-shadow .15s;touch-action:manipulation;box-shadow:0 4px 18px rgba(196,104,42,0.32)}
.home-empty-cta:active{transform:scale(.95)}

/* ══ Step 1: Onboarding screen ══ */
.onboard-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:calc(100dvh - 130px);padding:0 32px 40px}
.onboard-illus{width:110px;height:110px;border-radius:32px;background:var(--accent-l);display:flex;align-items:center;justify-content:center;font-size:56px;margin:0 auto 24px;box-shadow:0 8px 32px rgba(196,104,42,.18);animation:onboard-pop .5s var(--t-spring) both}
@keyframes onboard-pop{from{opacity:0;transform:scale(.8) translateY(12px)}to{opacity:1;transform:none}}
.onboard-logo{font-family:var(--fd);font-size:36px;font-weight:700;color:var(--text);letter-spacing:-1px;line-height:1}
.onboard-logo span{color:var(--accent)}
.onboard-tagline{font-size:14px;color:var(--muted);margin:6px 0 28px;line-height:1.5}
.onboard-feats{display:flex;flex-direction:column;gap:13px;margin-bottom:36px;text-align:left;width:100%;max-width:280px}
.onboard-feat{display:flex;align-items:center;gap:12px;font-size:14.5px;color:var(--text);line-height:1.4}
.onboard-feat-ico{width:36px;height:36px;border-radius:12px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.onboard-cta{width:100%;max-width:280px;padding:17px;background:var(--accent);color:#fff;border:none;border-radius:18px;font-family:var(--fb);font-size:17px;font-weight:700;letter-spacing:-.2px;cursor:pointer;-webkit-tap-highlight-color:transparent;margin-bottom:14px;box-shadow:0 6px 24px rgba(196,104,42,.35);transition:transform .15s var(--t-spring),box-shadow .15s;touch-action:manipulation}
.onboard-cta:active{transform:scale(.96);box-shadow:0 3px 12px rgba(196,104,42,.25)}
.onboard-skip{background:none;border:none;color:var(--muted);font-size:13.5px;cursor:pointer;padding:8px;-webkit-tap-highlight-color:transparent;font-family:var(--fb)}
.onboard-skip:active{opacity:.6}

/* ══ Step 2: Data-loss warning banner ══ */
.data-warn-banner{display:flex;align-items:center;gap:10px;margin:0 16px 10px;padding:10px 12px;background:rgba(196,104,42,.05);border:1px solid rgba(196,104,42,.12);border-radius:12px;font-size:12px;line-height:1.45;color:var(--text);animation:fadeInDown .35s ease both}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.data-warn-ico{font-size:16px;flex-shrink:0}
.data-warn-text{flex:1;color:var(--muted)}
.data-warn-text strong{color:var(--text)}
.data-warn-export{background:transparent;color:var(--accent);border:1.5px solid rgba(196,104,42,.38);border-radius:8px;padding:5px 11px;font-size:11.5px;font-weight:700;cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;font-family:var(--fb);transition:background .15s}
.data-warn-dismiss{background:none;border:none;color:var(--muted2);font-size:11px;cursor:pointer;white-space:nowrap;padding:5px;-webkit-tap-highlight-color:transparent}

/* Social feed card (Following tab) */
.soc-feed-user{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.soc-feed-avatar{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.soc-feed-uname{font-size:12px;font-weight:600;color:var(--muted)}
/* Search bar — only rendered when open */
.home-search-wrap{padding:0 16px 10px;position:relative;animation:searchExpand .24s cubic-bezier(0.22,1,0.36,1) both}
@keyframes searchExpand{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.home-search-wrap{animation:none}}
.home-search{width:100%;padding:10px 36px 10px 38px;background:rgba(0,0,0,0.06);border:none;border-radius:12px;font-family:var(--fb);font-size:16px;color:var(--text);outline:none;transition:background .18s,box-shadow .18s;-webkit-appearance:none;display:block}
.home-search:focus{background:var(--surface);box-shadow:0 0 0 2px var(--accent)}
.home-search::placeholder{color:var(--muted2);font-size:13px}
.home-search-icon{position:absolute;left:28px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none;opacity:.4;line-height:1}
.home-search-clear{position:absolute;right:24px;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.14);border:none;border-radius:50%;width:18px;height:18px;cursor:pointer;font-size:10px;color:var(--text2);display:none;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;line-height:1}
.home-search-clear.show{display:flex}
.search-results-bar{padding:6px 16px 2px;font-size:12px;color:var(--muted);font-weight:500}
.cat-chips{display:flex;gap:6px;overflow-x:auto;overflow-y:hidden;padding:0 14px 13px;scrollbar-width:none;max-height:52px;opacity:1;transition:max-height .28s cubic-bezier(0.22,1,0.36,1),opacity .2s ease,padding-bottom .28s cubic-bezier(0.22,1,0.36,1)}
.cat-chips::-webkit-scrollbar{display:none}
.home-sticky.cats-hidden .cat-chips{max-height:0;opacity:0;padding-bottom:0}
.cat-chip{padding:8px 18px;border-radius:24px;font-family:var(--fb);font-size:13px;font-weight:600;white-space:nowrap;cursor:pointer;border:none;-webkit-tap-highlight-color:transparent;transition:all .2s var(--t-smooth);letter-spacing:.1px;touch-action:manipulation}
.cat-chip:active{transform:scale(0.93)}
.cat-chip.on{background:linear-gradient(148deg,#D4784A 0%,#C4682A 100%);color:#fff;box-shadow:0 3px 14px rgba(196,104,42,0.38),inset 0 1px 0 rgba(255,255,255,0.22)}
.cat-chip.off{background:rgba(255,255,255,0.8);color:var(--text2);border:1px solid var(--border2);box-shadow:0 1px 3px rgba(0,0,0,0.04)}

/* ── XHS two-column feed (strict L/R/L/R by post order) ── */
.xhs-grid{display:flex;gap:10px;padding:10px 12px;align-items:flex-start}
.xhs-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}
.xhs-card{background:var(--surface);border-radius:20px;overflow:hidden;cursor:pointer;display:block;box-shadow:0 2px 6px rgba(0,0,0,0.05),0 6px 20px rgba(0,0,0,0.09);-webkit-tap-highlight-color:transparent;position:relative;transition:transform .18s var(--t-smooth),box-shadow .18s}
.xhs-card:active{transform:scale(0.96);box-shadow:0 1px 2px rgba(0,0,0,0.04)}
.xhs-photo{width:100%;position:relative;overflow:hidden;background:#1a1008}
.xhs-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.xhs-photo-ov{position:absolute;bottom:0;left:0;right:0;padding:36px 9px 9px;background:linear-gradient(transparent,rgba(0,0,0,0.72));pointer-events:none;display:flex;align-items:flex-end;justify-content:space-between;gap:4px}
.xhs-ov-left{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.xhs-ov-right{display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:all;flex-shrink:0}
.xhs-ov-rating{font-size:13px;font-weight:800;color:#FFD700;text-shadow:0 1px 3px rgba(0,0,0,.55);line-height:1}
.xhs-ov-like,.xhs-ov-cmt{background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;display:flex;flex-direction:column;align-items:center;gap:2px;color:#fff;padding:3px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));pointer-events:all;transition:transform .15s}
.xhs-ov-like:active,.xhs-ov-cmt:active{transform:scale(1.3)}
.xhs-ov-like span,.xhs-ov-cmt span{font-size:10.5px;font-weight:700;color:rgba(255,255,255,.9);line-height:1}
.xhs-ov-like.liked .ico{color:#ff4757}
.xhs-rest-pill{display:inline-flex;align-items:center;gap:2px;background:rgba(0,0,0,0.32);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:none;border-radius:6px;padding:2px 5px;font-size:9px;font-weight:600;color:rgba(255,255,255,.78);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}
.xhs-nophoto-loc{position:absolute;bottom:7px;left:8px;right:8px;pointer-events:none}
.xhs-count{position:absolute;top:8px;right:8px;background:rgba(0,0,0,0.48);color:#fff;font-size:10px;font-weight:700;padding:3px 7px;border-radius:9px;backdrop-filter:blur(6px)}
.xhs-multi-badge{position:absolute;top:7px;right:7px;color:#fff;pointer-events:none;filter:drop-shadow(0 1px 3px rgba(0,0,0,0.55));z-index:2;line-height:0}
.xhs-must-badge{position:absolute;top:8px;left:8px;background:linear-gradient(135deg,#FF4500,#FF6B35);color:#fff;border-radius:10px;padding:3px 9px;font-size:9.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;box-shadow:0 2px 8px rgba(255,69,0,0.4)}
.xhs-nophoto{overflow:hidden}
.xhs-nophoto-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px;text-align:center;gap:6px}
.xhs-nophoto-emoji{font-size:36px;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,0.3))}
.xhs-nophoto-name{font-size:12.5px;font-weight:700;color:rgba(255,255,255,.95);line-height:1.35;text-shadow:0 1px 4px rgba(0,0,0,0.35);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.xhs-nophoto-rating{font-size:11px;font-weight:700;color:#FFD700;text-shadow:0 1px 3px rgba(0,0,0,0.4);letter-spacing:.2px}
.xhs-nophoto-actions{position:absolute;bottom:8px;right:8px;display:flex;flex-direction:column;align-items:center;gap:6px}
.xhs-body{padding:10px 13px 12px}
.xhs-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:6px;margin-bottom:3px}
.xhs-title-row .xhs-shop-title{margin-bottom:0}
.xhs-body-like{background:none;border:none;display:flex;align-items:center;gap:3px;font-size:12px;font-weight:600;color:var(--muted2);cursor:pointer;padding:2px 0 2px 2px;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:color .15s}
.xhs-body-like .ico{color:var(--muted2);transition:color .15s}
.xhs-body-like.liked,.xhs-body-like.liked .ico{color:#ff4d6d}
.xhs-body-menu{background:none;border:none;display:flex;align-items:center;justify-content:center;width:28px;height:28px;margin:-4px -4px -4px 0;color:var(--muted2);cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:transform .2s cubic-bezier(0.34,1.56,0.64,1),opacity .15s}
.xhs-body-menu .ico{color:var(--muted2)}
.xhs-body-menu:active{transform:scale(0.85);opacity:.6}
.xhs-shop-title{font-size:14.5px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0 0 3px;line-height:1.35;letter-spacing:-.01em}
.xhs-card-stars{font-size:11px;letter-spacing:.4px;line-height:1;margin-bottom:1px}
.xhs-card-note{font-size:12px;color:var(--muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px}
.xhs-trip-badge{display:inline-flex;align-items:center;gap:4px;margin-top:5px;padding:3px 9px 3px 6px;border-radius:20px;background:rgba(196,104,42,0.1);border:1px solid rgba(196,104,42,0.2);font-size:11px;font-weight:600;color:var(--accent);cursor:pointer;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background .15s,transform .1s;-webkit-tap-highlight-color:transparent}
.xhs-trip-badge:active{background:rgba(196,104,42,0.18);transform:scale(0.96)}
.xhs-caption{font-size:12.5px;line-height:1.5;color:var(--text2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;margin:0 0 4px}
.xhs-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:2px}
.xhs-tag{font-size:10.5px;color:var(--accent);font-weight:600;opacity:.8}
.xhs-poll{border-top:1px solid var(--border);padding-top:7px;margin-top:6px}
.xhs-poll-q{font-size:11px;font-weight:700;color:var(--text);margin-bottom:5px;line-height:1.35}
.xhs-poll-opt{margin-bottom:4px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.xhs-poll-bar{height:26px;border-radius:8px;background:var(--surface2);position:relative;overflow:hidden}
.xhs-poll-fill{position:absolute;top:0;left:0;height:100%;border-radius:8px;transition:width .6s cubic-bezier(0.34,1.1,0.64,1)}
.xhs-poll-label{position:absolute;inset:0;display:flex;align-items:center;padding:0 8px;font-size:10px;font-weight:700;color:var(--text)}
.xhs-poll-pct{position:absolute;right:7px;font-size:9px;font-weight:700;color:var(--muted);top:50%;transform:translateY(-50%)}
/* Legacy bar — kept for any remaining references */
.xhs-bar{display:none}
.xhs-like-btn{background:none;border:none;cursor:pointer;padding:5px 3px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;display:inline-flex;align-items:center;gap:3px;color:var(--muted);font-size:11px;font-weight:700;font-family:var(--fb);transition:transform .15s}
.xhs-like-btn:active{transform:scale(1.3)}
.xhs-cmt-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;padding:5px 3px;font-size:11px;font-weight:700;color:var(--muted);font-family:var(--fb);cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:transform .15s}
.xhs-cmt-btn:active{transform:scale(0.92)}
.xhs-react,.pi-react{background:var(--surface);border:1.5px solid var(--border2);border-radius:22px;padding:8px 15px;font-size:13px;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;display:inline-flex;align-items:center;gap:5px;font-family:var(--fb);font-weight:600;color:var(--muted);transition:all .2s var(--t-smooth);white-space:nowrap;flex-shrink:0;min-height:40px;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.xhs-react.voted,.pi-react.voted{background:var(--accent-l);color:var(--accent);border-color:rgba(196,104,42,0.28);box-shadow:0 2px 8px rgba(196,104,42,0.12)}
.xhs-react:active,.pi-react:active{transform:scale(0.92)}

/* ── INLINE POST — single scroll (photo + content) ── */
.post-inline{position:fixed;inset:0;z-index:300;background:#000;display:flex;flex-direction:column;overflow:hidden;transform:translate3d(0,100%,0);will-change:transform;backface-visibility:hidden}
.post-inline.pi-enter{animation:piSheetIn .38s cubic-bezier(0.32,0.72,0,1) forwards}
.post-inline.pi-enter-done{transform:translate3d(0,0,0);will-change:auto}
.post-inline.pi-exit{animation:piSheetOut .3s cubic-bezier(0.4,0,0.2,1) forwards}
@keyframes piSheetIn{from{transform:translate3d(0,100%,0)}to{transform:translate3d(0,0,0)}}
@keyframes piSheetOut{from{transform:translate3d(0,0,0)}to{transform:translate3d(0,100%,0)}}
@media (prefers-reduced-motion:reduce){
  .post-inline{transform:none;will-change:auto}
  .post-inline.pi-enter,.post-inline.pi-exit{animation:none}
  .post-inline.pi-enter-done{transform:none}
}
.pi-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;background:var(--bg)}
/* Full width always — aspect-ratio + max-height shrinks width and shows bg gap on the right */
.pi-photos{position:relative;width:100%;height:min(62vh,calc(min(100vw,520px) * 1.25));max-height:62vh;flex-shrink:0;background:#111;overflow:hidden}
.pi-photos::after{display:none}
.pi-sw-wrap{width:100%;height:100%;overflow:hidden}
.pi-swiper{display:flex;height:100%;width:100%;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:none}
.pi-swiper::-webkit-scrollbar{display:none}
.pi-slide{flex:0 0 100%;width:100%;height:100%;position:relative;flex-shrink:0;scroll-snap-align:start;scroll-snap-stop:always;box-sizing:border-box}
.pi-slide img,.pi-slide-img{width:100%;height:100%;object-fit:cover;display:block;position:relative;z-index:0}
.pi-slide-pins{position:absolute;inset:0;z-index:8;pointer-events:none}
.pi-slide-pins .pin-dot,.pi-slide-pins .pin-tooltip{pointer-events:auto}
.pi-slide-ph{display:flex;align-items:center;justify-content:center;font-size:72px;background:linear-gradient(135deg,#1a0a00,#3a1a08)}
.pi-topbar{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:max(env(safe-area-inset-top),14px) 14px 0;pointer-events:none}
.pi-topbar>*{pointer-events:all}
.pi-back{width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,0.42);border:1px solid rgba(255,255,255,0.15);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);-webkit-tap-highlight-color:transparent;transition:background .15s,transform .15s}
.pi-back:active{background:rgba(0,0,0,0.65);transform:scale(0.9)}
.pi-photo-counter{background:rgba(0,0,0,0.42);color:rgba(255,255,255,.9);font-size:11px;font-weight:700;padding:5px 12px;border-radius:20px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);letter-spacing:.3px}
.pi-topbar-acts{display:flex;align-items:center;gap:6px}
.pi-topbar-btn{width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,0.42);border:1px solid rgba(255,255,255,0.15);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);-webkit-tap-highlight-color:transparent;transition:background .15s,transform .15s}
.pi-topbar-btn:active{background:rgba(0,0,0,0.65);transform:scale(0.9)}
.pi-topbar-btn .ico{color:#fff}
.pi-pin-btn{background:rgba(0,0,0,0.38);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:11px;font-weight:600;padding:5px 11px;border-radius:20px;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-family:var(--fb);-webkit-tap-highlight-color:transparent;z-index:15;position:relative}
.pi-dots{position:absolute;bottom:14px;left:0;right:0;display:flex;justify-content:center;gap:5px;z-index:4;pointer-events:none;padding:0 16px}
.pi-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.38);transition:all .26s cubic-bezier(0.34,1.2,0.64,1)}
.pi-dot.on{background:#fff;width:14px;border-radius:3px}
.pi-photo-ov{position:absolute;bottom:max(16px,env(safe-area-inset-bottom));left:16px;right:16px;z-index:2;pointer-events:none;display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.pi-rest-name{font-family:var(--fd);font-size:24px;font-weight:700;color:#fff;line-height:1.18;text-shadow:0 2px 14px rgba(0,0,0,.6);letter-spacing:-.02em}
.pi-rating-big{display:flex;align-items:center;gap:6px;margin-top:6px}
.pi-rating-stars{font-size:14px;color:#FFD700;letter-spacing:1px;text-shadow:0 1px 5px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.5);line-height:1}
.pi-rating-score{font-size:13px;font-weight:800;color:#fff;text-shadow:0 1px 5px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.5)}
.pi-rating-label{font-size:11px;font-weight:600;color:rgba(255,255,255,.85);letter-spacing:.2px;text-shadow:0 1px 5px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.5)}
.pi-slide-cap{font-size:13px;line-height:1.5;color:#fff;margin-top:1px;pointer-events:all;max-width:100%;word-break:break-word;text-shadow:0 1px 5px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.5)}
.pi-slide-cap[onclick]{cursor:pointer}
.pi-slide-cap-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;max-width:100%}
.pi-slide-cap-text{flex:1;min-width:0}
.pi-slide-cap-more{color:rgba(255,255,255,.55);font-size:12px;font-weight:600;flex-shrink:0}
.pi-cap-edit-btn{
  flex-shrink:0;font-family:var(--fb);font-size:11px;font-weight:700;letter-spacing:.02em;
  color:#fff;background:rgba(0,0,0,.42);border:1px solid rgba(255,255,255,.26);
  border-radius:20px;padding:4px 11px;cursor:pointer;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  -webkit-tap-highlight-color:transparent;line-height:1.25;
  box-shadow:0 2px 8px rgba(0,0,0,.22);transition:transform .15s,background .15s,border-color .15s;
}
.pi-cap-edit-btn:active{transform:scale(.96);background:rgba(196,104,42,.52);border-color:rgba(255,255,255,.38)}
.pi-cap-edit-btn--add{margin-top:5px;background:rgba(196,104,42,.38);border-color:rgba(255,255,255,.32)}
.pi-slide-loc{font-size:11.5px;color:rgba(255,255,255,.92);margin-top:2px;letter-spacing:.1px;text-shadow:0 1px 5px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.5)}
.pi-photo-cap{font-size:11.5px;color:rgba(255,255,255,.78);font-style:italic;margin-top:3px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
/* Right side: pin = top edge, edit = bottom edge, social = vertical center */
.pi-photo-actions{position:absolute;inset:0;left:auto;width:48px;right:10px;z-index:5;pointer-events:none}
.pi-photo-actions .pi-side-btn--pin{position:absolute;top:max(10px,env(safe-area-inset-top));right:0;pointer-events:all}
.pi-photo-actions .pi-side-btn--edit{position:absolute;bottom:max(10px,env(safe-area-inset-bottom));right:0;pointer-events:all}
.pi-photo-actions .pi-side{position:absolute;top:50%;right:0;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:14px;padding:8px 0;pointer-events:all}
.pi-photo-actions--readonly .pi-side{top:50%;transform:translateY(-50%)}
.pi-side-btn{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:none;border:none;min-width:44px;min-height:48px;justify-content:center}
.pi-side-icon{width:42px;height:42px;border-radius:50%;background:rgba(0,0,0,0.35);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.16);display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3));transition:transform .2s cubic-bezier(0.34,1.56,0.64,1),background .15s}
.pi-side-btn:active .pi-side-icon{transform:scale(0.88);background:rgba(0,0,0,0.55)}
.pi-side-lbl{font-size:10.5px;font-weight:700;color:rgba(255,255,255,.9);font-family:var(--fb);text-shadow:0 1px 3px rgba(0,0,0,.5)}
@keyframes heartPop{0%{transform:scale(1)}40%{transform:scale(1.55)}70%{transform:scale(0.92)}100%{transform:scale(1)}}
.pi-side-btn.liked .pi-side-icon{animation:heartPop .35s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes heartSplash{
  0%  {opacity:0;transform:translate(-50%,-50%) scale(0.12)}
  20% {opacity:1;transform:translate(-50%,-50%) scale(1.28)}
  38% {opacity:1;transform:translate(-50%,-50%) scale(0.93)}
  54% {opacity:1;transform:translate(-50%,-50%) scale(1.07)}
  70% {opacity:1;transform:translate(-50%,-50%) scale(1.03) translateY(0)}
  85% {opacity:0.55;transform:translate(-50%,-50%) scale(1.03) translateY(-26px)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.05) translateY(-54px)}
}
@keyframes heartPing{
  0%  {opacity:0.55;transform:translate(-50%,-50%) scale(0.22)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(2.8)}
}
@keyframes heartParticle{
  0%  {opacity:0;transform:translate(0,0) scale(0)}
  28% {opacity:1;transform:translate(var(--pdx),var(--pdy)) scale(1)}
  100%{opacity:0;transform:translate(calc(var(--pdx)*2.0),calc(var(--pdy)*2.0 + 14px)) scale(0.2)}
}
.pi-heart-splash{position:fixed;font-size:84px;pointer-events:none;z-index:2000;animation:heartSplash .80s cubic-bezier(0.22,1,0.36,1) forwards;filter:drop-shadow(0 6px 22px rgba(218,50,68,0.40))}
.pi-heart-ping{position:fixed;pointer-events:none;z-index:1999;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,rgba(218,50,68,0.22) 0%,rgba(218,50,68,0) 72%);animation:heartPing .75s cubic-bezier(0.22,1,0.36,1) forwards}
.pi-heart-particle{position:fixed;pointer-events:none;z-index:1999;border-radius:50%;animation:heartParticle .68s cubic-bezier(0.22,1,0.36,1) forwards}
/* Content below photo — two separate stacked containers, no overlap */
.pi-body{flex:none;overflow:visible;background:var(--bg);border-radius:20px 20px 0 0;margin-top:-20px;position:relative;z-index:2;box-shadow:0 -2px 16px rgba(0,0,0,0.10)}
.pi-body::before{display:none}
.pi-body-inner{padding:20px 18px 52px}
.pi-shop-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:6px}
.pi-shop{font-family:var(--fd);font-size:26px;font-weight:700;line-height:1.15;flex:1;color:var(--text);letter-spacing:-.02em}
.pi-rating-pill{background:linear-gradient(135deg,rgba(232,160,32,0.18),rgba(232,160,32,0.09));color:var(--gold);border-radius:14px;padding:7px 14px;font-size:16px;font-weight:800;flex-shrink:0;border:1.5px solid rgba(232,160,32,.25);line-height:1}
.pi-vibes{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.pi-vibe{background:rgba(196,104,42,0.08);color:var(--accent);border-radius:20px;padding:5px 12px;font-size:11.5px;font-weight:700;border:1px solid rgba(196,104,42,0.14)}
.pi-photo-caps{margin-bottom:12px;display:flex;flex-direction:column;gap:5px}
.pi-photo-cap-row{font-size:13px;color:var(--muted);font-style:italic;display:flex;align-items:baseline;gap:7px;line-height:1.5}
.pi-photo-cap-num{font-size:10px;font-weight:700;color:var(--muted2);background:var(--surface2);border-radius:4px;padding:1px 5px;font-style:normal;flex-shrink:0}
.pi-caption-wrap{margin-bottom:14px}
.pi-caption-text{font-size:15px;line-height:1.8;color:var(--text);white-space:pre-wrap;word-break:break-word}
.pi-caption-text.clamped{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.pi-more-btn{color:var(--accent);font-weight:700;font-size:13px;background:none;border:none;cursor:pointer;padding:2px 0;font-family:var(--fb)}
.pi-bento{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12.5px;color:var(--muted);font-weight:500;margin-bottom:18px;padding:12px 14px;background:var(--surface);border-radius:14px;border:1px solid var(--border);box-shadow:var(--sh1)}
.pi-bento-sep{opacity:.25;font-size:10px}
.pi-meta{display:flex;flex-wrap:wrap;gap:7px;align-items:center;margin-bottom:18px}
.pi-meta-loc{display:inline-flex;align-items:center;gap:5px;padding:7px 13px 7px 9px;border-radius:20px;font-size:12.5px;font-weight:600;color:var(--accent);background:linear-gradient(135deg,rgba(196,104,42,0.09),rgba(232,160,32,0.05));border:1px solid rgba(196,104,42,0.18);box-shadow:0 1px 4px rgba(196,104,42,0.10);max-width:260px}
.pi-meta-date{display:inline-flex;align-items:center;gap:5px;padding:7px 12px 7px 8px;border-radius:20px;font-size:12px;font-weight:500;color:var(--text2);background:var(--surface);border:1px solid var(--border);box-shadow:0 1px 2px rgba(0,0,0,0.04)}
.pi-meta-chip{display:inline-flex;align-items:center;gap:5px;padding:7px 12px 7px 8px;border-radius:20px;font-size:12px;font-weight:500;color:var(--text2);background:var(--surface);border:1px solid var(--border);box-shadow:0 1px 2px rgba(0,0,0,0.04)}
.pi-meta-txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.pi-sec-lbl{font-size:11px;font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:10px;display:flex;align-items:center;gap:7px}
.pi-sec-lbl::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(196,104,42,0.2),transparent)}
.pi-dishes-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;margin-bottom:12px}
.pi-dishes-row::-webkit-scrollbar{display:none}
.pi-dish-chip{flex-shrink:0;background:var(--surface);border:1.5px solid var(--border);border-radius:22px;padding:7px 13px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .2s var(--t-smooth);display:flex;align-items:center;gap:6px;box-shadow:0 1px 3px rgba(0,0,0,0.05);touch-action:manipulation}
.pi-dish-chip:active,.pi-dish-chip.active{border-color:var(--accent);background:var(--accent-l);transform:scale(0.97);box-shadow:none}
.pi-dish-name{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;letter-spacing:-.01em}
.pi-dish-star{font-size:12px;color:var(--gold);font-weight:700}
.pi-dish-pin-btn{background:none;border:none;cursor:pointer;font-size:14px;padding:0;line-height:1;-webkit-tap-highlight-color:transparent;opacity:.65;transition:opacity .15s;touch-action:manipulation}
.pi-dish-pin-btn:active{opacity:1;transform:scale(1.2)}
.pi-dish-detail{background:var(--surface);border:1.5px solid var(--accent);border-radius:16px;padding:14px 16px;margin-bottom:14px;animation:dishIn .2s cubic-bezier(0.34,1.1,0.64,1);box-shadow:0 2px 10px rgba(196,104,42,0.1)}
@keyframes dishIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.pi-food-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.pi-food-tag{background:var(--accent-l);color:var(--accent);border-radius:10px;padding:5px 12px;font-size:12px;font-weight:700;border:1px solid rgba(196,104,42,0.15)}
.pi-reactions{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;margin-bottom:20px;margin-top:2px}
.pi-reactions::-webkit-scrollbar{display:none}
.pi-poll{background:var(--bg);border-radius:14px;padding:14px 16px;margin-bottom:14px;border:1px solid var(--border)}
.pi-poll-q{font-size:14px;font-weight:700;margin-bottom:12px;line-height:1.4;color:var(--text)}
.pi-poll-opt{margin-bottom:8px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.pi-poll-bar{height:38px;border-radius:10px;background:var(--surface2);position:relative;overflow:hidden}
.pi-poll-bar:active{opacity:.8}
.pi-poll-fill{position:absolute;top:0;left:0;height:100%;border-radius:10px;transition:width .5s cubic-bezier(0.34,1.1,0.64,1)}
.pi-poll-label{position:absolute;inset:0;display:flex;align-items:center;padding:0 12px;font-size:13px;font-weight:600;color:var(--text)}
.pi-poll-pct{position:absolute;right:12px;font-size:11px;font-weight:700;color:var(--muted);top:50%;transform:translateY(-50%)}
.pi-map,.sc-map.loc-explore-bar{height:68px;background:linear-gradient(135deg,#1C2B3A,#2D4356);border-radius:12px;display:flex;align-items:center;gap:12px;padding:0 14px;color:#fff;cursor:pointer;margin-bottom:14px;-webkit-tap-highlight-color:transparent;text-align:left}
.sc-map.loc-explore-bar{height:80px;margin-bottom:0}
.loc-explore-bar:active{opacity:.82}
.loc-bar-ico{flex-shrink:0;width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center}
.loc-bar-ico .ico{color:#fff}
.loc-bar-body{flex:1;min-width:0}
.loc-bar-title{font-weight:700;font-size:13px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.loc-bar-sub{font-size:11px;opacity:.65;margin-top:2px}
.loc-bar-chevron{flex-shrink:0;opacity:.75;transform:rotate(180deg);display:flex}
.loc-bar-chevron .ico{color:#fff}
.pi-actions{display:flex;gap:6px;padding:12px 0 6px;border-top:1px solid var(--border);margin-top:4px}
.pi-action{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;background:var(--bg);border:1px solid var(--border);border-radius:12px;cursor:pointer;font-family:var(--fb);font-size:11px;font-weight:700;color:var(--muted);padding:9px 4px;-webkit-tap-highlight-color:transparent;transition:all .15s}
.pi-action:active{background:var(--accent-l);color:var(--accent);border-color:var(--accent)}
.pi-comments{padding-top:0}
/* ── Comments section header ── */
.pi-cmt-sec-hdr{display:flex;align-items:center;gap:8px;padding-top:18px;margin-top:14px;margin-bottom:16px;border-top:1px solid var(--border)}
.pi-cmt-sec-title{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.01em}
.pi-cmt-sec-count{font-size:13px;font-weight:600;color:var(--muted2);line-height:1}
/* ── Empty state ── */
.pi-cmt-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:22px 20px 28px;gap:5px}
.pi-cmt-empty-ico{width:52px;height:52px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;margin-bottom:4px}
.pi-cmt-empty-ico .ico{color:var(--muted2)}
.pi-cmt-empty-title{font-size:14px;font-weight:700;color:var(--text2)}
.pi-cmt-empty-sub{font-size:12.5px;color:var(--muted2)}
/* ── XHS-style comment thread ── */
.pi-cmt{display:flex;gap:10px;align-items:flex-start;margin-bottom:18px}
.pi-cmt:last-child{margin-bottom:4px}
.pi-cmt-av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0}
.pi-cmt-main{flex:1;min-width:0}
.pi-cmt-name{font-size:13px;font-weight:600;color:var(--muted);line-height:1.3;margin-bottom:3px}
.pi-cmt-text{font-size:15px;line-height:1.5;color:var(--text);margin:0 0 6px;word-break:break-word}
.pi-cmt-at{color:var(--accent);font-weight:600}
.pi-cmt-foot{display:flex;align-items:center;gap:16px}
.pi-cmt-ts{font-size:11.5px;color:var(--muted2);line-height:1}
.pi-cmt-reply-btn{background:none;border:none;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.pi-cmt-reply-btn:active{opacity:.5}
.pi-cmt-edited{font-size:11px;color:var(--muted2);font-style:italic}
.pi-cmt-more{background:none;border:none;display:inline-flex;align-items:center;justify-content:center;color:var(--muted2);cursor:pointer;padding:2px;margin-left:-4px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:color .15s}
.pi-cmt-more .ico{color:var(--muted2)}
.pi-cmt-more:active{opacity:.5}
/* long-press feedback + lifecycle animations */
.pi-cmt-pressing{background:var(--surface2);border-radius:12px;transition:background .12s ease}
.pi-cmt-flash{animation:cmtFlash 1.1s ease}
@keyframes cmtFlash{0%{background:var(--accent-m)}60%{background:var(--accent-m)}100%{background:transparent}}
.pi-cmt-flash{border-radius:12px}
.pi-cmt-removing{animation:cmtRemove .28s cubic-bezier(0.4,0,1,1) forwards;overflow:hidden}
@keyframes cmtRemove{0%{opacity:1;transform:translateX(0)}100%{opacity:0;transform:translateX(-24px);max-height:0;margin:0;padding:0}}
/* like on the right edge, vertical */
.pi-cmt-like{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;padding:2px 0 2px 8px;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.pi-cmt-like .ico{color:var(--muted2);transition:color .15s}
.pi-cmt-like-n{font-size:11px;font-weight:600;color:var(--muted2);line-height:1;min-height:11px}
.pi-cmt-like.liked .ico,.pi-cmt-like.liked .pi-cmt-like-n{color:#ff4d6d}
.pi-cmt-like.pop-anim .ico{animation:cardHeartPop .44s cubic-bezier(0.34,1.56,0.64,1)}
/* replies (indented under parent main column) */
.pi-cmt-replies{margin-top:14px}
.pi-cmt--reply{margin-bottom:14px}
.pi-cmt--reply:last-child{margin-bottom:0}
.pi-cmt-expand{background:none;border:none;display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;padding:2px 0;margin-top:2px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.pi-cmt-expand-line{width:22px;height:1px;background:var(--border2);display:inline-block;flex-shrink:0}
.pi-cmt-expand:active{opacity:.5}
/* Reply indicator above input */
.pi-reply-indicator{display:none;align-items:center;justify-content:space-between;padding:8px 0 7px;font-size:12px;color:var(--muted);border-bottom:1px solid var(--border);animation:fadeIn .15s ease}
.pi-reply-label strong{color:var(--text);font-weight:700}
.pi-reply-cancel{background:none;border:none;font-size:20px;line-height:1;color:var(--muted2);cursor:pointer;padding:2px 4px;-webkit-tap-highlight-color:transparent}
.pi-comment-bar{display:flex;flex-direction:column;padding:0 14px calc(env(safe-area-inset-bottom) + 8px);background:rgba(247,243,238,0.97);backdrop-filter:blur(20px) saturate(1.6);-webkit-backdrop-filter:blur(20px) saturate(1.6);border-top:1px solid rgba(0,0,0,0.06);flex-shrink:0}
/* Single-row XHS-style: pill input + icon buttons */
.pi-cmt-row{display:flex;align-items:center;gap:7px;padding:10px 0 2px}
.pi-cmt-myav{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.pi-cmt-pill{flex:1;display:flex;align-items:center;gap:6px;background:rgba(0,0,0,0.06);border-radius:22px;padding:9px 14px;min-width:0;cursor:text}
.pi-comment-inp{flex:1;border:none;background:transparent;font-family:var(--fb);font-size:15px;color:var(--text);outline:none;min-width:0;padding:0}
.pi-comment-inp::placeholder{color:var(--muted2)}
.pi-comment-send--pill{background:none;border:none;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.pi-comment-send--pill .ico{color:var(--accent)}
/* Icon action buttons */
.pi-cmt-ico-btn{display:flex;flex-direction:column;align-items:center;gap:1px;background:none;border:none;cursor:pointer;padding:6px 7px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;flex-shrink:0}
.pi-cmt-ico-btn:active{opacity:.6}
.pi-cmt-ico-wrap .ico{color:var(--text);opacity:.75;transition:color .18s,opacity .18s}
.pi-cmt-ico-lbl{font-size:11px;font-weight:600;color:var(--muted);line-height:1}
.pi-cmt-ico-btn.liked .pi-cmt-ico-wrap .ico{color:#ff4d6d;opacity:1}
.pi-cmt-ico-btn.liked .pi-cmt-ico-lbl{color:#ff4d6d}
/* keep legacy send button styles for non-pill usage */
.pi-comment-send{background:linear-gradient(145deg,#D8783A,#C4682A);color:#fff;border:none;border-radius:50%;width:44px;height:44px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:transform .18s,box-shadow .18s;box-shadow:0 3px 10px rgba(196,104,42,.35)}
.pi-comment-send .ico{color:#fff}
.pi-comment-send:active{transform:scale(0.88);box-shadow:0 1px 4px rgba(196,104,42,.2)}
.pi-side-btn--cmt .pi-side-icon .ico{color:#fff;opacity:.95}
.pi-edit-fab{
  position:absolute;right:12px;bottom:max(20px,env(safe-area-inset-bottom));
  z-index:12;display:flex;align-items:center;gap:7px;padding:8px 14px 8px 12px;
  border:none;border-radius:22px;cursor:pointer;
  background:rgba(0,0,0,.48);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-family:var(--fb);font-size:12px;font-weight:700;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 4px 16px rgba(0,0,0,.28);-webkit-tap-highlight-color:transparent;
  transition:transform .15s,background .15s;
}
.pi-edit-fab:active{transform:scale(.96);background:rgba(196,104,42,.65)}
.pi-edit-fab-ico{display:flex;align-items:center;justify-content:center}
.pi-edit-fab-ico .ico{color:#fff}
.pi-pager--trip .pi-edit-fab{bottom:max(68px,env(safe-area-inset-bottom) + 52px)}

/* ADD CHOOSER */
.add-chooser{display:flex;flex-direction:column;gap:10px;padding:4px 0 8px}
.add-choice{display:flex;align-items:center;gap:14px;background:var(--bg);border:1.5px solid var(--border2);border-radius:14px;padding:16px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s}
.add-choice:active{border-color:var(--accent);background:var(--accent-l)}
.add-choice-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.add-choice-title{font-weight:700;font-size:15px;margin-bottom:3px}
.add-choice-sub{font-size:12px;color:var(--muted);line-height:1.4}

/* TRIPS TAB */
.trip-list-view{padding:0 0 20px}
.trip-list-section{padding:0 18px 16px}
.trip-list-section--tight{padding-bottom:10px}
.trip-list-section-hdr{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
.trip-list-section-title{font-size:11px;font-weight:800;color:var(--muted2);text-transform:uppercase;letter-spacing:.7px;margin:0;display:flex;align-items:center;gap:8px}.trip-list-section-title::before{content:'';flex-shrink:0;width:3px;height:14px;background:var(--accent);border-radius:2px;opacity:.7}
.trip-list-section .trip-grid{padding:0}
.trip-list-expand{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:var(--surface2);color:var(--accent-d);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s}
.trip-list-expand:active{background:var(--accent-l)}
.trip-list-expand .ico{display:block}
.trips-hub{padding:16px 18px 10px}
.trips-hub .tl-hdr{padding:0 0 14px}
.tl-hdr{padding:18px 18px 4px;display:flex;align-items:center;justify-content:space-between}
.tl-hdr h2{font-family:var(--fd);font-size:20px;font-weight:700}
.trips-hub-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.trips-hub-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;gap:12px;padding:18px 16px 16px;min-height:136px;border-radius:20px;border:none;cursor:pointer;font-family:var(--fb);-webkit-tap-highlight-color:transparent;transition:transform .22s var(--t-smooth),box-shadow .22s;position:relative;overflow:hidden}
.trips-hub-card::after{content:'';position:absolute;top:-28px;right:-28px;width:88px;height:88px;border-radius:50%;pointer-events:none}
.trips-hub-card:active{transform:scale(0.97)}
.trips-hub-card--primary{background:linear-gradient(148deg,#E07840 0%,#C4682A 55%,#A85522 100%);color:#fff;box-shadow:0 8px 24px rgba(196,104,42,.30),0 2px 8px rgba(196,104,42,.20),inset 0 1px 0 rgba(255,255,255,.22)}
.trips-hub-card--primary::after{background:rgba(255,255,255,.14)}
.trips-hub-card--trip{background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:var(--sh2)}
.trips-hub-card--trip::after{background:var(--accent-l);opacity:.9}
.trips-hub-card__icon{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.trips-hub-card--primary .trips-hub-card__icon{background:rgba(255,255,255,.2);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.trips-hub-card--primary .trips-hub-card__icon .ico{color:#fff}
.trips-hub-card--trip .trips-hub-card__icon{background:var(--accent-l)}
.trips-hub-card--trip .trips-hub-card__icon .ico{color:var(--accent)}
.trips-hub-card__body{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}
.trips-hub-card__title{font-size:15px;font-weight:700;line-height:1.25;letter-spacing:-.2px}
.trips-hub-card__desc{font-size:11px;line-height:1.45;opacity:.9}
.trips-hub-card--trip .trips-hub-card__desc{color:var(--muted);opacity:1}

/* ══ DRAFTS / UNSORTED SNAPS ══ */
.drafts-section{padding:14px 0 4px;border-bottom:1px solid var(--border);margin-bottom:4px}
.drafts-section-hdr{display:flex;align-items:center;gap:8px;padding:0 18px 10px}
.drafts-section-title{font-family:var(--fd);font-size:15px;font-weight:700;color:var(--text)}
.drafts-count{background:var(--accent);color:#fff;font-size:10px;font-weight:700;border-radius:20px;padding:2px 8px;font-family:var(--fb);letter-spacing:.02em}
.drafts-scroll{display:flex;gap:10px;padding:0 18px 10px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.drafts-scroll::-webkit-scrollbar{display:none}
.draft-card{flex-shrink:0;width:108px;cursor:pointer;border-radius:12px;overflow:hidden;background:var(--surface);border:1px solid var(--border);box-shadow:var(--sh);transition:transform .15s;-webkit-tap-highlight-color:transparent}
.draft-card:active{transform:scale(0.95)}
.draft-thumb{position:relative;width:108px;height:108px;background:var(--surface2)}
.draft-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.draft-photo-count{position:absolute;top:6px;left:6px;background:rgba(0,0,0,0.58);color:#fff;font-size:10px;font-weight:700;border-radius:10px;padding:2px 6px;font-family:var(--fb)}
.draft-rm{position:absolute;top:5px;right:5px;width:20px;height:20px;background:rgba(0,0,0,0.55);border:none;border-radius:50%;color:#fff;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;-webkit-tap-highlight-color:transparent;backdrop-filter:blur(4px)}
.draft-rm:active{background:rgba(196,42,42,.75)}
.draft-info{padding:7px 8px 8px;display:flex;flex-direction:column;gap:2px}
.draft-time{font-size:12px;font-weight:600;color:var(--text);line-height:1.2}
.draft-hint{font-size:10px;color:var(--accent);font-weight:500}

.trip-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 18px}
.trip-card{cursor:pointer;border-radius:var(--r-lg);background:var(--surface);box-shadow:var(--sh2);overflow:hidden;transition:transform .2s var(--t-smooth),box-shadow .2s;position:relative;-webkit-tap-highlight-color:transparent}
.trip-card:active{transform:scale(0.97);box-shadow:var(--sh1)}
.trip-card-post{outline:1.5px solid rgba(196,104,42,0.2)}
.trip-thumb{height:120px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--surface3)}
.trip-thumb img{width:100%;height:100%;object-fit:cover}
.trip-thumb-ph{font-size:34px;opacity:.3}
.trip-overlay{position:absolute;bottom:0;left:0;right:0;padding:7px 10px;background:linear-gradient(transparent,rgba(0,0,0,0.6))}
.trip-badge{display:inline-flex;align-items:center;gap:3px;background:rgba(255,255,255,0.18);color:#fff;font-size:10px;border-radius:20px;padding:2px 8px;backdrop-filter:blur(8px)}
.trip-info{padding:9px 11px 11px;position:relative}
.trip-info:has(.card-menu-btn){padding-right:46px}
.trip-name{font-weight:700;font-size:13px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.trip-meta{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:4px}
.trip-del{position:absolute;top:7px;right:7px;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,0.5);border:none;color:#fff;cursor:pointer;font-size:11px;display:none;align-items:center;justify-content:center}
.trip-card:hover .trip-del{display:flex}
.new-trip-card{border:2px dashed var(--border2);background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:28px 12px;cursor:pointer;border-radius:var(--r);transition:all .15s;color:var(--muted);text-align:center;min-height:166px;-webkit-tap-highlight-color:transparent}
.new-trip-card:active{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}

/* ══ TRIP DETAIL ══ */
#view-trip{background:#F5F0E8;min-height:100vh;padding-bottom:calc(var(--nav-h) + var(--nav-fab) + 16px + env(safe-area-inset-bottom))}
.trip-story{padding-bottom:8px}
.trip-hero{height:196px;position:relative;overflow:hidden;background:var(--surface2);display:flex;align-items:center;justify-content:center}
.trip-hero--story{height:148px}
.trip-timeline{position:relative;padding:8px 14px 0 22px}
.trip-timeline::before{content:'';position:absolute;left:9px;top:0;bottom:0;width:2px;background:rgba(192,57,43,0.22);border-radius:1px}
.trip-day{position:relative;margin-bottom:26px}
.trip-day-head{display:flex;align-items:flex-start;gap:10px;margin:0 0 14px 4px;position:relative}
.trip-day-node{flex-shrink:0;width:14px;height:14px;margin-top:5px;margin-left:-17px;border-radius:50%;background:#fff;border:2.5px solid #C0392B;box-shadow:0 0 0 3px #F5F0E8;z-index:1}
.trip-day-text{flex:1;min-width:0}
.trip-day-title{font-family:var(--fd);font-size:18px;font-weight:700;color:#9E3B2E;line-height:1.25;margin:0}
.trip-day-meta{font-size:12px;color:var(--muted);margin:4px 0 0}
.trip-day-add-btn{flex-shrink:0;padding:6px 12px!important;font-size:12px!important;border-radius:10px!important}
.trip-day-logs{display:flex;flex-direction:column;gap:14px}
.trip-day-empty{margin:0 0 8px 4px;font-size:13px;color:var(--muted);line-height:1.5}
.trip-log-card{position:relative;background:#fff;border-radius:20px;overflow:hidden;box-shadow:var(--sh3);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .18s var(--t-smooth)}
.trip-log-card:active{transform:scale(0.987)}
.trip-log-card .ec-vis-btn{top:10px;right:10px}
.trip-log-photo-wrap{position:relative;background:var(--surface2);aspect-ratio:4/3;overflow:hidden}
.trip-log-photo{width:100%;height:100%;object-fit:cover;display:block}
.trip-log-photo--ph{display:flex;align-items:center;justify-content:center;font-size:48px;opacity:.35}
.trip-log-place-pill{position:absolute;left:12px;bottom:12px;max-width:calc(100% - 24px);display:inline-flex;align-items:center;gap:6px;padding:6px 12px 6px 8px;border-radius:980px;background:rgba(0,0,0,0.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-size:12px;font-weight:600}
.trip-log-place-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trip-log-place-ico .ico{color:#fff}
.trip-log-photo-count{position:absolute;top:12px;right:12px;display:inline-flex;align-items:center;gap:4px;padding:5px 9px;border-radius:10px;background:rgba(0,0,0,0.55);color:#fff;font-size:11px;font-weight:700}
.trip-log-fab{position:absolute;right:12px;bottom:12px;width:48px;height:48px;border-radius:14px;border:none;background:linear-gradient(145deg,#E8884A,#C4682A,#A85420);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(196,104,42,0.45);cursor:pointer;-webkit-tap-highlight-color:transparent}
.trip-log-fab:active{transform:scale(0.92)}
.trip-log-fab .ico{color:#fff}
.trip-log-body{padding:12px 14px 14px}
.trip-log-rating{display:inline-flex;align-items:center;gap:5px;font-size:14px;font-weight:700;color:#E8A020;margin-bottom:6px}
.trip-log-rating .ico{color:#E8A020}
.trip-log-caption{font-size:13px;line-height:1.55;color:var(--text2);margin:0 0 10px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.trip-log-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:2px;border-top:0.5px solid rgba(0,0,0,0.06)}
.trip-log-actions{display:flex;align-items:center;gap:14px}
.trip-log-act{display:inline-flex;align-items:center;gap:5px;border:none;background:none;padding:0;font-family:var(--fb);font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;-webkit-tap-highlight-color:transparent}
.trip-log-act.on,.trip-log-act.on .ico{color:#C0392B}
.trip-log-time{font-size:12px;color:var(--muted2);white-space:nowrap}
.trip-hero img{width:100%;height:100%;object-fit:cover}
.trip-hero-ph{font-size:56px;opacity:.2}
.trip-hero-ov{position:absolute;inset:0;background:linear-gradient(transparent 25%,rgba(0,0,0,0.68));display:flex;align-items:flex-end;padding:18px 20px}
.trip-hero-title{color:#fff;font-family:var(--fd);font-size:24px;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,0.3)}
.trip-hero-sub{color:rgba(255,255,255,0.78);font-size:12px;margin-top:2px}
.trip-hero-cover-btn{position:absolute;top:10px;right:10px;display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);border-radius:50%;cursor:pointer;color:#fff;transition:background .15s,transform .15s}
.trip-hero-cover-btn:hover{background:rgba(0,0,0,.65);transform:scale(1.08)}
.trip-hero-cover-btn:active{transform:scale(.94)}
.day-block{margin:18px 18px 0}
.day-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.day-label{font-family:var(--fd);font-size:15px;font-weight:600}
.day-label small{font-family:var(--fb);font-size:11px;color:var(--muted);font-weight:400;margin-left:6px}
.entry-card{position:relative;background:var(--surface);border-radius:12px;border:1px solid var(--border);margin-bottom:8px;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}
.entry-card:active{transform:scale(0.98)}
.ec-vis-btn{position:absolute;top:8px;right:8px;z-index:2;width:32px;height:32px;border:none;border-radius:50%;background:none;color:var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;filter:drop-shadow(0 1px 2px rgba(0,0,0,.12))}
.ec-vis-btn.private{color:var(--muted)}
.ec-vis-btn:active{transform:scale(0.85)}
.ec-inner{display:flex}
.ec-photo{width:82px;min-width:82px;height:82px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:24px;overflow:hidden}
.ec-photo img{width:100%;height:100%;object-fit:cover}
.ec-info{padding:10px 12px;flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}
.ec-shop{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ec-foods{font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ec-loc{font-size:11px;color:var(--green);margin-top:3px}
.ec-stars{margin-top:3px}
.add-day-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin:12px 18px 0;padding:11px;border:1.5px dashed var(--border2);border-radius:var(--rs);background:transparent;cursor:pointer;color:var(--muted);font-size:14px;font-family:var(--fb);width:calc(100% - 36px);transition:all .15s}
.add-day-btn:active{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}
.add-day-form{margin-bottom:0}
.modal--add-day{max-height:min(72dvh,520px)}
.modal--add-day .modal-scroll{padding:4px 16px 0}
.modal--add-day .modal-title.add-day-modal-title{font-size:17px;margin-bottom:10px}
.add-day-cal{padding:10px 8px;background:var(--bg);border:1.5px solid var(--border2);border-radius:14px;transition:border-color .2s,box-shadow .2s}
.add-day-cal.is-duplicate{border-color:rgba(196,104,42,0.35);box-shadow:0 0 0 2px rgba(196,104,42,0.08)}
.add-day-cal-sel{display:flex;align-items:baseline;justify-content:center;gap:8px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.add-day-cal-sel-day{font-family:var(--fd);font-size:26px;font-weight:700;line-height:1;color:#9E3B2E}
.add-day-cal-sel-meta{font-size:11px;font-weight:600;color:var(--muted)}
.add-day-cal-hdr{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:6px}
.add-day-cal-month{flex:1;text-align:center;font-family:var(--fd);font-size:14px;font-weight:700;color:#9E3B2E}
.add-day-cal-nav{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;background:var(--surface);color:var(--accent-d);cursor:pointer;-webkit-tap-highlight-color:transparent}
.add-day-cal-nav:active{transform:scale(0.94);background:var(--accent-l)}
.add-day-cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.add-day-cal-weekdays span{text-align:center;font-size:9px;font-weight:700;color:var(--muted2)}
.add-day-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.add-day-cal-cell{height:30px;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;background:var(--surface);font-family:var(--fb);font-size:12px;font-weight:600;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .12s,color .12s}
.add-day-cal-cell:active{transform:scale(0.94)}
.add-day-cal-cell.is-other{background:transparent;color:var(--muted2);opacity:.55}
.add-day-cal-cell.is-today:not(.is-selected){box-shadow:inset 0 0 0 1px rgba(196,104,42,0.5);color:var(--accent-d)}
.add-day-cal-cell.is-on-trip:not(.is-selected){background:var(--accent-l);color:var(--accent-d)}
.add-day-cal-cell.is-selected{background:var(--accent);color:#fff}
.add-day-date-hint{display:none;margin:8px 0 0;text-align:center;font-size:11px;font-weight:600;color:var(--muted)}
.add-day-date-hint.show{display:block}
.add-day-date-hint--warn.show{color:var(--accent-d)}
.modal-actions{display:flex;gap:10px;margin-top:18px}
.modal-actions--compact{margin-top:12px}
.modal-actions .btn{flex:1}
.modal-actions .btn-primary{flex:2}
.story-chapter-title--default{color:#8F8278}
.story-chapter--empty .story-chapter-title--default{color:var(--muted2)}

/* Trip pick view (day grid — storyline on post detail swipe) */
.trip-pick-body{padding:12px 16px 0}
.trip-pick-hint{margin:0 0 14px;font-size:13px;line-height:1.55;color:var(--muted)}
.trip-main-card{display:flex;align-items:center;gap:12px;width:100%;margin:0 0 16px;padding:12px;border:none;border-radius:16px;background:#fff;box-shadow:0 4px 18px rgba(26,20,9,0.08);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}
.trip-main-card:active{transform:scale(0.99)}
.trip-main-badge{flex-shrink:0;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:#fff;background:linear-gradient(135deg,#E8884A,#C4682A);padding:4px 8px;border-radius:8px}
.trip-main-thumb{flex-shrink:0;width:64px;height:64px;border-radius:12px;overflow:hidden;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:28px}
.trip-main-thumb img{width:100%;height:100%;object-fit:cover}
.trip-main-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
.trip-main-title{font-family:var(--fd);font-size:16px;font-weight:700;line-height:1.3}
.trip-main-sub{font-size:12px;color:var(--muted)}
.trip-story-wrap{padding:4px 2px 20px}
.trip-story-wrap .story-timeline{padding-top:0}
.trip-story-wrap .story-lede{margin-left:48px}
.trip-pick-day{margin-bottom:22px}
.trip-pick-day-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.trip-pick-day-title{font-family:var(--fd);font-size:17px;font-weight:700;color:#9E3B2E;margin:0;line-height:1.25}
.trip-pick-day-meta{font-size:12px;color:var(--muted);margin:4px 0 0}
.trip-pick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.trip-pick-card{position:relative;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 12px rgba(26,20,9,0.06);cursor:pointer;-webkit-tap-highlight-color:transparent}
.trip-pick-card:active{transform:scale(0.98)}
.trip-pick-card--main{outline:2px solid rgba(196,104,42,0.45)}
.trip-pick-main-tag{position:absolute;top:8px;left:8px;z-index:2;font-size:9px;font-weight:800;text-transform:uppercase;color:#fff;background:rgba(196,104,42,0.92);padding:3px 7px;border-radius:6px}
.trip-pick-thumb{aspect-ratio:1;background:var(--surface2);overflow:hidden}
.trip-pick-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.trip-pick-ph{display:flex;align-items:center;justify-content:center;height:100%;font-size:32px;opacity:.35}
.trip-pick-info{padding:8px 10px 10px;position:relative}
.trip-pick-name{font-size:13px;font-weight:700;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;padding-right:24px}
.trip-pick-meta{font-size:11px;color:var(--muted);margin-top:3px}
.trip-pick-info .card-menu-btn{top:6px;right:4px}

/* Trip post — horizontal pager: post | storyline (swipe left) */
.post-inline:has(.pi-pager--trip){background:#111}
.pi-pager{flex:1;min-height:0;display:flex;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.pi-pager::-webkit-scrollbar{display:none}
.pi-pager-page{flex:0 0 100%;width:100%;height:100%;scroll-snap-align:start;scroll-snap-stop:always;display:flex;flex-direction:column;min-height:0;overflow:hidden}
.pi-pager-page--story{background:var(--bg);touch-action:pan-y}
.pi-story-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;padding:0 16px 32px;background:var(--bg);background-image:radial-gradient(ellipse 85% 45% at 50% -5%,rgba(196,104,42,0.09),transparent 55%),linear-gradient(180deg,#F7F3EE 0%,#EFEBE5 100%);touch-action:pan-y}
.pi-story-hdr{display:flex;align-items:center;gap:12px;padding:max(env(safe-area-inset-top),12px) 0 12px;position:sticky;top:0;z-index:3;background:rgba(247,243,238,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.pi-story-back{width:36px;height:36px;border-radius:50%;border:none;background:rgba(0,0,0,0.06);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}
.pi-story-back .ico{color:var(--text)}
.pi-story-brand{display:flex;flex-direction:column;gap:2px;min-width:0}
.pi-story-eyebrow{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-d);line-height:1}
.pi-story-title{font-family:var(--fd);font-size:18px;font-weight:700;color:#9E3B2E;line-height:1.15}
.pi-trip-banner{width:100%;display:flex;align-items:center;gap:12px;padding:12px 14px;background:linear-gradient(135deg,rgba(196,104,42,0.07),rgba(232,160,32,0.04));border:1px solid rgba(196,104,42,0.14);border-radius:16px;cursor:pointer;margin-bottom:20px;-webkit-tap-highlight-color:transparent;transition:background .15s,transform .15s;touch-action:manipulation;text-align:left}
.pi-trip-banner:active{background:rgba(196,104,42,0.12);transform:scale(0.99)}
.pi-trip-banner.hide{display:none}
.pi-trip-banner-ico{width:36px;height:36px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}
.pi-trip-banner-info{flex:1;min-width:0}
.pi-trip-banner-eyebrow{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;display:block;margin-bottom:2px}
.pi-trip-banner-name{font-size:13.5px;font-weight:700;color:var(--text);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pi-trip-banner-arr{color:var(--muted);flex-shrink:0}
.post-inline.pi-on-story .pi-trip-banner{display:none}
.post-inline.pi-on-story .pi-comment-bar{display:none}
.post-inline.pi-on-story .pi-topbar{display:none}
.pi-pager.pi-pager--arming{overflow:hidden}
.pi-pager.pi-pager--arming .pi-pager-page--story{visibility:hidden;pointer-events:none}
/* Trip storyline — warm timeline (matches app theme) */
.story-timeline{position:relative;padding:4px 0 24px}
.story-ambient{position:absolute;left:-15%;right:-15%;top:-24px;height:160px;background:radial-gradient(ellipse at 50% 0%,rgba(196,104,42,0.1),transparent 68%);pointer-events:none;opacity:0;transform:translateY(-12px)}
.story-timeline.is-visible .story-ambient{animation:storyAmbientIn 0.38s cubic-bezier(0.22,1,0.36,1) forwards}
@keyframes storyAmbientIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.story-lede{margin:0 0 18px 48px;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted2);opacity:0;transform:translateY(8px)}
.story-timeline.is-visible .story-lede{animation:storyLedeIn .3s cubic-bezier(0.22,1,0.36,1) forwards}
@keyframes storyLedeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.story-chapter{display:flex;gap:11px;align-items:flex-start;margin-bottom:18px;opacity:0;transform:translate3d(0,18px,0)}
.story-chapter:last-child{margin-bottom:8px}
.story-spine{flex:0 0 38px;display:flex;flex-direction:column;align-items:center;padding-top:4px;align-self:stretch}
.story-spine-dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(145deg,var(--accent),var(--accent-d));box-shadow:0 0 0 3px var(--bg),0 0 0 5px rgba(196,104,42,0.2);flex-shrink:0;transform:scale(0);opacity:0}
.story-timeline.is-visible .story-chapter .story-spine-dot{animation:storySpineDotIn .32s cubic-bezier(0.34,1.35,0.64,1) forwards;animation-delay:calc(var(--i) * 0.03s + 0.02s)}
@keyframes storySpineDotIn{0%{transform:scale(0);opacity:0}65%{transform:scale(1.18);opacity:1}100%{transform:scale(1);opacity:1}}
.story-spine-date{text-align:center;margin-top:8px;opacity:0;transform:translateY(6px)}
.story-timeline.is-visible .story-chapter .story-spine-date{animation:storySpineDateIn .28s cubic-bezier(0.22,1,0.36,1) forwards;animation-delay:calc(var(--i) * 0.03s + 0.06s)}
@keyframes storySpineDateIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.story-spine-date b{display:block;font-family:var(--fd);font-size:20px;font-weight:700;color:#9E3B2E;line-height:1}
.story-spine-date small{display:block;margin-top:2px;font-size:8px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.story-spine-line{flex:0 0 auto;width:2px;margin-top:12px;min-height:28px;border-radius:1px;background:linear-gradient(180deg,rgba(196,104,42,0.42),rgba(196,104,42,0.05));transform-origin:top center;transform:scaleY(0);opacity:0}
.story-timeline.is-visible .story-chapter:not(:last-child) .story-spine-line{animation:storySpineLineGrow .42s cubic-bezier(0.22,1,0.36,1) forwards;animation-delay:calc(var(--i) * 0.03s + 0.1s)}
@keyframes storySpineLineGrow{from{transform:scaleY(0);opacity:0}to{transform:scaleY(1);opacity:1}}
.story-chapter:last-child .story-spine-line{display:none}
.story-chapter-main{flex:1;min-width:0}
.story-chapter-hdr{position:sticky;top:54px;z-index:2;margin:0 0 10px;padding:2px 0 6px;background:linear-gradient(180deg,var(--bg) 72%,rgba(247,243,238,0));opacity:0;transform:translateX(8px)}
.story-timeline.is-visible .story-chapter .story-chapter-hdr{animation:storyHdrSlide .3s cubic-bezier(0.22,1,0.36,1) forwards;animation-delay:calc(var(--i) * 0.03s + 0.04s)}
@keyframes storyHdrSlide{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}
.story-chapter-hdr--row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.story-chapter-num{display:block;margin-bottom:4px;font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-d)}
.story-chapter-title{font-family:var(--fd);font-size:19px;font-weight:700;color:#9E3B2E;margin:0;line-height:1.2;display:inline-flex;align-items:baseline;flex-wrap:wrap;gap:6px;max-width:100%}
.story-day-title-editable--default:not(.is-editing) .story-day-title-text{color:#8F8278}
.story-day-title-editable--custom .story-day-title-text,
.story-day-title-editable.is-editing .story-day-title-text{color:#9E3B2E}
.story-day-title-text{min-width:1.5ch;outline:none;cursor:text;border-radius:4px;padding:0 1px;margin:0 -1px;-webkit-tap-highlight-color:transparent;caret-color:#9E3B2E;font-family:inherit;font-size:max(16px,1em);font-weight:inherit;line-height:inherit}
.story-day-title-text:focus{outline:none}
.story-day-title-editable--default:not(.is-editing) .story-day-title-text:empty::before{content:attr(data-placeholder);color:#8F8278;pointer-events:none}
.story-day-title-editable.is-editing .story-day-title-text:empty::before{content:attr(data-placeholder);color:rgba(158,59,46,0.45);pointer-events:none}
.story-day-title-edit-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin:-4px -6px -4px 0;padding:0;border:none;border-radius:50%;background:rgba(196,104,42,0.1);cursor:pointer;-webkit-tap-highlight-color:transparent}
.story-day-title-edit-btn:active{background:rgba(196,104,42,0.2);transform:scale(0.94)}
.story-day-title-editable.is-editing .story-day-title-edit-btn{opacity:0;pointer-events:none}
.story-day-title-edit-hint{flex-shrink:0;color:#9E3B2E;opacity:1;pointer-events:none}
.story-day-title-edit-hint .ico{color:#9E3B2E}
.story-chapter-meta{margin:4px 0 0;font-size:12px;color:var(--muted)}
.story-chapter-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.story-chapter-add{flex-shrink:0;padding:6px 12px;border:none;border-radius:var(--rs);background:var(--accent);color:#fff;font-family:var(--fb);font-size:11px;font-weight:700;cursor:pointer;box-shadow:0 2px 10px rgba(196,104,42,0.28);-webkit-tap-highlight-color:transparent;transition:transform .15s cubic-bezier(0.22,1,0.36,1),box-shadow .15s}
.story-chapter-add:active{transform:scale(0.96)}
.story-chapter-remove{width:34px;height:34px;padding:0;border:1px solid var(--border2);border-radius:50%;background:var(--surface);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent}
.story-chapter-remove:active{background:var(--surface2);color:#C0392B}
.story-chapter-remove .ico{color:currentColor}
.story-chapter-empty{margin:0;padding:12px 14px;border-radius:var(--rs);background:var(--surface2);border:1px dashed var(--border2);font-size:13px;line-height:1.5;text-align:center;opacity:0}
.story-chapter-empty p{margin:0 0 8px;color:var(--muted)}
.story-chapter-remove-txt{margin:0;padding:0;border:none;background:none;font-family:var(--fb);font-size:12px;font-weight:600;color:var(--muted2);text-decoration:underline;cursor:pointer;-webkit-tap-highlight-color:transparent}
.story-chapter-remove-txt:active{color:#C0392B}
.story-timeline.is-visible .story-chapter--empty .story-chapter-empty{animation:storyMomentIn .28s cubic-bezier(0.22,1,0.36,1) forwards;animation-delay:calc(var(--i) * 0.03s + 0.08s)}
.story-moments{display:flex;flex-direction:column;gap:8px}
.story-masonry{display:flex;gap:8px;align-items:flex-start}
.story-masonry .xhs-col{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}
.story-masonry .story-moment-row{border-radius:16px;overflow:hidden}
.story-masonry .xhs-card{box-shadow:0 2px 6px rgba(0,0,0,0.05),0 6px 20px rgba(0,0,0,0.09)}
/* currently-viewed moment in the read-only storyline */
.xhs-card--active{box-shadow:0 0 0 2.5px var(--accent),0 6px 20px rgba(0,0,0,0.12)}
.xhs-card--active::after{content:"Viewing";position:absolute;top:8px;right:8px;z-index:4;background:var(--accent);color:#fff;font-size:10px;font-weight:700;letter-spacing:.02em;padding:3px 8px;border-radius:11px;box-shadow:0 2px 6px rgba(0,0,0,0.2)}
.xhs-card--active .xhs-multi-badge,.xhs-card--active .xhs-must-badge{display:none}
.story-timeline.is-visible .story-chapter{animation:storyChapterIn .35s cubic-bezier(0.22,1,0.36,1) forwards;animation-delay:calc(var(--i) * 0.03s)}
@keyframes storyChapterIn{from{opacity:0;transform:translate3d(0,20px,0)}to{opacity:1;transform:translate3d(0,0,0)}}
.story-moment-row{--swipe-w:108px;position:relative;border-radius:14px;touch-action:pan-y;-webkit-user-select:none;user-select:none;opacity:0;isolation:isolate}
.story-moment-row.is-inview{animation:storyRowIn .28s cubic-bezier(0.22,1,0.36,1) forwards;animation-delay:calc(var(--mi,0) * 0.025s)}
@keyframes storyRowIn{from{opacity:0}to{opacity:1}}
.story-moment-tray{position:absolute;inset:0 0 0 auto;z-index:0;width:var(--swipe-w);display:flex;flex-direction:row;align-items:center;justify-content:center;gap:7px;padding:0 10px 0 0;pointer-events:none}
.story-moment-row.is-open .story-moment-tray,.story-moment-row.is-dragging .story-moment-tray{pointer-events:auto}
.story-moment-act{flex:0 0 42px;width:42px;height:42px;border:none;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:0;font-family:var(--fb);font-size:8.5px;font-weight:700;letter-spacing:.02em;cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 8px rgba(0,0,0,0.14);transform:scale(0.82);opacity:0;transition:transform .25s cubic-bezier(0.34,1.3,0.64,1),opacity .2s}
.story-moment-row.is-open .story-moment-act{transform:scale(1);opacity:1}
.story-moment-row.is-open .story-moment-act--edit{transition-delay:.03s}
.story-moment-row.is-open .story-moment-act--delete{transition-delay:.06s}
.story-moment-act span{pointer-events:none}
.story-moment-act--edit{background:#F0EAE2;color:var(--accent-d)}
.story-moment-act--edit .ico{color:var(--accent)}
.story-moment-act--delete{background:#C0392B;color:#fff}
.story-moment-act--delete .ico{color:#fff}
.story-moment-act:active{filter:brightness(0.9);transform:scale(0.92)!important}
.story-moment-sheet{position:relative;z-index:1;transition:transform .3s cubic-bezier(0.25,0.46,0.45,0.94);will-change:transform;touch-action:pan-y}
.story-moment-row.is-dragging .story-moment-sheet{transition:none}
.story-moment-row.is-open .story-moment-sheet{transform:translate3d(calc(-1 * var(--swipe-w)),0,0)}
.story-moment-row.is-open .story-moment{box-shadow:3px 0 14px rgba(26,20,9,0.09)}
.story-moment-row.is-dragging .story-moment{animation:none!important;transform:none!important}
.story-moment--text{align-items:flex-start;min-height:54px;padding:11px 12px}
.story-moment--text .story-moment-body{padding-right:0}
.story-moment{position:relative;display:flex;align-items:center;gap:10px;width:100%;padding:11px 12px 11px 14px;border:1px solid rgba(0,0,0,0.05);border-radius:16px;background:var(--surface);box-shadow:var(--sh1);cursor:pointer;text-align:left;font-family:var(--fb);overflow:hidden;-webkit-tap-highlight-color:transparent;opacity:0;transform:translate3d(-10px,14px,0);transition:border-color .2s,box-shadow .2s,background .2s}
.story-moment-row.is-inview .story-moment,.story-moment.is-inview{animation:storyMomentIn .55s cubic-bezier(0.22,1,0.36,1) forwards;animation-delay:calc(var(--mi,0) * 0.05s + 0.04s)}
.story-moment-row.is-inview:not(.is-open):not(.is-dragging) .story-moment:active{transform:scale(0.985)}
@keyframes storyMomentIn{from{opacity:0;transform:translate3d(-12px,24px,0) scale(0.96)}to{opacity:1;transform:translate3d(0,0,0) scale(1)}}
.story-moment.is-active,.story-moment.is-main{border-color:rgba(196,104,42,0.35);background:var(--accent-l);box-shadow:0 2px 16px rgba(196,104,42,0.12),inset 3px 0 0 var(--accent)}
.story-moment.is-main{box-shadow:0 2px 16px rgba(232,160,32,0.12),inset 3px 0 0 var(--gold)}
.story-moment-tag--main{background:var(--gold)!important;box-shadow:0 2px 8px rgba(232,160,32,0.35)!important}
.story-moment.is-inview:active{transform:scale(0.985)}
.story-moment--pulse{animation:storyMomentPulse .95s cubic-bezier(0.22,1,0.36,1)!important}
@keyframes storyMomentPulse{0%,100%{box-shadow:0 2px 16px rgba(196,104,42,0.12),inset 3px 0 0 var(--accent)}45%{box-shadow:0 8px 32px rgba(196,104,42,0.28),inset 4px 0 0 var(--accent);transform:scale(1.012)}}
.story-moment.is-main.story-moment--pulse{animation-name:storyMomentPulseMain!important}
@keyframes storyMomentPulseMain{0%,100%{box-shadow:0 2px 16px rgba(232,160,32,0.12),inset 3px 0 0 var(--gold)}45%{box-shadow:0 8px 32px rgba(232,160,32,0.3),inset 4px 0 0 var(--gold);transform:scale(1.012)}}
.story-moment-media{position:relative;flex:0 0 76px;height:76px;border-radius:12px;overflow:hidden;background:var(--surface2);flex-shrink:0}
.story-moment-media img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.12);transition:transform .75s cubic-bezier(0.22,1,0.36,1)}
.story-moment-row.is-inview .story-moment-media img,.story-moment.is-inview .story-moment-media img{transform:scale(1);transition-delay:calc(var(--mi,0) * 0.05s + 0.12s)}
.story-moment-ph{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:28px;opacity:.3}
.story-moment-stack{position:absolute;right:5px;bottom:5px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:rgba(0,0,0,0.55);color:#fff;font-size:9px;font-weight:800;line-height:18px;text-align:center;opacity:0;transform:scale(0.6)}
.story-moment-row.is-inview .story-moment-stack,.story-moment.is-inview .story-moment-stack{animation:storyStackIn .4s cubic-bezier(0.34,1.3,0.64,1) forwards;animation-delay:calc(var(--mi,0) * 0.05s + 0.28s)}
@keyframes storyStackIn{from{opacity:0;transform:scale(0.5)}to{opacity:1;transform:scale(1)}}
.story-moment-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:4px;padding-right:4px}
.story-moment-chips{display:flex;flex-wrap:wrap;align-items:center;gap:5px}
.story-moment-time{font-size:10px;font-weight:700;color:var(--muted);padding:2px 7px;border-radius:6px;background:var(--surface2)}
.story-moment-rating{font-size:10px;font-weight:700;color:var(--gold);padding:2px 7px;border-radius:6px;background:rgba(232,160,32,0.12)}
.story-moment-rating .ico{color:var(--gold)}
.story-moment-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.28;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.story-moment-note{font-size:12px;line-height:1.4;color:var(--text2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.story-moment-foot{display:flex;align-items:center;flex-wrap:wrap;gap:8px 10px;width:100%;margin-top:1px}
.story-moment-stat{font-size:11px;font-weight:600;color:var(--muted);gap:3px}
.story-moment-stat.on,.story-moment-stat.on .ico{color:#C0392B}
.story-moment-go{flex-shrink:0;align-self:center;color:var(--muted2);opacity:0;transform:translateX(-6px);transition:opacity .35s cubic-bezier(0.22,1,0.36,1),transform .35s cubic-bezier(0.22,1,0.36,1),color .2s}
.story-moment-row.is-inview .story-moment-go,.story-moment.is-inview .story-moment-go{opacity:.72;transform:translateX(0);transition-delay:calc(var(--mi,0) * 0.08s + 0.22s)}
.story-moment.is-active .story-moment-go{color:var(--accent-d);opacity:1}
.story-moment-now{position:absolute;top:8px;right:8px;z-index:2;padding:3px 8px;border-radius:20px;background:var(--accent);color:#fff;font-size:9px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 2px 8px rgba(196,104,42,0.35);animation:storyNowIn .45s cubic-bezier(0.34,1.2,0.64,1) both}
@keyframes storyNowIn{from{opacity:0;transform:scale(0.85) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}
.pi-story-scroll:not(.is-story-ready) .pi-story-hdr{opacity:0;transform:translateY(-12px)}
.pi-story-scroll.is-story-ready .pi-story-hdr{animation:storyPiHdrIn .5s cubic-bezier(0.22,1,0.36,1) forwards}
@keyframes storyPiHdrIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@media (prefers-reduced-motion:reduce){
  .story-timeline.is-visible .story-chapter,.story-timeline.is-visible .story-lede,.story-timeline.is-visible .story-ambient,.story-timeline.is-visible .story-chapter .story-spine-dot,.story-timeline.is-visible .story-chapter .story-spine-date,.story-timeline.is-visible .story-chapter .story-spine-line,.story-timeline.is-visible .story-chapter .story-chapter-hdr,.story-timeline.is-visible .story-chapter--empty .story-chapter-empty{animation:none!important;opacity:1!important;transform:none!important}
  .story-moment-row,.story-moment-row.is-inview,.story-moment,.story-moment.is-inview{animation:none!important;opacity:1!important;transform:none!important}
  .story-moment-sheet{transform:none!important;transition:none!important}
  .story-moment-row.is-open .story-moment{box-shadow:var(--sh)!important}
  .story-moment-media img,.story-moment-go,.story-moment-stack{opacity:1!important;transform:none!important;transition:none!important}
  .pi-story-scroll .pi-story-hdr{animation:none!important;opacity:1!important;transform:none!important}
}

/* ══ MODAL ══ */
.modal-bd{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:400;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s}
.modal-bd.modal-bd--closing{animation:fadeOut .22s ease both}
.modal{background:var(--surface);border-radius:24px 24px 0 0;width:100%;max-width:520px;max-height:92dvh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(0.32,0.72,0,1);box-shadow:0 -4px 32px rgba(0,0,0,0.14),0 -1px 0 rgba(0,0,0,0.04)}
.modal.modal--closing{animation:slideDown .28s cubic-bezier(0.4,0,0.2,1) both}
.modal-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 20px;overscroll-behavior:contain}
.modal-footer{flex-shrink:0;display:flex;gap:10px;padding:12px 20px max(env(safe-area-inset-bottom),20px);background:var(--surface);border-top:1px solid var(--border)}
.modal-footer .btn{flex:1}
.modal-footer .btn-primary{flex:2}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeOut{from{opacity:1}to{opacity:0}}
@keyframes slideDown{from{transform:translateY(0)}to{transform:translateY(100%)}}
@media(prefers-reduced-motion:reduce){.modal-bd--closing,.modal--closing{animation:none!important}}
@keyframes slideUp{from{transform:translateY(48px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-handle{width:40px;height:4px;background:rgba(0,0,0,0.12);border-radius:2px;margin:12px auto 16px}
.modal-title{font-family:var(--fd);font-size:21px;font-weight:700;margin-bottom:18px;color:var(--text)}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px;letter-spacing:.3px}
.form-input{width:100%;padding:13px 15px;border:1.5px solid var(--border2);border-radius:var(--r-md);font-family:var(--fb);font-size:16px;background:var(--surface);color:var(--text);outline:none;transition:border-color .18s,box-shadow .18s;-webkit-appearance:none;appearance:none}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,104,42,0.12)}
.form-input::placeholder{color:var(--muted);opacity:.5}
.form-input.error{border-color:var(--danger);box-shadow:0 0 0 3px rgba(196,42,42,0.1)}
.form-error{font-size:12px;color:var(--danger);margin-top:4px;font-weight:500;display:none}
.form-input.error+.form-error{display:block}

/* ══ XHS MASONRY HOME FEED ══ */
#view-post{background:#EFEBE5;min-height:100vh}
.feed-hdr{padding:14px 18px 10px;background:rgba(239,235,229,0.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:space-between;position:sticky;top:56px;z-index:90;border-bottom:1px solid rgba(0,0,0,0.05)}
.feed-hdr-title{font-family:var(--fd);font-size:19px;font-weight:700}
.feed-count{font-size:11px;color:var(--muted);background:rgba(0,0,0,0.07);padding:3px 10px;border-radius:20px;font-weight:600}
.masonry{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:8px}
.masonry-card{background:var(--surface);border-radius:14px;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .18s;box-shadow:0 1px 6px rgba(0,0,0,0.07)}
.masonry-card:active{transform:scale(0.97)}
.masonry-img{width:100%;position:relative;overflow:hidden;background:var(--surface2)}
.masonry-img img{width:100%;display:block;object-fit:cover}
.masonry-img-ph{aspect-ratio:.85;display:flex;align-items:center;justify-content:center;font-size:48px;opacity:.3}
.masonry-multi{position:absolute;top:8px;right:8px;background:rgba(0,0,0,0.5);color:#fff;font-size:10px;font-weight:600;padding:3px 7px;border-radius:10px;backdrop-filter:blur(4px)}
.masonry-body{padding:9px 10px 11px}
.masonry-shop{font-weight:700;font-size:13px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.masonry-meta{display:flex;align-items:center;justify-content:space-between;margin-top:5px}
.masonry-loc{font-size:10px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}
.masonry-rating{font-size:10px;color:var(--gold);font-weight:700;display:flex;align-items:center;gap:2px}
.masonry-foods{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.masonry-food-tag{font-size:10.5px;color:var(--accent);background:var(--accent-l);border-radius:8px;padding:3px 8px;font-weight:600;border:1px solid rgba(196,104,42,0.15)}
.feed-empty{text-align:center;padding:80px 30px}
.feed-empty-icon{font-size:64px;margin-bottom:16px;opacity:.25}
.feed-empty h3{font-family:var(--fd);font-size:20px;font-weight:600;margin-bottom:8px}
.feed-empty p{font-size:14px;color:var(--muted);line-height:1.7}

/* ══ POST DETAIL — STORY CARD ══ */
.post-detail{position:fixed;inset:0;z-index:300;background:#000;overflow:hidden}
.sc-photo-layer{position:absolute;inset:0;z-index:1}
.sc-swiper{display:flex;height:100%;transition:transform .35s cubic-bezier(0.25,.8,.25,1);will-change:transform}
.sc-slide{min-width:100%;height:100%;position:relative;flex-shrink:0;overflow:hidden}
.sc-slide img,.sc-slide-img{width:100%;height:100%;object-fit:cover;display:block;position:relative;z-index:0}
.sc-slide-pins{position:absolute;inset:0;z-index:6;pointer-events:none}
.sc-slide-pins .pin-dot,.sc-slide-pins .pin-tooltip{pointer-events:auto}
.sc-slide-ph{width:100%;height:100%;background:linear-gradient(135deg,#1a1009,#3d2510);display:flex;align-items:center;justify-content:center;font-size:80px}
.sc-grad-top{position:absolute;top:0;left:0;right:0;height:160px;background:linear-gradient(to bottom,rgba(0,0,0,0.65),transparent);z-index:2;pointer-events:none}
.sc-grad-bot{position:absolute;bottom:0;left:0;right:0;height:62%;background:linear-gradient(to top,rgba(0,0,0,0.9) 0%,rgba(0,0,0,0.55) 45%,transparent 100%);z-index:2;pointer-events:none}
.sc-topbar{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:max(env(safe-area-inset-top),14px) 16px 14px}
.sc-back{width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,0.38);border:none;color:#fff;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);-webkit-tap-highlight-color:transparent}
.sc-counter{color:#fff;font-size:12px;font-weight:600;background:rgba(0,0,0,0.38);padding:5px 12px;border-radius:20px;backdrop-filter:blur(8px)}
.sc-top-btn{background:rgba(0,0,0,0.38);border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;backdrop-filter:blur(10px);-webkit-tap-highlight-color:transparent}
.sc-vibes{position:absolute;top:0;left:0;right:0;z-index:3;display:flex;gap:7px;padding:max(env(safe-area-inset-top),60px) 16px 0;pointer-events:none;flex-wrap:wrap}
.sc-vibe-pill{background:rgba(255,255,255,0.18);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.22);color:#fff;font-size:11px;font-weight:600;padding:4px 11px;border-radius:20px;white-space:nowrap}
.sc-info-overlay{position:absolute;bottom:0;left:0;right:0;z-index:3;padding:0 18px 16px;pointer-events:none}
.sc-shop-name{font-family:var(--fd);font-size:26px;font-weight:700;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,0.55);line-height:1.2;margin-bottom:7px}
.sc-info-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.sc-loc{color:rgba(255,255,255,0.85);font-size:12px;font-weight:500;display:flex;align-items:center;gap:4px}
.sc-rating-badge{background:rgba(0,0,0,0.45);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.22);border-radius:20px;padding:5px 13px;display:flex;align-items:center;gap:5px}
.sc-rating-num{font-family:var(--fd);font-size:19px;font-weight:700;color:#FFD700}
.sc-photo-caption{color:rgba(255,255,255,0.88);font-size:13px;line-height:1.5;margin-bottom:10px;font-style:italic;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 6px rgba(0,0,0,0.5)}
.sc-dots{display:flex;justify-content:center;gap:5px;margin-bottom:10px}
.sc-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,0.4);transition:all .25s}
.sc-dot.on{background:#fff;width:16px;border-radius:3px}
/* THE SHELF */
.sc-shelf{position:absolute;bottom:0;left:0;right:0;z-index:5;transform:translateY(calc(100% - 128px));transition:transform .42s cubic-bezier(0.32,0.72,0,1)}
.sc-shelf.expanded{transform:translateY(0)}
.sc-shelf-inner{background:rgba(248,245,240,0.97);backdrop-filter:blur(32px) saturate(1.8);-webkit-backdrop-filter:blur(32px) saturate(1.8);border-radius:24px 24px 0 0;border-top:1px solid rgba(255,255,255,0.7);box-shadow:0 -4px 40px rgba(0,0,0,0.22),inset 0 1px 0 rgba(255,255,255,0.8);max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 0 max(env(safe-area-inset-bottom),24px)}
.sc-handle{width:38px;height:5px;background:rgba(0,0,0,0.18);border-radius:3px;margin:10px auto 4px;cursor:pointer}
.sc-peek{padding:8px 18px 14px;display:flex;flex-direction:column;gap:8px}
.sc-dish-row{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.sc-dish-row::-webkit-scrollbar{display:none}
.sc-dish-chip{flex-shrink:0;background:var(--surface);border:1.5px solid var(--border);border-radius:20px;padding:6px 13px;cursor:pointer;display:flex;align-items:center;gap:6px;-webkit-tap-highlight-color:transparent;transition:all .2s;white-space:nowrap}
.sc-dish-chip.active{border-color:var(--accent);background:var(--accent-l)}
.sc-dish-chip:active{transform:scale(0.95)}
.sc-dish-chip-name{font-size:12px;font-weight:700;color:var(--text)}
.sc-dish-chip-star{font-size:10px;color:var(--gold);font-weight:700}
.sc-bento{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.sc-bento-item{font-size:11px;color:var(--muted);font-weight:500}
.sc-bento-sep{color:var(--border2)}
.sc-detail{padding:0 18px}
.sc-dish-detail{background:var(--surface);border-radius:14px;padding:14px 16px;margin-bottom:12px;border:1.5px solid var(--accent);animation:dishSlideIn .25s cubic-bezier(0.34,1.1,0.64,1)}
@keyframes dishSlideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.sc-dish-detail-name{font-family:var(--fd);font-size:17px;font-weight:700;margin-bottom:4px}
.sc-dish-detail-note{font-size:14px;color:var(--muted);line-height:1.6;font-style:italic}
.sc-section{padding:14px 0;border-top:1px solid var(--border)}
.sc-section-lbl{font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}
.sc-caption-full{font-size:14px;line-height:1.8;color:var(--text);white-space:pre-wrap;font-style:italic;background:linear-gradient(135deg,#FFF8F0,#F7F3EC);border-radius:12px;padding:13px 15px;border-left:3px solid var(--accent)}
.sc-food-tags{display:flex;flex-wrap:wrap;gap:6px}
.sc-food-tag{background:var(--accent-l);color:var(--accent);border-radius:8px;padding:4px 11px;font-size:11px;font-weight:700}
.sc-actions{display:flex;gap:8px;padding:12px 0 4px}
.sc-action{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;background:rgba(0,0,0,0.04);border:none;border-radius:12px;cursor:pointer;font-family:var(--fb);font-size:11px;font-weight:600;color:var(--muted);padding:9px 4px;-webkit-tap-highlight-color:transparent;transition:transform .2s cubic-bezier(0.34,1.56,0.64,1),background .15s,color .15s}
.sc-action:active{background:var(--accent-l);color:var(--accent);transform:scale(0.94)}
.sc-action-icon{display:flex;align-items:center;justify-content:center;line-height:0}
.sc-map{height:80px;background:linear-gradient(135deg,#1C2B3A,#2D4356);border-radius:12px;display:flex;align-items:center;justify-content:center;gap:10px;color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent}
.sc-map:active{opacity:.85}
.sc-add-dish-btn{background:transparent;border:1.5px dashed var(--border2);border-radius:20px;padding:6px 13px;cursor:pointer;display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--muted);font-family:var(--fb);-webkit-tap-highlight-color:transparent;flex-shrink:0}
.sc-add-dish-btn:active{border-color:var(--accent);color:var(--accent)}
/* Pin dots */
.pin-dot{position:absolute;width:28px;height:28px;padding:0;border:2.5px solid #fff;border-radius:50%;background:rgba(196,104,42,0.9);color:#fff;font-family:var(--fb);font-size:11px;font-weight:700;line-height:1;cursor:pointer;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(0,0,0,0.4);z-index:9;touch-action:manipulation;-webkit-tap-highlight-color:transparent;appearance:none;-webkit-appearance:none;animation:pinPop .3s cubic-bezier(0.34,1.56,0.64,1)}
.pin-dot::before{content:'';position:absolute;inset:-14px;border-radius:50%}
.pin-dot-readonly{cursor:pointer}
.post-inline.pi-readonly .pi-pin-btn,.post-inline.pi-readonly .pi-dish-pin-btn,.post-inline.pi-readonly .pi-edit-fab,.post-inline.pi-readonly .pi-pin-bar,.post-inline.pi-readonly .pi-side-btn--pin,.post-inline.pi-readonly .pi-side-btn--edit,.post-inline.pi-readonly .pi-dishes-row .pi-dish-chip[style*="dashed"],.post-inline.pi-readonly .btn[onclick*="openAddDishModal"]{display:none!important}
@keyframes pinPop{from{transform:translate(-50%,-50%) scale(0)}to{transform:translate(-50%,-50%) scale(1)}}
.pin-tooltip{position:absolute;background:rgba(20,12,4,0.94);color:#fff;border-radius:12px;padding:8px 12px;font-size:12px;max-width:160px;z-index:10;pointer-events:none;backdrop-filter:blur(8px);box-shadow:0 4px 16px rgba(0,0,0,0.35);transform:translate(-50%,-100%) translateY(-10px);line-height:1.4}
.pin-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:rgba(20,12,4,0.94)}
.pin-tooltip-name{font-weight:700;font-size:12px;margin-bottom:2px}
.pin-tooltip-note{opacity:.78;font-size:11px}
/* ══ PIN MODAL — full photo, bottom sheet ══ */
.pin-modal{position:fixed;inset:0;z-index:600;background:#1a1108;display:flex;flex-direction:column;height:100dvh;max-height:100dvh;animation:pinModalIn .26s cubic-bezier(0.22,1,0.36,1) both}
@keyframes pinModalIn{from{opacity:0}to{opacity:1}}
.pin-modal-img{position:relative;flex:1 1 auto;min-height:min(48vh,380px);max-height:58vh;overflow:hidden;cursor:crosshair;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.pin-modal-img img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;user-select:none;-webkit-user-drag:none}
.pin-actions .btn-primary:disabled{opacity:.45;pointer-events:none}
.pin-hint-pill{position:absolute;top:max(env(safe-area-inset-top),52px);left:50%;transform:translateX(-50%);background:rgba(0,0,0,0.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fff;font-size:12px;font-weight:600;padding:7px 18px;border-radius:20px;white-space:nowrap;z-index:5;pointer-events:none;font-family:var(--fb);transition:all .3s}
.pin-hint-pill.placed{background:rgba(42,122,90,0.85);border:1px solid rgba(255,255,255,0.25)}
.pin-back-overlay{position:absolute;top:max(env(safe-area-inset-top),12px);left:14px;z-index:6;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,0.42);border:none;color:#fff;cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .15s}
.pin-back-overlay:active{background:rgba(0,0,0,0.7)}
.pin-placed-dot{position:absolute;width:34px;height:34px;border-radius:50%;background:var(--accent);border:3px solid #fff;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;box-shadow:0 0 0 6px rgba(196,104,42,0.25),0 4px 16px rgba(196,104,42,0.5);z-index:4;pointer-events:none;animation:pinDrop .38s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes pinDrop{from{transform:translate(-50%,-80%) scale(0.2);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}
/* Bottom input panel */
.pin-panel{flex:0 0 auto;max-height:min(46vh,360px);overflow-y:auto;-webkit-overflow-scrolling:touch;background:rgba(250,247,242,0.98);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,0.8);border-radius:24px 24px 0 0;padding:0 18px max(calc(env(safe-area-inset-bottom) + 16px),28px);box-shadow:0 -6px 40px rgba(0,0,0,0.22),inset 0 1px 0 rgba(255,255,255,0.9)}
.pin-panel-handle{width:36px;height:5px;background:rgba(0,0,0,0.14);border-radius:3px;margin:10px auto 14px}
.pin-panel-label{font-size:10px;font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.pin-inp{width:100%;padding:12px 14px;border:1.5px solid rgba(0,0,0,0.09);border-radius:12px;font-family:var(--fb);font-size:16px;color:var(--text);background:rgba(255,255,255,0.75);outline:none;transition:border-color .15s,box-shadow .15s,background .15s;margin-bottom:8px}
.pin-inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,104,42,0.1);background:#fff}
.pin-inp::placeholder{color:rgba(0,0,0,0.3)}
.pin-ta{min-height:68px;resize:none;line-height:1.6}
.pin-star-mini{display:flex;align-items:center;gap:6px;padding:6px 0 12px}
.pin-star-mini-lbl{font-size:12px;color:var(--muted);font-weight:500}
.pin-actions{display:flex;gap:8px}
.pin-actions .btn{flex:1;justify-content:center;padding:13px;font-size:14px}
.dish-sheet-bd{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:550;display:flex;align-items:flex-end;justify-content:center}
.dish-sheet{background:var(--surface);border-radius:22px 22px 0 0;width:100%;max-width:520px;padding:8px 20px max(env(safe-area-inset-bottom),32px);animation:slideUp .25s cubic-bezier(0.34,1.1,0.64,1)}
.dish-sheet-handle{width:36px;height:4px;background:var(--border2);border-radius:2px;margin:10px auto 18px}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
/* ══ MAP / PLACES VIEW ════════════════════════════════ */
/* ══ MAP PAGE — full-bleed map + bottom sheet ═══════════════════════════ */
#view-map{background:#F0E9DA;min-height:100dvh}
#view-map.view.active{display:block;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--nav-h) + var(--nav-fab) + 16px + env(safe-area-inset-bottom))}
#view-map.map-has-data.view.active{overflow:hidden;padding-bottom:0;height:calc(100dvh - var(--hdr-h) - var(--nav-h) - var(--nav-fab) - env(safe-area-inset-bottom));min-height:400px}

/* Map page container */
.map-page{display:block;min-height:0}
.map-page--empty{padding:0}
#view-map.map-has-data .map-page{position:relative;height:100%;overflow:hidden}

/* Full-bleed map canvas */
.map-page-map{position:absolute;inset:0}
.map-page-canvas{position:absolute;inset:0}
.map-page-canvas .map-canvas-wrap{margin:0;border-radius:0;min-height:100%;height:100%;box-shadow:none}
.map-canvas-wrap--full{min-height:100%;height:100%}

/* ── BOTTOM SHEET ── */
.map-bottom-sheet{
  position:absolute;left:0;right:0;bottom:0;
  height:calc(100% - 60px);
  transform:translateY(calc(100% - 200px));
  transition:transform .38s cubic-bezier(0.32,0.72,0,1);
  border-radius:22px 22px 0 0;
  background:var(--bg);
  box-shadow:0 -6px 40px rgba(0,0,0,0.13),0 -1px 0 rgba(0,0,0,0.05);
  display:flex;flex-direction:column;
  z-index:10;overflow:hidden;
}
.map-bottom-sheet.is-expanded{transform:translateY(0)}

/* Drag grip */
.map-sheet-grip{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:10px 0 6px;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;user-select:none}
.map-sheet-grip-bar{width:36px;height:4px;border-radius:2px;background:rgba(0,0,0,0.14);transition:width .2s}
.map-sheet-grip:active .map-sheet-grip-bar{width:48px}

/* Non-scrolling header */
.map-sheet-hdr{flex-shrink:0;padding:0 14px 10px}

/* Search row */
.map-search-row{display:flex;align-items:center;gap:8px;background:var(--surface);border-radius:12px;padding:10px 14px;border:1.5px solid var(--border);margin-bottom:10px;transition:border-color .15s}
.map-search-row:focus-within{border-color:var(--accent)}
.map-search-ico{flex-shrink:0;color:var(--muted);display:flex;align-items:center}
.map-search-inp{flex:1;border:none;background:transparent;font-size:14px;color:var(--text);outline:none;font-family:var(--fb);-webkit-appearance:none;min-width:0}
.map-search-inp::placeholder{color:var(--muted)}
.map-search-clear{border:none;background:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;touch-action:manipulation;-webkit-tap-highlight-color:transparent;flex-shrink:0}
.map-search-clear:active{background:var(--surface2)}

/* Stats row (all-places view) */
.map-stats-row{display:flex;align-items:center;gap:8px;min-height:28px}
.map-stat-pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--text2);font-weight:600;background:var(--surface);border-radius:980px;padding:5px 11px;white-space:nowrap}
.map-stat-pill b{color:#C0392B;font-weight:800}

/* Selected-place back bar */
.map-sel-bar{display:flex;align-items:center;gap:10px;min-height:28px}
.map-sel-back{border:none;background:var(--surface);color:var(--text2);border-radius:980px;padding:6px 12px 6px 8px;font-size:12px;font-weight:600;font-family:var(--fb);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;gap:2px;flex-shrink:0;white-space:nowrap;transition:background .15s}
.map-sel-back:active{background:var(--surface2)}
.map-sel-title-wrap{flex:1;min-width:0}
.map-sel-name{display:block;font-size:15px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-sel-count{font-size:11px;color:var(--muted)}

/* Scrollable body */
.map-sheet-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:4px 14px calc(var(--nav-fab) + env(safe-area-inset-bottom) + 36px);overscroll-behavior:contain}

/* ── PLACE GRID (all-places view) ── */
.map-place-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-bottom:8px}
.map-place-card{background:var(--surface);border-radius:18px;overflow:hidden;border:none;text-align:left;cursor:pointer;font-family:var(--fb);touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform .18s var(--t-smooth),box-shadow .18s;display:flex;flex-direction:column;box-shadow:var(--sh2)}
.map-place-card:active{transform:scale(0.97);box-shadow:var(--sh1)}
.map-place-card-img{width:100%;aspect-ratio:4/3;background:var(--surface2);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.map-place-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.map-place-card-emoji{font-size:32px}
.map-place-card-body{padding:8px 10px 11px;flex:1;display:flex;flex-direction:column;gap:2px}
.map-place-card-name{font-weight:700;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-place-card-meta{font-size:11px;color:var(--muted)}
.map-place-card-rating{font-size:12px;color:#E67E22;font-weight:700;margin-top:3px}
.map-no-results{text-align:center;color:var(--muted);padding:40px 16px;font-size:14px}

/* ── SELECTED PLACE BODY ── */
.map-sel-actions{display:flex;gap:10px;padding-top:2px;margin-bottom:16px}
.map-action-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:14px 10px;border-radius:14px;border:none;background:var(--surface);color:var(--text);font-size:12px;font-weight:700;font-family:var(--fb);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform .15s;min-height:64px;white-space:nowrap;box-shadow:0 1px 6px rgba(0,0,0,0.07)}
.map-action-btn:active{transform:scale(0.95);box-shadow:none}
.map-action-btn--primary{background:#C0392B;color:#fff;box-shadow:0 3px 12px rgba(192,57,43,0.3)}
.map-action-btn--primary:active{background:#A93226}
.map-sel-section-hdr{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin:4px 0 8px}
.map-sel-visits-list{margin-top:2px}

/* Visit rows (reused in selected view) */
.map-sheet-row{display:flex;align-items:center;gap:12px;width:100%;padding:10px 0;border:none;background:transparent;cursor:pointer;text-align:left;font-family:var(--fb);-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.map-sheet-row:active{opacity:.7}
.map-sheet-thumb{width:46px;height:46px;border-radius:11px;overflow:hidden;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.map-sheet-thumb img{width:100%;height:100%;object-fit:cover}
.map-sheet-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.map-sheet-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.map-sheet-meta{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-sheet-go{color:var(--muted2);flex-shrink:0}
.map-sheet-divider{height:.5px;background:var(--border);margin:0}

/* Hub button inside selected view */
.map-hub-btn{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;border:none;border-radius:14px;background:linear-gradient(135deg,rgba(192,57,43,0.1),rgba(192,57,43,0.05));cursor:pointer;text-align:left;font-family:var(--fb);touch-action:manipulation;-webkit-tap-highlight-color:transparent;margin-bottom:12px;transition:background .15s}
.map-hub-btn:active{background:linear-gradient(135deg,rgba(192,57,43,0.16),rgba(192,57,43,0.1))}
.map-hub-btn-txt{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.map-hub-btn-txt strong{font-size:14px;font-weight:700;color:var(--text)}
.map-hub-btn-txt span{font-size:11px;color:var(--muted)}

/* Empty state */
.map-empty-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 32px;gap:12px}
.map-empty-hero{font-size:64px;opacity:.3}
.map-empty-title{font-family:var(--fd);font-size:20px;font-weight:700;color:var(--text)}
.map-empty-hint{font-size:14px;color:var(--muted);line-height:1.6;max-width:260px}
.map-empty-canvas--page{min-height:280px;border-radius:22px;background:#F0E9DA;width:100%}

/* Leaflet pin markers */
.map-l-pin-visits{position:absolute;top:-2px;right:-4px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#C0392B;color:#fff;font-size:9px;font-weight:800;font-family:var(--fb);display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:0 1px 4px rgba(0,0,0,0.2)}
.places-leaflet-map{position:absolute;inset:0;width:100%;height:100%;z-index:0;background:#F0E9DA}
.places-leaflet-map .leaflet-control-zoom{border:none;box-shadow:0 2px 10px rgba(0,0,0,0.12)}
.places-leaflet-map .leaflet-control-zoom a{background:#fff;color:#C0392B;font-weight:700}
.map-l-marker-wrap{background:transparent;border:none}
.map-l-marker{position:relative;width:44px;height:56px;display:flex;flex-direction:column;align-items:center}
.map-l-pin-body{width:40px;height:40px;border-radius:50%;border:3px solid #C0392B;background:#E8DDD0;box-shadow:0 2px 10px rgba(0,0,0,0.22);overflow:hidden;display:flex;align-items:center;justify-content:center}
.map-l-pin-img{width:100%;height:100%;object-fit:cover;display:block}
.map-l-pin-emoji{font-size:18px;line-height:1}
.map-l-pin-num{position:absolute;top:-2px;left:-4px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#fff;border:1.5px solid #C0392B;color:#C0392B;font-size:9px;font-weight:800;font-family:var(--fb);display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:0 1px 4px rgba(0,0,0,0.12)}
.map-l-pin-tail{width:3px;height:10px;background:#C0392B;border-radius:2px;margin-top:-1px}
/* Step 7: rating badge on pin */
.map-l-pin-rating{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.65);color:#ffd700;font-size:8px;font-weight:800;padding:1px 4px;border-radius:7px;white-space:nowrap;z-index:3;pointer-events:none;line-height:1.6}
/* color-coded pin borders by rating */
.map-l-marker--r5 .map-l-pin-body{border-color:#22a855;box-shadow:0 2px 12px rgba(34,168,85,.42)}
.map-l-marker--r5 .map-l-pin-tail{background:#22a855}
.map-l-marker--r4 .map-l-pin-body{border-color:#f59e0b;box-shadow:0 2px 12px rgba(245,158,11,.32)}
.map-l-marker--r4 .map-l-pin-tail{background:#f59e0b}
.map-l-marker--r3 .map-l-pin-body{border-color:#f97316}
.map-l-marker--r3 .map-l-pin-tail{background:#f97316}
.map-l-marker--r2 .map-l-pin-body{border-color:#9ca3af}
/* Step 7: rating filter row */
.map-rf-row{display:flex;gap:7px;margin-bottom:10px}
.map-rf-chip{flex-shrink:0;padding:5px 13px;border:1.5px solid var(--border);border-radius:20px;background:var(--surface);font-size:11.5px;font-weight:700;font-family:var(--fb);color:var(--muted2);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}
.map-rf-chip.on{background:rgba(245,158,11,.12);border-color:#f59e0b;color:#b45309}

/* ── Plan pins ── */
.map-l-marker--plan .map-l-pin-body{background:rgba(255,255,255,0.96);border:2.5px dashed #E07B1A;box-shadow:0 2px 10px rgba(224,123,26,0.28)}
.map-l-pin-tail--plan{background:#E07B1A}
/* ── Map view-mode toggle (floats over map) ── */
.map-view-toggle{position:absolute;top:max(env(safe-area-inset-top,0px) + 10px,16px);left:50%;transform:translateX(-50%);z-index:800;display:flex;gap:3px;background:rgba(255,255,255,0.72);backdrop-filter:blur(28px) saturate(2);-webkit-backdrop-filter:blur(28px) saturate(2);border:1px solid rgba(255,255,255,0.85);border-radius:24px;padding:4px;box-shadow:0 4px 20px rgba(26,20,9,0.18),inset 0 1px 0 rgba(255,255,255,0.95);pointer-events:auto}
.map-view-btn{padding:6px 16px;border-radius:20px;border:none;font-size:12px;font-weight:700;font-family:var(--fb);color:var(--muted);background:transparent;cursor:pointer;transition:all .2s cubic-bezier(0.22,1,0.36,1);-webkit-tap-highlight-color:transparent;white-space:nowrap;touch-action:manipulation;display:flex;align-items:center;gap:4px}
.map-view-btn.on{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(196,104,42,0.35)}
.map-view-btn:active{transform:scale(0.93)}
.map-view-count{min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:rgba(255,255,255,0.3);font-size:10px;font-weight:800;display:inline-flex;align-items:center;justify-content:center}
.map-view-btn.on .map-view-count{background:rgba(255,255,255,0.35);color:#fff}
/* ── Plan bottom sheet ── */
.map-plan-hdr{display:flex;align-items:center;justify-content:space-between;padding:2px 0 10px}
.map-plan-hdr-title{font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px}
.map-plan-count{min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent);color:#fff;font-size:10px;font-weight:800;font-family:var(--fb);display:inline-flex;align-items:center;justify-content:center}
.map-plan-add-btn{display:flex;align-items:center;gap:4px;padding:7px 14px;border-radius:20px;background:var(--accent);color:#fff;border:none;font-family:var(--fb);font-size:12px;font-weight:700;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform .15s,box-shadow .15s;box-shadow:0 2px 8px rgba(196,104,42,0.32)}
.map-plan-add-btn:active{transform:scale(0.94)}
/* Plan cards */
.map-plan-card{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:16px;background:var(--surface);margin-bottom:8px;border:1.5px solid var(--border);transition:border-color .18s}
.map-plan-card:last-child{margin-bottom:0}
.map-plan-card-icon{flex-shrink:0;color:var(--accent);margin-top:1px}
.map-plan-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.map-plan-card-name{font-weight:700;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-plan-card-loc{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:3px}
.map-plan-card-notes{font-size:12px;color:var(--muted2);font-style:italic;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.map-plan-card-actions{flex-shrink:0;display:flex;gap:4px;align-items:center}
.map-plan-log-btn{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform .15s;box-shadow:0 2px 6px rgba(196,104,42,0.3)}
.map-plan-log-btn:active{transform:scale(0.88)}
.map-plan-rm-btn{width:32px;height:32px;border-radius:50%;background:var(--surface2);color:var(--muted);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform .15s}
.map-plan-rm-btn:active{transform:scale(0.88)}
.map-plan-empty{text-align:center;padding:40px 20px}
.map-plan-empty-ico{color:var(--muted2);opacity:.3;margin-bottom:16px;display:flex;justify-content:center}
.map-plan-empty-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:8px}
.map-plan-empty-hint{font-size:13px;color:var(--muted);line-height:1.5}
.map-tt-plan-notes{font-size:11px;color:var(--muted);padding:4px 0;font-style:italic}
.map-tt-plan-rm{color:#E05252}
.places-map-embed{border:0;position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.places-map-tile{width:100%;height:100%;display:block;object-fit:cover;position:absolute;inset:0;z-index:0}
.map-illus-bg{width:100%;height:100%;background:#F0E9DA;display:flex;align-items:center;justify-content:center;position:absolute;inset:0;z-index:0}
.map-illus-bg--fallback{display:none}
.map-illus-bg--fallback.show{display:flex}
.place-map-area{margin:0 12px 10px}
.place-map-area .map-canvas-wrap{margin:0;min-height:187px;height:187px}
.loc-explore-bar--map{margin:0 0 12px;width:100%}
.place-order--map{margin:0 0 14px}
.places-tab-sub{display:block;font-size:12px;color:var(--muted);margin:-6px 0 12px;padding:0 2px}

/* ── ILLUSTRATED CANVAS ── */
.map-canvas-wrap{margin:12px 14px;border-radius:22px;overflow:hidden;position:relative;min-height:280px;height:280px;box-shadow:0 4px 32px rgba(0,0,0,0.14),0 1px 4px rgba(0,0,0,0.08)}
.map-svg-canvas{width:100%;display:block;background:#F0E9DA;cursor:default}
/* Paper texture overlay */
.map-canvas-wrap::before{content:'';position:absolute;inset:0;border-radius:22px;background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23C4A882' fill-opacity='0.06'%3E%3Ccircle cx='20' cy='20' r='1'/%3E%3C/g%3E%3C/svg%3E");pointer-events:none;z-index:1}

/* Pin photo circles */
.map-pin-photo{width:44px;height:44px;border-radius:50%;border:3px solid #C0392B;object-fit:cover;display:block;box-shadow:0 2px 10px rgba(0,0,0,0.25);background:#E8DDD0}
.map-pin-photo-ph{width:44px;height:44px;border-radius:50%;border:3px solid #C0392B;background:#E8DDD0;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 2px 10px rgba(0,0,0,0.2)}

/* Tooltip card over pin */
.map-pin-tooltip{
  position:fixed;z-index:400;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-radius:16px;
  padding:11px 14px;
  box-shadow:0 8px 32px rgba(0,0,0,0.18),0 2px 8px rgba(0,0,0,0.1);
  min-width:160px;max-width:220px;
  animation:tooltipIn .22s cubic-bezier(0.34,1.2,0.64,1);
  cursor:pointer;
  border:0.5px solid rgba(0,0,0,0.07);
}
@keyframes tooltipIn{from{transform:scale(0.88) translateY(6px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.map-tt-name{font-weight:700;font-size:13px;color:var(--text);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-tt-sub{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}
.map-tt-cta{font-size:11px;color:#C0392B;font-weight:700;margin-top:6px;display:flex;align-items:center;gap:3px}
.map-tt-arrow{position:absolute;bottom:-7px;left:50%;transform:translateX(-50%);width:14px;height:7px;overflow:hidden}
.map-tt-arrow::after{content:'';position:absolute;top:-5px;left:50%;transform:translateX(-50%) rotate(45deg);width:12px;height:12px;background:rgba(255,255,255,0.97);border-right:0.5px solid rgba(0,0,0,0.07);border-bottom:0.5px solid rgba(0,0,0,0.07)}

/* ── STAT STRIP ── */
.map-stats-strip{display:flex;gap:0;padding:14px 16px;border-bottom:0.5px solid rgba(0,0,0,0.07)}
.map-stat-item{flex:1;text-align:center}
.map-stat-item+.map-stat-item{border-left:0.5px solid rgba(0,0,0,0.07)}
.map-stat-val{font-family:var(--fd);font-size:26px;font-weight:700;color:#C0392B;line-height:1}
.map-stat-label{font-size:10px;color:var(--muted);margin-top:3px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}

/* ── SPOTS LIST ── */
.map-spots-hdr{padding:16px 16px 8px;display:flex;align-items:center;justify-content:space-between}
.map-spots-hdr-title{font-family:var(--fd);font-size:17px;font-weight:700}
.map-spots-hdr-count{font-size:12px;color:var(--muted)}
.map-spot-row{display:flex;align-items:center;gap:12px;padding:11px 16px;border-bottom:0.5px solid rgba(0,0,0,0.05);cursor:pointer;-webkit-tap-highlight-color:transparent;background:var(--surface);transition:background .15s}
.map-spot-row:first-child{border-radius:16px 16px 0 0}
.map-spot-row:last-child{border-bottom:none;border-radius:0 0 16px 16px;margin-bottom:14px}
.map-spot-row:only-child{border-radius:16px;margin-bottom:14px}
.map-spot-row:active{background:var(--surface2)}
.map-spot-thumb{width:50px;height:50px;border-radius:12px;overflow:hidden;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.map-spot-thumb img{width:100%;height:100%;object-fit:cover}
.map-spot-info{flex:1;min-width:0}
.map-spot-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-spot-meta{font-size:11px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:5px}
.map-spot-day{font-size:10px;color:#C0392B;font-weight:700;margin-top:2px}
/* Day number circle */
.map-day-num{width:22px;height:22px;border-radius:50%;background:#C0392B;color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* SVG overlay on illustrated (no-coords) map */
.map-svg-overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:2}
.map-svg-overlay .map-svg-pin{pointer-events:auto;cursor:pointer}
.map-canvas-wrap{position:relative}
/* Achievement card */
.map-achieve{margin:0 14px 14px;background:linear-gradient(135deg,#2C1810,#4A2518);border-radius:18px;padding:18px;display:flex;align-items:center;gap:14px;box-shadow:0 4px 20px rgba(44,24,16,0.25)}
.map-achieve-ring{position:relative;width:64px;height:64px;flex-shrink:0}
.map-achieve-txt{flex:1;min-width:0}
.map-achieve-title{font-weight:700;font-size:14px;color:#fff;margin-bottom:3px}
.map-achieve-sub{font-size:12px;color:rgba(255,255,255,.65);line-height:1.4}

/* Empty canvas state */
.map-empty-canvas{height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}
.map-empty-icon{font-size:48px;opacity:.25}
.map-empty-txt{font-size:14px;color:var(--muted);text-align:center;line-height:1.6}

/* ══ LEADERBOARD ════════════════════════════════════════ */
.lb-wrap{padding:0 14px 24px}
.lb-section-hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 0 12px}
.lb-section-title{font-family:var(--fd);font-size:18px;font-weight:700}
.lb-section-sub{font-size:11px;color:var(--muted);font-weight:500}
/* Top 3 podium */
.lb-podium{display:flex;align-items:flex-end;justify-content:center;gap:8px;margin-bottom:20px;padding:0 4px}
.lb-podium-col{display:flex;flex-direction:column;align-items:center;flex:1}
.lb-podium-col.first{order:2;flex:1.1}
.lb-podium-col.second{order:1}
.lb-podium-col.third{order:3}
.lb-podium-photo{border-radius:50%;object-fit:cover;border:3px solid #C0392B;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--surface2);flex-shrink:0}
.lb-podium-col.first .lb-podium-photo{width:72px;height:72px;border-width:3.5px;border-color:#FFD700;box-shadow:0 4px 20px rgba(255,215,0,0.3)}
.lb-podium-col.second .lb-podium-photo,.lb-podium-col.third .lb-podium-photo{width:58px;height:58px}
.lb-podium-medal{font-size:20px;margin-bottom:4px}
.lb-podium-col.first .lb-podium-medal{font-size:26px}
.lb-podium-name{font-size:11px;font-weight:700;color:var(--text);text-align:center;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:5px}
.lb-podium-score{font-size:10px;color:var(--muted);margin-top:1px;text-align:center}
.lb-podium-bar{border-radius:8px 8px 0 0;width:100%;margin-top:8px}
.lb-podium-col.first .lb-podium-bar{height:52px;background:linear-gradient(to top,#FFD700,#FFF0A0)}
.lb-podium-col.second .lb-podium-bar{height:36px;background:linear-gradient(to top,#C0C0C0,#E8E8E8)}
.lb-podium-col.third .lb-podium-bar{height:24px;background:linear-gradient(to top,#CD7F32,#E8B080)}
/* Ranked list */
.lb-row{display:flex;align-items:center;gap:13px;padding:12px 16px;background:var(--surface);border-radius:16px;margin-bottom:8px;box-shadow:0 1px 4px rgba(0,0,0,0.06);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}
.lb-row:active{transform:scale(0.98)}
.lb-rank{font-family:var(--fd);font-size:16px;font-weight:700;color:var(--muted2);width:22px;text-align:center;flex-shrink:0}
.lb-photo{width:50px;height:50px;border-radius:13px;overflow:hidden;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.lb-photo img{width:100%;height:100%;object-fit:cover}
.lb-info{flex:1;min-width:0}
.lb-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.lb-meta{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}
.lb-score-badge{background:var(--accent-l);color:var(--accent);border-radius:980px;padding:4px 12px;font-size:12px;font-weight:800;flex-shrink:0}
/* Category tabs */
.lb-tabs{display:flex;gap:6px;margin-bottom:16px;background:var(--surface2);border-radius:12px;padding:3px}
.lb-tab{flex:1;padding:8px 4px;border:none;background:transparent;border-radius:10px;font-family:var(--fb);font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .18s;text-align:center}
.lb-tab.on{background:var(--surface);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,0.1)}
/* Stat cards row */
.lb-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}
.lb-stat-card{background:var(--surface);border-radius:16px;padding:16px;box-shadow:0 1px 6px rgba(0,0,0,0.06)}
.lb-stat-emoji{font-size:22px;margin-bottom:6px;display:block}
.lb-stat-val{font-family:var(--fd);font-size:28px;font-weight:700;color:var(--accent);line-height:1}
.lb-stat-label{font-size:11px;color:var(--muted);margin-top:3px;font-weight:500}
/* Dish leaderboard item */
.lb-dish-row{display:flex;align-items:center;gap:12px;padding:11px 16px;background:var(--surface);border-radius:14px;margin-bottom:7px;box-shadow:0 1px 4px rgba(0,0,0,0.05)}
.lb-dish-rank{font-size:16px;width:24px;text-align:center;flex-shrink:0}
.lb-dish-info{flex:1;min-width:0}
.lb-dish-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-dish-meta{font-size:11px;color:var(--muted);margin-top:1px}
.lb-dish-rating{background:rgba(255,214,10,0.15);border-radius:20px;padding:4px 11px;font-size:12px;font-weight:800;color:#9B7500;flex-shrink:0}

/* ══ ENTRY SCREEN (camera/photo/details) ══ */
/* ── Fullscreen photo viewer ── */
/* ══ Step 6: Enhanced photo viewer ══ */
.photo-fs{position:fixed;inset:0;z-index:800;background:#000;overflow:hidden;animation:fadeIn .18s;transition:transform .25s ease,opacity .25s ease}
.photo-fs-close{position:absolute;top:max(env(safe-area-inset-top),14px);right:14px;z-index:20;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,0.55);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);-webkit-tap-highlight-color:transparent}
.pfs-track{display:flex;width:100%;height:100%;will-change:transform}
.pfs-slide{flex:0 0 100%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pfs-zoom-layer{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transform-origin:center center;transition:transform .15s ease;will-change:transform}
.pfs-zoom-layer img{max-width:100%;max-height:100%;object-fit:contain;display:block;-webkit-user-drag:none;user-select:none;pointer-events:none}
/* dot indicator */
.pfs-dots{position:absolute;bottom:calc(max(env(safe-area-inset-bottom),16px) + 64px);left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:20}
.pfs-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.38);transition:background .2s,transform .2s}
.pfs-dot.active{background:#fff;transform:scale(1.25)}
/* info bar at bottom */
.pfs-info{position:absolute;bottom:0;left:0;right:0;z-index:20;padding:28px 20px max(env(safe-area-inset-bottom),20px);background:linear-gradient(transparent,rgba(0,0,0,.72));pointer-events:none}
.pfs-info-title{color:#fff;font-size:15px;font-weight:700;font-family:var(--fd);margin-bottom:3px;text-shadow:0 1px 6px rgba(0,0,0,.5);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pfs-info-sub{color:rgba(255,255,255,.72);font-size:12.5px;text-shadow:0 1px 4px rgba(0,0,0,.5)}
/* legacy — kept for compat */
.photo-fs-img,.photo-fs-sw,.photo-fs-loc{display:none}
.photo-fs-nav,.photo-fs-counter{display:none}
/* ── Entry screen ── */
.fs{position:fixed;inset:0;background:#000;z-index:500;overflow:hidden;animation:fsSlideUp .36s cubic-bezier(0.32,0.72,0,1)}
@keyframes fsSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.fs-cam{position:absolute;inset:0}
#fs-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* ── Redesigned no-camera picker ── */
.fs-no-cam{position:absolute;inset:0;z-index:30;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center}
.fs-picker-back{position:absolute;top:max(env(safe-area-inset-top),16px);left:14px;display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--text2);font-family:var(--fb);font-size:15px;font-weight:600;cursor:pointer;padding:10px 10px;min-height:44px;min-width:44px;border-radius:12px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:background .15s,opacity .15s}
.fs-picker-back:active{background:rgba(0,0,0,.07);opacity:.7}
.fs-picker-back .ico{color:var(--text2)}
.fs--picker .fs-controls{display:none!important}
.fs-picker{display:flex;flex-direction:column;align-items:center;gap:0;text-align:center;padding:0 32px;width:100%;max-width:360px}
.fs-picker-icon{font-size:48px;margin-bottom:16px;line-height:1}
.fs-picker-hint{font-size:22px;font-weight:700;color:var(--text);margin:0 0 32px;font-family:var(--fd)}
.fs-picker-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;margin-bottom:20px}
.fs-picker-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px 16px;border-radius:20px;border:none;background:var(--surface);box-shadow:0 2px 12px rgba(0,0,0,.06);font-family:var(--fb);font-size:13px;font-weight:700;color:var(--text);cursor:pointer;touch-action:manipulation;transition:transform .15s cubic-bezier(0.34,1.56,0.64,1),box-shadow .15s;-webkit-tap-highlight-color:transparent}
.fs-picker-btn:active{transform:scale(0.94);box-shadow:0 1px 4px rgba(0,0,0,.06)}
.fs-picker-btn-ico{width:52px;height:52px;border-radius:16px;background:rgba(196,104,42,0.1);display:flex;align-items:center;justify-content:center}
.fs-picker-btn-ico .ico{color:var(--accent)}
.fs-picker-skip{border:none;background:none;font-family:var(--fb);font-size:13px;color:var(--muted2);cursor:pointer;padding:8px 16px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;text-decoration:underline;text-underline-offset:3px}
/* Topbar: transparent over camera, clean over picker */
.fs-topbar{position:absolute;top:0;left:0;right:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding-top:max(env(safe-area-inset-top),14px);padding-left:16px;padding-right:16px;padding-bottom:14px;background:linear-gradient(to bottom,rgba(0,0,0,0.6),transparent)}
.fs-close-ico{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.18);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.2);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.fs-close-ico .ico{color:#fff}
.fs-close-ico:active{background:rgba(255,255,255,0.35);transform:scale(0.9)}
/* Picker mode: light background, dark controls */
.fs--picker .fs-topbar{background:transparent}
.fs--picker .fs-close-ico{background:var(--surface2);border-color:var(--border)}
.fs--picker .fs-close-ico .ico{color:var(--text)}
.fs--picker .fs-count{background:transparent;color:var(--muted2)}
.fs-pill{background:rgba(255,255,255,0.18);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.2);color:#fff;font-family:var(--fb);font-size:13px;font-weight:500;padding:10px 20px;border-radius:22px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:44px;transition:transform .15s cubic-bezier(0.34,1.56,0.64,1),background .15s}
.fs-pill:active{background:rgba(255,255,255,0.38);transform:scale(0.94)}
.fs-icon-btn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.18);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.2);color:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}
.fs-count{color:#fff;font-size:13px;font-weight:500;background:rgba(0,0,0,0.35);padding:5px 12px;border-radius:20px;backdrop-filter:blur(8px)}
.fs-topbar-end{display:flex;align-items:center;gap:8px;flex-shrink:0}
.fs-pin-btn{display:inline-flex;align-items:center;gap:5px;background:rgba(0,0,0,0.42);border:1px solid rgba(255,255,255,.24);color:#fff;font-size:11px;font-weight:700;padding:6px 12px;border-radius:20px;cursor:pointer;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);font-family:var(--fb);-webkit-tap-highlight-color:transparent}
.fs-pin-btn .ico{color:#fff}
.fs-pin-btn:active{background:rgba(196,104,42,.55)}
.fs-preview-edit{position:absolute;right:16px;bottom:max(22px,env(safe-area-inset-bottom));z-index:25;display:inline-flex;align-items:center;gap:7px;padding:8px 14px 8px 12px;border:none;border-radius:22px;cursor:pointer;background:rgba(0,0,0,.48);border:1px solid rgba(255,255,255,.2);color:#fff;font-family:var(--fb);font-size:12px;font-weight:700;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 16px rgba(0,0,0,.28);-webkit-tap-highlight-color:transparent}
.fs-preview-edit:active{transform:scale(.96);background:rgba(196,104,42,.65)}
.fs-preview-edit-ico .ico{color:#fff}
.fs-in-preview .fs-pin-btn{margin-right:4px}
.fs-compose-open .fs-pin-btn{display:inline-flex!important}
.fs-done{position:absolute;top:max(env(safe-area-inset-top),14px);right:16px;z-index:30;background:linear-gradient(135deg,rgba(10,132,255,0.92),rgba(0,100,220,0.88));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.32);color:#fff;font-family:var(--fb);font-size:15px;font-weight:700;padding:10px 24px;border-radius:22px;cursor:pointer;box-shadow:0 4px 20px rgba(10,132,255,0.45),inset 0 1px 0 rgba(255,255,255,0.28);transform:scale(0.6) translateY(-8px);opacity:0;pointer-events:none;transition:transform .42s cubic-bezier(0.34,1.56,0.64,1),opacity .25s,background .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:44px}
.fs-done.show{transform:scale(1) translateY(0);opacity:1;pointer-events:all}
.fs-done:active{transform:scale(0.9)}
.fs-done.success{background:linear-gradient(135deg,rgba(42,122,90,0.95),rgba(30,90,60,0.9));animation:btnSuccess .5s cubic-bezier(0.34,1.56,0.64,1)}
.fs-strip{position:absolute;left:0;right:0;bottom:110px;display:flex;gap:6px;padding:0 12px;overflow-x:auto;scrollbar-width:none;z-index:15}
.fs-strip::-webkit-scrollbar{display:none}
.fs-strip-thumb{width:56px;min-width:56px;height:56px;border-radius:8px;overflow:hidden;border:2.5px solid transparent;cursor:pointer;position:relative;flex-shrink:0}
.fs-strip-thumb.active{border-color:#fff}
.fs-strip-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.fs-strip-rm{position:absolute;top:2px;right:2px;width:18px;height:18px;background:rgba(0,0,0,0.7);border:none;border-radius:50%;color:#fff;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2}
@keyframes thumbIn{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.fs-controls{position:absolute;bottom:0;left:0;right:0;padding:12px 28px max(env(safe-area-inset-bottom),24px);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(transparent,rgba(0,0,0,0.82));z-index:20}
.fs-ctrl{display:flex;flex-direction:column;align-items:center;gap:5px;background:none;border:none;color:#fff;cursor:pointer;font-size:11px;font-family:var(--fb);width:64px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:64px;justify-content:center}
.fs-ctrl-icon{width:52px;height:52px;background:rgba(255,255,255,0.16);border-radius:50%;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);transition:transform .2s cubic-bezier(0.34,1.56,0.64,1),background .15s}
.fs-ctrl:active .fs-ctrl-icon{background:rgba(255,255,255,0.35);transform:scale(0.88)}
.pi-side-btn.liked .ico{color:#ff6b6b}
.fs-shutter{width:74px;height:74px;border-radius:50%;background:#fff;border:5px solid rgba(255,255,255,0.35);cursor:pointer;transition:transform .1s;-webkit-tap-highlight-color:transparent}
.fs-shutter:active{transform:scale(0.91)}
.fs-preview{position:absolute;inset:0;display:none;background:#000;z-index:10}
.fs-preview.show{display:block}
.fs-swiper{display:flex;height:100%;transition:transform .32s cubic-bezier(0.25,.8,.25,1)}
.fs-slide{min-width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}
.fs-slide img{max-width:100%;max-height:100%;object-fit:contain}
.fs-slide-pins{position:absolute;inset:0;z-index:4;pointer-events:none}
.fs-slide-pins .pin-dot{pointer-events:auto}
.compose-pin-bar{display:flex;align-items:center;gap:8px;width:100%;margin:6px 0 12px;padding:10px 14px;border:1px dashed rgba(196,104,42,.35);border-radius:12px;background:rgba(196,104,42,.06);color:#C4682A;font-family:var(--fb);font-size:13px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent}
.compose-pin-bar:active{background:rgba(196,104,42,.12)}
.pi-pin-bar{display:flex;align-items:center;gap:8px;width:100%;margin:0 0 12px;padding:10px 14px;border:1px dashed rgba(196,104,42,.35);border-radius:12px;background:rgba(196,104,42,.06);color:#C4682A;font-family:var(--fb);font-size:13px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent}
.pi-pin-bar:active{background:rgba(196,104,42,.12)}
.fs-dots{position:absolute;bottom:110px;left:0;right:0;display:flex;justify-content:center;gap:6px;z-index:16}
.fs-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.4);transition:background .2s,transform .2s}
.fs-dot.on{background:#fff;transform:scale(1.3)}
.fs-swipe-hint{position:absolute;bottom:0;left:0;right:0;z-index:16;display:none;flex-direction:column;align-items:center;padding:20px 20px max(env(safe-area-inset-bottom),40px);background:linear-gradient(transparent,rgba(0,0,0,0.52));pointer-events:none}
.fs-swipe-pill{width:38px;height:5px;background:rgba(255,255,255,0.6);border-radius:3px;margin-bottom:8px;animation:hintFloat 2s ease-in-out infinite}
@keyframes hintFloat{0%,100%{transform:translateY(0);opacity:.6}50%{transform:translateY(-6px);opacity:1}}
.fs-swipe-label{color:rgba(255,255,255,.75);font-size:13px;font-weight:500;font-family:var(--fb)}
.fs-panel-bd{position:absolute;inset:0;background:transparent;z-index:25;pointer-events:none;transition:background .3s}
.fs-panel-bd.open{background:rgba(0,0,0,0.38);pointer-events:all}
.fs-panel{position:absolute;bottom:0;left:0;right:0;z-index:26;background:rgba(250,248,244,0.84);backdrop-filter:blur(48px) saturate(1.9);-webkit-backdrop-filter:blur(48px) saturate(1.9);border-top:1px solid rgba(255,255,255,0.72);border-radius:24px 24px 0 0;transform:translateY(100%);transition:transform .42s cubic-bezier(0.32,0.72,0,1);max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 16px max(env(safe-area-inset-bottom),48px);box-shadow:0 -2px 48px rgba(0,0,0,0.15),inset 0 1px 0 rgba(255,255,255,0.85)}
.fs-panel.open{transform:translateY(0)}
.fs-panel-drag{width:36px;height:5px;background:rgba(0,0,0,0.16);border-radius:3px;margin:10px auto 20px}
.glass-sec{background:rgba(255,255,255,0.62);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.75);border-radius:16px;padding:14px 16px;margin-bottom:10px;box-shadow:0 2px 12px rgba(0,0,0,0.05),inset 0 1px 0 rgba(255,255,255,0.92);opacity:0;transform:translateY(14px);transition:opacity .3s,transform .3s}
.fs-panel.open .glass-sec{opacity:1;transform:translateY(0)}
.fs-panel.open .glass-sec:nth-child(2){transition-delay:.04s}.fs-panel.open .glass-sec:nth-child(3){transition-delay:.08s}.fs-panel.open .glass-sec:nth-child(4){transition-delay:.12s}.fs-panel.open .glass-sec:nth-child(5){transition-delay:.16s}.fs-panel.open .glass-sec:nth-child(6){transition-delay:.20s}
.glass-lbl{font-size:11px;font-weight:600;color:rgba(0,0,0,0.38);text-transform:uppercase;letter-spacing:.9px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.glass-inp{width:100%;padding:0;border:none;outline:none;background:transparent;font-family:var(--fb);font-size:16px;color:#1a1a1a}
.glass-inp::placeholder{color:rgba(0,0,0,0.28)}
.glass-ta{width:100%;border:none;outline:none;background:transparent;font-family:var(--fb);font-size:16px;color:#1a1a1a;line-height:1.65;resize:none;min-height:80px;overflow:hidden}
.glass-ta::placeholder{color:rgba(0,0,0,0.28)}
.glass-pills{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.glass-pill{display:inline-flex;align-items:center;gap:5px;background:rgba(196,104,42,0.1);border:1px solid rgba(196,104,42,0.2);color:var(--accent);border-radius:20px;padding:5px 12px;font-size:13px;font-weight:500;animation:pillPop .25s cubic-bezier(0.34,1.56,0.64,1) both}
@keyframes pillPop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.glass-pill button{background:none;border:none;cursor:pointer;color:var(--accent);font-size:15px;opacity:.55;padding:0;line-height:1}
.loc-pill{display:inline-flex;align-items:center;gap:5px;background:rgba(42,122,90,0.09);border:1px solid rgba(42,122,90,0.18);color:#1a6b46;border-radius:20px;padding:5px 12px;font-size:13px;font-weight:500;margin-bottom:8px}
.star-wrap{-webkit-user-select:none;user-select:none;touch-action:none}
.star-track{display:flex;align-items:center;gap:2px;padding:6px 0 2px;cursor:pointer}
.star-slot{position:relative;width:44px;height:44px;display:flex;align-items:center;justify-content:center;transition:transform .22s cubic-bezier(0.34,1.56,0.64,1);flex-shrink:0}
.star-slot.pop{transform:scale(1.4) rotate(-5deg)}.star-slot.settle{transform:scale(1.1)}
.star-bg{font-size:38px;color:rgba(0,0,0,0.12);position:absolute;pointer-events:none;line-height:1}
.star-fg{font-size:38px;color:#FF9F0A;position:absolute;pointer-events:none;line-height:1;clip-path:inset(0 100% 0 0);transition:clip-path .12s ease;filter:drop-shadow(0 1px 3px rgba(255,159,10,0.3))}
.star-val{font-size:13px;font-weight:600;color:rgba(0,0,0,0.35);margin-left:8px;min-width:28px;transition:color .2s}
.star-val.on{color:#FF9F0A}
.panel-footer{display:flex;gap:10px;margin-top:16px;position:sticky;bottom:0;background:rgba(245,240,232,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:12px 16px 6px;z-index:2}
/* Compose — WYSIWYG edit matching published post */
.fs.compose-open{display:flex;flex-direction:column;overflow:hidden;background:var(--surface)}
.fs.compose-open .fs-preview{position:relative;flex:0 0 min(46vh,420px);height:min(46vh,420px);z-index:5}
.fs.compose-open .fs-preview.show{display:block}
.fs.compose-open .fs-topbar,.fs.compose-open .fs-done,.fs.compose-open .fs-back-btn{z-index:12}
.fs.compose-open .fs-controls{display:none!important}
.fs-preview-ov{z-index:3;right:16px}
.fs-ov-notes{font-family:var(--fb);font-size:12px;line-height:1.45;color:rgba(255,255,255,.88);margin-top:6px;max-width:min(280px,72vw);text-shadow:0 1px 4px rgba(0,0,0,.5)}
.compose-field-lbl{display:block;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin:0 0 6px}
.compose-title-block{margin-bottom:10px}
.compose-title-block .pi-shop-row{margin-top:0}
.compose-loc-block{margin-bottom:14px}
.compose-loc-hint{font-size:11px;color:var(--muted);margin:-2px 0 8px;line-height:1.4}
.compose-meta-row{display:flex;align-items:center;flex-wrap:wrap;gap:4px 6px;margin-bottom:0;padding:8px 12px}
.compose-meta-row:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,104,42,.08)}
.compose-meta-loc,.compose-meta-trip{display:inline-flex;align-items:center;gap:4px;min-width:0}
.compose-meta-loc{flex:1 1 120px}
.compose-meta-trip{flex:0 1 100px;max-width:38%}
.compose-meta-trip::before{content:'Trip';font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-right:2px;flex-shrink:0}
.compose-meta-date{flex-shrink:0;white-space:nowrap}
.compose-meta-ico{flex-shrink:0;font-size:12px;line-height:1}
.compose-meta-inp{border:none;outline:none;background:transparent;font-family:var(--fb);font-size:16px;font-weight:500;color:var(--text);min-width:0;width:100%}
.compose-meta-inp::placeholder{color:var(--muted2);font-weight:400}
.compose-meta-trip-inp{max-width:100%}
.compose-loc-status{font-size:10px;color:var(--muted);white-space:nowrap;flex:0 0 auto;margin-left:auto}
.compose-thoughts{margin-bottom:14px}
.compose-thoughts-hint{font-size:11px;color:var(--muted);margin:-2px 0 8px;line-height:1.4}
.compose-thoughts-box{background:var(--bg);border:1.5px solid var(--border2);border-radius:12px;padding:12px 14px}
.compose-thoughts-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,104,42,.08)}
.compose-thoughts-box .pi-edit-caption{min-height:72px}
.compose-edit-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}
.compose-edit-actions .compose-hint{margin:0}
.compose-poll-preview{margin-bottom:4px}
.fs-compose{display:none;flex:1;flex-direction:column;min-height:0;background:var(--surface)}
.fs.compose-open .fs-compose{display:flex;animation:composeSlideUp .38s cubic-bezier(0.32,0.72,0,1)}
@keyframes composeSlideUp{from{transform:translateY(24px);opacity:.6}to{transform:translateY(0);opacity:1}}
.fs-compose-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.fs-compose-footer{flex-shrink:0;margin:0;padding:12px 16px max(env(safe-area-inset-bottom),16px);background:rgba(255,255,255,.97);border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(0,0,0,0.06)}
.fs-vis-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 12px;border-radius:20px;border:1px solid var(--border);background:var(--surface2);font-family:var(--fb);font-size:11px;font-weight:700;color:var(--accent);cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.fs-vis-btn.private{color:var(--muted)}
.pi-edit-title{font-family:var(--fd);font-size:21px;font-weight:700;line-height:1.2;flex:1;border:none;outline:none;background:transparent;color:var(--text);width:100%;min-width:0}
.pi-edit-title::placeholder{color:var(--muted2);opacity:.85}
.pi-edit-caption{width:100%;border:none;outline:none;background:transparent;font-family:var(--fb);font-size:16px;line-height:1.75;color:var(--text);resize:none;min-height:48px}
.pi-edit-caption::placeholder{color:var(--muted2)}
.pi-edit-inp{width:100%;border:1.5px solid var(--border2);border-radius:10px;padding:10px 12px;font-family:var(--fb);font-size:16px;background:var(--bg);color:var(--text);outline:none;margin-bottom:10px}
.pi-edit-inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,104,42,.08)}
.pi-edit-inline{border:none;outline:none;background:transparent;font-family:var(--fb);font-size:16px;color:var(--text);min-width:80px;flex:1}
.pi-edit-loc{display:inline-flex;align-items:center;gap:2px;flex-wrap:wrap}
.compose-stars{margin-bottom:14px}
.compose-hint{font-size:11px;color:var(--muted);margin:-8px 0 14px;line-height:1.4}
.pi-reactions-preview{pointer-events:none;opacity:.92}
.compose-comment-preview{opacity:.55;pointer-events:none;margin-bottom:8px}
.compose-comment-ph{flex:1;border:1.5px solid var(--border2);border-radius:20px;padding:9px 14px;font-size:14px;color:var(--muted2);background:var(--bg)}
.compose-photo-caps{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}

/* Card ⋮ menu & action sheet */
.card-menu-btn{position:absolute;top:6px;right:6px;z-index:2;width:32px;height:32px;border:none;border-radius:50%;background:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:transform .2s cubic-bezier(0.34,1.56,0.64,1),opacity .15s}
.card-menu-btn:active{transform:scale(0.85);opacity:.6}
.trip-info .card-menu-btn{top:8px;right:8px}
.action-sheet-backdrop{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.42);display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s}
.action-sheet{background:var(--surface);border-radius:20px 20px 0 0;width:100%;max-width:520px;padding:8px 12px max(env(safe-area-inset-bottom),16px);animation:slideUp .28s cubic-bezier(.32,.72,0,1)}
.action-sheet-title{text-align:center;font-size:13px;font-weight:600;color:var(--muted);padding:10px 8px 6px}
.action-sheet-group{display:flex;flex-direction:column;gap:2px;margin-bottom:8px}
.action-sheet-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border:none;border-radius:12px;background:transparent;font-family:var(--fb);font-size:16px;font-weight:500;color:var(--text);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}
.action-sheet-item:active{background:var(--surface2)}
.action-sheet-item.destructive{color:var(--danger)}
.action-sheet-ico{font-size:18px;width:24px;text-align:center}
.action-sheet-cancel{width:100%;padding:14px;border:none;border-radius:12px;background:var(--surface2);font-family:var(--fb);font-size:16px;font-weight:600;color:var(--text);cursor:pointer;margin-top:4px;-webkit-tap-highlight-color:transparent}
.action-sheet-item{transition:transform .15s cubic-bezier(0.34,1.56,0.64,1),background .15s}
.action-sheet-item:active{transform:scale(0.98)}

/* ── Icon system ── */
.ico-wrap{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;line-height:0}
.ico{display:block;flex-shrink:0}
.ico-tap{cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:transform .2s cubic-bezier(0.34,1.56,0.64,1)}
.ico-tap:active{transform:scale(0.88)}
.ico-tap.ico-pulse{animation:icoPulse .42s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes icoPulse{0%{transform:scale(1)}35%{transform:scale(0.82)}65%{transform:scale(1.1)}100%{transform:scale(1)}}
@media (prefers-reduced-motion:reduce){.ico-tap.ico-pulse{animation:none}}
.storage-pill .ico{margin-right:4px;vertical-align:-2px}
.card-menu-btn .ico{color:var(--muted)}
.action-sheet-ico .ico{color:var(--text)}
.action-sheet-item.destructive .ico{color:var(--danger)}
.compose-meta-ico .ico{color:var(--accent)}
.compose-meta-date{display:inline-flex;align-items:center;gap:4px;color:var(--muted);font-size:12px}
.compose-meta-date .ico{opacity:.75}
.fs-ctrl-icon .ico{color:#fff}
.sc-action .ico{color:var(--muted)}
.sc-action:active .ico{color:var(--accent)}
.pi-side-icon .ico{color:#fff}
.xhs-like-btn .ico{color:var(--muted)}
.xhs-like-btn.liked .ico{color:#e74c3c}
.xhs-cmt-btn .ico{color:var(--muted)}
.home-search-icon-btn .ico{color:var(--text)}
.ec-vis-btn .ico{color:var(--accent)}
.ec-vis-btn.private .ico{color:var(--muted)}

/* ── Place hub (compact XHS-style) ── */
#view-place.view.active{display:block;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;max-height:calc(100dvh - 56px - var(--nav-h) - env(safe-area-inset-bottom));min-height:calc(100dvh - 56px - var(--nav-h) - env(safe-area-inset-bottom));background:#EDEAE5;padding-bottom:max(env(safe-area-inset-bottom),72px)}
.place-hub{display:block;min-height:min-content}
.place-hero{padding:8px 12px 6px;background:#EDEAE5}
.place-hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}
.place-hero-title{display:flex;gap:8px;align-items:flex-start;min-width:0;flex:1}
.place-hero-pin{color:var(--accent);flex-shrink:0;margin-top:2px}
.place-hero-names{min-width:0}
.place-hero-names h1{font-family:var(--fd);font-size:17px;font-weight:800;line-height:1.2;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.place-hero-sub{display:block;font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.place-hero-btns{display:flex;gap:6px;flex-shrink:0}
.place-icon-btn{width:36px;height:36px;border:none;border-radius:50%;background:none;display:inline-flex;align-items:center;justify-content:center;color:var(--muted2);cursor:pointer;padding:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.08));transition:transform .15s,color .15s}
.place-icon-btn:active{transform:scale(0.85)}
.place-icon-btn.on,.place-icon-btn--accent{color:var(--accent)}
.place-stats{display:flex;gap:10px;margin-bottom:6px}
.place-stat{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--muted);background:var(--surface);padding:4px 8px;border-radius:12px}
.place-stat b{font-weight:700;color:var(--text);font-size:12px}
.place-search-row{display:flex;align-items:center;gap:6px;margin:6px 0 4px}
.place-search-inp{flex:1;min-width:0;border:1px solid var(--border);border-radius:18px;padding:6px 10px;font-family:var(--fb);font-size:12px;background:var(--surface)}
.place-filter-clear{width:28px;height:28px;border:none;background:var(--surface2);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;padding:0}
.place-dish-tabs{display:flex;gap:4px;margin-left:auto}
.place-dish-tab{width:30px;height:30px;border:1px solid var(--border);border-radius:50%;background:var(--surface);display:inline-flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;padding:0}
.place-dish-tab.on{background:var(--accent);border-color:var(--accent);color:#fff}
.place-order{flex:0 0 auto;margin:4px 12px 8px;padding:8px 10px 10px;background:var(--surface);border-radius:12px;box-shadow:0 1px 6px rgba(0,0,0,.05)}
.place-hub .place-order+.place-map-area{margin-top:0}
.place-order-hdr{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.place-order-hdr .ico-wrap{color:var(--accent)}

/* ── DISH PHOTO CARD STRIP ── */
.dish-strip{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding:0 0 4px;-webkit-overflow-scrolling:touch}
.dish-strip::-webkit-scrollbar{display:none}
.dish-card{flex-shrink:0;width:84px;border:none;background:transparent;cursor:pointer;text-align:left;touch-action:manipulation;-webkit-tap-highlight-color:transparent;scroll-snap-align:start;padding:0;font-family:var(--fb)}
.dish-card:active{opacity:.8}
.dish-card-img{width:84px;height:84px;border-radius:14px;overflow:hidden;position:relative;background:var(--surface2);display:flex;align-items:center;justify-content:center}
.dish-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.dish-card-emoji{font-size:28px}
.dish-card-badge{position:absolute;bottom:5px;right:5px;background:rgba(0,0,0,0.65);color:#fff;font-size:10px;font-weight:800;padding:2px 5px;border-radius:8px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.dish-card-name{font-size:12px;font-weight:600;color:var(--text);margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:84px}
.dish-card-verdict{font-size:10px;margin-top:2px;display:flex;align-items:center;gap:2px;color:var(--muted)}
.dish-card-verdict.verdict-good{color:#2a7a5a}
.dish-card-verdict.verdict-ok{color:var(--accent)}
.dish-card-verdict.verdict-bad{color:#c0392b}

/* ── DISH DETAIL MODAL ── */
.dish-detail-name{font-family:var(--fd);font-size:20px;font-weight:700;color:var(--text);margin-bottom:10px}
.dish-detail-hero{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface2);border-radius:12px;margin-bottom:14px}
.dish-detail-verdict-ico{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dish-detail-verdict-ico.verdict-good{background:#e6f5ee;color:#2a7a5a}
.dish-detail-verdict-ico.verdict-ok{background:var(--accent-l);color:var(--accent)}
.dish-detail-verdict-ico.verdict-bad{background:var(--danger-l);color:var(--danger)}
.dish-detail-avg{font-size:17px;font-weight:800;color:#E67E22}
.dish-detail-avg-sub{font-size:11px;color:var(--muted);margin-top:1px}
.dish-detail-sec-hdr{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.dish-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.dish-detail-post{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:none;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;background:var(--surface2);display:block;width:100%}
.dish-detail-post img{width:100%;height:100%;object-fit:cover;display:block}
.dish-detail-post:active{opacity:.85}
.dish-detail-post-star{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,0.65);color:#fff;font-size:11px;font-weight:800;padding:2px 6px;border-radius:8px}
.dish-detail-no-photo{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.dish-detail-row{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:12px;background:var(--surface2);border:none;cursor:pointer;touch-action:manipulation;font-family:var(--fb);width:100%;text-align:left;transition:opacity .15s}
.dish-detail-row:active{opacity:.7}
.dish-detail-row-name{font-size:13px;font-weight:600;color:var(--text)}
.dish-detail-row-meta{font-size:11px;color:var(--muted)}
.dish-detail-cmts{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.dish-detail-cmt{background:var(--surface2);border-radius:12px;padding:10px 12px}
.dish-detail-cmt-text{font-size:13px;color:var(--text);line-height:1.5;margin:0 0 3px;font-style:italic}
.dish-detail-cmt-meta{font-size:11px;color:var(--muted)}
.dish-detail-empty{font-size:13px;color:var(--muted);text-align:center;padding:24px 16px}
.place-feed{padding:4px 10px 8px;overflow:visible}
.place-feed .xhs-grid{margin:0;padding:6px 2px 8px}
.place-posts-empty{font-size:13px;color:var(--muted);text-align:center;padding:40px 12px;margin:0}
.place-map-row{padding:4px 12px 8px}
.place-map-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:9px 14px;border:1px solid var(--border2);border-radius:14px;background:var(--surface);font-family:var(--fb);font-size:13px;font-weight:600;color:var(--muted2);cursor:pointer;text-align:left}
.place-map-toggle .ico-wrap{color:var(--accent);flex-shrink:0}
.place-map-toggle-chevron{margin-left:auto;color:var(--muted)}
.place-search-chips{display:flex;flex-direction:column;gap:8px;padding:0 12px 12px}
.place-search-chip{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:14px;background:var(--surface);cursor:pointer;text-align:left;font-family:var(--fb);box-shadow:0 1px 6px rgba(0,0,0,.04)}
.place-search-chip-ico{color:var(--accent);flex-shrink:0}
.place-search-chip-body{flex:1;min-width:0}
.place-search-chip-name{display:block;font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.place-search-chip-meta{display:block;font-size:11px;color:var(--muted);margin-top:2px}
.place-search-chip-go{flex-shrink:0;color:var(--muted);transform:rotate(180deg)}
.xhs-place-pill{cursor:pointer;border:none;font:inherit;-webkit-tap-highlight-color:transparent}
.xhs-place-pill:active{opacity:.85}

/* iOS Safari auto-zooms focused fields when font-size < 16px */
@media (hover:none) and (pointer:coarse){
  input:not([type=button]):not([type=submit]):not([type=reset]):not([type=checkbox]):not([type=radio]):not([type=range]):not([type=hidden]),
  textarea,
  select,
  [contenteditable="plaintext-only"]{
    font-size:max(16px,1em);
  }
}
*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.ico-wrap .ico{transition:color .15s}
.section-divider{height:1px;background:var(--border);margin:4px 0}
::-webkit-scrollbar{width:0;height:0}
.masonry-card{border-radius:18px;box-shadow:var(--sh2);transition:transform .18s var(--t-smooth)}
.masonry-card:active{transform:scale(0.97)}
.trip-pick-card{border-radius:16px;box-shadow:var(--sh2)}
.home-search{border-radius:14px;font-size:16px;padding:11px 36px 11px 40px}
.add-choice{border-radius:16px;padding:16px 18px}
.add-choice-icon{border-radius:14px}
.storage-pill{font-size:10.5px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:4px 10px;font-weight:600;color:var(--muted)}
.lb-stat-card{border-radius:18px;box-shadow:var(--sh2)}
.map-stat-pill{background:var(--surface);border-radius:980px;padding:6px 13px;box-shadow:var(--sh1);font-size:12px;font-weight:600}
.map-action-btn{border-radius:16px;box-shadow:var(--sh2)}
.trip-day-node{box-shadow:0 0 0 3px #F5F0E8,0 0 0 5px rgba(192,57,43,0.15)}
.trip-hero{border-radius:0 0 24px 24px;overflow:hidden}
.map-action-btn--primary{background:var(--accent);box-shadow:0 4px 14px rgba(196,104,42,0.35)}

/* ══ INTERACTION ANIMATIONS ══ */
/* 1. View tab fade-up entrance */
.view.active{animation:viewIn .28s cubic-bezier(0.22,1,0.36,1) both}
@keyframes viewIn{from{opacity:0;transform:translateY(9px)}to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){.view.active{animation:none!important}}

/* 1b. View exit — absolute overlay fades out while incoming view animates in */
.view-exiting{display:block!important;position:absolute;top:0;left:0;right:0;pointer-events:none;z-index:0;animation:viewOut .22s ease-in both}
@keyframes viewOut{from{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(0.98) translateY(-4px)}}
@media(prefers-reduced-motion:reduce){.view-exiting{display:none!important}}

/* Sliding nav pill — glides behind the active nav item */
.nav-inner{position:relative}
.nav-pill{position:absolute;top:50%;height:36px;border-radius:16px;background:rgba(196,104,42,0.1);transform:translateY(-50%);pointer-events:none;transition:left .32s cubic-bezier(0.34,1.56,0.64,1),width .32s cubic-bezier(0.34,1.56,0.64,1),opacity .15s ease;will-change:left,width;z-index:0}

/* Smooth nav icon color + opacity when active state changes */
.nav-icon .ico{transition:color .22s ease,opacity .22s ease}

/* 2. Card stagger entrance — set --anim-i on element */
@keyframes cardIn{from{opacity:0;transform:translateY(18px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.trips-hub-card{animation:cardIn .32s cubic-bezier(0.22,1,0.36,1) both;animation-delay:var(--anim-i,0s)}
.trip-log-card{animation:cardIn .38s cubic-bezier(0.22,1,0.36,1) both;animation-delay:var(--anim-i,0s)}
@media(prefers-reduced-motion:reduce){.trips-hub-card,.trip-log-card{animation:none!important}}

/* 3. Nav icon squish-bounce on tap */
@keyframes navBounce{0%,100%{transform:scale(1)}25%{transform:scale(0.68)}60%{transform:scale(1.2)}80%{transform:scale(0.96)}}
.nav-item:active .nav-icon{animation:navBounce .34s cubic-bezier(0.34,1.56,0.64,1) both}

/* 4. FAB press spring */
@keyframes fabPress{0%,100%{transform:scale(1)}35%{transform:scale(0.82)}65%{transform:scale(1.1)}85%{transform:scale(0.97)}}
.nav-post:active .nav-post-btn{animation:fabPress .4s cubic-bezier(0.34,1.56,0.64,1)}

/* 5. Heart burst particle */
@keyframes heartFloat{0%{opacity:.95;transform:translate(var(--hx,0px),0) scale(0.5)}28%{opacity:1;transform:translate(var(--hx,0px),-26px) scale(1.1)}100%{opacity:0;transform:translate(var(--hx,0px),-58px) scale(0.4)}}
.heart-particle{position:fixed;pointer-events:none;z-index:9999;font-size:14px;line-height:1;will-change:transform,opacity;animation:heartFloat .72s ease-out both}

/* 6. Category chip spring-pop when activated */
@keyframes chipPop{0%,100%{transform:scale(1)}35%{transform:scale(0.86)}70%{transform:scale(1.12)}85%{transform:scale(0.97)}}
.cat-chip.chip-activated{animation:chipPop .32s cubic-bezier(0.34,1.56,0.64,1)}

/* 7. Active nav — sliding pill only (no duplicate dot) */
.nav-item{position:relative}
.nav-item.active{color:var(--accent-d);background:transparent!important}
.nav-item.active .nav-icon .ico{color:var(--accent);opacity:1}

/* 8. Scroll-reveal — cards below fold animate in when scrolled to */
.scroll-reveal{opacity:0;transform:translateY(14px)}
.scroll-reveal.is-visible{transition:opacity .42s cubic-bezier(0.22,1,0.36,1) var(--reveal-delay,0s),transform .42s cubic-bezier(0.22,1,0.36,1) var(--reveal-delay,0s);opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){.scroll-reveal{opacity:1;transform:none!important}.scroll-reveal.is-visible{transition:none!important}}

/* 9. Trip card stagger (in trip grid) */
.trip-card{animation:cardIn .36s cubic-bezier(0.22,1,0.36,1) both;animation-delay:var(--anim-i,0s)}
@media(prefers-reduced-motion:reduce){.trip-card{animation:none!important}}

/* 10. Global tap highlight & scroll smoothness */
*{-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
.view.active,.post-inline,.pfs-overlay{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
button,a,[role=button]{touch-action:manipulation}
.nav-item{transition:color .18s ease}
.ico-tap{transition:transform .1s ease,opacity .12s ease}
.ico-tap:active{transform:scale(0.88);opacity:0.7}
.place-map-area .map-canvas-wrap{border-radius:18px}

/* ══ MAP PAGE REDESIGN ══════════════════════════════════ */

/* Mode tabs */
.map-mode-tabs{display:flex;gap:0;background:var(--surface2);border-radius:12px;padding:3px;margin-top:10px}
.map-mode-tab{flex:1;padding:7px 4px;border:none;background:transparent;border-radius:10px;font-family:var(--fb);font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .22s cubic-bezier(0.22,1,0.36,1);-webkit-tap-highlight-color:transparent}
.map-mode-tab.on{background:var(--surface);color:var(--text);box-shadow:0 1px 6px rgba(0,0,0,0.1);animation:tabPop .26s cubic-bezier(0.34,1.56,0.64,1) both}
@keyframes tabPop{from{transform:scale(0.92)}to{transform:scale(1)}}

/* Sort chips */
.map-sort-chips{display:flex;gap:7px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:2px;margin-bottom:12px}
.map-sort-chips::-webkit-scrollbar{display:none}
.map-sort-chip{flex-shrink:0;padding:6px 14px;border:1.5px solid var(--border);border-radius:20px;background:var(--surface);font-family:var(--fb);font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .18s cubic-bezier(0.22,1,0.36,1);-webkit-tap-highlight-color:transparent;white-space:nowrap}
.map-sort-chip.on{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(196,104,42,0.3)}
.map-sort-chip:active{transform:scale(0.94)}

/* Quick stats row */
.map-quick-stats{display:flex;gap:8px;margin-bottom:14px}

/* Search suggestions */
.map-search-wrap{position:relative}
.map-search-suggestions{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--sh3);margin-top:8px;overflow:hidden;animation:fadeIn .15s ease-out}
.map-suggest-hdr{font-size:10px;font-weight:800;color:var(--muted2);text-transform:uppercase;letter-spacing:.7px;padding:10px 14px 5px}
.map-suggest-empty{font-size:13px;color:var(--muted);padding:14px 16px;text-align:center}
.map-suggest-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;transition:background .12s}
.map-suggest-item:active{background:var(--surface2)}
.map-suggest-ico{color:var(--muted);flex-shrink:0;font-size:16px;width:18px;text-align:center}
.map-suggest-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.map-suggest-name{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-suggest-meta{font-size:11px;color:var(--muted)}
.map-suggest-go{color:var(--muted2);flex-shrink:0}

/* Rankings stats strip */
.map-stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:18px}
.map-stats-card{background:var(--surface);border-radius:14px;padding:12px 6px;text-align:center;box-shadow:var(--sh2);animation:cardIn .32s cubic-bezier(0.22,1,0.36,1) both;animation-delay:var(--anim-i,0s)}
.map-stats-num{font-family:var(--fd);font-size:20px;font-weight:700;color:var(--accent);line-height:1}
.map-stats-lbl{font-size:10px;color:var(--muted);font-weight:500;margin-top:3px}

/* Rankings tabs */
.map-lb-tabs{display:flex;gap:0;background:var(--surface2);border-radius:12px;padding:3px;margin-bottom:14px}
.map-lb-tab{flex:1;padding:7px 4px;border:none;background:transparent;border-radius:10px;font-family:var(--fb);font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}
.map-lb-tab.on{background:var(--surface);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,0.1);animation:tabPop .26s cubic-bezier(0.34,1.56,0.64,1) both}

/* Podium */
.map-lb-podium{display:flex;align-items:flex-end;justify-content:center;gap:4px;margin-bottom:16px;padding:0 4px;animation:cardIn .36s cubic-bezier(0.22,1,0.36,1) both}
.map-lb-pod-col{display:flex;flex-direction:column;align-items:center;flex:1;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s}
.map-lb-pod-col:active{transform:scale(0.96)}
.map-lb-pod-col.first{order:2;flex:1.2}
.map-lb-pod-col.second{order:1}
.map-lb-pod-col.third{order:3}
.map-lb-pod-medal{font-size:18px;margin-bottom:3px}
.map-lb-pod-col.first .map-lb-pod-medal{font-size:24px}
.map-lb-pod-photo{border-radius:50%;overflow:hidden;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:18px;border:2.5px solid var(--border)}
.map-lb-pod-col.first .map-lb-pod-photo{width:68px;height:68px;border-color:#FFD700;box-shadow:0 4px 16px rgba(255,215,0,0.3)}
.map-lb-pod-col.second .map-lb-pod-photo,.map-lb-pod-col.third .map-lb-pod-photo{width:54px;height:54px}
.map-lb-pod-photo img{width:100%;height:100%;object-fit:cover}
.map-lb-pod-name{font-size:10px;font-weight:700;color:var(--text);text-align:center;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:4px}
.map-lb-pod-score{font-size:10px;color:var(--muted);margin-top:1px}
.map-lb-pod-bar{width:100%;margin-top:6px;border-radius:8px 8px 0 0}
.map-lb-pod-col.first .map-lb-pod-bar{height:44px;background:linear-gradient(to top,#FFD700,#FFF5A0)}
.map-lb-pod-col.second .map-lb-pod-bar{height:30px;background:linear-gradient(to top,#C0C0C0,#E8E8E8)}
.map-lb-pod-col.third .map-lb-pod-bar{height:20px;background:linear-gradient(to top,#CD7F32,#E8B888)}

/* LB rows */
.map-lb-row{display:flex;align-items:center;gap:10px;width:100%;padding:11px 12px;background:var(--surface);border-radius:14px;margin-bottom:7px;border:none;cursor:pointer;text-align:left;box-shadow:var(--sh1);-webkit-tap-highlight-color:transparent;transition:transform .15s,box-shadow .15s}
.map-lb-row:active{transform:scale(0.98);box-shadow:none}
.map-lb-rank{font-size:13px;font-weight:800;color:var(--muted);width:20px;text-align:center;flex-shrink:0}
.map-lb-thumb{width:38px;height:38px;border-radius:10px;object-fit:cover;flex-shrink:0}
.map-lb-thumb-empty{display:inline-flex;align-items:center;justify-content:center;background:var(--surface2);font-size:18px;border-radius:10px;width:38px;height:38px;flex-shrink:0}
.map-lb-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.map-lb-name-row{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-lb-meta-row{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-lb-badge{flex-shrink:0;background:rgba(255,214,10,0.15);border-radius:20px;padding:4px 10px;font-size:12px;font-weight:800;color:#9B7500;white-space:nowrap}

/* Dish list */
.map-lb-dish-list{display:flex;flex-direction:column;gap:7px;animation:cardIn .32s cubic-bezier(0.22,1,0.36,1) both}
.map-lb-dish-row{display:flex;align-items:center;gap:10px;padding:11px 12px;background:var(--surface);border-radius:14px;box-shadow:var(--sh1)}
.map-lb-dish-rank{font-size:14px;width:20px;text-align:center;flex-shrink:0}
.map-lb-dish-info{flex:1;min-width:0}
.map-lb-dish-name{display:block;font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-lb-dish-meta{font-size:11px;color:var(--muted);margin-top:1px}

/* LB content wrapper */
.map-lb-content{animation:fadeIn .2s ease-out}

/* Empty state */
.map-lb-empty{text-align:center;padding:28px 20px;color:var(--muted);font-size:14px;display:flex;flex-direction:column;align-items:center;gap:8px;line-height:1.5}
.map-lb-empty-ico{font-size:36px;opacity:.28}
/* ═══════════════════════════════════════════════════════
   SOCIAL — Discover, Profile, Stars, Follow, Planning
   ═══════════════════════════════════════════════════════ */

/* ── Trip card social additions ────────────────────────────────────────── */
.trip-star-btn{position:absolute;bottom:8px;right:8px;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);border:none;border-radius:20px;padding:4px 8px;cursor:pointer;display:flex;align-items:center;gap:4px;color:var(--text2);transition:background .15s,transform .12s}
.trip-star-btn:active{transform:scale(.88)}
.trip-star-btn.soc-starred svg{filter:drop-shadow(0 0 4px rgba(232,160,32,.5))}
.trip-info{position:relative}
.trip-planning-badge{position:absolute;top:8px;left:8px;background:rgba(42,122,90,.88);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;letter-spacing:.4px}
.trip-card--planning .trip-thumb{border:2px solid var(--green)}

/* ── Planning banner in trip detail ────────────────────────────────────── */
.trip-plan-banner{background:var(--green-l);border-bottom:1.5px solid var(--green);padding:10px 18px;display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;color:var(--green)}
.trip-plan-start-btn{background:var(--green);color:#fff;border:none;border-radius:20px;padding:5px 14px;font-size:12px;font-weight:600;cursor:pointer}

/* ── Plan toggle in new trip modal ─────────────────────────────────────── */
.plan-toggle-row{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:10px 0}
.plan-toggle-label{display:block;font-size:14px;font-weight:600;color:var(--text)}
.plan-toggle-desc{display:block;font-size:12px;color:var(--muted2);margin-top:2px}

/* ── Discover view ──────────────────────────────────────────────────────── */
.disc-view{padding-bottom:120px}
.disc-search-wrap{padding:14px 18px 8px;position:sticky;top:0;background:var(--bg);z-index:10}
.disc-search-bar{display:flex;align-items:center;gap:10px;background:var(--surface);border:1.5px solid var(--border2);border-radius:24px;padding:10px 16px}
.disc-search-input{flex:1;border:none;background:none;font-size:14px;color:var(--text);outline:none}
.disc-section{padding:18px 0 4px}
.disc-section-hdr{display:flex;align-items:baseline;justify-content:space-between;padding:0 18px 10px}
.disc-section-title{font-family:var(--fd);font-size:17px;font-weight:700;color:var(--text)}
.disc-section-count{font-size:12px;color:var(--muted2)}
.disc-empty-feed{text-align:center;padding:28px 20px;color:var(--muted);font-size:14px;line-height:1.6}
.disc-all-followed{text-align:center;padding:16px;color:var(--muted2);font-size:14px}
.disc-scroll{overflow-x:auto;padding:0 18px;display:flex;gap:14px;scrollbar-width:none}
.disc-scroll::-webkit-scrollbar{display:none}

/* ── Social trip card ───────────────────────────────────────────────────── */
.soc-trip-card{background:var(--surface);border-radius:16px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,.07);flex-shrink:0;width:300px}
#disc-following-feed .soc-trip-card{width:auto;margin:0 18px 12px;flex-shrink:1}
.soc-trip-cover{position:relative;height:160px;overflow:hidden;background:var(--surface2)}
.soc-trip-cover img{width:100%;height:100%;object-fit:cover}
.soc-trip-cover-ov{position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(0,0,0,.4));display:flex;align-items:flex-end;justify-content:flex-end;padding:10px}
.soc-star-btn{display:flex;align-items:center;gap:5px;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);border:none;border-radius:20px;padding:5px 10px;cursor:pointer;color:#fff;font-size:12px;font-weight:600;transition:transform .12s}
.soc-star-btn:active{transform:scale(.9)}
.soc-star-btn.soc-starred{background:rgba(232,160,32,.2);border:1px solid var(--gold);color:var(--gold)}
.btn.soc-star-btn{padding:8px 16px;font-size:13px}
.soc-trip-body{padding:14px}
.soc-trip-user{display:flex;align-items:center;gap:8px;margin-bottom:8px;cursor:pointer}
.soc-trip-username{font-size:13px;font-weight:600;color:var(--text)}
.soc-trip-handle{font-size:12px;color:var(--muted2)}
.soc-trip-name{font-family:var(--fd);font-size:15px;font-weight:700;color:var(--text);margin-bottom:3px}
.soc-trip-meta{font-size:12px;color:var(--muted2);margin-bottom:6px}
.soc-trip-preview{font-size:12px;color:var(--muted);font-style:italic;margin-bottom:10px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.soc-trip-actions{display:flex;align-items:center;gap:8px}
.soc-trip-plan-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:8px 12px;background:rgba(196,104,42,0.1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(196,104,42,0.18);border-radius:22px;font-size:12px;font-weight:600;color:var(--accent);cursor:pointer;transition:transform .15s}
.soc-trip-plan-btn:active{transform:scale(0.94)}
.soc-trip-view-btn{padding:8px 14px;background:rgba(255,255,255,0.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.75);border-radius:22px;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;box-shadow:0 1px 4px rgba(26,20,9,0.06),inset 0 1px 0 rgba(255,255,255,0.9);transition:transform .15s}
.soc-trip-view-btn:active{transform:scale(0.94)}

/* ── Avatar ─────────────────────────────────────────────────────────────── */
.soc-avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ── User card ──────────────────────────────────────────────────────────── */
.soc-user-card{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}
.soc-user-info{flex:1;min-width:0}
.soc-user-name{font-size:14px;font-weight:700;color:var(--text)}
.soc-user-meta{font-size:12px;color:var(--muted2);margin-bottom:3px}
.soc-user-bio{font-size:12px;color:var(--muted);line-height:1.4;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.soc-user-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}
.soc-follow-btn{padding:7px 16px;background:var(--accent);color:#fff;border:none;border-radius:22px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:5px;transition:transform .15s,background .15s;box-shadow:0 2px 8px rgba(196,104,42,0.28),inset 0 1px 0 rgba(255,255,255,0.2)}
.soc-follow-btn:active{transform:scale(0.94)}
.soc-follow-btn.soc-following{background:rgba(255,255,255,0.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text2);border:1px solid rgba(255,255,255,0.75);box-shadow:0 1px 4px rgba(26,20,9,0.06)}
.soc-view-btn{padding:6px 13px;background:rgba(255,255,255,0.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.75);color:var(--text2);border-radius:22px;font-size:11px;cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,0.9)}

/* ── User profile bottom sheet (redesigned) ─────────────────────────────── */
.up-hero{height:90px;position:relative;margin:0 -20px;flex-shrink:0;overflow:hidden}
.up-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(255,255,255,.08),rgba(0,0,0,.18))}
.up-hero-handle{width:36px;height:4px;background:rgba(255,255,255,0.45);border-radius:2px;margin:12px auto 0;position:relative;z-index:2}
.up-x{position:absolute;top:10px;right:12px;z-index:3;width:30px;height:30px;border-radius:50%;background:rgba(0,0,0,0.28);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;-webkit-tap-highlight-color:transparent;transition:background .15s}
.up-x:active{background:rgba(0,0,0,0.5)}
.up-av-ring{display:flex;justify-content:center;margin-top:-40px;margin-bottom:10px;position:relative;z-index:2}
.up-av{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;border:3.5px solid var(--surface);box-shadow:0 4px 20px rgba(0,0,0,0.16)}
.up-id{text-align:center;padding:0 24px 18px}
.up-name{font-family:var(--fd);font-size:21px;font-weight:700;color:var(--text);margin-bottom:4px;line-height:1.2}
.up-meta{display:flex;align-items:center;justify-content:center;gap:5px;font-size:12px;color:var(--muted2);margin-bottom:9px;flex-wrap:wrap}
.up-handle{font-weight:600;color:var(--muted)}
.up-dot{color:var(--border2)}
.up-bio{font-size:13px;color:var(--muted);line-height:1.55;margin:0}
.up-stats{display:flex;align-items:stretch;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:0 0 18px}
.up-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 6px}
.up-stat-n{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--text);line-height:1}
.up-stat-l{font-size:10px;color:var(--muted2);letter-spacing:.5px;text-transform:uppercase;margin-top:3px}
.up-stat-sep{width:1px;background:var(--border);align-self:stretch}
.up-actions{padding:0 0 18px}
.up-follow-btn{width:100%;padding:14px;border-radius:14px;border:none;background:var(--accent);color:#fff;font-family:var(--fb);font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:background .18s,transform .15s cubic-bezier(0.34,1.56,0.64,1);-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-shadow:0 2px 12px rgba(196,104,42,0.28)}
.up-follow-btn:active{transform:scale(.97)}
.up-follow-btn.up-following{background:var(--surface2);color:var(--text2);border:1.5px solid var(--border2);box-shadow:none}
.up-trips-label{font-size:11px;font-weight:700;color:var(--muted2);text-transform:uppercase;letter-spacing:.7px;border-top:1px solid var(--border);padding-top:16px;margin-bottom:12px}
.up-trips-row{display:flex;gap:10px;overflow-x:auto;margin:0 -20px;padding:0 20px 28px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.up-trips-row::-webkit-scrollbar{display:none}
.up-trip-card{flex:0 0 148px;border-radius:14px;overflow:hidden;cursor:pointer;box-shadow:var(--sh2);background:var(--surface);transition:transform .2s var(--t-spring);-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.up-trip-card:active{transform:scale(.95)}
.up-trip-thumb{height:110px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.up-trip-emoji{font-size:50px;line-height:1;position:relative;z-index:1}
.up-trip-pill{position:absolute;bottom:7px;right:7px;background:rgba(0,0,0,0.42);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-size:10px;font-weight:700;padding:3px 7px;border-radius:20px;display:flex;align-items:center;gap:3px;z-index:2}
.up-trip-info{padding:8px 10px 10px}
.up-trip-card-name{font-size:12.5px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.up-trip-card-dest{font-size:10.5px;color:var(--muted2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── Trip preview in modal ───────────────────────────────────────────────── */
.soc-trip-preview-hdr{padding:24px 20px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.soc-tp-name{font-family:var(--fd);font-size:20px;font-weight:700;color:#fff}
.soc-tp-meta{font-size:13px;color:rgba(255,255,255,.75)}
.soc-tp-user{display:flex;align-items:center;gap:8px;padding:12px 18px;border-bottom:1px solid var(--border);cursor:pointer}
.soc-entry-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.soc-entry-thumb{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.soc-entry-name{font-size:14px;font-weight:700;color:var(--text)}
.soc-entry-stars{font-size:12px;margin:2px 0}
.soc-entry-note{font-size:12px;color:var(--muted);line-height:1.4}
.soc-entry-likes{font-size:12px;color:var(--muted2);white-space:nowrap}

/* ── Plan spots list ─────────────────────────────────────────────────────── */
.plan-spots-list{display:flex;flex-direction:column;gap:4px}
.plan-spot-row{display:flex;align-items:center;gap:12px;padding:8px;border-radius:10px;cursor:pointer;transition:background .12s}
.plan-spot-row:hover{background:var(--surface2)}

/* ── Profile view ────────────────────────────────────────────────────────── */
.prof-view{padding-bottom:120px}
.prof-hero{padding:24px 20px;text-align:center;border-bottom:1px solid var(--border)}
.prof-avatar-wrap{position:relative;display:inline-block;margin-bottom:12px}
.prof-avatar{width:80px;height:80px;border-radius:50%;background:var(--accent-l);font-size:42px;display:flex;align-items:center;justify-content:center;margin:0 auto}
.prof-edit-btn{position:absolute;bottom:0;right:-4px;background:rgba(255,255,255,0.55);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.8);border-radius:50%;width:28px;height:28px;padding:0;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);box-shadow:0 2px 6px rgba(26,20,9,0.12),inset 0 1px 0 rgba(255,255,255,0.9);transition:transform .15s}
.prof-edit-btn:active{transform:scale(0.88)}
.prof-name{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--text);margin-bottom:2px}
.prof-handle{font-size:13px;color:var(--muted2);margin-bottom:8px}
.prof-bio{font-size:13px;color:var(--muted);line-height:1.5;max-width:300px;margin:0 auto 16px}
.prof-add-bio{border:none;background:none;color:var(--accent);font-size:13px;cursor:pointer;margin-bottom:16px}
.prof-stats{display:flex;flex-direction:row;margin:14px 18px 4px}
.prof-stat-div{display:none}
.prof-stat{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;padding:10px 4px;min-width:0}
.prof-stat:last-child{border-right:none}
.prof-stat-icon{display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:1px;opacity:.75}
.prof-stat-n{font-family:var(--fd);font-size:19px;font-weight:700;color:var(--text);line-height:1}
.prof-stat-l{font-size:10px;color:var(--muted);margin-top:1px;white-space:nowrap;font-weight:500}
.prof-tabs{display:flex;border-bottom:1.5px solid var(--border);margin-top:4px}
.prof-tab{flex:1;padding:12px 0;border:none;background:none;font-size:14px;font-weight:600;color:var(--muted2);cursor:pointer;position:relative}
.prof-tab.active{color:var(--accent)}
.prof-tab.active::after{content:'';position:absolute;bottom:-1.5px;left:20%;right:20%;height:2.5px;background:var(--accent);border-radius:2px}
.prof-tab-pane{padding:0;display:none;opacity:0;transform:translateY(6px);transition:opacity .22s cubic-bezier(0.22,1,0.36,1),transform .22s cubic-bezier(0.22,1,0.36,1)}
.prof-tab-pane--active{display:block;opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){.prof-tab-pane{transition:none!important}.prof-tab-pane--active{opacity:1!important;transform:none!important}}
.prof-trip-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px 16px}
.prof-trip-grid>:last-child:nth-child(odd){grid-column:1/-1;max-width:calc(50% - 5px);justify-self:center;width:100%}
.prof-trip-card{background:var(--surface);border-radius:14px;overflow:hidden;cursor:pointer;position:relative;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.prof-trip-thumb{height:110px;background:var(--surface2);overflow:hidden;display:flex;align-items:center;justify-content:center}
.prof-trip-thumb img{width:100%;height:100%;object-fit:cover}
.prof-trip-name{font-size:13px;font-weight:700;color:var(--text);padding:8px 10px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prof-trip-meta{font-size:11px;color:var(--muted2);padding:0 10px 9px}
.prof-tab-pane-liked{padding-bottom:120px}
.prof-trip-card .trip-planning-badge{top:6px;left:6px}
/* Compact 2-col grid for Liked + Starred */
.prof-grid2{display:grid;grid-template-columns:1fr 1fr;gap:3px;padding:3px 0 120px}
.prof-grid2-card{cursor:pointer;overflow:hidden;position:relative;border-radius:0;background:var(--surface2);aspect-ratio:1}
.prof-grid2-card img{width:100%;height:100%;object-fit:cover;display:block}
.prof-grid2-card-foot{position:absolute;bottom:0;left:0;right:0;padding:20px 7px 6px;background:linear-gradient(transparent,rgba(0,0,0,.55));pointer-events:none}
.prof-grid2-name{font-size:11.5px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.prof-grid2-stars{font-size:9px;color:rgba(255,255,255,.82);letter-spacing:.3px;margin-top:1px}
.prof-grid2-empty{font-size:28px;width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted2);background:var(--surface2)}
/* Liked/Starred old list styles kept for compat */
.prof-liked-card{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.prof-liked-name{font-size:14px;font-weight:600;color:var(--text)}
.prof-liked-meta{font-size:12px;margin-top:2px}

/* ── Profile avatar picker ───────────────────────────────────────────────── */
.prof-av-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.prof-av-opt{width:44px;height:44px;border-radius:12px;border:2px solid var(--border);background:var(--surface2);font-size:24px;cursor:pointer;transition:border-color .15s,transform .12s}
.prof-av-opt.selected{border-color:var(--accent);transform:scale(1.1)}

/* ══ #12 Undo toast ══ */
.toast-undo{display:flex;align-items:center;gap:10px;padding:11px 14px 11px 18px !important}
.toast-msg{flex:1}
.toast-undo-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:8px;padding:4px 10px;font-size:12px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap}

/* ══ #1 Onboarding overlay ══ */
.ob-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.ob-card{background:var(--bg);border-radius:28px;padding:36px 28px 28px;max-width:340px;width:100%;text-align:center;box-shadow:0 24px 64px rgba(0,0,0,.4)}
.ob-icon{font-size:56px;margin-bottom:16px;line-height:1}
.ob-title{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--text);margin-bottom:10px;line-height:1.2}
.ob-body{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:24px}
.ob-dots{display:flex;justify-content:center;gap:6px;margin-bottom:22px}
.ob-dot{width:7px;height:7px;border-radius:50%;background:var(--border2);transition:background .2s,width .2s;display:inline-block}
.ob-dot-on{background:var(--accent);width:18px;border-radius:4px}
.ob-next{width:100%;padding:14px;border-radius:14px;border:none;background:var(--accent);color:#fff;font-family:var(--fb);font-size:15px;font-weight:700;cursor:pointer;transition:transform .15s;-webkit-tap-highlight-color:transparent;margin-bottom:8px}
.ob-next:active{transform:scale(.97)}
.ob-back{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:6px 12px;margin-right:8px}
.ob-skip{background:none;border:none;color:var(--muted2);font-size:13px;cursor:pointer;padding:6px 12px}

/* ══ #11 Swipe hint ══ */
.swipe-hint{text-align:center;font-size:11.5px;color:var(--muted2);padding:3px 0 0;letter-spacing:.2px;display:flex;align-items:center;justify-content:center;gap:4px;transition:opacity .5s}
.swipe-hint-arrow{font-size:13px;opacity:.7}
.swipe-hint-fade{opacity:0}

/* ══ #18 Skeleton screens ══ */
.skel{background:linear-gradient(90deg,var(--surface2) 25%,var(--surface) 50%,var(--surface2) 75%);background-size:200% 100%;animation:skel-shine 1.4s infinite}
@keyframes skel-shine{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skel-card{border-radius:16px;overflow:hidden}
.skel-photo{width:100%;padding-bottom:110%;background:var(--surface2)}
.skel-line{height:12px;border-radius:6px}

/* ══ #19 Chip clear button ══ */
.cat-clear{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--text);color:var(--bg);font-size:14px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;transition:transform .15s;line-height:1}
.cat-clear:active{transform:scale(.88)}

/* ══ #10 Read-more caption ══ */
.xhs-caption-clamp{-webkit-line-clamp:3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.xhs-read-more{background:none;border:none;color:var(--accent);font-size:11px;font-weight:700;padding:0 0 2px;cursor:pointer;-webkit-tap-highlight-color:transparent;display:block;margin-top:-2px}

/* ══ #9 Category colors handled in JS via _cardCategoryColor ══ */

/* ══ #5 Public feed banner ══ */
.fy-public-banner{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:var(--accent);padding:12px 14px 4px;letter-spacing:.05px;text-transform:uppercase;font-family:var(--fb)}
.fy-public-banner .ico{color:var(--accent)}

/* ══ #6 Discover enhancements ══ */
.disc-dish-row{display:flex;flex-wrap:wrap;gap:8px;padding:0 18px 12px}
.disc-dish-chip{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:7px 14px;font-size:12.5px;font-weight:600;color:var(--text2);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s}
.disc-dish-chip:active{background:var(--text);color:var(--bg)}
.disc-spots-list{padding:0 18px 4px;display:flex;flex-direction:column;gap:10px}
.disc-spot-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface);border-radius:14px;border:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}
.disc-spot-card:active{background:var(--surface2)}
.disc-spot-icon{width:40px;height:40px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.disc-spot-name{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:2px}
.disc-spot-meta{font-size:11.5px;color:var(--muted)}

/* ══ #14 Profile stats as navigation ══ */
.prof-stat-btn{background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;padding:0;font:inherit;text-align:center;transition:opacity .15s}
.prof-stat-btn:active{opacity:.6}

/* ══ #17 Streak counter ══ */
.prof-streak{display:flex;align-items:center;justify-content:center;gap:5px;margin-top:10px;padding:7px 16px;background:linear-gradient(135deg,rgba(196,104,42,.12),rgba(228,140,40,.08));border-radius:20px;border:1px solid rgba(196,104,42,.2);width:fit-content;margin-left:auto;margin-right:auto}
.prof-streak-fire{font-size:16px}
.prof-streak-n{font-size:16px;font-weight:800;color:var(--accent)}
.prof-streak-l{font-size:12px;font-weight:600;color:var(--muted)}

/* ══ #7 Trip hero action pills ══ */
.trip-hero-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.trip-hero-pill{display:inline-flex;align-items:center;gap:4px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:14px;padding:5px 12px;font-size:11.5px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .15s}
.trip-hero-pill:active{background:rgba(255,255,255,.32)}
.trip-hero-pill .ico{opacity:.85}

/* ══ #15 Share — handled inline via shareEntry/shareTrip functions ══ */

/* ══ #2/#4 Add flow — FAB label hint on long press (accessibility) ══ */
.nav-post[aria-label]::before{content:attr(aria-label);position:absolute;bottom:100%;left:50%;transform:translateX(-50%);white-space:nowrap;font-size:11px;background:rgba(0,0,0,.7);color:#fff;padding:4px 8px;border-radius:8px;pointer-events:none;opacity:0;transition:opacity .2s;margin-bottom:6px}
.nav-post:focus-visible::before{opacity:1}

/* ══ Step 3: FAB sheet + quick-post sheet ══ */
.fab-sheet-bd{position:fixed;inset:0;z-index:1100;background:rgba(0,0,0,.45);display:flex;align-items:flex-end;animation:fadeIn .2s ease both}
.fab-sheet{background:var(--bg);border-radius:28px 28px 0 0;padding:12px 20px 32px;width:100%;max-width:480px;margin:0 auto;animation:slideUp .3s var(--t-spring) both}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:none}}
.fab-sheet-title{font-family:var(--fd);font-size:18px;font-weight:700;color:var(--text);text-align:center;margin:6px 0 20px}
.fab-sheet-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.fab-sheet-btn{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:18px 8px 14px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .12s,transform .12s;touch-action:manipulation}
.fab-sheet-btn:active{background:var(--border2);transform:scale(.94)}
.fab-sheet-ico{font-size:32px;line-height:1}
.fab-sheet-lbl{font-size:13px;font-weight:700;color:var(--text2)}

/* quick-post mini sheet */
.qp-sheet{padding:12px 20px calc(env(safe-area-inset-bottom,0px) + 28px)}
.qp-thumb{width:100%;aspect-ratio:4/3;border-radius:16px;overflow:hidden;margin:10px 0 16px;background:var(--surface2)}
.qp-input{width:100%;box-sizing:border-box;padding:14px 16px;border:2px solid var(--border2);border-radius:14px;font-size:16px;font-family:var(--fb);color:var(--text);background:var(--surface);outline:none;transition:border-color .2s}
.qp-input:focus{border-color:var(--accent)}
.qp-save-btn{width:100%;margin-top:14px;padding:16px;background:var(--accent);color:#fff;border:none;border-radius:16px;font-size:17px;font-weight:700;font-family:var(--fb);cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:0 4px 18px rgba(196,104,42,.32);transition:transform .12s,box-shadow .12s;touch-action:manipulation}
.qp-save-btn:active{transform:scale(.96);box-shadow:0 2px 8px rgba(196,104,42,.22)}
.qp-detail-btn{width:100%;margin-top:10px;background:none;border:none;color:var(--muted);font-size:13.5px;font-family:var(--fb);cursor:pointer;padding:8px;-webkit-tap-highlight-color:transparent}
.qp-detail-btn:active{opacity:.6}


/* ══ Admin Console — Desktop layout ══════════════════════════════════════════ */

/* Overlay */
.ac-overlay{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.6);display:flex;animation:fadeIn .18s ease both}
.ac-overlay--pin{align-items:center;justify-content:center}

/* Layout */
.ac-layout{display:flex;width:100%;height:100%;overflow:hidden;background:#f9fafb}

/* ── Sidebar ── */
.ac-sidebar{width:240px;min-width:240px;background:#111827;display:flex;flex-direction:column;height:100%;overflow:hidden}
.ac-sb-brand{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.ac-sb-logo{display:flex;align-items:center;gap:9px;margin-bottom:4px}
.ac-sb-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.22);flex-shrink:0}
.ac-sb-name{font-size:17px;font-weight:700;color:#fff;letter-spacing:-.01em}
.ac-sb-tagline{font-size:11px;font-weight:500;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.08em;padding-left:19px}

.ac-nav{flex:1;overflow-y:auto;padding:16px 12px;display:flex;flex-direction:column;gap:2px;scrollbar-width:none}
.ac-nav::-webkit-scrollbar{display:none}
.ac-nav-section{font-size:10px;font-weight:700;color:rgba(255,255,255,.25);letter-spacing:.1em;text-transform:uppercase;padding:6px 10px 10px}
.ac-nav-btn{display:flex;align-items:center;gap:11px;width:100%;padding:9px 12px;border-radius:10px;border:none;background:transparent;color:rgba(255,255,255,.55);font-size:13.5px;font-weight:500;font-family:var(--fb,system-ui,sans-serif);cursor:pointer;text-align:left;transition:background .12s,color .12s;-webkit-tap-highlight-color:transparent}
.ac-nav-btn:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85)}
.ac-nav-btn--active{background:rgba(196,104,42,.18);color:#e8a068 !important}
.ac-nav-btn--active .ac-nav-ico{color:#C4682A}
.ac-nav-ico{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:inherit}
.ac-nav-ico svg{width:18px;height:18px}
.ac-nav-lbl{line-height:1}

.ac-sb-foot{padding:16px 16px calc(env(safe-area-inset-bottom,0px)+16px);border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:8px}
.ac-sb-status{display:flex;align-items:center;gap:7px;font-size:11.5px;color:rgba(255,255,255,.4)}
.ac-sb-version{font-size:11px;color:rgba(255,255,255,.22);font-family:monospace}
.ac-sb-close{display:flex;align-items:center;gap:7px;padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:transparent;color:rgba(255,255,255,.4);font-size:12px;font-weight:500;font-family:var(--fb,system-ui,sans-serif);cursor:pointer;transition:background .12s,color .12s;-webkit-tap-highlight-color:transparent}
.ac-sb-close svg{width:14px;height:14px}
.ac-sb-close:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.7)}

/* ── Main area ── */
.ac-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.ac-topbar{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:60px;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;gap:16px}
.ac-topbar-title{font-size:19px;font-weight:700;color:#111827;letter-spacing:-.02em;margin:0;font-family:var(--fd,Georgia,serif)}
.ac-topbar-actions{display:flex;align-items:center;gap:8px}
.ac-icon-btn{width:36px;height:36px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,color .12s;-webkit-tap-highlight-color:transparent}
.ac-icon-btn:hover{background:#f3f4f6;color:#111827}
.ac-icon-btn svg{width:16px;height:16px}
.ac-icon-btn--close{border-color:transparent}
.ac-icon-btn--close:hover{background:#fee2e2;color:#ef4444;border-color:#fca5a5}
.ac-content{flex:1;overflow-y:auto;padding:28px;display:flex;flex-direction:column;gap:20px;-webkit-overflow-scrolling:touch}

/* ── Page header ── */
.ac-page-hd{display:flex;align-items:baseline;gap:12px;padding-bottom:4px}
.ac-page-hd h2{font-size:22px;font-weight:700;color:#111827;margin:0;font-family:var(--fd,Georgia,serif)}
.ac-page-sub{font-size:13px;color:#9ca3af}

/* ── KPI grid ── */
.ac-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.ac-kpi{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:18px 18px 16px;display:flex;flex-direction:column;gap:4px;transition:box-shadow .15s}
.ac-kpi:hover{box-shadow:0 4px 16px rgba(0,0,0,.07)}
.ac-kpi-row1{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.ac-kpi-label{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}
.ac-kpi-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.ac-kpi-val{font-size:28px;font-weight:700;color:#111827;line-height:1;font-family:var(--fd,Georgia,serif)}
.ac-kpi-sub{font-size:11.5px;color:#9ca3af}

/* ── 2-col grid ── */
.ac-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ac-grid-2--ann{grid-template-columns:1fr 380px}

/* ── Cards ── */
.ac-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:20px}
.ac-card--no-pad{padding:0;overflow:hidden}
.ac-card--danger{background:#fff;border:1.5px solid #fecaca;border-radius:14px;overflow:hidden}
.ac-card-hd{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:14px}
.ac-card-title{font-size:14px;font-weight:700;color:#111827}
.ac-card-sub{font-size:12px;color:#9ca3af}
.ac-card-divider{border-top:1px solid #f3f4f6;margin:14px -20px;padding:0}
.ac-card-foot{padding:12px 16px;border-top:1px solid #f3f4f6;display:flex;justify-content:flex-end}

/* ── Charts ── */
.ac-chart-area{width:100%;overflow:hidden}
.ac-chart-area svg{display:block;width:100%;height:auto}
.ac-chart-area--center{display:flex;justify-content:center;align-items:flex-end;padding:8px 0}
.ac-chart-axis{display:flex;justify-content:space-between;font-size:10px;color:#9ca3af;margin-top:6px;font-family:monospace}

/* ── Location list ── */
.ac-loc-list{display:flex;flex-direction:column;gap:10px}
.ac-loc-row{display:grid;grid-template-columns:140px 1fr 36px;align-items:center;gap:10px}
.ac-loc-name{font-size:13px;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-loc-track{height:6px;border-radius:3px;background:#f3f4f6;overflow:hidden}
.ac-loc-fill{height:100%;border-radius:3px;background:#C4682A;opacity:.75}
.ac-loc-n{font-size:12px;font-weight:600;color:#6b7280;text-align:right;font-family:monospace}

/* ── Flags ── */
.ac-flag-wrap{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}
.ac-flag{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}
.ac-flag--on{background:#dcfce7;color:#166534}
.ac-flag--off{background:#fee2e2;color:#991b1b}
.ac-flag-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.ac-flag--on .ac-flag-dot{background:#22c55e}
.ac-flag--off .ac-flag-dot{background:#ef4444}

/* ── Meta list ── */
.ac-meta-list{display:flex;flex-direction:column;gap:1px}
.ac-meta-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid #f9fafb;font-size:13px;color:#374151}
.ac-meta-row:last-child{border-bottom:none}

/* ── Dots & badges ── */
.ac-dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle;margin-right:2px;flex-shrink:0}
.ac-dot--green{background:#22c55e}
.ac-dot--gray{background:#9ca3af}
.ac-dot--yellow{background:#f59e0b}
.ac-dot--red{background:#ef4444}
.ac-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;line-height:1.4}
.ac-badge--green{background:#dcfce7;color:#166534}
.ac-badge--red{background:#fee2e2;color:#991b1b}
.ac-badge--yellow{background:#fef9c3;color:#854d0e}
.ac-badge--gray{background:#f3f4f6;color:#6b7280}
.ac-badge--blue{background:#dbeafe;color:#1e40af}

/* ── Sections ── */
.ac-section{display:flex;flex-direction:column;gap:10px}
.ac-section-title{font-size:12px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:8px}
.ac-section-title--danger{color:#dc2626}
.ac-section-badge{background:#f3f4f6;color:#6b7280;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;text-transform:none;letter-spacing:0}

/* ── Inputs ── */
.ac-input{width:100%;box-sizing:border-box;padding:9px 13px;border:1.5px solid #d1d5db;border-radius:9px;font-size:13.5px;font-family:var(--fb,system-ui,sans-serif);color:#111827;background:#fff;outline:none;transition:border-color .18s,box-shadow .18s}
.ac-input:focus{border-color:#C4682A;box-shadow:0 0 0 3px rgba(196,104,42,.1)}
.ac-input--grow{flex:1;min-width:0}
.ac-input-row{display:flex;gap:8px;align-items:center}
.ac-field{display:flex;flex-direction:column;gap:6px;margin-top:14px}
.ac-field:first-child{margin-top:0}
.ac-label{font-size:13px;font-weight:600;color:#374151}
.ac-req{color:#ef4444}
.ac-optional{font-weight:400;color:#9ca3af;font-size:11px}
.ac-body-text{font-size:13.5px;color:#6b7280;line-height:1.6;margin:0 0 16px}

/* ── Buttons ── */
.ac-btn{padding:8px 16px;border-radius:9px;border:1.5px solid #d1d5db;background:#fff;color:#374151;font-size:13px;font-weight:600;font-family:var(--fb,system-ui,sans-serif);cursor:pointer;white-space:nowrap;transition:background .12s,border-color .12s,transform .1s;-webkit-tap-highlight-color:transparent}
.ac-btn:active{transform:scale(.96)}
.ac-btn:hover{background:#f9fafb}
.ac-btn--primary{background:#C4682A;border-color:#C4682A;color:#fff}
.ac-btn--primary:hover{background:#b05a22;border-color:#b05a22}
.ac-btn--ghost{background:transparent;border-color:transparent;color:#6b7280}
.ac-btn--ghost:hover{background:#f3f4f6;color:#374151}
.ac-btn--danger{background:#fff;border-color:#fca5a5;color:#dc2626}
.ac-btn--danger:hover{background:#fef2f2}
.ac-btn--destroy{background:#dc2626;border-color:#dc2626;color:#fff}
.ac-btn--destroy:hover{background:#b91c1c;border-color:#b91c1c}
.ac-btn-row{display:flex;gap:8px;flex-wrap:wrap}

/* ── Toggle switch ── */
.ac-toggle-row{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding:12px 0;border-bottom:1px solid #f3f4f6}
.ac-toggle-row:last-of-type{border-bottom:none}
.ac-toggle-label{font-size:14px;font-weight:600;color:#111827;margin-bottom:3px}
.ac-toggle-sub{font-size:12.5px;color:#6b7280;line-height:1.5;max-width:380px}
.ac-switch{position:relative;display:inline-flex;flex-shrink:0;width:46px;height:26px;cursor:pointer}
.ac-switch input{opacity:0;width:0;height:0;position:absolute}
.ac-switch-track{position:absolute;inset:0;border-radius:13px;background:#d1d5db;transition:background .2s}
.ac-switch-track::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.2);transition:transform .2s cubic-bezier(.22,1,.36,1)}
.ac-switch input:checked+.ac-switch-track{background:#C4682A}
.ac-switch input:checked+.ac-switch-track::after{transform:translateX(20px)}

/* ── Details/summary ── */
.ac-details{border:1px solid #e5e7eb;border-radius:9px;overflow:hidden;margin-top:14px}
.ac-details summary{padding:10px 14px;font-size:13px;font-weight:600;color:#374151;cursor:pointer;list-style:none;-webkit-tap-highlight-color:transparent}
.ac-details summary::-webkit-details-marker{display:none}
.ac-details[open] summary{border-bottom:1px solid #e5e7eb}
.ac-pre{margin:0;padding:14px;font-size:11.5px;font-family:monospace;color:#374151;background:#f9fafb;overflow-x:auto;line-height:1.7;white-space:pre}
.ac-status{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280;margin-top:10px}

/* ── Tables ── */
.ac-table-wrap{overflow-x:auto}
.ac-log-table-wrap{overflow-x:auto;max-height:600px;overflow-y:auto}
.ac-table{width:100%;border-collapse:collapse;font-size:13px;font-family:var(--fb,system-ui,sans-serif)}
.ac-table th{padding:10px 16px;text-align:left;background:#f9fafb;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;border-bottom:1.5px solid #e5e7eb;white-space:nowrap}
.ac-table td{padding:10px 16px;border-bottom:1px solid #f3f4f6;color:#374151;vertical-align:middle}
.ac-tr:last-child td{border-bottom:none}
.ac-tr:hover{background:#fafafa}
.ac-code-key{font-family:monospace;font-size:12px;color:#C4682A;background:#fff8f0;padding:2px 6px;border-radius:4px}
.ac-td-num{font-family:monospace;font-size:12px;color:#6b7280;white-space:nowrap}
.ac-td-preview{font-family:monospace;font-size:11.5px;color:#9ca3af;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ac-td-ts{font-family:monospace;font-size:12px;color:#9ca3af;white-space:nowrap}
.ac-td-detail{font-size:12px;color:#6b7280;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ac-td-empty{text-align:center;color:#9ca3af;padding:24px!important;font-style:italic}
.ac-table-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f3f4f6;gap:12px}
.ac-table-desc{font-size:13px;color:#6b7280;margin:0}
.ac-override-tag{display:inline-block;font-size:10px;font-weight:700;color:#b45309;background:#fef3c7;padding:1px 6px;border-radius:4px;margin-left:4px;vertical-align:middle}
.ac-action-tag{display:inline-flex;padding:3px 8px;border-radius:6px;font-size:12px;font-weight:600;font-family:monospace}

/* ── Flags table ── */
.ac-flags-table{display:flex;flex-direction:column;gap:0}

/* ── Feature flags config row ── */
.ac-flag-name{font-family:monospace;font-size:13px;color:#374151}

/* ── Storage ── */
.ac-storage-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.ac-storage-chart{flex-shrink:0}
.ac-storage-info{flex:1;min-width:180px;display:flex;flex-direction:column;gap:8px}
.ac-storage-used{font-size:24px;font-weight:700;color:#111827;font-family:var(--fd,Georgia,serif)}
.ac-storage-total{font-size:14px;font-weight:400;color:#9ca3af}
.ac-storage-bar{height:6px;border-radius:3px;background:#e5e7eb;overflow:hidden}
.ac-storage-fill{height:100%;border-radius:3px;transition:width .4s ease}

/* ── Danger zone ── */
.ac-danger-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid #fecaca}
.ac-danger-row--last{border-bottom:none}
.ac-danger-title{font-size:14px;font-weight:700;color:#374151;margin-bottom:4px}
.ac-danger-sub{font-size:12.5px;color:#6b7280;line-height:1.5;max-width:440px}

/* ── Announcements ── */
.ac-type-row{display:flex;gap:8px;flex-wrap:wrap}
.ac-type-btn{padding:6px 14px;border-radius:20px;border:1.5px solid #e5e7eb;background:#fff;font-size:12px;font-weight:600;font-family:var(--fb,system-ui,sans-serif);cursor:pointer;transition:background .12s,border-color .12s,transform .1s;text-transform:capitalize;-webkit-tap-highlight-color:transparent}
.ac-type-btn:active{transform:scale(.94)}
.ac-type-btn--info.ac-type-btn--active{background:#dbeafe;border-color:#93c5fd;color:#1e40af}
.ac-type-btn--success.ac-type-btn--active{background:#dcfce7;border-color:#86efac;color:#166534}
.ac-type-btn--warning.ac-type-btn--active{background:#fef9c3;border-color:#fde047;color:#854d0e}
.ac-type-btn--error.ac-type-btn--active{background:#fee2e2;border-color:#fca5a5;color:#991b1b}
.ac-ann-preview{padding:4px 0 8px;min-height:60px;display:flex;align-items:center}
.ac-ann-preview .app-ann{flex:1}
.ac-ann-examples{display:flex;flex-direction:column;gap:8px}

/* ── Misc ── */
.ac-muted{color:#9ca3af;font-size:12.5px}
.ac-empty{color:#9ca3af;font-size:13px;font-style:italic;margin:8px 0}
.ac-empty--padded{padding:32px;text-align:center}
.ac-body-text + .ac-input-row{margin-top:-4px}

/* ── PIN Screen ── */
.ac-pin-layout{display:flex;width:min(900px,96vw);height:min(620px,92dvh);border-radius:20px;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.3)}
.ac-pin-left{flex:1;background:#111827;padding:48px 44px;display:flex;flex-direction:column;justify-content:center}
.ac-pin-brand{display:flex;align-items:center;gap:10px;margin-bottom:28px}
.ac-pin-brand-name{font-size:22px;font-weight:700;color:#fff;letter-spacing:-.01em}
.ac-pin-heading{font-size:30px;font-weight:700;color:#fff;margin:0 0 14px;letter-spacing:-.02em;font-family:var(--fd,Georgia,serif)}
.ac-pin-desc{font-size:14px;color:rgba(255,255,255,.55);line-height:1.7;margin:0 0 24px;max-width:280px}
.ac-pin-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.ac-pin-list li{font-size:13px;color:rgba(255,255,255,.45);padding-left:16px;position:relative}
.ac-pin-list li::before{content:'·';position:absolute;left:0;color:#C4682A;font-size:18px;line-height:1}
.ac-pin-form{width:320px;background:#fff;display:flex;align-items:center;justify-content:center;padding:32px}
.ac-pin-card{display:flex;flex-direction:column;align-items:center;gap:0;width:100%}
.ac-pin-lock{width:52px;height:52px;border-radius:16px;background:#fff8f0;border:1.5px solid #fed7aa;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.ac-pin-lock svg{width:28px;height:28px}
.ac-pin-title{font-size:18px;font-weight:700;color:#111827;margin-bottom:4px;text-align:center}
.ac-pin-sub{font-size:12.5px;color:#9ca3af;margin-bottom:22px;text-align:center}
.ac-pin-dots{display:flex;gap:14px;margin-bottom:8px}
.ac-pin-dots span{width:13px;height:13px;border-radius:50%;border:2px solid #d1d5db;transition:background .15s,border-color .15s}
.ac-pin-dots span.filled{background:#C4682A;border-color:#C4682A}
.ac-pin-error{font-size:12.5px;color:#dc2626;font-weight:600;text-align:center;margin:6px 0 0;animation:shake .3s ease both}
@keyframes shake{0%,100%{transform:none}20%,60%{transform:translateX(-5px)}40%,80%{transform:translateX(5px)}}
.ac-numpad{display:grid;grid-template-columns:repeat(3,68px);gap:10px;margin-top:22px}
.ac-key{width:68px;height:68px;border-radius:50%;border:none;background:#f9fafb;border:1.5px solid #f3f4f6;font-size:20px;font-weight:700;color:#111827;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,transform .1s;font-family:var(--fb,system-ui,sans-serif);-webkit-tap-highlight-color:transparent}
.ac-key:hover{background:#f3f4f6}
.ac-key:active{background:#e5e7eb;transform:scale(.88)}
.ac-key:disabled{opacity:0;pointer-events:none}

/* ══ Announcement bar (injected into main app) ════════════════════════════════ */
.app-ann{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 16px;font-size:13px;font-weight:500;line-height:1.4;animation:slideDown .3s var(--t-spring,cubic-bezier(.22,1,.36,1)) both}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:none;opacity:1}}
.app-ann--info{background:#dbeafe;color:#1e3a5f}
.app-ann--success{background:#d1fae5;color:#065f46}
.app-ann--warning{background:#fef3c7;color:#78350f}
.app-ann--error{background:#fee2e2;color:#7f1d1d}
.app-ann-text{flex:1}
.app-ann-link{color:inherit;font-weight:700;text-decoration:underline}
.app-ann-close{flex-shrink:0;background:none;border:none;font-size:20px;line-height:1;cursor:pointer;opacity:.65;padding:0 2px;-webkit-tap-highlight-color:transparent;color:inherit}
.app-ann-close:active{opacity:1}

/* ── Feature pack: price, occasion, visit badge, cuisine hint ── */
.compose-row-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:4px}
.compose-price-wrap{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:10px;overflow:hidden;margin-top:6px;background:var(--surface)}
.compose-price-sym{padding:0 10px;font-size:14px;color:var(--muted);font-weight:600;border-right:1.5px solid var(--border);background:var(--surface2);height:100%;display:flex;align-items:center}
.compose-price-inp{border:none;outline:none;padding:10px 10px;font-size:14px;width:100%;background:transparent;color:var(--text);font-family:var(--fb)}
.compose-occ-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.compose-occ-chip{padding:5px 12px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface2);color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:all .18s ease;-webkit-tap-highlight-color:transparent;font-family:var(--fb)}
.compose-occ-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.compose-occ-chip:active{transform:scale(0.94)}
.pi-occ-tag{display:inline-block;background:rgba(196,104,42,0.12);color:var(--accent);font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;margin-bottom:6px;text-transform:capitalize}
.pi-visit-badge{background:rgba(196,104,42,0.12);color:var(--accent);font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;white-space:nowrap}
.cuisine-hint-row{min-height:22px;margin-top:4px}
.cuisine-suggest{background:rgba(196,104,42,0.1);border:1px dashed var(--accent);color:var(--accent);font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;cursor:pointer;font-family:var(--fb);-webkit-tap-highlight-color:transparent}
.cuisine-suggest:active{background:rgba(196,104,42,0.2)}

/* ── Profile insights ── */
.prof-insights{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;margin:10px 0 2px;padding:12px 16px;background:var(--surface2);border-radius:14px}
.prof-insight{display:flex;flex-direction:column;align-items:center;flex:1;min-width:64px;padding:4px 6px}
.prof-insight-val{font-size:14px;font-weight:700;color:var(--text)}
.prof-insight-lbl{font-size:10px;color:var(--muted);margin-top:2px;text-align:center}
.prof-tab-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:20px;font-size:10px;font-weight:700;padding:1px 5px;margin-left:4px;vertical-align:middle}

/* ── Wishlist ── */
.prof-tab-pane-wishlist{padding:16px}
.wish-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.wish-header-title{font-size:14px;font-weight:700;color:var(--text)}
.wish-add-btn{background:var(--accent);color:#fff;border:none;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--fb);-webkit-tap-highlight-color:transparent}
.wish-list{display:flex;flex-direction:column;gap:10px}
.wish-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;display:flex;align-items:flex-start;gap:12px;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.wish-info{flex:1;min-width:0}
.wish-name{font-size:14px;font-weight:600;color:var(--text)}
.wish-loc{font-size:12px;color:var(--muted);margin-top:2px}
.wish-note{font-size:12px;color:var(--muted);margin-top:4px;font-style:italic}
.wish-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}
.wish-log-btn{background:rgba(196,104,42,0.1);color:var(--accent);border:1px solid rgba(196,104,42,0.25);border-radius:20px;padding:5px 10px;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;font-family:var(--fb);-webkit-tap-highlight-color:transparent}
.wish-del-btn{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;line-height:1;padding:4px 8px;-webkit-tap-highlight-color:transparent}
.wish-log-btn:active{opacity:.75}.wish-del-btn:active{opacity:.5}

/* ── Search filters ── */
.us-filters{display:flex;gap:6px;padding:8px 16px 4px;overflow-x:auto;scrollbar-width:none;align-items:center;flex-wrap:nowrap}
.us-filters::-webkit-scrollbar{display:none}
.us-fchip{flex-shrink:0;padding:5px 12px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface2);color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:all .18s;-webkit-tap-highlight-color:transparent}
.us-fchip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.us-fchip:active{transform:scale(.93)}
.us-filter-sep{flex-shrink:0;color:var(--border);font-size:14px;user-select:none}

/* ── Route playback overlay ── */
.route-overlay{position:fixed;inset:0;z-index:900;background:#fff;display:flex;flex-direction:column}
.route-header{display:flex;align-items:center;justify-content:space-between;padding:max(env(safe-area-inset-top),14px) 16px 12px;border-bottom:1px solid var(--border);background:#fff}
.route-title{font-size:15px;font-weight:700;color:var(--text)}
.route-map-el{flex:1;min-height:0}
.route-footer{padding:12px 16px max(env(safe-area-inset-bottom),16px);display:flex;align-items:center;gap:12px;border-top:1px solid var(--border);background:#fff}
.route-label{font-size:13px;color:var(--muted);font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── Taste DNA overlay ── */
.dna-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,0.80);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:flex-end;opacity:0;transition:opacity .28s ease;overscroll-behavior:none;-webkit-overflow-scrolling:touch}
.dna-overlay.dna-overlay--in{opacity:1}
.dna-scroll{width:100%;max-height:92dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;border-radius:24px 24px 0 0}
.dna-scroll::-webkit-scrollbar{display:none}
.dna-card{background:linear-gradient(160deg,#1C0D04 0%,#2A1508 50%,#1A0A03 100%);min-height:100%;padding-bottom:max(env(safe-area-inset-bottom),24px);border-radius:24px 24px 0 0;position:relative;overflow:hidden}
.dna-card::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(255,200,80,.013) 3px,rgba(255,200,80,.013) 4px);pointer-events:none}
.dna-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 0;position:relative}
.dna-topbar-close,.dna-share-btn-top{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.10);border:none;color:rgba(255,255,255,0.70);cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:background .15s;flex-shrink:0}
.dna-topbar-close{font-size:15px}
.dna-topbar-close:active,.dna-share-btn-top:active{background:rgba(255,255,255,0.20)}
.dna-topbar-title{font-size:13.5px;font-weight:700;color:rgba(255,255,255,0.45);letter-spacing:.9px;text-transform:uppercase}
.dna-hero{display:flex;flex-direction:column;align-items:center;padding:24px 24px 20px;text-align:center;gap:6px}
.dna-avatar{width:96px;height:96px;border-radius:50%;background:radial-gradient(circle,rgba(232,160,32,0.22),rgba(196,104,42,0.07));border:2px solid rgba(232,160,32,0.36);display:flex;align-items:center;justify-content:center;font-size:52px;margin-bottom:8px}
.dna-user-name{font-size:18px;font-weight:600;color:rgba(255,255,255,0.88);font-family:var(--fb)}
.dna-archetype-title{font-size:27px;font-weight:700;font-style:italic;color:#E8A020;font-family:var(--fd);line-height:1.25}
.dna-tagline{font-size:13px;color:rgba(255,255,255,0.48);font-style:italic;max-width:270px;line-height:1.55}
.dna-stats{display:flex;justify-content:center;background:rgba(255,255,255,0.04);border-top:1px solid rgba(255,255,255,0.07);border-bottom:1px solid rgba(255,255,255,0.07)}
.dna-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:15px 8px;border-right:1px solid rgba(255,255,255,0.07)}
.dna-stat:last-child{border-right:none}
.dna-stat-n{font-size:19px;font-weight:700;color:#E8A020;font-family:var(--fb);margin-bottom:2px}
.dna-stat-l{font-size:10px;font-weight:600;color:rgba(255,255,255,0.38);text-transform:uppercase;letter-spacing:.5px}
.dna-divider{height:1px;background:rgba(255,255,255,0.07);margin:0 20px}
.dna-section{padding:20px 20px 6px}
.dna-section-lbl{font-size:10px;font-weight:700;color:rgba(255,255,255,0.38);text-transform:uppercase;letter-spacing:.9px;margin-bottom:14px}
.dna-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.dna-bar-name{font-size:12.5px;font-weight:500;color:rgba(255,255,255,0.74);flex:0 0 80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-transform:capitalize}
.dna-bar-track{flex:1;height:8px;background:rgba(255,255,255,0.07);border-radius:4px;overflow:hidden}
.dna-bar-fill{height:100%;border-radius:4px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.dna-bar-count{font-size:11px;font-weight:600;color:rgba(255,255,255,0.32);flex:0 0 22px;text-align:right}
.dna-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.dna-pill{display:inline-flex;align-items:center;padding:7px 14px;border-radius:20px;font-size:12.5px;font-weight:600;color:rgba(255,255,255,0.84);background:rgba(196,104,42,0.18);border:1px solid rgba(196,104,42,0.35);font-family:var(--fb)}
.dna-tops{display:flex;gap:12px;padding:20px 20px 12px}
.dna-top-card{flex:1;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:16px;padding:14px;min-width:0}
.dna-top-eyebrow{font-size:9.5px;font-weight:700;color:rgba(232,160,32,0.68);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.dna-top-val{font-size:13.5px;font-weight:700;color:rgba(255,255,255,0.88);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dna-top-sub{font-size:11px;color:rgba(255,255,255,0.38);margin-top:3px}
.dna-footer{display:flex;flex-direction:column;align-items:center;padding:18px 20px 6px;gap:4px}
.dna-footer-brand{font-size:10.5px;font-weight:700;color:rgba(255,255,255,0.22);text-transform:uppercase;letter-spacing:1px}
.dna-footer-sub{font-size:10px;color:rgba(255,255,255,0.14);font-style:italic}
.dna-share-bar{padding:12px 20px 8px;display:flex;justify-content:center}
.dna-share-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;background:linear-gradient(135deg,#C4682A,#E8A020);border:none;border-radius:28px;font-size:14.5px;font-weight:700;color:#fff;cursor:pointer;font-family:var(--fb);-webkit-tap-highlight-color:transparent;box-shadow:0 4px 20px rgba(196,104,42,0.35);transition:opacity .15s,transform .15s;width:100%;max-width:320px}
.dna-share-btn:active{opacity:.85;transform:scale(.97)}

/* ── Profile: Taste DNA entry button ── */
.prof-dna-btn{display:flex;align-items:center;gap:14px;width:100%;margin:14px 0 4px;padding:14px 16px;background:linear-gradient(135deg,#1C0D04 0%,#2D1A0A 100%);border:1.5px solid rgba(232,160,32,0.28);border-radius:18px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .15s,transform .15s;font-family:var(--fb);text-align:left}
.prof-dna-btn:active{opacity:.80;transform:scale(.98)}
.prof-dna-btn-ico{font-size:28px;flex-shrink:0;line-height:1}
.prof-dna-btn-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.prof-dna-btn-title{font-size:14.5px;font-weight:700;color:#E8A020;font-family:var(--fd);font-style:italic;display:block}
.prof-dna-btn-sub{font-size:12px;color:rgba(255,255,255,0.52);font-weight:400;display:block}
.prof-dna-btn-arr{font-size:22px;color:rgba(232,160,32,0.55);flex-shrink:0;line-height:1}

/* ── Location autocomplete dropdown ── */
.loc-ac-drop{background:var(--surface);border:1px solid var(--border2);border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,0.12);overflow:hidden;margin-top:4px;z-index:300}
.loc-ac-item{padding:10px 14px;font-size:13.5px;color:var(--text2);cursor:pointer;border-bottom:1px solid var(--border);line-height:1.4;-webkit-tap-highlight-color:transparent}
.loc-ac-item:last-child{border-bottom:none}
.loc-ac-item:active{background:var(--surface2)}
/* ── Per-photo location pin button ── */
.photo-loc-btn{padding:6px;border-radius:10px;border:1.5px solid var(--border2);background:var(--surface2);color:var(--muted);transition:all .15s}
.photo-loc-btn.has-loc{border-color:rgba(196,104,42,0.4);color:var(--accent);background:var(--accent-l)}
.photo-loc-btn:active{transform:scale(.9)}

/* ════════════════════════════════════════════════════════════════════════
   PREMIUM REDESIGN — overrides targeting visual quality lift
   Touch no business logic, no IDs used in JS, no z-index above existing
   ════════════════════════════════════════════════════════════════════════ */

/* ── Enhanced root tokens ── */
:root{
  --sh1:0 1px 3px rgba(0,0,0,0.05),0 3px 8px rgba(0,0,0,0.05);
  --sh2:0 2px 6px rgba(0,0,0,0.06),0 6px 18px rgba(0,0,0,0.07);
  --sh3:0 4px 14px rgba(0,0,0,0.08),0 12px 32px rgba(0,0,0,0.09);
  --sh4:0 10px 28px rgba(0,0,0,0.10),0 24px 56px rgba(0,0,0,0.09);
  --card-r:22px;
  --gold-gradient:linear-gradient(135deg,#F0B429,#E8A020);
  --accent-gradient:linear-gradient(148deg,#E8884A 0%,#C4682A 55%,#A85420 100%);
}

/* ── Header — richer warmth ── */
.hdr{background:rgba(247,243,238,0.98);backdrop-filter:blur(32px) saturate(2);-webkit-backdrop-filter:blur(32px) saturate(2);border-bottom:1px solid rgba(196,104,42,0.08)}
.logo{font-size:23px;letter-spacing:-.4px;background:linear-gradient(135deg,#C4682A,#9E4F18);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.logo span{background:linear-gradient(135deg,var(--text),var(--text2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── XHS Cards — hero food photography feel ── */
.xhs-card{border-radius:var(--card-r);box-shadow:var(--sh3)}
.xhs-card:active{transform:scale(0.965);box-shadow:var(--sh1)}
.xhs-photo-ov{padding:48px 10px 10px;background:linear-gradient(transparent 10%,rgba(0,0,0,0.35) 55%,rgba(0,0,0,0.78))}
.xhs-shop-title{font-size:15.5px;font-weight:800;letter-spacing:-.025em;line-height:1.3}
.xhs-body{padding:11px 13px 13px}
.xhs-card-stars{font-size:11.5px;letter-spacing:.6px}
.xhs-caption{font-size:12px;line-height:1.55;color:var(--muted)}
.xhs-ov-rating{font-size:13.5px;font-weight:800;color:#FFD866;text-shadow:0 1px 4px rgba(0,0,0,.65)}

/* ── Masonry skeleton — premium shimmer ── */
.skel{background:linear-gradient(105deg,var(--surface2) 20%,rgba(255,255,255,0.7) 45%,var(--surface2) 70%);background-size:300% 100%;animation:skel-shine 1.6s ease-in-out infinite}
@keyframes skel-shine{0%{background-position:200% 0}100%{background-position:-100% 0}}
.skel-photo{border-radius:0;padding-bottom:118%}

/* ── Home tab bar — polished ── */
.home-tab-bar{padding:8px 12px 7px}
.home-tab{font-size:12.5px;font-weight:700;letter-spacing:.02em}
.home-tab.active{color:var(--text)}
.cat-chip.on{box-shadow:0 3px 16px rgba(196,104,42,0.42),inset 0 1px 0 rgba(255,255,255,0.22)}

/* ── Bottom nav — more elevated ── */
.nav-inner{box-shadow:0 14px 48px rgba(26,20,9,0.16),0 2px 8px rgba(26,20,9,0.07),inset 0 1px 0 rgba(255,255,255,0.95),inset 0 -1px 0 rgba(0,0,0,0.03)}
.nav-post-btn{box-shadow:0 8px 24px rgba(196,104,42,0.52),0 2px 8px rgba(26,20,9,0.14),inset 0 1px 0 rgba(255,255,255,0.32)}
.nav-post:active .nav-post-btn{box-shadow:0 3px 10px rgba(196,104,42,0.4)}

/* ── Primary button — more premium ── */
.btn-primary{background:var(--accent-gradient);box-shadow:0 4px 14px rgba(196,104,42,0.32),inset 0 1px 0 rgba(255,255,255,0.24)}
.btn-primary:active{box-shadow:0 1px 4px rgba(196,104,42,0.2)}

/* ── Toast — refined glass ── */
.toast{background:rgba(20,14,6,0.92);backdrop-filter:blur(24px) saturate(1.8);-webkit-backdrop-filter:blur(24px) saturate(1.8);box-shadow:0 6px 28px rgba(0,0,0,0.28);border-radius:24px;padding:12px 24px;font-size:14px;font-weight:600;letter-spacing:.01em;border:1px solid rgba(255,255,255,0.08)}

/* ── Post detail — enhanced shelf ── */
.sc-shop-name{font-size:28px;letter-spacing:-.03em;font-weight:800}
.sc-shelf-inner{background:rgba(249,246,241,0.98);backdrop-filter:blur(40px) saturate(2);-webkit-backdrop-filter:blur(40px) saturate(2);border-top:1px solid rgba(255,255,255,0.8);box-shadow:0 -6px 48px rgba(0,0,0,0.24),inset 0 1px 0 rgba(255,255,255,0.9)}
.sc-handle{width:40px;height:5px;background:rgba(0,0,0,0.14);border-radius:3px;margin:11px auto 5px}
.sc-rating-num{font-size:21px;font-weight:800}
.sc-photo-caption{font-size:13.5px;line-height:1.6}

/* ── Post detail body card — photo fully above, content fully below ── */
.pi-body{background:var(--bg);border-radius:28px 28px 0 0;margin-top:0;box-shadow:0 -3px 18px rgba(0,0,0,0.08)}
.pi-body::before{display:none}
.pi-body-inner{padding:16px 18px 52px}
.pi-shop{font-size:27px;letter-spacing:-.025em;font-weight:800}
.pi-rating-pill{font-size:17px;font-weight:900;padding:8px 16px}

/* ── Post inline topbar ── */
.pi-topbar-btn{box-shadow:0 2px 10px rgba(0,0,0,0.3)}

/* ── Comment bar — warm glass ── */
.pi-comment-bar{background:rgba(248,244,239,0.98);backdrop-filter:blur(24px) saturate(1.8);-webkit-backdrop-filter:blur(24px) saturate(1.8);border-top:1px solid rgba(196,104,42,0.08)}
.pi-cmt-pill{background:rgba(0,0,0,0.055);border-radius:24px}

/* ── Trip cards — travel journal ── */
.trip-thumb{height:136px}
.trip-card{border-radius:var(--card-r);box-shadow:var(--sh3)}
.trip-card:active{box-shadow:var(--sh1)}
.trip-name{font-size:13.5px;font-weight:800;letter-spacing:-.01em}
.trip-overlay{background:linear-gradient(transparent,rgba(0,0,0,0.72))}
.trip-badge{font-size:10.5px;font-weight:700}

/* ── Trip detail hero — more immersive ── */
.trip-hero{height:220px;border-radius:0 0 28px 28px}
.trip-hero-title{font-size:26px;letter-spacing:-.03em;text-shadow:0 2px 12px rgba(0,0,0,0.35)}
.trip-hero-ov{background:linear-gradient(transparent 18%,rgba(0,0,0,0.72))}

/* ── Trip log cards — premium ── */
.trip-log-card{border-radius:24px;box-shadow:var(--sh3)}
.trip-log-photo-wrap{aspect-ratio:16/10}

/* ── Trips hub cards — richer gradients ── */
.trips-hub-card{border-radius:22px}
.trips-hub-card--primary{box-shadow:0 10px 28px rgba(196,104,42,0.36),0 2px 8px rgba(196,104,42,0.22),inset 0 1px 0 rgba(255,255,255,0.24)}

/* ── Profile — premium social ── */
.prof-hero{padding:28px 20px 20px;background:linear-gradient(170deg,rgba(196,104,42,0.06) 0%,rgba(247,243,238,0) 60%);border-bottom:1px solid rgba(196,104,42,0.08)}
.prof-avatar{border:3px solid rgba(255,255,255,0.9);box-shadow:0 4px 24px rgba(196,104,42,0.20),0 1px 6px rgba(0,0,0,0.08)}
.prof-name{font-size:23px;letter-spacing:-.03em;font-weight:800}
.prof-stats{margin:16px 16px 4px;padding:12px 0;background:var(--surface);border-radius:18px;box-shadow:var(--sh2)}
.prof-stat-n{font-size:22px;font-weight:800;letter-spacing:-.02em}
.prof-stat-l{font-size:10px;letter-spacing:.4px}
.prof-tab{font-size:14px;font-weight:700;letter-spacing:.02em}
.prof-tab.active{color:var(--accent-d)}
.prof-tab.active::after{left:25%;right:25%;height:3px;border-radius:2px;background:var(--accent-gradient)}
.prof-trip-card{border-radius:18px;box-shadow:var(--sh2)}
.prof-trip-thumb{height:124px}
.prof-trip-name{font-size:13.5px;font-weight:800;padding:9px 11px 3px;letter-spacing:-.01em}
.prof-dna-btn{border-radius:22px}

/* ── Profile insights row ── */
.prof-insights{border-radius:18px;box-shadow:var(--sh1);border:1px solid var(--border)}
.prof-streak{border-radius:24px;font-weight:600}

/* ── Map — Airbnb-style polish ── */
.map-bottom-sheet{border-radius:26px 26px 0 0;box-shadow:0 -8px 48px rgba(0,0,0,0.15),0 -1px 0 rgba(0,0,0,0.04)}
.map-place-card{border-radius:22px;box-shadow:var(--sh3)}
.map-place-card:active{box-shadow:var(--sh1)}
.map-search-row{border-radius:16px;border:1.5px solid var(--border)}
.map-sort-chip.on{box-shadow:0 3px 12px rgba(196,104,42,0.32)}
.map-action-btn{border-radius:18px;box-shadow:var(--sh2)}
.map-action-btn--primary{background:var(--accent-gradient);box-shadow:0 4px 16px rgba(196,104,42,0.38)}

/* ── Modal — premium glass sheet ── */
.modal{border-radius:28px 28px 0 0;box-shadow:0 -6px 48px rgba(0,0,0,0.18),0 -1px 0 rgba(0,0,0,0.04)}
.modal-handle{width:44px;height:5px;border-radius:3px;background:rgba(0,0,0,0.11);margin:13px auto 18px}
.modal-title{font-size:22px;font-weight:800;letter-spacing:-.025em;margin-bottom:20px}

/* ── Action sheet ── */
.action-sheet{border-radius:24px 24px 0 0}
.action-sheet-item{font-size:16px;font-weight:600;border-radius:14px}

/* ── Place hub — premium ── */
.place-hero-names h1{font-size:19px;font-weight:800;letter-spacing:-.025em}
.place-stat{border-radius:14px;padding:5px 10px}
.place-stat b{font-size:13px}

/* ── Dish chips — more premium ── */
.pi-dish-chip{border-radius:24px;border-width:1.5px}
.pi-dish-chip.active{box-shadow:0 2px 10px rgba(196,104,42,0.2)}
.sc-dish-chip{border-radius:22px}
.sc-dish-chip.active{box-shadow:0 2px 8px rgba(196,104,42,0.18)}

/* ── Rating pill ── */
.pi-rating-pill{background:linear-gradient(135deg,rgba(232,160,32,0.20),rgba(232,160,32,0.10));border:1.5px solid rgba(232,160,32,0.28)}

/* ── Meta chips ── */
.pi-meta-loc{border-radius:24px;box-shadow:0 1px 4px rgba(196,104,42,0.12)}
.pi-meta-date,.pi-meta-chip{border-radius:24px}

/* ── Section labels ── */
.pi-sec-lbl{letter-spacing:1.4px}

/* ── Vibe tags ── */
.pi-vibe{border-radius:22px;font-size:11px;letter-spacing:.02em}

/* ── Entry form (compose) — cleaner ── */
.glass-sec{background:rgba(255,255,255,0.65);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 2px 16px rgba(0,0,0,0.05),inset 0 1px 0 rgba(255,255,255,0.95)}
.fs-panel{background:rgba(252,249,245,0.86);backdrop-filter:blur(52px) saturate(2);-webkit-backdrop-filter:blur(52px) saturate(2);box-shadow:0 -4px 56px rgba(0,0,0,0.16),inset 0 1px 0 rgba(255,255,255,0.9)}
.fs-picker-btn{border-radius:22px;box-shadow:0 3px 14px rgba(0,0,0,0.07)}

/* ── Story timeline ── */
.story-moment{border-radius:18px;box-shadow:var(--sh2)}
.story-chapter-add{border-radius:var(--rs);box-shadow:0 3px 12px rgba(196,104,42,0.30)}

/* ── Empty states ── */
.feed-empty{padding:80px 32px}
.feed-empty h3{font-size:22px;font-weight:800;letter-spacing:-.025em;font-family:var(--fd)}
.feed-empty p{font-size:14.5px;color:var(--muted);line-height:1.75}

/* ── Discover ── */
.disc-section-title{font-size:18px;font-weight:800;letter-spacing:-.025em}

/* ── Leaderboard ── */
.lb-stat-val{font-size:30px;font-weight:800;letter-spacing:-.03em}
.lb-score-badge{border-radius:980px;box-shadow:0 1px 4px rgba(196,104,42,0.16)}

/* ── Form inputs ── */
.form-input{border-radius:16px}
.form-input:focus{box-shadow:0 0 0 4px rgba(196,104,42,0.10)}

/* ── Add choice ── */
.add-choice{border-radius:18px;border-width:1.5px}
.add-choice-icon{border-radius:16px}

/* ── Search / Universal search ── */
.us-row-thumb{border-radius:14px}
.map-search-suggestions{border-radius:20px;box-shadow:var(--sh4)}

/* ── Scroll reveal — directional entrance with --rx per-column offset ── */
.scroll-reveal{opacity:0;transform:translateX(var(--rx,0px)) translateY(16px) scale(0.972)}
.scroll-reveal.is-visible{transition:opacity .4s cubic-bezier(0.22,1,0.36,1) var(--reveal-delay,0s),transform .4s cubic-bezier(0.22,1,0.36,1) var(--reveal-delay,0s);opacity:1;transform:none}

/* ── Story-moment cards ── */
.story-masonry .xhs-card{border-radius:18px;box-shadow:var(--sh3)}

/* ── Trip timeline ── */
.trip-day-node{border-width:3px;box-shadow:0 0 0 4px #F5F0E8,0 0 0 6px rgba(192,57,43,0.18)}
.story-spine-dot{box-shadow:0 0 0 4px var(--bg),0 0 0 6px rgba(196,104,42,0.22)}

/* ── Pin modal ── */
.pin-panel{border-radius:28px 28px 0 0;box-shadow:0 -8px 48px rgba(0,0,0,0.24),inset 0 1px 0 rgba(255,255,255,0.92)}

/* ── Quick capture sheet ── */
.fab-sheet{border-radius:32px 32px 0 0}
.fab-sheet-btn{border-radius:22px}
.qp-save-btn{border-radius:18px;box-shadow:0 6px 22px rgba(196,104,42,0.36)}

/* ── View transitions ── */
@keyframes viewIn{from{opacity:0;transform:translateY(12px) scale(0.992)}to{opacity:1;transform:translateY(0) scale(1)}}
.view.active{animation:viewIn .3s cubic-bezier(0.22,1,0.36,1) both}

/* ── Vibes on post detail photo ── */
.sc-vibe-pill{background:rgba(255,255,255,0.15);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,0.25);font-size:11.5px;font-weight:700;padding:5px 13px;border-radius:22px}

/* ── Rating badge on detail ── */
.sc-rating-badge{background:rgba(0,0,0,0.42);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.24);border-radius:22px;padding:6px 14px}

/* ── Topbar buttons on post detail ── */
.sc-back,.sc-top-btn{background:rgba(0,0,0,0.40);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}

/* ── Draft cards ── */
.draft-card{border-radius:16px;box-shadow:var(--sh2)}
.draft-thumb{border-radius:0;height:108px}

/* ── Masonry cards (map/discover) ── */
.masonry-card{border-radius:20px;box-shadow:var(--sh3)}
.masonry-card:active{box-shadow:var(--sh1)}
.masonry-shop{font-size:13.5px;font-weight:800;letter-spacing:-.015em}

/* ── Map place cards ── */
.map-place-card-name{font-weight:800;font-size:14px;letter-spacing:-.015em}
.map-l-pin-body{border-width:3px}

/* ── Trip story moment cards ── */
.story-moment-title{font-size:14.5px;font-weight:800;letter-spacing:-.02em}
.story-moment-body{gap:5px}

/* ── Discover spots ── */
.disc-spot-name{font-size:14px;font-weight:800;letter-spacing:-.015em}

/* ── Better trip detail day nodes ── */
.trip-day-title{font-size:19px;letter-spacing:-.02em}
.trip-day-meta{font-size:12.5px}

/* ── Reduce motion compliance ── */
@media(prefers-reduced-motion:reduce){
  .scroll-reveal{opacity:1!important;transform:none!important;transition:none!important}
  .scroll-reveal.is-visible{transition:none!important}
}

/* ── iOS safe area ── */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .pi-comment-bar{padding-bottom:calc(env(safe-area-inset-bottom) + 10px)}
}

/* ════════════════════════════════════════════════════════════════════════
   THEME SYSTEM — Dark mode + accent colours
   ════════════════════════════════════════════════════════════════════════ */

/* Smooth transition when user actively toggles theme — scoped so new DOM never flickers */
html{transition:background-color 0.22s ease}
body{transition:background-color 0.22s ease,color 0.18s ease}
html.is-theme-transitioning *,
html.is-theme-transitioning *::before,
html.is-theme-transitioning *::after{transition:background-color 0.22s ease,color 0.18s ease,border-color 0.18s ease,box-shadow 0.18s ease!important}
html.is-theme-transitioning img,
html.is-theme-transitioning .nav-pill{transition:none!important}

/* ── Dark mode: XHS AMOLED-black neutral ── */
[data-theme="dark"]{
  color-scheme:dark;
  --bg:#0A0A0A;--surface:#161616;--surface2:#1E1E1E;--surface3:#272727;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.10);
  --text:#FFFFFF;--text2:#888888;--muted:#555555;--muted2:#333333;
  --accent-l:rgba(196,104,42,0.18);--accent-m:rgba(196,104,42,0.12);
  --green:#3AAA70;--green-l:rgba(58,170,112,0.18);
  --gold:#F0C040;
  --danger:#E84848;--danger-l:rgba(232,72,72,0.18);
  --sh1:0 1px 3px rgba(0,0,0,0.7),0 3px 8px rgba(0,0,0,0.6);
  --sh2:0 2px 8px rgba(0,0,0,0.8),0 6px 20px rgba(0,0,0,0.7);
  --sh3:0 4px 16px rgba(0,0,0,0.85),0 14px 36px rgba(0,0,0,0.75);
  --sh4:0 10px 30px rgba(0,0,0,0.9),0 24px 60px rgba(0,0,0,0.8);
  --accent-gradient:linear-gradient(148deg,#F09458 0%,#D87838 55%,#B46020 100%);
  --gold-gradient:linear-gradient(135deg,#F8CC48,#F0AA28);
}

/* Targeted dark overrides — elements that hardcode light colours */
[data-theme="dark"] body{background:var(--bg)}
[data-theme="dark"] .hdr{background:rgba(10,10,10,0.97);backdrop-filter:blur(32px) saturate(1.0);-webkit-backdrop-filter:blur(32px) saturate(1.0);border-bottom-color:rgba(255,255,255,0.06)}
[data-theme="dark"] .nav-inner{background:rgba(14,14,14,0.98)!important;box-shadow:0 14px 48px rgba(0,0,0,0.8),0 2px 8px rgba(0,0,0,0.6),inset 0 1px 0 rgba(255,255,255,0.04),inset 0 -1px 0 rgba(0,0,0,0.3)}
[data-theme="dark"] .pi-comment-bar{background:rgba(14,14,14,0.97);border-top-color:rgba(255,255,255,0.06)}
[data-theme="dark"] .pi-cmt-pill{background:rgba(255,255,255,0.08)}
[data-theme="dark"] .sc-shelf-inner{background:rgba(12,12,12,0.99);border-top-color:rgba(255,255,255,0.06);box-shadow:0 -6px 48px rgba(0,0,0,0.8),inset 0 1px 0 rgba(255,255,255,0.03)}
[data-theme="dark"] .sc-handle{background:rgba(255,255,255,0.18)}
[data-theme="dark"] .modal{background:var(--surface)}
[data-theme="dark"] .modal-handle{background:rgba(255,255,255,0.20)}
[data-theme="dark"] .action-sheet{background:var(--surface)}
[data-theme="dark"] .glass-sec{background:rgba(22,22,22,0.85);box-shadow:0 2px 16px rgba(0,0,0,0.5),inset 0 1px 0 rgba(255,255,255,0.04)}
[data-theme="dark"] .fs-panel{background:rgba(12,12,12,0.96);border-top-color:rgba(255,255,255,0.06);box-shadow:0 -4px 56px rgba(0,0,0,0.75),inset 0 1px 0 rgba(255,255,255,0.03)}
[data-theme="dark"] .prof-hero{background:linear-gradient(170deg,rgba(196,104,42,0.08) 0%,rgba(10,10,10,0) 60%);border-bottom-color:rgba(255,255,255,0.06)}
[data-theme="dark"] .prof-stats{background:var(--surface);box-shadow:var(--sh2)}
[data-theme="dark"] .xhs-card{background:var(--surface)}
[data-theme="dark"] .xhs-body{background:var(--surface)}
[data-theme="dark"] .pi-body{background:var(--bg)}
[data-theme="dark"] .home-tab-bar{background:var(--bg)}
[data-theme="dark"] .toast{background:rgba(245,245,245,0.96);color:#0A0A0A}
[data-theme="dark"] .skel{background:linear-gradient(105deg,var(--surface2) 20%,rgba(255,255,255,0.04) 45%,var(--surface2) 70%);background-size:300% 100%}
[data-theme="dark"] input,[data-theme="dark"] textarea,[data-theme="dark"] select{background:var(--surface2);color:var(--text);border-color:var(--border2)}
[data-theme="dark"] .form-input{background:var(--surface2);border-color:var(--border2)}
[data-theme="dark"] .cat-chip{background:var(--surface2);border-color:var(--border)}
[data-theme="dark"] .cat-chip.on{background:var(--accent);color:#fff}
[data-theme="dark"] .map-bottom-sheet{background:var(--surface)}
[data-theme="dark"] .map-search-row{background:var(--surface2);border-color:var(--border2)}
[data-theme="dark"] .logo{background:linear-gradient(135deg,#F09458,#D87838);-webkit-background-clip:text;background-clip:text}
[data-theme="dark"] .logo span{background:linear-gradient(135deg,var(--text),var(--text2));-webkit-background-clip:text;background-clip:text}
[data-theme="dark"] .us-overlay{background:var(--bg)}
[data-theme="dark"] .trips-hub-card--primary{box-shadow:0 10px 28px rgba(196,104,42,0.25),0 2px 8px rgba(196,104,42,0.15),inset 0 1px 0 rgba(255,255,255,0.10)}


/* ── Appearance section in profile ── */
.appear-section{margin:0;padding:16px 20px;border-bottom:1px solid var(--border)}
.appear-title{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.appear-modes{display:flex;gap:8px;margin-bottom:0}
.appear-mode{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:var(--surface2);border:1.5px solid var(--border);border-radius:16px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s ease}
.appear-mode.active{background:var(--accent-l);border-color:var(--accent);color:var(--accent)}
.appear-mode:active{transform:scale(.94)}
.appear-mode-ico{line-height:1;color:inherit}
.appear-mode-lbl{font-size:12px;font-weight:700;letter-spacing:.01em;color:inherit}
.appear-mode:not(.active) .appear-mode-ico,.appear-mode:not(.active) .appear-mode-lbl{color:var(--muted)}

/* ════════════════════════════════════════════════════════════════════════
   MOTION SYSTEM v2 — World-class UX polish
   ════════════════════════════════════════════════════════════════════════ */

/* ── 1. Post sheet — spring physics entrance, sharp exit ── */
/* iOS-native feel: decelerate with spring overshoot, exit accelerates away */
.post-inline.pi-enter{animation:piSheetIn .46s cubic-bezier(0.22,1,0.36,1) forwards}
.post-inline.pi-exit{animation:piSheetOut .25s cubic-bezier(0.55,0,1,0.45) forwards}
@keyframes piSheetIn{0%{transform:translate3d(0,100%,0);opacity:.3}5%{opacity:1}100%{transform:translate3d(0,0,0);opacity:1}}
@keyframes piSheetOut{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(0,110%,0);opacity:0}}

/* ── 2. Depth blur on all overlay backdrops (iOS-native) ── */
.modal-bd{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.action-sheet-backdrop{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.fab-sheet-bd{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}

/* ── 3. Masonry card column-directional entrance ── */
/* Left column cards drift in from the left, right column from the right */
.xhs-col:nth-child(1) .scroll-reveal{--rx:-10px}
.xhs-col:nth-child(2) .scroll-reveal{--rx:10px}

/* ── 4. Card press — deeper tactile scale ── */
.xhs-card{transition:transform .22s cubic-bezier(0.22,1,0.36,1),box-shadow .22s cubic-bezier(0.22,1,0.36,1)}
.xhs-card:active{transform:scale(0.93)!important;box-shadow:0 1px 3px rgba(0,0,0,0.04)!important}

/* ── 5. Like button heart pop on card body ── */
@keyframes cardHeartPop{0%{transform:scale(1)}20%{transform:scale(0.65)}55%{transform:scale(1.38)}78%{transform:scale(0.9)}100%{transform:scale(1)}}
.xhs-body-like.pop-anim .ico{animation:cardHeartPop .44s cubic-bezier(0.34,1.56,0.64,1)}

/* ── 6. Photo fullscreen zoom entrance + swipe-down exit ── */
.photo-fs{animation:photoFsIn .32s cubic-bezier(0.22,1,0.36,1) both}
@keyframes photoFsIn{from{opacity:0;transform:scale(0.84)}to{opacity:1;transform:scale(1)}}
.photo-fs.is-closing{animation:photoFsOut .24s cubic-bezier(0.55,0,1,0.45) forwards}
@keyframes photoFsOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.84)}}

/* ── 7. Nav icon selection bounce on tap ── */
@keyframes navIconSelect{0%{transform:scale(1) translateY(0)}26%{transform:scale(0.65) translateY(3px)}60%{transform:scale(1.28) translateY(-3px)}82%{transform:scale(0.95) translateY(1px)}100%{transform:scale(1) translateY(0)}}
.nav-item.nav-selecting .nav-icon{animation:navIconSelect .42s cubic-bezier(0.34,1.56,0.64,1) both}

/* ── 8. Action sheet items stagger in ── */
@keyframes actionItemIn{from{opacity:0;transform:translateY(12px) scale(0.96)}to{opacity:1;transform:none}}
.action-sheet-group .action-sheet-item{animation:actionItemIn .26s cubic-bezier(0.22,1,0.36,1) both}
.action-sheet-group .action-sheet-item:nth-child(2){animation-delay:.05s}
.action-sheet-group .action-sheet-item:nth-child(3){animation-delay:.09s}
.action-sheet-group .action-sheet-item:nth-child(4){animation-delay:.13s}
.action-sheet-group .action-sheet-item:nth-child(5){animation-delay:.17s}
.action-sheet-cancel{animation:actionItemIn .26s cubic-bezier(0.22,1,0.36,1) .20s both}

/* ── 9. FAB sheet option buttons stagger in ── */
.fab-sheet-row .fab-sheet-btn{animation:actionItemIn .3s cubic-bezier(0.22,1,0.36,1) both}
.fab-sheet-row .fab-sheet-btn:nth-child(2){animation-delay:.06s}
.fab-sheet-row .fab-sheet-btn:nth-child(3){animation-delay:.12s}

/* ── 10. Image shimmer skeleton while lazily loading ── */
@keyframes imgShimmer{0%{background-position:200% center}100%{background-position:-200% center}}
.xhs-photo{
  background:linear-gradient(90deg,var(--surface2) 25%,rgba(255,255,255,0.52) 50%,var(--surface2) 75%);
  background-size:400% 100%;
  animation:imgShimmer 1.6s linear infinite;
}
[data-theme="dark"] .xhs-photo{background-color:#1A1A1A}
[data-theme="dark"] .xhs-photo{
  background:linear-gradient(90deg,var(--surface2) 25%,rgba(255,255,255,0.07) 50%,var(--surface2) 75%);
  background-size:400% 100%;
}

/* ── 11. View transition depth ── */
@keyframes viewIn{from{opacity:0;transform:translateY(18px) scale(0.977)}to{opacity:1;transform:none}}
@keyframes viewOut{from{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(0.97) translateY(-10px)}}
.view.active{animation:viewIn .32s cubic-bezier(0.22,1,0.36,1) both}
.view-exiting{animation:viewOut .22s cubic-bezier(0.55,0,1,0.45) both}

/* ── 12. Toast exit slide-down + fade ── */
@keyframes toastOut{from{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}to{opacity:0;transform:translateX(-50%) translateY(10px) scale(0.94)}}
.toast.is-dismissing{animation:toastOut .22s cubic-bezier(0.4,0,1,1) forwards!important}

/* ── 13. Home panel tab transition — spring (used by JS inline style) ── */
/* JS already uses '.38s cubic-bezier(0.25,0.46,0.45,0.94)' — keep as-is */

/* ── 14. Story moment pulse ── */
/* Already has storyMomentPulse — keep as-is */

/* ── 15. Reduced motion — disable all new animations ── */
@media(prefers-reduced-motion:reduce){
  .post-inline.pi-enter,.post-inline.pi-exit{animation:none!important}
  .photo-fs{animation:none!important;opacity:1!important;transform:none!important}
  .photo-fs.is-closing{animation:none!important}
  .nav-item.nav-selecting .nav-icon{animation:none!important}
  .xhs-body-like.pop-anim .ico{animation:none!important}
  .action-sheet-group .action-sheet-item,.action-sheet-cancel{animation:none!important}
  .fab-sheet-row .fab-sheet-btn{animation:none!important}
  .xhs-photo{animation:none!important}
  .xhs-col:nth-child(1) .scroll-reveal,.xhs-col:nth-child(2) .scroll-reveal{--rx:0px}
  .toast.is-dismissing{animation:none!important}
  .view.active,.view-exiting{animation:none!important}
  .pi-cmt-like.pop-anim .ico{animation:none!important}
  .pi-cmt-flash,.pi-cmt-removing{animation:none!important}
  .auth-screen{animation:none!important}
}

/* ══════════════════════════════════════════════════════════════════════════════
   Auth Screen — Login / Register
══════════════════════════════════════════════════════════════════════════════ */
@keyframes authSlideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

.auth-screen{
  position:fixed;inset:0;z-index:9900;
  background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  overflow-y:auto;padding:max(env(safe-area-inset-top),24px) 24px max(env(safe-area-inset-bottom),24px);
}
.auth-screen.is-hiding{opacity:0;pointer-events:none;transition:opacity .25s ease;}

.cloud-loading{
  position:fixed;inset:0;z-index:9800;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
}
.cloud-loading-inner{font-size:15px;color:var(--muted);font-weight:500}

.auth-card{
  width:100%;max-width:400px;
  display:flex;flex-direction:column;align-items:center;
  animation:authSlideUp .35s cubic-bezier(.25,.46,.45,.94) both;
  padding:16px 0 32px;
}

/* Brand header */
.auth-brand{display:flex;flex-direction:column;align-items:center;margin-bottom:36px;}
.auth-brand-ico{font-size:56px;margin-bottom:14px;filter:drop-shadow(0 4px 12px rgba(196,104,42,.35));}
.auth-brand-name{font-size:30px;font-weight:700;letter-spacing:-.025em;color:var(--text);}
.auth-brand-name span{color:var(--accent);}
.auth-brand-sub{font-size:14px;color:var(--muted2);margin-top:6px;text-align:center;max-width:260px;line-height:1.5;}

/* Tab toggle */
.auth-tabs{
  display:flex;width:100%;margin-bottom:24px;
  background:var(--surface2);border-radius:16px;padding:4px;gap:4px;
}
.auth-tab{
  flex:1;padding:10px 0;border:none;background:none;cursor:pointer;
  font-size:14px;font-weight:600;color:var(--muted2);border-radius:12px;
  transition:background .15s,color .15s,box-shadow .15s;font-family:inherit;
}
.auth-tab.active{
  background:var(--surface);color:var(--text);
  box-shadow:0 1px 4px rgba(0,0,0,.12),0 1px 2px rgba(0,0,0,.06);
}

/* Fields */
.auth-fields{width:100%;display:flex;flex-direction:column;gap:12px;margin-bottom:8px;}
.auth-input-wrap{position:relative;width:100%;}
.auth-input{
  width:100%;height:54px;padding:0 48px 0 18px;box-sizing:border-box;
  background:var(--surface2);border:1.5px solid var(--border2);border-radius:16px;
  font-size:15px;color:var(--text);outline:none;font-family:inherit;
  transition:border-color .15s,box-shadow .15s;
}
.auth-input::placeholder{color:var(--muted2);}
.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,104,42,.12);}
.auth-eye{
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;line-height:0;
}

/* Error + submit */
.auth-error{font-size:13px;color:#E53E3E;text-align:center;min-height:16px;}
[data-theme="dark"] .auth-error{color:#FC8181;}
.auth-submit{
  width:100%;height:54px;margin-top:12px;
  background:var(--accent);color:#fff;border:none;border-radius:16px;
  font-size:16px;font-weight:600;cursor:pointer;font-family:inherit;
  transition:opacity .15s,transform .08s;
  box-shadow:0 4px 16px rgba(196,104,42,.35);
}
.auth-submit:hover{opacity:.92;}
.auth-submit:active{transform:scale(.98);}
.auth-submit:disabled{opacity:.55;cursor:not-allowed;transform:none;}

/* Divider + skip */
.auth-divider{
  display:flex;align-items:center;gap:10px;width:100%;
  margin:20px 0 12px;color:var(--muted2);font-size:12px;
}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.auth-skip{
  font-size:14px;color:var(--muted2);background:none;border:none;cursor:pointer;
  padding:8px 16px;font-family:inherit;
  text-decoration:underline;text-decoration-color:var(--border2);text-underline-offset:3px;
}
.auth-skip:hover{color:var(--text);}

/* API URL row (shown when not yet configured) */
.auth-api-row{
  width:100%;margin-bottom:16px;
  padding:14px 16px;box-sizing:border-box;
  background:var(--surface2);border:1.5px solid var(--border2);border-radius:16px;
}
.auth-api-label{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px;}
.auth-api-input{
  height:44px;font-size:13px;background:var(--surface);margin-bottom:0;
  border-radius:10px;padding:0 14px;
}
.auth-api-hint{font-size:11px;color:var(--muted2);margin-top:6px;line-height:1.4;}

/* Close button (shown when user has existing data) */
.auth-close{
  position:absolute;top:max(env(safe-area-inset-top),16px);right:20px;
  background:var(--surface2);border:none;border-radius:50%;
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text);
}

/* ── Profile: Login Prompt + Logout ──────────────────────────────────────── */
.prof-login-prompt{
  margin:0 20px 28px;padding:22px 20px;
  background:var(--surface);border:1.5px solid var(--border);border-radius:22px;
  text-align:center;
}
.prof-login-prompt-ico{font-size:38px;margin-bottom:10px;}
.prof-login-prompt-title{font-size:17px;font-weight:700;margin-bottom:6px;}
.prof-login-prompt-sub{font-size:13px;color:var(--muted2);margin-bottom:18px;line-height:1.5;}
.prof-login-prompt-btn{
  padding:12px 28px;background:var(--accent);color:#fff;border:none;
  border-radius:14px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;
}

.prof-cloud-badge{
  display:inline-flex;align-items:center;gap:5px;margin-top:4px;
  font-size:11px;color:var(--accent);font-weight:600;letter-spacing:.02em;
  padding:3px 10px;background:rgba(196,104,42,.1);border-radius:20px;
}
.prof-logout-row{
  margin:0 20px 4px;display:flex;
}
.prof-logout-btn{
  flex:1;padding:13px 16px;background:var(--surface2);border:1.5px solid var(--border2);
  border-radius:14px;font-size:14px;color:var(--muted2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;
  transition:border-color .15s,color .15s;
}
.prof-logout-btn:hover{color:#E53E3E;border-color:rgba(229,62,62,.3);}

/* ── Auth reduced motion ─────────────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  .auth-card{animation:none;}
}
