:root{
  --bg:#fbf7f4;          /* airy warm white */
  --bg-2:#f4eee9;        /* map area, light */
  --surface:#ffffff;
  --surface-2:#f7f2ee;
  --ink:#2d2722;         /* warm near-black */
  --ink-2:#988b80;       /* warm taupe muted */
  --ink-3:#c4b8ad;
  --line:rgba(45,39,34,0.08);
  --line-2:rgba(45,39,34,0.15);
  --accent:#d1735a;      /* fresh coral-terracotta */
  --accent-deep:#b6593c; /* legible on light */
  --accent-mid:#e08a72;
  --accent-soft:rgba(209,115,90,0.11);
  --accent-glow:rgba(209,115,90,0.20);
  --water:#e7eaea;       /* light, faintly cool (reads as water) */
  --park:#eaeadb;        /* light soft (parks) */
  --shadow:0 1px 2px rgba(45,39,34,.03), 0 6px 22px rgba(45,39,34,.05);
  --shadow-lg:0 2px 6px rgba(45,39,34,.04), 0 18px 46px rgba(45,39,34,.08);
  --r:18px;
  --mono:"Space Mono", ui-monospace, monospace;
  --disp:"Space Grotesk","Noto Sans SC", system-ui, sans-serif;
  --sans:"Space Grotesk","Noto Sans SC", system-ui, sans-serif;
}

*{box-sizing:border-box;}
html,body{margin:0;height:100%;}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow:hidden;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
.mono{font-family:var(--mono);}
.kicker{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-2);
}

/* ===== App shell ===== */
#app{
  position:fixed;inset:0;
  display:grid;
  grid-template-columns:1fr;
  grid-template-rows:1fr auto;
  grid-template-areas:"screens" "nav";
}
#screens{grid-area:screens;position:relative;min-height:0;}
.tab{
  position:absolute;inset:0;
  opacity:0;visibility:hidden;transition:opacity .4s ease;
  overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
}
.tab::-webkit-scrollbar{display:none;}
.tab.active{opacity:1;visibility:visible;}
.view{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .5s ease;}
.view.active{opacity:1;visibility:visible;}

/* ============================================================
   GLOBE VIEW
   ============================================================ */
#tab-globe{
  display:grid;overflow:hidden;
  grid-template-rows:auto auto 1fr auto;
  grid-template-columns:1fr;
  grid-template-areas:"top" "filter" "stage" "rail";
}
.topbar{grid-area:top;}
.country-filter-panel{grid-area:filter;}
.globe-stage{grid-area:stage;}
.lit-rail{grid-area:rail;}
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px 8px;
  gap:16px;
}
.brand{display:flex;align-items:center;gap:10px;}
.brand .dot{
  width:11px;height:11px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px var(--accent-glow);
}
.brand b{font-family:var(--disp);font-weight:700;font-size:16px;letter-spacing:-.01em;}
.brand span{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--ink-3);text-transform:uppercase;}
.counter{
  text-align:right;line-height:1;
}
.counter .big{font-family:var(--disp);font-weight:700;font-size:26px;letter-spacing:-.02em;}
.counter .big i{font-style:normal;color:var(--ink-3);font-weight:500;}
.counter small{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--ink-2);text-transform:uppercase;}
.demo-toggle{
  border:1px solid var(--line);
  border-radius:999px;
  padding:9px 13px;
  background:var(--surface);
  color:var(--ink);
  font-family:var(--mono);
  font-size:10px;
  font-weight:700;
  letter-spacing:.08em;
  box-shadow:var(--shadow);
  cursor:pointer;
  transition:transform .18s ease, background .18s ease, color .18s ease;
}
.demo-toggle:hover{transform:translateY(-1px);}
.demo-toggle.on{
  background:var(--accent);
  border-color:transparent;
  color:#fff;
}
.topbar-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.topbar-actions button[hidden]{display:none;}
.topbar-actions .demo-toggle,
.topbar-actions .country-filter-toggle{
  min-height:44px;
}
body.sample-mode .counter small::after{
  content:" · 样例";
  color:var(--accent-deep);
}

.globe-stage{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  min-height:0;
  overflow:hidden;
}
.globe-wrap{position:relative;touch-action:none;cursor:grab;}
.globe-wrap.dragging{cursor:grabbing;}
.globe-wrap canvas{position:absolute;inset:0;width:100%;height:100%;display:block;}

/* floating chips around the stage */
.legend-chips{
  position:absolute;left:18px;top:16px;
  display:flex;flex-direction:column;gap:8px;align-items:flex-start;
  z-index:5;
}
.chip{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;
  padding:7px 11px;border-radius:999px;
  background:var(--surface);border:1px solid var(--line);color:var(--ink-2);
  box-shadow:var(--shadow);
}
.chip i{width:10px;height:10px;border-radius:3px;background:transparent;border:1.5px solid var(--ink-3);display:inline-block;box-sizing:border-box;}
.chip.lit i{background:var(--accent);border-color:transparent;box-shadow:none;}
.chip.wish i{background:transparent;border:1.5px dashed var(--accent);}

.spin-hint{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--ink-3);
  text-transform:uppercase;pointer-events:none;z-index:5;
  opacity:0;animation:hintIn .6s ease .8s forwards;
}
@keyframes hintIn{to{opacity:1;}}

/* lit country cards rail */
.lit-rail{
  padding:6px 16px 14px;
  display:flex;gap:12px;overflow-x:auto;scrollbar-width:none;
}
.lit-rail::-webkit-scrollbar{display:none;}
.country-card{
  flex:0 0 auto;
  min-width:230px;
  text-align:left;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:16px 18px;
  box-shadow:var(--shadow);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  position:relative;overflow:hidden;
}
.country-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--line-2);}
.country-card .flagrow{display:flex;align-items:center;gap:9px;margin-bottom:12px;}
.country-card .flag{font-size:22px;line-height:1;}
.country-card .ctag{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent-deep);background:var(--accent-soft);
  padding:3px 7px;border-radius:6px;
}
.country-card h3{margin:0;font-family:var(--disp);font-weight:700;font-size:21px;letter-spacing:-.01em;}
.country-card p{margin:5px 0 14px;font-size:12.5px;color:var(--ink-2);line-height:1.5;}
.country-card .go{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);
}
.country-card .go .arrow{transition:transform .25s ease;}
.country-card:hover .go .arrow{transform:translateX(4px);}
.country-card .seam{position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow),transparent 70%);}

/* persistent bottom nav */
.bottomnav{
  grid-area:nav;
  display:flex;justify-content:space-around;align-items:stretch;
  padding:8px 6px calc(8px + env(safe-area-inset-bottom));
  border-top:1px solid var(--line);
  background:color-mix(in srgb, var(--surface) 90%, transparent);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  z-index:30;
}
.bottomnav button{
  position:relative;
  display:flex;flex-direction:column;align-items:center;gap:5px;
  font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--ink-3);
  padding:6px 8px;flex:1;transition:color .2s ease;
}
.bottomnav button .ic{width:24px;height:24px;display:grid;place-items:center;}
.bottomnav button .ic svg{width:23px;height:23px;fill:none;stroke:var(--ink-3);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease,transform .25s cubic-bezier(.2,.8,.2,1);}
.bottomnav button.on{color:var(--ink);}
.bottomnav button.on .ic svg{stroke:var(--accent);transform:translateY(-1px);}
.bottomnav button.on::after{content:"";position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:16px;height:2.5px;border-radius:2px;background:var(--accent);}
.bottomnav button:active .ic svg{transform:scale(.88);}

/* ============================================================
   FIELD GUIDE VIEW
   ============================================================ */
#view-guide{background:var(--bg);z-index:40;}
.guide-grid{
  position:absolute;inset:0;
  display:grid;
  grid-template-columns:minmax(340px,40%) 1fr;
}
.guide-editorial{
  padding:30px 34px;
  display:flex;flex-direction:column;
  overflow-y:auto;
  border-right:1px solid var(--line);
  background:var(--surface);
}
.guide-back{
  display:inline-flex;align-items:center;gap:9px;align-self:flex-start;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-2);padding:8px 0;margin-bottom:18px;
  transition:gap .2s ease,color .2s ease;
}
.guide-back:hover{gap:14px;color:var(--ink);}
.guide-head .kicker{display:flex;align-items:center;gap:10px;}
.guide-head .kicker .flag{font-size:15px;}
.guide-title{
  font-family:var(--disp);font-weight:700;
  font-size:clamp(40px,6vw,68px);line-height:.96;letter-spacing:-.03em;
  margin:14px 0 0;
}
.guide-title .district{display:block;color:var(--accent-deep);}
.guide-desc{
  margin:18px 0 0;max-width:38ch;
  font-size:14.5px;line-height:1.6;color:var(--ink-2);text-wrap:pretty;
}
.stats-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:14px;overflow:hidden;
  margin:26px 0 0;
}
.stat{background:var(--surface);min-height:82px;padding:16px 16px;}
.stat .v{font-family:var(--disp);font-weight:700;font-size:28px;letter-spacing:-.01em;line-height:1.08;}
.stat .v u{text-decoration:none;font-size:15px;color:var(--ink-2);font-weight:500;margin-left:3px;}
.stat .l{font-family:var(--mono);font-size:10px;line-height:1.35;letter-spacing:.08em;color:var(--ink-2);margin-top:8px;}

.guide-actions{margin-top:26px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.btn-go{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--accent);color:#faf2ec;
  font-family:var(--disp);font-weight:700;font-size:14px;
  padding:13px 20px;border-radius:12px;
  box-shadow:0 6px 18px rgba(209,115,90,.34);
  transition:transform .2s ease, box-shadow .2s ease;
}
.btn-go:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(209,115,90,.42);}
.btn-go .pulse{width:8px;height:8px;border-radius:50%;background:#faf2ec;animation:dotpulse 1.4s ease-in-out infinite;}
@keyframes dotpulse{0%,100%{opacity:.35;}50%{opacity:1;}}
.act-share{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--surface-2);color:var(--ink);
  border:1px solid var(--line);border-radius:12px;
  font-family:var(--disp);font-weight:700;font-size:14px;
  padding:13px 18px;
  transition:transform .2s ease,background .2s ease,border-color .2s ease;
}
.act-share:hover{transform:translateY(-2px);background:var(--surface);border-color:var(--line-2);}
.status-pill{
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-2);
  display:inline-flex;align-items:center;gap:8px;
}
.status-pill i{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);}

.guide-foot{margin-top:auto;padding-top:26px;}
.guide-foot .code{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--ink-3);}

/* map side */
.guide-map{position:relative;overflow:hidden;background:var(--bg-2);}
.guide-map canvas{position:absolute;inset:0;width:100%;height:100%;}
.map-overlay{position:absolute;inset:0;pointer-events:none;}
.map-overlay .map-legend{pointer-events:auto;}
.tips-layer{position:absolute;inset:0;pointer-events:none;}
.map-legend{
  position:absolute;left:22px;top:22px;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:14px 16px;box-shadow:var(--shadow);min-width:208px;
}
.map-legend .lh{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:10px;}
.map-legend .lrow{
  display:flex;align-items:center;gap:10px;padding:6px 0;
  opacity:0;transform:translateX(-8px);
}
.map-legend .lrow.in{opacity:1;transform:none;transition:all .45s cubic-bezier(.2,.7,.2,1);}
.map-legend .lrow .num{
  width:20px;height:20px;border-radius:50%;flex:0 0 auto;
  display:grid;place-items:center;
  font-family:var(--mono);font-size:11px;font-weight:700;
  background:var(--accent);color:#faf2ec;
}
.map-legend .lrow .nm{font-size:13px;font-weight:500;flex:1;}
.map-legend .lrow .mv{font-family:var(--mono);font-size:11px;color:var(--ink-2);}
.map-coord{
  position:absolute;right:20px;bottom:18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-2);
  background:var(--surface);border:1px solid var(--line);
  padding:7px 12px;border-radius:9px;box-shadow:var(--shadow);
}
.map-compass{
  position:absolute;right:20px;top:22px;
  width:42px;height:42px;border-radius:50%;
  background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);
  display:grid;place-items:center;font-family:var(--mono);font-size:10px;color:var(--ink-2);
}
.map-compass b{color:var(--ink);}

/* node tooltips drawn as DOM over canvas */
.node-tip{
  position:absolute;transform:translate(-50%,calc(-100% - 14px));
  background:var(--ink);color:#fff;
  border-radius:10px;padding:9px 12px;min-width:128px;
  box-shadow:var(--shadow-lg);pointer-events:none;
  opacity:0;transition:opacity .3s ease, transform .3s ease;
}
.node-tip.in{opacity:1;}
.node-tip .nt-t{font-family:var(--disp);font-weight:700;font-size:13px;}
.node-tip .nt-s{font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.7);margin-top:3px;}
.node-tip:after{content:"";position:absolute;left:50%;bottom:-6px;transform:translateX(-50%) rotate(45deg);width:12px;height:12px;background:var(--ink);}

/* ============================================================
   DRILL TRANSITION OVERLAY
   ============================================================ */
#drill-veil{
  position:fixed;inset:0;background:var(--bg);
  opacity:0;visibility:hidden;z-index:50;
  transition:opacity .45s ease;
}
#drill-veil.show{opacity:1;visibility:visible;}

/* ============================================================
   RESPONSIVE — mobile/app
   ============================================================ */
@media (max-width:860px){
  .guide-grid{grid-template-columns:1fr;grid-template-rows:auto 1fr;}
  .guide-editorial{
    border-right:none;border-bottom:1px solid var(--line);
    padding:24px 22px 22px;overflow:visible;
  }
  .guide-title{font-size:clamp(38px,13vw,60px);}
  .guide-foot{display:none;}
  .map-legend{left:14px;top:14px;min-width:0;padding:11px 13px;}
  .map-legend .nm{display:none;}
  .map-legend .lrow{gap:7px;}
  .stats-grid{margin-top:20px;}
}
@media (max-width:560px){
  .topbar{padding:16px 18px 6px;}
  .counter .big{font-size:22px;}
  .lit-rail{padding:6px 14px 12px;}
  .country-card{min-width:78vw;}
}

/* desktop: nav becomes left sidebar; globe tab two-column hero */
@media (min-width:1024px){
  #app{
    grid-template-columns:96px 1fr;grid-template-rows:1fr;
    grid-template-areas:"nav screens";
  }
  .bottomnav{
    flex-direction:column;justify-content:flex-start;gap:4px;
    border-top:none;border-right:1px solid var(--line);
    padding:26px 0;
  }
  .bottomnav button{flex:0 0 auto;padding:13px 6px;font-size:8.5px;}
  .bottomnav button.on::after{top:50%;left:-1px;transform:translateY(-50%);width:2.5px;height:18px;}

  #tab-globe{
    grid-template-columns:332px 1fr;
    grid-template-rows:auto auto 1fr;
    grid-template-areas:"top stage" "filter stage" "rail stage";
  }
  .topbar{
    flex-direction:column;align-items:flex-start;justify-content:flex-start;
    padding:34px 26px 0 34px;gap:15px;
  }
  .counter{text-align:left;}
  .counter .big{font-size:32px;}
  .topbar-actions{width:100%;gap:10px;}
  .topbar-actions .demo-toggle,
  .topbar-actions .country-filter-toggle{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:112px;
    padding:11px 12px;
    font-size:11px;
    text-align:center;
  }
  .topbar-actions .demo-toggle{min-width:126px;}
  .country-filter-panel{margin:10px 20px 0 34px;max-width:276px;}
  .lit-rail{
    flex-direction:column;overflow-y:auto;overflow-x:hidden;
    align-self:stretch;min-height:0;padding:14px 20px 24px 34px;max-width:332px;gap:12px;
  }
  .country-card{min-width:0;width:278px;}
}

/* ============================================================
   CONTENT TABS — explore / record / wish / me
   ============================================================ */
.screen{padding:26px 20px 36px;max-width:720px;margin:0 auto;}
.screen-head{margin-bottom:6px;}
.screen-head .kicker{display:block;margin-bottom:10px;}
.screen-head h1{font-family:var(--disp);font-weight:700;font-size:clamp(30px,8vw,44px);letter-spacing:-.025em;margin:0;line-height:1;}
.screen-head p{margin:10px 0 0;color:var(--ink-2);font-size:14px;line-height:1.55;max-width:42ch;text-wrap:pretty;}
.section-label{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin:28px 0 12px;}

.ph{background:repeating-linear-gradient(45deg,var(--surface-2),var(--surface-2) 7px,var(--bg-2) 7px,var(--bg-2) 14px);display:grid;place-items:center;color:var(--ink-3);font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-align:center;border-radius:12px;border:1px solid var(--line);padding:4px;}
.ph.photo-thumb{
  position:relative;overflow:hidden;place-items:end start;padding:8px;
  background-size:cover;background-position:center;color:#fff;border-color:rgba(255,255,255,.72);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.04);
}
.ph.photo-thumb::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(24,20,18,.03),rgba(24,20,18,.5));
}
.ph.photo-thumb span{
  position:relative;z-index:1;font-size:9px;font-weight:700;letter-spacing:.08em;
  text-shadow:0 1px 8px rgba(0,0,0,.45);
}

.cardlist{display:flex;flex-direction:column;gap:12px;}
.row-card{
  display:flex;gap:14px;align-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:12px;box-shadow:var(--shadow);text-align:left;width:100%;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.row-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--line-2);}
.row-card .thumb{width:74px;height:74px;flex:0 0 auto;}
.row-card .body{flex:1;min-width:0;}
.row-card .body .top{display:flex;align-items:baseline;gap:9px;flex-wrap:wrap;}
.row-card .body h4{margin:0;font-family:var(--disp);font-weight:700;font-size:17px;white-space:nowrap;}
.row-card .body .cc{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--ink-3);}
.row-card .body p{margin:5px 0 0;font-size:12.5px;color:var(--ink-2);line-height:1.45;}
.row-card .meta{display:flex;gap:6px;margin-top:9px;flex-wrap:wrap;}
.tagpill{font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;color:var(--ink-2);background:var(--surface-2);border:1px solid var(--line);padding:3px 8px;border-radius:999px;}
.tagpill.accent{color:var(--accent-deep);background:var(--accent-soft);border-color:transparent;}
.row-card .chev{color:var(--ink-3);flex:0 0 auto;font-family:var(--mono);}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.step{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:15px 14px;box-shadow:var(--shadow);}
.step .no{font-family:var(--mono);font-size:11px;color:var(--accent-deep);letter-spacing:.1em;}
.step h5{margin:12px 0 4px;font-family:var(--disp);font-weight:700;font-size:15px;}
.step p{margin:0;font-size:11.5px;color:var(--ink-2);line-height:1.45;}
.import-btn{
  margin-top:16px;width:100%;
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--accent);color:#faf2ec;font-family:var(--disp);font-weight:700;font-size:15px;
  padding:15px;border-radius:14px;box-shadow:0 8px 22px rgba(209,115,90,.30);
  transition:transform .2s ease,box-shadow .2s ease;
}
.import-btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(209,115,90,.4);}

.timeline{display:flex;flex-direction:column;}
.tl-item{display:flex;gap:14px;align-items:stretch;}
.tl-item .rail{display:flex;flex-direction:column;align-items:center;width:12px;flex:0 0 auto;}
.tl-item .rail .dot{width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);margin-top:18px;flex:0 0 auto;}
.tl-item .rail .ln{flex:1;width:2px;background:var(--line);margin:6px 0 0;}
.tl-item:last-child .rail .ln{display:none;}
.tl-card{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:14px;box-shadow:var(--shadow);text-align:left;width:100%;transition:transform .2s,box-shadow .2s,border-color .2s;}
.tl-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--line-2);}
.tl-card .when{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--ink-3);}
.tl-card h4{margin:6px 0 4px;font-family:var(--disp);font-weight:700;font-size:18px;}
.tl-card .sub{font-size:12.5px;color:var(--ink-2);}

.profile{display:flex;align-items:center;gap:16px;margin:2px 0 4px;}
.avatar{width:72px;height:72px;border-radius:50%;flex:0 0 auto;}
.profile h2{margin:0;font-family:var(--disp);font-weight:700;font-size:24px;letter-spacing:-.01em;}
.profile .handle{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.08em;margin-top:4px;}
.editable-avatar{
  cursor:pointer;
  overflow:hidden;
  background-size:cover;
  background-position:center;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;
}
.editable-avatar:hover{transform:translateY(-1px);border-color:var(--accent);box-shadow:var(--shadow);}
.editable-avatar.has-image span{
  align-self:flex-end;
  width:100%;
  padding:5px 6px;
  background:rgba(45,39,34,.54);
  color:#fff;
  font-size:9px;
}
.profile-file{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;}
.profile-main{min-width:0;flex:1;}
.profile-name-row{display:flex;align-items:center;gap:8px;min-width:0;}
.profile-name-row input{
  min-width:0;
  width:min(220px,100%);
  border:1px solid var(--line);
  border-radius:12px;
  background:var(--surface);
  color:var(--ink);
  font-family:var(--disp);
  font-size:22px;
  font-weight:700;
  letter-spacing:0;
  padding:8px 10px;
  outline:none;
}
.profile-name-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.profile-name-row button{
  flex:0 0 auto;
  border-radius:10px;
  background:var(--surface-2);
  border:1px solid var(--line);
  color:var(--accent-deep);
  font-family:var(--disp);
  font-size:12px;
  font-weight:700;
  padding:9px 12px;
}
.profile-name-row button:hover{border-color:var(--accent);background:var(--accent-soft);}
.statgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden;margin:22px 0;}
.statgrid .s{background:var(--surface);padding:16px 10px;text-align:center;}
.statgrid .s .n{font-family:var(--disp);font-weight:700;font-size:26px;letter-spacing:-.02em;line-height:1;}
.statgrid .s .t{font-family:var(--mono);font-size:9px;letter-spacing:.06em;color:var(--ink-2);margin-top:8px;}
.progress-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow);}
.progress-card .pt{display:flex;justify-content:space-between;align-items:baseline;}
.progress-card .pt b{font-family:var(--disp);font-weight:700;font-size:18px;white-space:nowrap;}
.progress-card .pt span{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em;}
.bar{height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-top:14px;border:1px solid var(--line);}
.bar i{display:block;height:100%;background:var(--accent);border-radius:999px;}
.lit-mini{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap;}
.lit-mini .lm{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-size:13px;font-weight:500;box-shadow:var(--shadow);white-space:nowrap;}
.lit-mini .lm .fl{font-size:16px;}

@media(min-width:1024px){
  .screen{max-width:760px;padding-top:42px;}
  .steps{gap:14px;}
  .statgrid .s .n{font-size:30px;}
}
@media(max-width:430px){
  .steps{grid-template-columns:1fr;}
  .statgrid{grid-template-columns:repeat(2,1fr);}
}

/* ============================================================
   COUNTRY VIEW — city list + map pins
   ============================================================ */
.city-list{display:flex;flex-direction:column;gap:10px;}
.city-row{
  display:flex;align-items:center;gap:14px;width:100%;text-align:left;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:14px 16px;box-shadow:var(--shadow);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.city-row:hover{transform:translateX(3px);box-shadow:var(--shadow-lg);border-color:var(--line-2);}
.city-row .cnum{
  width:26px;height:26px;flex:0 0 auto;border-radius:50%;
  display:grid;place-items:center;font-family:var(--mono);font-size:12px;font-weight:700;
  background:var(--accent);color:#fff;
}
.city-row .cbody{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;}
.city-row .cname{font-family:var(--disp);font-weight:700;font-size:18px;display:flex;align-items:baseline;gap:8px;}
.city-row .cname small{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;color:var(--ink-3);font-weight:400;}
.city-row .cmeta{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-2);}
.city-row .chev{color:var(--ink-3);font-family:var(--mono);}

.city-pins{position:absolute;inset:0;pointer-events:none;}
.city-pin{
  position:absolute;transform:translate(-50%,-100%);pointer-events:auto;
  display:flex;flex-direction:column;align-items:center;gap:0;
  opacity:0;transition:opacity .45s ease, transform .45s cubic-bezier(.2,1.3,.4,1);
  transform:translate(-50%,calc(-100% + 8px));
}
.city-pin.in{opacity:1;transform:translate(-50%,-100%);}
.city-pin .pin-label{
  order:-1;margin-bottom:5px;white-space:nowrap;
  background:var(--surface);border:1px solid var(--line);border-radius:999px;
  padding:5px 11px;font-family:var(--disp);font-weight:700;font-size:13px;color:var(--ink);
  box-shadow:var(--shadow);display:flex;align-items:center;gap:7px;
}
.city-pin .pin-label i{font-family:var(--mono);font-style:normal;font-size:9.5px;letter-spacing:.04em;color:var(--accent-deep);background:var(--accent-soft);padding:2px 6px;border-radius:6px;}
.city-pin .pin-dot{
  width:15px;height:15px;border-radius:50% 50% 50% 0;transform:rotate(45deg);
  background:var(--accent);border:2px solid var(--surface);
  box-shadow:0 3px 8px rgba(209,115,90,.5);
}
.city-pin:hover .pin-dot{background:var(--accent-deep);}
.city-pin:hover .pin-label{border-color:var(--accent);}

/* ============================================================
   CITY VIEW — visitor segmented + trip chips
   ============================================================ */
.seg{
  display:inline-flex;gap:3px;margin-top:18px;padding:3px;
  background:var(--surface-2);border:1px solid var(--line);border-radius:999px;align-self:flex-start;
  flex-wrap:wrap;
}
.seg-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 13px 7px 7px;border-radius:999px;
  font-family:var(--disp);font-weight:600;font-size:13px;color:var(--ink-2);
  transition:background .2s ease,color .2s ease;
}
.seg-btn .seg-av{
  width:22px;height:22px;border-radius:50%;display:grid;place-items:center;
  background:var(--bg-2);color:var(--ink-2);font-size:11px;font-weight:700;
}
.seg-btn.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow);}
.seg-btn.on .seg-av{background:var(--accent);color:#fff;}

.trip-chips{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap;}
.trip-chip{
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;
  padding:8px 14px;border-radius:12px;
  background:var(--surface);border:1px solid var(--line);
  font-family:var(--disp);font-weight:700;font-size:13px;color:var(--ink-2);
  transition:all .2s ease;
}
.trip-chip small{font-family:var(--mono);font-weight:400;font-size:9.5px;letter-spacing:.08em;color:var(--ink-3);}
.trip-chip.on{border-color:var(--accent);color:var(--ink);box-shadow:0 4px 12px rgba(209,115,90,.18);}
.trip-chip.on small{color:var(--accent-deep);}

/* friend route legend tint */
.map-legend.friend .lrow .num{background:#5b7aa8;}

/* ============================================================
   ACHIEVEMENTS + FRIENDS (me tab)
   ============================================================ */
.ach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:6px;}
.ach{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:15px 12px;text-align:center;box-shadow:var(--shadow);
}
.ach.locked{opacity:.55;filter:saturate(.5);}
.ach-ic{font-size:26px;line-height:1;}
.ach-t{font-family:var(--disp);font-weight:700;font-size:13px;margin-top:9px;}
.ach-s{font-family:var(--mono);font-size:9.5px;letter-spacing:.03em;color:var(--ink-2);margin-top:5px;}
.ach.done .ach-s{color:var(--accent-deep);}
.ach-toggle{
  width:100%;
  min-height:44px;
  margin:8px 0 6px;
  border-radius:12px;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--accent-deep);
  font-family:var(--disp);
  font-weight:700;
  font-size:13px;
  box-shadow:var(--shadow);
  transition:transform .18s ease,border-color .18s ease,background .18s ease;
}
.ach-toggle:hover{transform:translateY(-1px);border-color:var(--accent);background:var(--accent-soft);}

.avatar-sm{width:54px;height:54px;border-radius:50%;font-size:18px;font-weight:700;color:var(--ink-2);}
.row-card.friend .ph.avatar-sm{background:var(--accent-soft);color:var(--accent-deep);border-color:transparent;}

@media(max-width:430px){
  .ach-grid{grid-template-columns:repeat(2,1fr);}
}

/* ============================================================
   ACHIEVEMENT badge + tap feedback
   ============================================================ */
.ach{position:relative;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;}
.ach:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.ach.pop{animation:achpop .4s ease;}
@keyframes achpop{0%{transform:scale(1);}40%{transform:scale(1.06);}100%{transform:scale(1);}}
.ach-badge{
  margin-top:8px;font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;
  display:inline-block;padding:2px 8px;border-radius:999px;
  background:var(--accent-soft);color:var(--accent-deep);
}
.ach.locked .ach-badge{background:var(--surface-2);color:var(--ink-3);}

/* ============================================================
   FRIENDS — compact entry (me tab)
   ============================================================ */
.friends-card{
  display:flex;align-items:center;gap:16px;width:100%;text-align:left;
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:16px 18px;box-shadow:var(--shadow);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.friends-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--accent);}
.fav-stack{display:flex;flex:0 0 auto;}
.fav-stack .fav{
  width:38px;height:38px;border-radius:50%;margin-left:-10px;
  display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:14px;
  background:var(--accent-soft);color:var(--accent-deep);border:2px solid var(--surface);
}
.fav-stack .fav:first-child{margin-left:0;}
.friends-card .fbody{flex:1;min-width:0;}
.friends-card .fbody h4{margin:0;font-family:var(--disp);font-weight:700;font-size:18px;display:flex;align-items:baseline;gap:8px;}
.friends-card .fbody h4 span{font-family:var(--mono);font-size:12px;color:var(--accent-deep);background:var(--accent-soft);padding:1px 8px;border-radius:999px;}
.friends-card .fbody p{margin:4px 0 0;font-size:12.5px;color:var(--ink-2);}
.friends-card .chev{color:var(--ink-3);font-family:var(--mono);}

/* ============================================================
   FRIENDS LIST + PROFILE overlays
   ============================================================ */
#view-friends, #view-profile{background:var(--bg);z-index:40;}
.friends-screen{position:absolute;inset:0;overflow-y:auto;padding:30px 24px 40px;max-width:880px;margin:0 auto;}
.friends-screen .guide-back{margin-bottom:14px;}
.friends-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-top:18px;}
.friend-tile{
  text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:22px 14px 18px;box-shadow:var(--shadow);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.friend-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent);}
.avatar-md{width:60px;height:60px;border-radius:50%;margin:0 auto 12px;display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:22px;background:var(--accent-soft);color:var(--accent-deep);}
.ft-name{font-family:var(--disp);font-weight:700;font-size:17px;}
.ft-handle{font-family:var(--mono);font-size:10px;color:var(--ink-3);margin-top:3px;}
.ft-meta{font-family:var(--mono);font-size:10.5px;color:var(--accent-deep);margin-top:10px;}
.ft-places{font-size:11.5px;color:var(--ink-2);margin-top:6px;line-height:1.4;}

/* friend profile */
.profile-head{display:flex;align-items:center;gap:16px;margin:6px 0 4px;}
.avatar-lg{width:74px;height:74px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:28px;background:var(--accent-soft);color:var(--accent-deep);}
.profile-name{margin:0;font-family:var(--disp);font-weight:700;font-size:34px;letter-spacing:-.02em;}
.profile-handle{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em;margin-top:5px;}
.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin:22px 0 4px;}
.profile-stats>div{background:var(--surface);padding:15px 10px;text-align:center;}
.profile-stats b{display:block;font-family:var(--disp);font-weight:700;font-size:26px;letter-spacing:-.02em;}
.profile-stats span{font-family:var(--mono);font-size:9px;letter-spacing:.05em;color:var(--ink-2);margin-top:6px;display:block;}
.country-pick{display:flex;flex-direction:column;gap:9px;}
.cpick{
  display:flex;align-items:center;gap:13px;width:100%;text-align:left;
  background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:13px 15px;box-shadow:var(--shadow);
  transition:transform .2s ease,border-color .2s ease;
}
.cpick.has{cursor:pointer;}
.cpick.has:hover,.cpick.has:focus-visible{transform:translateX(3px);border-color:var(--accent);outline:none;box-shadow:var(--shadow-lg);}
.cpick.soon{opacity:.5;cursor:default;}
.cpick .cp-dot{width:11px;height:11px;border-radius:3px;flex:0 0 auto;background:var(--accent);}
.cpick.soon .cp-dot{background:transparent;border:1.5px dashed var(--ink-3);}
.cpick .cp-name{flex:1;font-family:var(--disp);font-weight:700;font-size:16px;display:flex;align-items:baseline;gap:8px;}
.cpick .cp-name small{font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--ink-3);font-weight:400;}
.cpick .cp-meta{font-family:var(--mono);font-size:10px;color:var(--ink-2);}
.profile-map{background:var(--bg-2);}
.profile-map .globe-stage{position:absolute;inset:0;}

@media(max-width:860px){
  .profile-map{min-height:42vh;}
  .friends-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));}
}

/* ============================================================
   MAPBOX (when token set)
   ============================================================ */
#mbx{position:absolute;inset:0;display:none;}
.mbx-pin{
  width:26px;height:26px;border-radius:50%;display:grid;place-items:center;
  background:#d1735a;color:#fff;font-family:"Space Mono",monospace;font-weight:700;font-size:12px;
  border:2px solid #fff;box-shadow:0 2px 8px rgba(45,39,34,.35);
}
.mbx-pin.friend{background:#5b7aa8;}

/* ============================================================
   IMPORT SCAN overlay + TOAST
   ============================================================ */
#scan-overlay{
  position:fixed;inset:0;z-index:60;display:none;
  background:rgba(45,39,34,0.32);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  align-items:center;justify-content:center;
}
#scan-overlay.show{display:flex;}
.scan-card{
  width:min(86vw,360px);background:var(--surface);border:1px solid var(--line);
  border-radius:20px;padding:28px 26px;box-shadow:var(--shadow-lg);text-align:center;
  animation:scanin .35s cubic-bezier(.2,1,.3,1);
}
@keyframes scanin{from{opacity:0;transform:translateY(14px) scale(.97);}to{opacity:1;transform:none;}}
.scan-ic{font-size:34px;}
.scan-card h3{font-family:var(--disp);font-weight:700;font-size:18px;margin:10px 0 18px;}
.scan-bar{height:8px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);overflow:hidden;}
.scan-bar i{display:block;height:100%;width:0;background:var(--accent);border-radius:999px;transition:width .4s ease;}
.scan-pct{font-family:var(--mono);font-size:11px;color:var(--accent-deep);margin-top:8px;letter-spacing:.08em;}
.scan-log{margin-top:14px;text-align:left;min-height:96px;}
.scan-line{font-family:var(--mono);font-size:11px;color:var(--ink-2);padding:3px 0;animation:scanline .3s ease;}
@keyframes scanline{from{opacity:0;transform:translateX(-6px);}to{opacity:1;transform:none;}}

.lm-toast{
  position:fixed;left:50%;bottom:88px;transform:translate(-50%,20px);
  z-index:70;background:var(--ink);color:#fff;border-radius:14px;
  padding:12px 18px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;
  transition:opacity .3s ease,transform .3s ease;display:flex;flex-direction:column;gap:3px;min-width:200px;max-width:80vw;
}
.lm-toast.show{opacity:1;transform:translate(-50%,0);}
.lm-toast b{font-family:var(--disp);font-weight:700;font-size:14px;}
.lm-toast span{font-family:var(--mono);font-size:10.5px;color:rgba(255,255,255,.7);}
@media(min-width:1024px){ .lm-toast{bottom:32px;} }

/* ============================================================
   ROUTE LIBRARY cards (探索/路线 tab)
   ============================================================ */
.route-card{
  display:flex;flex-direction:column;gap:0;width:100%;text-align:left;
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.route-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--line-2);}
.route-card .rc-main{display:flex;gap:14px;align-items:center;padding:12px;}
.route-card .thumb{width:72px;height:72px;flex:0 0 auto;}
.route-card .body{flex:1;min-width:0;}
.route-card .body .top h4{margin:0;font-family:var(--disp);font-weight:700;font-size:18px;}
.route-card .cc{font-family:var(--mono);font-size:11px;color:var(--ink-2);margin-top:4px;}
.route-card .meta{display:flex;gap:6px;margin-top:9px;flex-wrap:wrap;}
.rc-actions{display:flex;border-top:1px solid var(--line);}
.rc-actions button{
  flex:1;padding:12px;font-family:var(--disp);font-weight:700;font-size:13px;color:var(--ink);
  transition:background .18s ease;
}
.rc-actions .rc-open{border-right:1px solid var(--line);}
.rc-actions button:hover{background:var(--surface-2);}
.rc-actions .rc-share{color:var(--accent-deep);}

.empty-card{
  width:100%;padding:24px;border:1px solid var(--line);border-radius:18px;
  background:var(--surface);box-shadow:var(--shadow);color:var(--ink-2);
}
.empty-card h4{margin:0 0 8px;font-family:var(--disp);font-size:20px;color:var(--ink);}
.empty-card p{margin:0;font-size:13px;line-height:1.55;}

.auth-status{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--ink-2);text-transform:uppercase;}
.auth-status .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);}

.account-social-card{
  background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:18px;box-shadow:var(--shadow);margin:0 0 22px;
}
.asc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;}
.auth-status.small{font-size:9.5px;}
.account-social-card h3{margin:10px 0 6px;font-family:var(--disp);font-size:20px;line-height:1.15;}
.account-social-card p{margin:0;color:var(--ink-2);font-size:12.5px;line-height:1.55;max-width:45ch;}
.account-id{
  flex:0 0 auto;font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--accent-deep);
  background:var(--accent-soft);border-radius:999px;padding:7px 10px;border:1px solid transparent;
}
.account-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-top:16px;}
.account-actions button{
  min-height:42px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);
  color:var(--ink);font-family:var(--disp);font-weight:700;font-size:12.5px;
  transition:transform .18s ease,background .18s ease,border-color .18s ease;
}
.account-actions button:first-child{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 8px 18px rgba(209,115,90,.24);}
.account-actions button:hover{transform:translateY(-1px);border-color:var(--accent);}
.invite-preview{
  margin-top:10px;padding:10px 12px;border-radius:12px;background:var(--bg);
  border:1px dashed var(--line-2);font-family:var(--mono);font-size:10px;color:var(--ink-3);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
@media(max-width:430px){
  .asc-head{flex-direction:column;}
  .account-actions{grid-template-columns:1fr;}
}

/* ============================================================
   friend → wishlist buttons
   ============================================================ */
.cp-go-wish{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:10px;flex:0 0 auto;
  background:rgba(209,115,90,.10);border:1px solid rgba(209,115,90,.20);
  color:var(--accent);cursor:pointer;
  transition:transform .18s ease,background .18s ease,box-shadow .18s ease;
}
.cp-go-wish:hover{
  transform:translateY(-2px);
  background:rgba(209,115,90,.18);
  box-shadow:0 6px 16px rgba(209,115,90,.22);
}
.cp-go-wish svg{width:15px;height:15px;}
.cpick .cp-wish, .act-wish{
  font-family:var(--disp);font-weight:700;font-size:12.5px;color:var(--accent-deep);
  background:var(--accent-soft);border:1px solid transparent;border-radius:10px;padding:7px 12px;white-space:nowrap;
  transition:background .18s ease;
}
.cpick .cp-wish:hover, .act-wish:hover{background:var(--accent);color:#fff;}
.cpick .cp-wish.added{background:var(--surface-2);color:var(--ink-3);}
.act-wish{padding:11px 16px;border-radius:12px;}
.cpick.mine .cp-dot{background:var(--accent);}

/* ============================================================
   IMPORT confirm step
   ============================================================ */
.scan-sub{font-size:13px;color:var(--ink-2);line-height:1.5;margin:0 0 16px;}
.confirm-card{
  display:flex;align-items:center;gap:13px;text-align:left;
  background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:18px;
}
.confirm-card .cc-flag{font-size:26px;}
.confirm-card .cc-body{display:flex;flex-direction:column;gap:3px;}
.confirm-card .cc-body b{font-family:var(--disp);font-weight:700;font-size:16px;}
.confirm-card .cc-body span{font-family:var(--mono);font-size:11px;color:var(--ink-2);}
.confirm-actions{display:flex;gap:10px;}
.confirm-actions button{flex:1;padding:13px;border-radius:12px;font-family:var(--disp);font-weight:700;font-size:14px;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;}
#scan-cancel{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line);}
#scan-cancel:hover{background:var(--bg-2);}
#scan-add{background:var(--accent);color:#fff;box-shadow:0 6px 18px rgba(209,115,90,.3);}
#scan-add:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(209,115,90,.4);}

/* map attention pulse */
@keyframes map-pulse-ring{0%{box-shadow:0 0 0 0 rgba(209,115,90,.5);}70%{box-shadow:0 0 0 18px rgba(209,115,90,0);}100%{box-shadow:0 0 0 0 rgba(209,115,90,0);}}
#mbx.map-pulse{animation:map-pulse-ring .6s ease;}

/* ============================================================
   ONBOARDING OVERLAY
   ============================================================ */
.onboarding-overlay{
  position:fixed;inset:0;z-index:100;
  display:flex;align-items:center;justify-content:center;
  background:rgba(45,39,34,.54);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  animation:ob-fade-in .4s ease both;
}
.onboarding-overlay[hidden]{display:none;}
@keyframes ob-fade-in{from{opacity:0;}to{opacity:1;}}

.onboarding-card{
  position:relative;
  width:min(420px,calc(100vw - 32px));
  background:var(--surface);
  border:1px solid rgba(255,255,255,.9);
  border-radius:28px;
  box-shadow:0 32px 80px rgba(45,39,34,.22);
  overflow:hidden;
  animation:ob-card-in .48s cubic-bezier(.18,.9,.2,1) both;
}
@keyframes ob-card-in{from{opacity:0;transform:translateY(28px) scale(.97);}to{opacity:1;transform:none;}}

.onboarding-slides{
  position:relative;
  overflow:hidden;
}

.ob-slide{
  display:none;
  flex-direction:column;
  align-items:flex-start;
  gap:14px;
  padding:40px 36px 28px;
}
.ob-slide.active{display:flex;}

.ob-icon{font-size:46px;line-height:1;margin-bottom:4px;}
.ob-kicker{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent-deep);font-weight:700;
}
.ob-slide h2{
  margin:0;
  font-family:var(--disp);font-weight:700;font-size:clamp(22px,5vw,28px);
  line-height:1.12;letter-spacing:-.02em;color:var(--ink);
}
.ob-slide p{
  margin:0;font-size:14px;line-height:1.65;color:var(--ink-2);max-width:34ch;
}

.onboarding-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 36px 30px;
  border-top:1px solid var(--line);
  background:var(--surface-2);
}

.ob-dots{display:flex;gap:7px;align-items:center;}
.ob-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--ink-3);opacity:.35;
  transition:opacity .25s ease,width .25s ease,background .25s ease;
}
.ob-dot.active{width:20px;border-radius:4px;background:var(--accent);opacity:1;}

.ob-actions{display:flex;gap:10px;align-items:center;}
.ob-skip{
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;
  color:var(--ink-2);padding:8px 12px;border-radius:9px;
  transition:color .18s ease,background .18s ease;
}
.ob-skip:hover{color:var(--ink);background:var(--surface);}
.ob-next{
  font-family:var(--disp);font-weight:700;font-size:14px;
  background:var(--accent);color:#fff;
  padding:11px 22px;border-radius:12px;
  box-shadow:0 6px 18px rgba(209,115,90,.28);
  transition:transform .18s ease,box-shadow .18s ease;
}

/* ============================================================
   ★ DESIGN REFRESH — layered depth, glow, hierarchy
   ============================================================ */

/* 1. BACKGROUND — atmospheric multi-layer depth */
body{
  background:
    radial-gradient(ellipse 100% 55% at 50% -8%, rgba(242,143,124,.07) 0%, transparent 65%),
    radial-gradient(ellipse 65% 55% at 92% 96%, rgba(125,181,202,.08) 0%, transparent 58%),
    radial-gradient(ellipse 50% 45% at 8% 80%, rgba(230,185,93,.05) 0%, transparent 55%),
    linear-gradient(158deg, #fdf9f5 0%, #f9f4ee 42%, #f2ece7 100%);
}

/* 2. GLOBE STAGE — warm atmospheric glow behind the sphere */
.globe-stage{
  isolation:isolate;
  overflow:visible;  /* allow drop-shadow and glow to spill out */
}
.globe-stage::before{
  content:"";
  position:absolute;
  inset:-18%;
  background:
    radial-gradient(ellipse 70% 65% at 52% 52%,
      rgba(209,115,90,.09) 0%,
      rgba(125,181,202,.07) 42%,
      transparent 70%);
  pointer-events:none;
  z-index:0;
  animation:globe-pulse-bg 5s ease-in-out infinite alternate;
}
@keyframes globe-pulse-bg{
  from{opacity:.7;}
  to{opacity:1;}
}

/* 3. GLOBE WRAP — outer atmospheric glow + depth shadow */
.globe-wrap{
  filter:
    drop-shadow(0 0 36px rgba(125,181,202,.22))
    drop-shadow(0 28px 56px rgba(45,39,34,.16))
    drop-shadow(0 0 80px rgba(209,115,90,.10));
  z-index:1;
}

/* 4. TOPBAR — frosted glass, not flat */
.topbar{
  background:rgba(253,249,245,.78);
  border-bottom:1px solid rgba(255,255,255,.7);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
}
/* desktop topbar gets a subtle left border accent */
@media(min-width:1024px){
  .topbar{
    border-bottom:none;
    border-right:1px solid rgba(45,39,34,.06);
    background:rgba(253,249,245,.88);
  }
}

/* 5. COUNTER — stronger number hierarchy */
.counter .big{
  background:linear-gradient(135deg, var(--ink) 0%, var(--accent-deep) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* 6. LEGEND CHIPS — frosted glass treatment */
.chip{
  background:rgba(255,252,246,.85);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:0 4px 14px rgba(45,39,34,.07), inset 0 1px 0 rgba(255,255,255,.8);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  font-weight:600;
}
.chip.lit{
  background:rgba(255,248,242,.92);
  border-color:rgba(209,115,90,.18);
  color:var(--accent-deep);
}
.chip.wish{
  border-color:rgba(209,115,90,.22);
  color:var(--accent-deep);
}

/* 7. SPIN HINT — more visible */
.spin-hint{
  background:rgba(253,249,245,.7);
  border:1px solid rgba(255,255,255,.7);
  border-radius:999px;
  padding:6px 14px;
  backdrop-filter:blur(12px);
  letter-spacing:.14em;
}

/* 8. COUNTRY CARDS (lit-rail) — more depth, warmer gradient */
.country-card{
  background:linear-gradient(148deg, #ffffff 0%, #fdf9f5 100%);
  box-shadow:
    0 1px 2px rgba(45,39,34,.03),
    0 8px 28px rgba(45,39,34,.08),
    inset 0 1px 0 rgba(255,255,255,.9);
  border-color:rgba(45,39,34,.06);
}
.country-card:hover{
  transform:translateY(-5px);
  box-shadow:
    0 4px 8px rgba(45,39,34,.04),
    0 24px 52px rgba(45,39,34,.13),
    inset 0 1px 0 rgba(255,255,255,.9);
  border-color:rgba(209,115,90,.2);
}
.country-card h3{
  font-size:23px;
  letter-spacing:-.02em;
}
.country-card p{
  font-size:12px;
  line-height:1.6;
}

/* 9. BOTTOM NAV — floating capsule active state */
.bottomnav{
  background:rgba(252,248,243,.94);
  border-top:1px solid rgba(255,255,255,.7);
  box-shadow:0 -8px 32px rgba(45,39,34,.08), 0 -1px 0 rgba(255,255,255,.6);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
}
@media(min-width:1024px){
  .bottomnav{
    background:rgba(252,248,243,.96);
    border-right:1px solid rgba(45,39,34,.06);
    box-shadow:none;
  }
}

/* kill old line indicator */
.bottomnav button.on::after{ content:none !important; display:none !important; }

/* floating capsule behind active button */
.bottomnav button{
  z-index:0;
  border-radius:16px;
  transition:color .2s ease;
}
.bottomnav button.on::before{
  content:"";
  position:absolute;
  inset:2px 3px;
  border-radius:14px;
  background:rgba(255,255,255,.97);
  box-shadow:
    0 4px 14px rgba(45,39,34,.13),
    0 1px 3px rgba(45,39,34,.07),
    inset 0 1px 0 rgba(255,255,255,.9);
  z-index:-1;
  animation:capsule-pop .24s cubic-bezier(.2,.9,.25,1) both;
}
@keyframes capsule-pop{
  from{transform:scale(.82);opacity:0;}
  to{transform:scale(1);opacity:1;}
}

/* active icon — coral + glow + tiny lift */
.bottomnav button.on .ic svg{
  stroke:var(--accent);
  filter:drop-shadow(0 0 5px rgba(209,115,90,.42));
  transform:translateY(-1px);
  transition:all .22s cubic-bezier(.2,.9,.25,1);
}
.bottomnav button.on{
  color:var(--ink);
  font-weight:700;
}

/* desktop sidebar: capsule goes full-width */
@media(min-width:1024px){
  .bottomnav button{border-radius:14px;}
  .bottomnav button.on::before{
    inset:3px 8px;
    border-radius:12px;
  }
}

/* 10. ROUTE CARDS — more visual weight, image-forward */
.route-card{
  background:linear-gradient(148deg, #ffffff 0%, #fdf9f5 100%);
  box-shadow:
    0 1px 2px rgba(45,39,34,.03),
    0 8px 28px rgba(45,39,34,.08),
    inset 0 1px 0 rgba(255,255,255,.9);
  border-color:rgba(45,39,34,.06);
  border-radius:18px;
}
.route-card:hover{
  transform:translateY(-4px);
  box-shadow:
    0 4px 8px rgba(45,39,34,.04),
    0 22px 48px rgba(45,39,34,.13);
  border-color:rgba(209,115,90,.18);
}
.route-card .thumb{
  width:80px;height:80px;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 4px 12px rgba(45,39,34,.12);
}
.route-card .body .top h4{
  font-size:19px;
  letter-spacing:-.02em;
}
.rc-actions{
  background:rgba(248,243,236,.6);
  border-top:1px solid rgba(45,39,34,.05);
}
.rc-actions button{
  font-size:12px;
  font-weight:700;
  letter-spacing:.02em;
  color:var(--ink-2);
  padding:14px;
}
.rc-actions .rc-share{
  color:var(--accent);
  font-weight:800;
}

/* 11. ROW CARDS (wish / record tabs) */
.row-card{
  background:linear-gradient(148deg, #ffffff 0%, #fdf9f5 100%);
  box-shadow:
    0 1px 2px rgba(45,39,34,.03),
    0 8px 28px rgba(45,39,34,.07),
    inset 0 1px 0 rgba(255,255,255,.9);
  border-color:rgba(45,39,34,.06);
}
.row-card:hover{
  transform:translateY(-4px);
  box-shadow:
    0 4px 8px rgba(45,39,34,.04),
    0 20px 44px rgba(45,39,34,.12);
  border-color:rgba(209,115,90,.18);
}

/* 12. TAGPILL — more refined */
.tagpill{
  background:rgba(248,244,238,.9);
  border-color:rgba(45,39,34,.07);
  font-size:9px;
  letter-spacing:.07em;
  padding:4px 9px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
}
.tagpill.accent{
  background:rgba(209,115,90,.1);
  color:var(--accent-deep);
  border-color:rgba(209,115,90,.15);
}

/* 13. SCREEN TABS — subtle background to differentiate from main */
.screen{
  background:transparent;
}
.tab{
  background:
    radial-gradient(ellipse 80% 40% at 50% 0%, rgba(242,143,124,.04) 0%, transparent 60%),
    transparent;
}

/* 14. SECTION LABEL — more breathing room */
.section-label{
  margin:34px 0 14px;
  font-size:9.5px;
  letter-spacing:.2em;
  opacity:.7;
}

/* 15. IMPORT BUTTON — enhanced glow */
.import-btn{
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-mid) 100%);
  box-shadow:0 10px 28px rgba(209,115,90,.32), inset 0 1px 0 rgba(255,255,255,.18);
  letter-spacing:.01em;
}
.import-btn:hover{
  box-shadow:0 16px 38px rgba(209,115,90,.44), inset 0 1px 0 rgba(255,255,255,.22);
}

/* 16. ONBOARDING — icon container, warmer overlay, stronger title */
.onboarding-overlay{
  background:rgba(30,24,20,.48);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}
.onboarding-card{
  background:linear-gradient(158deg, #ffffff 0%, #fdf8f2 100%);
  border:1px solid rgba(255,255,255,.95);
  box-shadow:
    0 4px 16px rgba(45,39,34,.08),
    0 40px 96px rgba(45,39,34,.26),
    inset 0 1px 0 rgba(255,255,255,.9);
  border-radius:32px;
}
.ob-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:68px;
  height:68px;
  border-radius:20px;
  background:linear-gradient(135deg, rgba(209,115,90,.13) 0%, rgba(230,185,93,.08) 100%);
  border:1px solid rgba(209,115,90,.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 8px 20px rgba(209,115,90,.12);
  font-size:34px;
  line-height:1;
  margin-bottom:2px;
}
.ob-slide{
  padding:44px 40px 30px;
  gap:12px;
}
.ob-slide h2{
  font-size:clamp(24px,5vw,30px);
  letter-spacing:-.03em;
  line-height:1.05;
}
.ob-kicker{
  color:var(--accent);
  letter-spacing:.18em;
  font-size:9.5px;
}
.onboarding-footer{
  background:rgba(249,244,237,.7);
  border-top:1px solid rgba(45,39,34,.06);
  padding:20px 40px 34px;
  backdrop-filter:blur(8px);
}
.ob-dot{
  background:rgba(45,39,34,.15);
  opacity:1;
}
.ob-dot.active{
  width:22px;
  border-radius:5px;
  background:var(--accent);
  box-shadow:0 0 10px rgba(209,115,90,.45);
}
.ob-next{
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-mid) 100%);
  border-radius:14px;
  padding:12px 26px;
  font-size:14px;
  letter-spacing:.01em;
  box-shadow:0 8px 22px rgba(209,115,90,.34), inset 0 1px 0 rgba(255,255,255,.18);
}
.ob-next:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 32px rgba(209,115,90,.44);
}
.ob-skip{
  font-size:12px;
  color:rgba(45,39,34,.4);
  letter-spacing:.04em;
}

/* 17. GUIDE / FIELD GUIDE — elevated surfaces */
.guide-editorial{
  background:linear-gradient(158deg, #ffffff 0%, #fdf9f5 100%);
}
.btn-go{
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-mid) 100%);
  box-shadow:0 8px 22px rgba(209,115,90,.38), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-go:hover{
  box-shadow:0 14px 34px rgba(209,115,90,.48);
}
.stats-grid{
  background:transparent;
  border:1px solid rgba(45,39,34,.07);
  box-shadow:0 4px 16px rgba(45,39,34,.05);
}
.stat{
  background:linear-gradient(148deg, #ffffff 0%, #fdf9f5 100%);
}

/* 18. STEP CARDS (record tab) */
.step{
  background:linear-gradient(148deg, #ffffff 0%, #fdf9f5 100%);
  box-shadow:0 2px 8px rgba(45,39,34,.05), 0 12px 30px rgba(45,39,34,.07);
  border-color:rgba(45,39,34,.06);
  border-radius:16px;
}
.step .no{
  font-size:10px;
  letter-spacing:.15em;
  font-weight:800;
}

/* 19. ACCOUNT CARD (me tab) */
.account-social-card{
  background:linear-gradient(148deg, #ffffff 0%, #fdf9f5 100%);
  box-shadow:0 2px 8px rgba(45,39,34,.04), 0 14px 36px rgba(45,39,34,.08);
  border-color:rgba(45,39,34,.06);
}

/* 20. PROGRESS BAR */
.progress-card{
  background:linear-gradient(148deg, #ffffff 0%, #fdf9f5 100%);
  box-shadow:0 2px 8px rgba(45,39,34,.04), 0 14px 36px rgba(45,39,34,.08);
}

/* ============================================================
   END DESIGN REFRESH
   ============================================================ */
.ob-next:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(209,115,90,.38);}

/* ============================================================
   PATCH: Manual add, route filter, wish delete, lit-mini fold,
   scan confirm, import row, route delete, status dot
   ============================================================ */

/* -- import row (两个按钮并排) -- */
.import-row{display:flex;gap:10px;margin-bottom:4px;}
.import-btn{flex:1;}
.manual-btn{
  flex:0 0 auto;padding:0 20px;
  background:#f5f0eb;color:#2d2722;
  border:1.5px solid rgba(45,39,34,.14);
  border-radius:14px;font-size:15px;font-weight:600;
  cursor:pointer;white-space:nowrap;transition:background .15s,transform .1s;
}
.manual-btn:hover{background:#ede8e2;}
.manual-btn:active{transform:scale(.97);}

/* -- manual add overlay -- */
#manual-overlay{
  display:none;position:fixed;inset:0;z-index:600;
  background:rgba(45,39,34,.45);backdrop-filter:blur(6px);
  align-items:flex-end;justify-content:center;
}
#manual-overlay.show{display:flex;}
.manual-card{
  width:100%;max-width:480px;
  background:#fdf9f5;border-radius:24px 24px 0 0;
  padding:28px 24px 40px;box-shadow:0 -8px 40px rgba(45,39,34,.18);
  animation:slideUp .28s cubic-bezier(.32,1,.42,1);
}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.manual-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.manual-head h3{font-size:18px;font-weight:700;color:#2d2722;margin:0;}
.manual-close{
  width:32px;height:32px;border-radius:50%;
  background:#ede8e2;border:none;cursor:pointer;
  font-size:16px;color:#6b5e54;display:flex;align-items:center;justify-content:center;
}
.manual-form{display:flex;flex-direction:column;gap:14px;}
.manual-form label{
  font-size:12px;font-weight:700;color:#9a8880;letter-spacing:.06em;
  display:flex;flex-direction:column;gap:5px;position:relative;
}
.manual-form label small{font-weight:400;font-size:11px;}
.manual-form input{
  padding:11px 14px;border-radius:12px;
  border:1.5px solid rgba(45,39,34,.14);
  background:#fff;font-size:15px;color:#2d2722;
  font-family:inherit;outline:none;transition:border-color .15s;
}
.manual-form input:focus{border-color:#d1735a;}
.manual-form input.invalid{border-color:#c94f3d;background:#fff8f6;}
.manual-error{min-height:18px;margin:0;color:#c94f3d;font-size:12px;font-weight:700;}
.manual-suggest{
  position:absolute;top:100%;left:0;right:0;z-index:10;
  background:#fff;border-radius:12px;
  box-shadow:0 6px 24px rgba(45,39,34,.14);
  overflow:hidden;margin-top:2px;
}
.ms-item{
  display:block;width:100%;padding:11px 14px;text-align:left;
  border:none;background:none;font-size:14px;color:#2d2722;cursor:pointer;
}
.ms-item:hover{background:#fdf9f5;}
.manual-actions{display:flex;gap:10px;margin-top:20px;}
.manual-actions button{
  flex:1;padding:13px;border-radius:14px;font-size:15px;font-weight:600;
  cursor:pointer;border:none;transition:all .15s;
}
.manual-actions button:first-child{background:#ede8e2;color:#6b5e54;}
.manual-save-btn{background:#d1735a !important;color:#fff !important;}
.manual-save-btn:hover{background:#c26449 !important;transform:translateY(-1px);}

/* -- route filter chips -- */
.route-filter{
  display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;
  scrollbar-width:none;-ms-overflow-style:none;
}
.route-filter::-webkit-scrollbar{display:none;}
.rf-chip{
  flex:0 0 auto;padding:6px 14px;border-radius:20px;
  font-size:13px;font-weight:600;cursor:pointer;
  background:#f0ebe6;color:#6b5e54;border:1.5px solid transparent;
  transition:all .15s;white-space:nowrap;
}
.rf-chip span{
  display:inline-block;margin-left:4px;padding:1px 6px;border-radius:10px;
  background:rgba(45,39,34,.10);font-size:11px;
}
.rf-chip.on{background:#d1735a;color:#fff;border-color:#d1735a;}
.rf-chip.on span{background:rgba(255,255,255,.25);}

/* -- globe country continent filter -- */
.country-filter-toggle{
  align-self:center;
  padding:9px 14px;
  border:1px solid rgba(209,115,90,.22);
  border-radius:999px;
  background:#fff8f5;
  color:var(--accent-deep);
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  white-space:nowrap;
  box-shadow:0 8px 20px rgba(45,39,34,.06);
}
.country-filter-toggle:hover{border-color:var(--accent);transform:translateY(-1px);}
.country-filter-panel{
  margin:0 24px 12px;
  padding:14px;
  border:1px solid rgba(45,39,34,.08);
  border-radius:18px;
  background:rgba(255,255,255,.88);
  box-shadow:0 16px 36px rgba(45,39,34,.10);
}
.cf-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;}
.cf-head span{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  color:var(--ink-2);
  text-transform:uppercase;
}
.cf-close{
  border:0;
  background:#f0ebe6;
  color:var(--ink-2);
  border-radius:999px;
  padding:5px 10px;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
}
.cf-actions{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none;}
.cf-actions::-webkit-scrollbar{display:none;}
.cf-chip{
  flex:0 0 auto;
  border:1px solid rgba(45,39,34,.08);
  border-radius:999px;
  background:#f8f2ee;
  color:var(--ink-2);
  padding:7px 11px;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  white-space:nowrap;
}
.cf-chip span{margin-left:4px;color:var(--accent-deep);}
.cf-chip.on{background:var(--accent);border-color:var(--accent);color:#fff;}
.cf-chip.on span{color:#fff;}
.cf-groups{display:grid;gap:10px;max-height:260px;overflow:auto;padding-right:2px;}
.cf-group h4{
  display:flex;align-items:center;justify-content:space-between;
  margin:0 0 6px;
  color:var(--ink);
  font-size:13px;
}
.cf-group h4 span{font-family:var(--mono);font-size:11px;color:var(--ink-3);}
.cf-group div{display:flex;gap:7px;flex-wrap:wrap;}
.cf-country{
  border:1px solid rgba(45,39,34,.08);
  border-radius:12px;
  background:#fff;
  color:var(--ink);
  padding:7px 9px;
  font-size:13px;
  font-weight:800;
  cursor:pointer;
}
.cf-country span{margin-right:5px;}
.country-filter-empty{
  min-width:260px;
  padding:24px;
  border:1px dashed rgba(45,39,34,.18);
  border-radius:18px;
  color:var(--ink-3);
  font-size:13px;
  font-weight:700;
}
@media (min-width:1024px){
  #tab-globe .country-filter-panel{
    margin:10px 20px 0 34px;
    max-width:276px;
  }
}

/* -- route card delete button -- */
.rc-delete-wrap{position:relative;height:0;}
.rc-delete{
  position:absolute;top:10px;right:10px;z-index:2;
  width:26px;height:26px;border-radius:50%;
  background:rgba(209,115,90,0);color:rgba(45,39,34,.3);
  border:1.5px solid rgba(45,39,34,.12);font-size:14px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .18s;opacity:0;
}
.route-card:hover .rc-delete{opacity:1;}
.rc-delete.confirming{
  background:#d1735a;color:#fff;border-color:#d1735a;
  width:auto;padding:0 10px;border-radius:12px;font-size:11px;font-weight:700;
  opacity:1;white-space:nowrap;
}
.rc-delete:hover{background:rgba(209,115,90,.1);color:#d1735a;}

/* -- route card status dot -- */
.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:3px;}
.status-dot.album{background:#6aab7e;}
.status-dot.manual{background:#d1ac5a;}
.rc-main .body .top{display:flex;align-items:flex-start;gap:6px;}

/* -- wish delete -- */
.wish-item-wrap{position:relative;}
.wish-delete{
  position:absolute;top:50%;right:12px;transform:translateY(-50%);
  width:28px;height:28px;border-radius:50%;
  background:rgba(209,115,90,.08);color:#d1735a;
  border:1.5px solid rgba(209,115,90,.20);font-size:15px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .18s;
}
.wish-item-wrap:hover .wish-delete{opacity:1;}

/* -- lit-mini fold -- */
.lit-expand-btn{
  display:inline-block;margin-top:6px;padding:4px 12px;
  border-radius:12px;font-size:12px;font-weight:600;
  background:#f0ebe6;color:#6b5e54;border:none;cursor:pointer;
  transition:background .15s;
}
.lit-expand-btn:hover{background:#e6e0d8;}

/* -- lit-rail scroll hint (right fade) -- */
.lit-rail{position:relative;}

/* wish drill-in cover */
.wish-drill-cover{
  width:100%; height:160px; border-radius:14px;
  background-size:cover; background-position:center;
  margin:14px 0 12px;
  box-shadow:0 4px 16px rgba(45,39,34,.12);
}
.wish-meta-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}

/* wish detail buttons */
.act-wish-route{
  padding:12px 20px;border-radius:14px;
  background:#d1735a;color:#fff;border:none;
  font-size:14px;font-weight:700;cursor:pointer;
  display:flex;align-items:center;gap:8px;
  transition:background .15s,transform .1s;
}
.act-wish-route:hover{background:#c26449;transform:translateY(-1px);}
.act-wish-remove{
  padding:10px 18px;border-radius:12px;
  background:#f0ebe6;color:#9a8880;
  border:1.5px solid rgba(45,39,34,.10);
  font-size:13px;font-weight:600;cursor:pointer;
  transition:background .15s;
}
.act-wish-remove:hover{background:#e8e2db;color:#6b5e54;}

/* wish detail map placeholder */
.wish-map-placeholder{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;color:#c5bdb6;
}
.wish-map-placeholder span{font-size:32px;opacity:.5;}
.wish-map-placeholder p{font-size:15px;font-weight:600;margin:0;}
.wish-map-placeholder small{font-size:12px;opacity:.7;}
