/* ============================================================
   府城 ĐÀI NAM — Editorial-Luxury travel app
   Display: Fraunces (variable serif) · Body: Be Vietnam Pro
   Palette: rice-paper + temple vermillion + brass + jade
   Self-hosted fonts, warm tinted shadows, double-bezel cards,
   spring motion. All class hooks preserved.
   ============================================================ */

/* ---------- FONTS (self-hosted) ---------- */
@font-face{font-family:"Fraunces";font-style:normal;font-weight:100 900;font-display:swap;
  src:url("../assets/vendor/fonts/fraunces-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Fraunces";font-style:normal;font-weight:100 900;font-display:swap;
  src:url("../assets/vendor/fonts/fraunces-viet.woff2") format("woff2");
  unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB;}
@font-face{font-family:"Fraunces";font-style:italic;font-weight:100 900;font-display:swap;
  src:url("../assets/vendor/fonts/fraunces-italic-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2122,U+FEFF,U+FFFD;}
@font-face{font-family:"Be Vietnam Pro";font-style:normal;font-weight:400;font-display:swap;
  src:url("../assets/vendor/fonts/bvp-latin-400.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Be Vietnam Pro";font-style:normal;font-weight:400;font-display:swap;
  src:url("../assets/vendor/fonts/bvp-viet-400.woff2") format("woff2");
  unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB;}
@font-face{font-family:"Be Vietnam Pro";font-style:normal;font-weight:600;font-display:swap;
  src:url("../assets/vendor/fonts/bvp-latin-600.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Be Vietnam Pro";font-style:normal;font-weight:600;font-display:swap;
  src:url("../assets/vendor/fonts/bvp-viet-600.woff2") format("woff2");
  unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB;}
@font-face{font-family:"Be Vietnam Pro";font-style:normal;font-weight:700;font-display:swap;
  src:url("../assets/vendor/fonts/bvp-latin-700.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:"Be Vietnam Pro";font-style:normal;font-weight:700;font-display:swap;
  src:url("../assets/vendor/fonts/bvp-viet-700.woff2") format("woff2");
  unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB;}

/* ---------- TOKENS ---------- */
:root{
  --paper:#f3e7d0; --paper-2:#ecddc0; --card:#faf3e3; --card-2:#f4ead2;
  --ink:#2a2018; --ink-soft:#6a5942; --ink-mute:#9a8867;
  --cinnabar:#b5342a; --cinnabar-d:#8c281f; --cinnabar-soft:#fbeee2;
  --brass:#a9772e; --brass-l:#c79a45;
  --jade:#3f7361; --jade-d:#2c5446; --jade-soft:#e9f0ea;
  --slate:#33464f; --gps:#2f6f9e;
  --hair:rgba(42,32,24,.12); --hair-2:rgba(42,32,24,.22);
  --inset:inset 0 1px 0 rgba(255,255,255,.6);
  --e1:0 1px 2px rgba(42,32,24,.06), 0 2px 5px rgba(42,32,24,.05);
  --e2:0 2px 6px rgba(42,32,24,.07), 0 12px 26px rgba(42,32,24,.10);
  --e3:0 8px 18px rgba(42,32,24,.12), 0 24px 60px rgba(42,32,24,.20);
  --serif:"Fraunces","Noto Serif TC","Songti TC","Songti SC",Georgia,serif;
  --sans:"Be Vietnam Pro","Noto Sans TC","PingFang TC","Microsoft JhengHei",system-ui,sans-serif;
  --mono:ui-monospace,"SFMono-Regular","JetBrains Mono",Menlo,monospace;
  --r-xl:26px; --r-lg:20px; --r-md:14px; --r-sm:10px; --pill:999px;
  --spring:cubic-bezier(.32,.72,0,1); --ease:cubic-bezier(.4,0,.2,1);
  --app-w:460px;
  --safe-b:env(safe-area-inset-bottom,0px); --safe-t:env(safe-area-inset-top,0px);
  --z-nav:20; --z-fab:30; --z-grain:45; --z-sheet:60; --z-toast:70;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:var(--sans);color:var(--ink);font-size:15px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overscroll-behavior:none;
  background:
    radial-gradient(120% 80% at 78% -10%, rgba(181,52,42,.20), transparent 55%),
    radial-gradient(120% 90% at 10% 110%, rgba(63,115,97,.16), transparent 55%),
    linear-gradient(160deg,#2a2018,#3c2e22 45%,#241a13);
}
button{font-family:inherit;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent}
input{font-family:inherit}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}
.skip{position:fixed;left:50%;top:-60px;transform:translateX(-50%);z-index:100;background:var(--ink);color:var(--paper);
  padding:10px 16px;border-radius:var(--pill);transition:top .2s var(--ease)}
.skip:focus{top:8px}
:focus-visible{outline:2.5px solid var(--brass-l);outline-offset:2px;border-radius:4px}
.ic{width:22px;height:22px;display:block}

/* film grain */
body::after{content:"";position:fixed;inset:0;z-index:var(--z-grain);pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---------- APP SHELL (premium device) ---------- */
.app{
  display:flex;flex-direction:column;height:100dvh;max-width:var(--app-w);margin:0 auto;
  position:relative;overflow:hidden;background:var(--paper);
}
@supports not (height:100dvh){.app{height:100vh}}
@media (min-width:560px){
  body{display:flex;align-items:center;justify-content:center;padding:22px 0}
  .app{height:min(900px,calc(100dvh - 44px));border-radius:38px;
    box-shadow:var(--e3), inset 0 0 0 1px rgba(255,255,255,.14), 0 0 0 8px rgba(20,14,8,.55);
  }
}

/* ---------- APP BAR ---------- */
.appbar{display:flex;align-items:center;gap:13px;flex:none;z-index:var(--z-nav);
  padding:calc(11px + var(--safe-t)) 16px 11px;
  background:linear-gradient(180deg,rgba(250,243,227,.92),rgba(243,231,208,.75));
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--hair);}
.appbar__brand{display:flex;align-items:center;gap:11px;margin:0;font-weight:400}
.appbar__seal{flex:none;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  font-family:var(--serif);font-size:23px;color:#fbeede;
  background:linear-gradient(165deg,#bd3c30,#9c2c22);
  box-shadow:var(--e1),inset 0 1px 1px rgba(255,255,255,.3),inset 0 0 0 1px rgba(255,255,255,.18);}
.appbar__word{display:flex;flex-direction:column;line-height:1}
.appbar__zh{font-family:var(--serif);font-size:.62rem;letter-spacing:.3em;color:var(--brass);margin-bottom:3px;font-weight:500}
.appbar__vi{font-family:var(--serif);font-size:1.34rem;font-weight:600;letter-spacing:-.01em;color:var(--ink);
  font-optical-sizing:auto}
.langtoggle{margin-left:auto;font-family:var(--sans);font-size:.8rem;font-weight:600;letter-spacing:.02em;
  background:var(--card);color:var(--ink);border:1px solid var(--hair-2);border-radius:var(--pill);
  padding:8px 17px;box-shadow:var(--e1),var(--inset);transition:transform .2s var(--spring),background .2s}
.langtoggle:hover{background:#fff}
.langtoggle:active{transform:scale(.95)}

/* ---------- MAIN / VIEWS ---------- */
.main{flex:1;position:relative;min-height:0;background:var(--paper)}
.view{position:absolute;inset:0;display:none}
.view--active{display:flex;flex-direction:column}
.view--active.scrollview{display:block;animation:viewIn .5s var(--spring) both}
#view-map.view--active{animation:fade .4s var(--ease) both}
.scrollview{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 16px}
.footspace{height:32px}
.viewtitle{padding:20px 2px 8px}
.viewtitle h2{margin:0;font-family:var(--serif);font-size:1.75rem;font-weight:600;letter-spacing:-.02em;
  color:var(--ink);text-wrap:balance;font-optical-sizing:auto}
.muted{color:var(--ink-soft);font-size:.92rem;margin:6px 0 0;line-height:1.55;text-wrap:pretty}
.muted.small{font-size:.82rem}
.body{color:var(--ink);font-size:.95rem;line-height:1.6;margin:6px 0 0;text-wrap:pretty}

@keyframes viewIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes pop{0%{opacity:0;transform:scale(.4)}60%{transform:scale(1.08)}100%{opacity:1;transform:scale(1)}}

/* ---------- MAP VIEW ---------- */
#view-map{flex-direction:column}
.mapctrls{padding:11px 14px 12px;flex:none;z-index:10;
  background:linear-gradient(180deg,var(--paper),rgba(243,231,208,.0));}
.chips{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}
.chips::-webkit-scrollbar{display:none}
.mapchip{flex:none;font-family:var(--sans);font-size:.82rem;font-weight:600;letter-spacing:.01em;
  border:1px solid var(--hair-2);background:var(--card);color:var(--ink-soft);
  padding:8px 16px;border-radius:var(--pill);white-space:nowrap;box-shadow:var(--e1),var(--inset);
  transition:transform .18s var(--spring),background .2s,color .2s,box-shadow .2s}
.mapchip:active{transform:scale(.95)}
.mapchip.is-active{background:var(--ink);color:var(--paper);border-color:transparent}
.mapchip.day1.is-active{background:var(--cinnabar);color:#fff}
.mapchip.day2.is-active{background:var(--brass);color:#fff}
.mapchip.day3.is-active{background:var(--jade);color:#fff}
.mapchip.lowkey.is-active{background:var(--slate);color:#fff}
#map{flex:1;min-height:0;width:100%;background:#e9ddc2;z-index:1;
  box-shadow:inset 0 8px 16px -10px rgba(42,32,24,.4), inset 0 -8px 16px -10px rgba(42,32,24,.3);}

/* FABs */
.fabs{position:absolute;right:16px;bottom:104px;display:flex;flex-direction:column;gap:11px;z-index:var(--z-fab)}
.fab{width:50px;height:50px;border-radius:50%;border:1px solid var(--hair-2);background:var(--card);color:var(--ink);
  display:grid;place-items:center;box-shadow:var(--e2),var(--inset);
  transition:transform .2s var(--spring),background .2s}
.fab:hover{background:#fff}
.fab:active{transform:scale(.92)}
.fab--primary{background:linear-gradient(165deg,#bd3c30,#9c2c22);border-color:transparent;color:#fff;
  box-shadow:var(--e2),0 6px 16px -4px rgba(140,40,31,.5),inset 0 1px 0 rgba(255,255,255,.25)}
.fab.is-on{background:linear-gradient(165deg,#3a85bf,#2f6f9e);border-color:transparent;color:#fff}
.fab.is-loading{opacity:.6;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* near button + panel */
.nearbtn{position:absolute;left:16px;bottom:104px;z-index:var(--z-fab);display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(165deg,#352a1f,#241a12);color:var(--paper);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--pill);padding:12px 17px;font-size:.86rem;font-weight:600;
  box-shadow:var(--e2),inset 0 1px 0 rgba(255,255,255,.12);transition:transform .2s var(--spring)}
.nearbtn:active{transform:scale(.96)}
.nearbtn .ic{width:18px;height:18px}
.nearpanel{position:absolute;left:0;right:0;bottom:0;z-index:35;max-height:64%;
  background:var(--card);border-top:1px solid var(--hair);border-radius:24px 24px 0 0;
  box-shadow:0 -10px 30px rgba(42,32,24,.22);transform:translateY(106%);
  transition:transform .42s var(--spring);display:flex;flex-direction:column}
.nearpanel.is-open{transform:translateY(0)}
.nearpanel__head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 10px;
  font-family:var(--serif);font-weight:600;font-size:1.1rem;border-bottom:1px solid var(--hair)}
.nearpanel__x{background:var(--paper-2);border:none;width:32px;height:32px;border-radius:50%;font-size:1.3rem;
  line-height:1;color:var(--ink-soft);display:grid;place-items:center}
.nearpanel__list{overflow-y:auto;padding:8px 12px 18px}
.near__empty{color:var(--ink-soft);font-size:.92rem;margin:16px 6px;text-align:center}
#near-list .btn--primary{margin:0 auto;max-width:240px}
.nearrow{display:flex;align-items:center;gap:12px;width:100%;text-align:left;
  background:var(--paper);border:1px solid var(--hair);border-radius:var(--r-md);
  padding:11px 13px;margin-bottom:9px;box-shadow:var(--e1);transition:transform .15s var(--spring),box-shadow .2s}
.nearrow:active{transform:scale(.98)}
.nearrow__badge{flex:none;width:28px;height:28px;border-radius:50%;background:var(--mk,#888);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:.78rem;font-variant-numeric:tabular-nums;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3)}
.nearrow__main{display:flex;flex-direction:column;min-width:0}
.nearrow__name{font-weight:600;font-size:.97rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nearrow__sub{font-size:.74rem;color:var(--ink-soft);font-variant-numeric:tabular-nums}
.nearrow__tick{margin-left:auto;color:var(--jade);font-weight:700}

/* ---------- LEAFLET MARKERS (refined coins) ---------- */
.mk-wrap{background:none;border:none}
.mk{width:30px;height:30px;border-radius:50%;background:var(--mk,#888);
  border:2.5px solid #faf3e3;display:grid;place-items:center;position:relative;
  box-shadow:0 3px 7px rgba(42,32,24,.4),inset 0 1px 0 rgba(255,255,255,.35);
  animation:pop .42s var(--spring) both}
.mk__lbl{color:#fff;font-family:var(--sans);font-weight:700;font-size:.78rem;line-height:1;
  font-variant-numeric:tabular-nums}
.mk--low{border-style:dashed;border-color:#faf3e3;opacity:.96}
.mk--done{filter:saturate(.35) brightness(1.06)}
.mk--done .mk__lbl{opacity:.45}
.mk__tick{position:absolute;top:-6px;right:-6px;background:var(--jade);color:#fff;width:17px;height:17px;
  border-radius:50%;display:grid;place-items:center;font-size:.62rem;border:2px solid #faf3e3;
  box-shadow:0 1px 2px rgba(42,32,24,.3)}
.user-wrap{background:none;border:none}
.user-dot{width:18px;height:18px;border-radius:50%;background:var(--gps);border:3px solid #fff;
  box-shadow:0 0 0 1px var(--gps),0 2px 6px rgba(0,0,0,.3);margin:2px;position:relative}
.user-dot::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:2px solid var(--gps);
  animation:ping 1.9s ease-out infinite}
@keyframes ping{0%{transform:scale(.55);opacity:.7}100%{transform:scale(1.8);opacity:0}}
.leaflet-container{font-family:var(--sans)}
.leaflet-control-zoom a{border-radius:8px!important;color:var(--ink)!important}
.leaflet-bar{border:1px solid var(--hair)!important;box-shadow:var(--e1)!important}

/* ---------- PLAN: day switch ---------- */
.dayswitch{display:flex;gap:6px;margin:8px 0 16px;background:var(--paper-2);padding:5px;
  border-radius:var(--pill);box-shadow:inset 0 1px 3px rgba(42,32,24,.12)}
.dayswitch__btn{flex:1;font-family:var(--sans);font-size:.82rem;font-weight:600;padding:9px 4px;
  border-radius:var(--pill);border:none;background:transparent;color:var(--ink-soft);line-height:1.2;
  transition:transform .18s var(--spring),background .25s,color .25s,box-shadow .25s}
.dayswitch__btn:active{transform:scale(.97)}
.dayswitch__btn.is-active{color:#fff;box-shadow:var(--e1),var(--inset)}
.dayswitch__btn.day1.is-active{background:var(--cinnabar)}
.dayswitch__btn.day2.is-active{background:var(--brass)}
.dayswitch__btn.day3.is-active{background:var(--jade)}

/* weather strip */
.wstrip{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.wstrip__cell{background:var(--card);border:1px solid var(--hair);border-radius:var(--r-md);
  padding:11px 9px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--e1),var(--inset);position:relative;overflow:hidden}
.wstrip__cell::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:var(--wc,#888)}
.wstrip__t{font-weight:700;font-size:.95rem;color:var(--wc);font-variant-numeric:tabular-nums;margin-top:3px}
.wstrip__l{font-size:.64rem;line-height:1.3;color:var(--ink-soft);font-weight:500}
.festnote{position:relative;background:var(--cinnabar-soft);border:1px solid rgba(181,52,42,.25);
  border-radius:var(--r-md);padding:13px 16px 13px 18px;font-size:.9rem;color:var(--cinnabar-d);
  margin:0 0 18px;box-shadow:var(--e1);line-height:1.5;text-wrap:pretty}
.festnote::before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:4px;border-radius:4px;background:var(--cinnabar)}

/* band head + place cards */
.bandhead{display:flex;align-items:center;gap:10px;margin:22px 0 11px}
.bandhead__dot{width:9px;height:9px;border-radius:50%;background:var(--wc,#888);flex:none;
  box-shadow:0 0 0 4px color-mix(in srgb,var(--wc,#888) 18%,transparent)}
.bandhead__txt{font-family:var(--sans);font-size:.68rem;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft)}
.bandhead::after{content:"";flex:1;height:1px;background:var(--hair)}
.pcards{display:flex;flex-direction:column;gap:11px}
.pcard{display:flex;align-items:center;gap:13px;text-align:left;width:100%;
  background:var(--card);border:1px solid var(--hair);border-radius:var(--r-lg);
  padding:14px 15px;box-shadow:var(--e2),var(--inset);
  transition:transform .2s var(--spring),box-shadow .25s;
  animation:rise .5s var(--spring) both}
.pcards .pcard:nth-child(2){animation-delay:.05s}
.pcards .pcard:nth-child(3){animation-delay:.1s}
.pcards .pcard:nth-child(4){animation-delay:.15s}
.pcards .pcard:nth-child(n+5){animation-delay:.2s}
.pcard:hover{box-shadow:var(--e3),var(--inset)}
.pcard:active{transform:scale(.99)}
.pcard--done{opacity:.6}
.pcard__badge{flex:none;width:34px;height:34px;border-radius:50%;background:var(--mk,#888);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:.9rem;font-variant-numeric:tabular-nums;
  box-shadow:var(--e1),inset 0 1px 0 rgba(255,255,255,.3)}
.pcard__main{display:flex;flex-direction:column;min-width:0;flex:1;gap:1px}
.pcard__name{font-family:var(--serif);font-weight:600;font-size:1.08rem;color:var(--ink);letter-spacing:-.01em;line-height:1.2}
.pcard__zh{font-family:var(--serif);font-size:.82rem;color:var(--ink-mute)}
.pcard__meta{font-size:.74rem;color:var(--ink-soft);margin-top:3px;font-variant-numeric:tabular-nums}
.pcard__tick{flex:none;color:var(--jade);font-weight:700;font-size:1.1rem;width:18px;text-align:center}

/* ---------- CHECKLIST ---------- */
.lhero{position:relative;display:flex;align-items:center;gap:20px;background:var(--card);
  border:1px solid var(--hair);border-radius:var(--r-xl);padding:18px;box-shadow:var(--e2),var(--inset);
  margin:8px 0 20px;overflow:hidden}
.lhero::before{content:"";position:absolute;right:-30px;top:-30px;width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle,rgba(181,52,42,.1),transparent 70%)}
.ring{position:relative;width:104px;height:104px;flex:none}
.ring__svg{width:104px;height:104px;transform:rotate(-90deg)}
.ring__bg{fill:none;stroke:var(--hair-2);stroke-width:9}
.ring__fg{fill:none;stroke:var(--cinnabar);stroke-width:9;stroke-linecap:round;
  transition:stroke-dashoffset .9s var(--spring)}
.ring__ctr{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring__num{font-family:var(--serif);font-size:2rem;font-weight:600;color:var(--cinnabar);line-height:1;
  font-variant-numeric:tabular-nums}
.ring__den{font-size:.74rem;color:var(--ink-soft);font-variant-numeric:tabular-nums;margin-top:1px}
.lhero__info{display:flex;flex-direction:column;gap:1px;min-width:0;z-index:1}
.lhero__lab{font-family:var(--serif);font-weight:600;font-size:1.1rem}
.lhero__budlab{margin-top:10px;font-size:.66rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.12em;font-weight:600}
.lhero__bud{font-family:var(--serif);font-size:1.4rem;color:var(--ink);font-variant-numeric:tabular-nums}
.lhero__bud b{color:var(--cinnabar);font-weight:600}
.lsec{font-family:var(--serif);font-size:1.25rem;font-weight:600;margin:24px 0 10px;color:var(--ink);
  letter-spacing:-.01em;display:flex;align-items:center;gap:10px}
.lsec::after{content:"";flex:1;height:1px;background:var(--hair)}
.lsub{font-family:var(--sans);font-size:.66rem;font-weight:600;letter-spacing:.14em;color:var(--brass);
  text-transform:uppercase;margin:16px 0 8px}
.crow{display:flex;align-items:center;gap:12px;padding:5px 0}
.crow__chk{flex:none;width:30px;height:30px;border-radius:9px;border:2px solid var(--mk,var(--hair-2));
  background:var(--card);color:#fff;display:grid;place-items:center;font-size:.9rem;font-weight:700;
  box-shadow:var(--e1);transition:transform .18s var(--spring),background .2s}
.crow__chk:active{transform:scale(.9)}
.crow__chk.is-on{background:var(--mk,var(--jade));border-color:var(--mk,var(--jade))}
.crow__lab{flex:1;background:none;border:none;text-align:left;display:flex;flex-direction:column;padding:4px 0}
.crow__name{font-weight:600;font-size:.97rem}
.crow__name.is-done{text-decoration:line-through;color:var(--ink-mute)}
.crow__sub{font-size:.72rem;color:var(--ink-soft);font-variant-numeric:tabular-nums}
.editlist{display:flex;flex-direction:column;gap:7px}
.erow{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--hair);
  border-radius:var(--r-md);padding:9px 11px;box-shadow:var(--e1)}
.erow__chk{flex:none;width:26px;height:26px;border-radius:8px;border:2px solid var(--hair-2);
  background:var(--paper);color:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:700;transition:transform .18s var(--spring)}
.erow__chk:active{transform:scale(.9)}
.erow__chk.is-on{background:var(--jade);border-color:var(--jade)}
.erow__txt{flex:1;font-size:.94rem}
.erow__txt.is-done{text-decoration:line-through;color:var(--ink-mute)}
.erow__del{flex:none;background:none;border:none;font-size:1.3rem;line-height:1;color:var(--ink-mute);padding:0 4px}
.addrow{display:flex;gap:8px;margin-top:5px}
.addrow__in{flex:1;border:1px solid var(--hair-2);border-radius:var(--r-md);padding:10px 13px;font-size:.92rem;
  background:var(--paper);color:var(--ink);transition:border-color .2s,box-shadow .2s}
.addrow__in:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(169,119,46,.18)}
.addrow__btn{background:linear-gradient(165deg,#b6852f,#9a6a26);color:#fff;border:none;border-radius:var(--r-md);
  padding:0 18px;font-weight:600;font-size:.88rem;box-shadow:var(--e1);transition:transform .18s var(--spring)}
.addrow__btn:active{transform:scale(.95)}
.resetbtn{margin:26px 0 8px;width:100%;background:none;border:1px dashed var(--hair-2);color:var(--ink-soft);
  border-radius:var(--r-md);padding:12px;font-size:.86rem;font-weight:600;transition:color .2s,border-color .2s}
.resetbtn:hover{color:var(--cinnabar-d);border-color:var(--cinnabar)}

/* ---------- INFO ---------- */
.facts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:8px 0 6px}
.facts__b{background:var(--card);border:1px solid var(--hair);border-radius:var(--r-md);padding:12px 14px;
  display:flex;flex-direction:column;gap:4px;box-shadow:var(--e1),var(--inset)}
.facts__k{font-size:.6rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--brass)}
.facts__v{font-size:.92rem;font-weight:600;line-height:1.3}
.wgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.wcard{background:var(--card);border:1px solid var(--hair);border-radius:var(--r-md);padding:13px 14px;
  display:flex;flex-direction:column;gap:4px;box-shadow:var(--e1),var(--inset);position:relative;overflow:hidden}
.wcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--wc)}
.wcard__t{font-family:var(--serif);font-weight:600;font-size:1.1rem;color:var(--wc);font-variant-numeric:tabular-nums}
.wcard__l{font-weight:700;font-size:.82rem}
.wcard__tip{font-size:.78rem;color:var(--ink-soft);line-height:1.4;text-wrap:pretty}
.opennow{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:var(--jade-soft);
  border:1px solid rgba(63,115,97,.3);border-radius:var(--r-md);padding:11px 14px;margin:4px 0 14px;box-shadow:var(--e1)}
.opennow__lab{font-weight:700;color:var(--jade-d);font-size:.9rem}
.opennow__chip{background:var(--jade);color:#fff;border-radius:var(--pill);padding:5px 13px;font-size:.84rem;font-weight:600;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.2)}
.opennow__none{color:var(--ink-mute)}
.ntable{width:100%;border-collapse:separate;border-spacing:0;font-size:.88rem;background:var(--card);
  border:1px solid var(--hair);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--e1)}
.ntable th{background:var(--ink);color:var(--paper);font-family:var(--sans);font-weight:600;font-size:.66rem;
  letter-spacing:.08em;text-transform:uppercase;padding:9px 11px;text-align:left}
.ntable td{padding:9px 11px;border-top:1px solid var(--hair)}
.ntable tr.is-open td{background:var(--jade-soft);font-weight:700;color:var(--jade-d)}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}

/* ---------- BOTTOM SHEET ---------- */
.sheet-backdrop{position:fixed;inset:0;background:rgba(28,20,12,.42);-webkit-backdrop-filter:blur(5px);
  backdrop-filter:blur(5px);opacity:0;visibility:hidden;transition:opacity .3s var(--ease);z-index:50}
.sheet-backdrop.is-open{opacity:1;visibility:visible}
.sheet{position:fixed;left:50%;bottom:0;transform:translate(-50%,106%);width:100%;max-width:var(--app-w);
  background:var(--card);border-radius:26px 26px 0 0;border-top:1px solid var(--hair);
  box-shadow:0 -12px 36px rgba(28,20,12,.28),var(--inset);z-index:var(--z-sheet);
  transition:transform .44s var(--spring);max-height:88dvh;overflow-y:auto;
  padding:10px 20px calc(24px + var(--safe-b))}
.sheet.is-open{transform:translate(-50%,0)}
.sheet__grab{width:42px;height:5px;border-radius:3px;background:var(--hair-2);margin:7px auto 6px}
.sheet__close{position:absolute;top:14px;right:16px;width:34px;height:34px;border-radius:50%;border:none;
  background:var(--paper-2);color:var(--ink);display:grid;place-items:center;box-shadow:var(--inset);
  transition:transform .18s var(--spring)}
.sheet__close:active{transform:scale(.9)}
.sheet__head{display:flex;align-items:flex-start;gap:13px;margin:6px 0 14px;padding-right:40px}
.sheet__badge{flex:none;width:42px;height:42px;border-radius:13px;color:#fff;display:grid;place-items:center;
  font-weight:700;font-size:1.1rem;font-variant-numeric:tabular-nums;
  box-shadow:var(--e1),inset 0 1px 0 rgba(255,255,255,.3)}
.sheet__titles{min-width:0}
.sheet__name{margin:0;font-family:var(--serif);font-size:1.5rem;font-weight:600;line-height:1.1;letter-spacing:-.02em;
  color:var(--ink);font-optical-sizing:auto;text-wrap:balance}
.sheet__zh{margin:3px 0 0;font-family:var(--serif);font-size:.92rem;color:var(--ink-mute)}
.sheet__dist{display:flex;align-items:center;gap:11px;background:#e7f0f6;border:1px solid rgba(47,111,158,.3);
  border-radius:var(--r-md);padding:10px 13px;margin-bottom:13px;font-size:.88rem;color:#1d496f;font-weight:600;
  font-variant-numeric:tabular-nums;box-shadow:var(--e1)}
.compass{color:var(--gps);display:inline-grid;place-items:center;transition:transform .4s var(--spring)}
.sheet__chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:13px}
.chip{font-family:var(--sans);font-size:.68rem;font-weight:600;letter-spacing:.01em;padding:5px 11px;
  border-radius:var(--pill);border:1px solid var(--hair-2);color:var(--ink-soft);background:var(--paper)}
.chip--price{border-color:rgba(181,52,42,.4);color:var(--cinnabar-d);background:var(--cinnabar-soft)}
.chip--free{border-color:rgba(63,115,97,.4);color:var(--jade-d);background:var(--jade-soft)}
.chip--low{background:var(--slate);color:#fff;border-color:var(--slate)}
.sheet__note{font-size:.97rem;line-height:1.62;color:var(--ink);margin:0 0 18px;text-wrap:pretty}
.sheet__acts{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--paper-2);
  border:1px solid var(--hair-2);color:var(--ink);border-radius:var(--r-md);padding:12px;font-size:.9rem;
  font-weight:600;box-shadow:var(--e1),var(--inset);transition:transform .2s var(--spring),background .2s,box-shadow .2s}
.btn:hover{background:#fff}
.btn:active{transform:scale(.97)}
.btn .ic{width:18px;height:18px}
.btn--primary{background:linear-gradient(165deg,#bd3c30,#9c2c22);border-color:transparent;color:#fff;grid-column:1 / -1;
  box-shadow:var(--e2),0 6px 16px -5px rgba(140,40,31,.5),inset 0 1px 0 rgba(255,255,255,.22);position:relative;padding-right:46px}
.btn--primary::after{content:"";position:absolute;right:8px;top:50%;transform:translateY(-50%);
  width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.16)}
.btn--primary:hover{background:linear-gradient(165deg,#c5402f,#a32f24)}
.btn--on{background:linear-gradient(165deg,#46806e,#2c5446);border-color:transparent;color:#fff}

/* ---------- TOAST ---------- */
.toast{position:fixed;left:50%;bottom:calc(86px + var(--safe-b));transform:translateX(-50%) translateY(20px);
  background:linear-gradient(165deg,#352a1f,#241a12);color:var(--paper);border-radius:var(--pill);
  padding:13px 19px;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:13px;max-width:90%;
  z-index:var(--z-toast);opacity:0;visibility:hidden;transition:opacity .28s var(--ease),transform .28s var(--spring);
  box-shadow:var(--e3),inset 0 1px 0 rgba(255,255,255,.1);text-wrap:pretty}
.toast.is-show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.toast__act{background:var(--brass-l);color:var(--ink);border:none;border-radius:var(--pill);padding:7px 15px;
  font-weight:700;font-size:.84rem;flex:none}

/* ---------- TAB BAR ---------- */
.tabbar{display:flex;background:linear-gradient(180deg,rgba(250,243,227,.85),var(--paper-2));
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border-top:1px solid var(--hair);padding-bottom:var(--safe-b);flex:none;z-index:var(--z-nav)}
.tabbar__btn{flex:1;background:none;border:none;padding:10px 4px 8px;display:flex;flex-direction:column;
  align-items:center;gap:4px;color:var(--ink-mute);font-size:.66rem;font-weight:600;position:relative;
  transition:color .25s}
.tabbar__btn .ic{width:23px;height:23px;transition:transform .25s var(--spring)}
.tabbar__btn::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%) scaleX(0);
  width:26px;height:3px;border-radius:3px;background:var(--cinnabar);transition:transform .3s var(--spring)}
.tabbar__btn.is-active{color:var(--cinnabar)}
.tabbar__btn.is-active::before{transform:translateX(-50%) scaleX(1)}
.tabbar__btn.is-active .ic{transform:translateY(-1px) scale(1.06)}
.tabbar__btn:active .ic{transform:scale(.9)}

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important}
  .user-dot::after{display:none}
}
