
:root{--ink:#1c2530;--ink2:#5b6573;--bg:#f4f1ea;--card:#fff;--line:#e4ded2;--accent:#c8453b;--indigo:#10243e;--gold:#d9a441;
--sight:#d6557a;--food:#e8743b;--shop:#9b5de5;--museum:#3a86ff;--nature:#2a9d8f;--onsen:#e4572e;--festival:#e0a800;--stay:#6b7280;
--safe-b:env(safe-area-inset-bottom,0px);--safe-t:env(safe-area-inset-top,0px);}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;color:var(--ink);background:var(--bg);overscroll-behavior:none}
#app{display:flex;flex-direction:column;height:100%;max-width:820px;margin:0 auto;background:var(--bg);position:relative}
header{background:var(--indigo);color:#fff;padding:calc(var(--safe-t) + 9px) 13px 9px;flex:0 0 auto;z-index:30}
.htitle{display:flex;align-items:baseline;gap:8px}.htitle b{font-size:17px}.htitle span{font-size:12px;color:#b9c6d8}
#nextbar{margin-top:7px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);border-radius:11px;padding:7px 10px;display:flex;align-items:center;gap:10px;cursor:pointer}
#nextbar .lbl{font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:#9fb0c6;font-weight:700}
#nextbar .ev{font-size:13px;font-weight:600;line-height:1.25}#nextbar .when{font-size:12px;color:#cdd8e6}
#nextbar .go{margin-left:auto;background:var(--gold);color:#3a2a00;font-weight:700;font-size:12px;padding:6px 10px;border-radius:9px;white-space:nowrap;text-decoration:none}
.tabwrap{flex:1 1 auto;position:relative;overflow:hidden}
.view{position:absolute;inset:0;display:none;flex-direction:column}.view.active{display:flex}
#mapfilters{flex:0 0 auto;background:var(--bg);border-bottom:1px solid var(--line);padding:6px 0 5px}
.chiprow{display:flex;gap:6px;overflow-x:auto;padding:0 11px 2px;scrollbar-width:none;align-items:center}.chiprow::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;border:1px solid var(--line);background:var(--card);color:var(--ink2);border-radius:999px;padding:5px 10px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px;cursor:pointer;user-select:none;white-space:nowrap}
.chip .dot{width:9px;height:9px;border-radius:50%}
.chip.on{color:#fff;border-color:transparent}.chip.region.on{background:var(--indigo)}.chip.cat.on{background:var(--c)}
.chip.day{border-width:1.5px}.chip.day.on{color:#fff;border-color:transparent}
.chip.sub.on{background:var(--indigo);color:#fff}.chip.tg.on{background:var(--accent);color:#fff}
.fhint{font-size:10.5px;color:var(--ink2);font-weight:800;flex:0 0 auto;text-transform:uppercase;letter-spacing:.04em}
#mapbox{flex:1 1 auto;position:relative}#map{position:absolute;inset:0;background:#cfe8f5}
.leaflet-container{background:#cfe8f5;font:inherit}.leaflet-control-attribution{font-size:9px;background:rgba(255,255,255,.7)}
.leaflet-tooltip{font-size:11.5px;font-weight:600;padding:3px 7px;border-radius:6px}
.pin{display:flex;align-items:center;justify-content:center;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.4)}
.pin>span{transform:rotate(45deg);font-size:11px;line-height:1}
.pin.poi{width:20px;height:20px}.pin.big{width:29px;height:29px}.pin.big>span{font-size:15px}
.pin.idea{width:14px;height:14px;opacity:.92;border-width:1.5px}.pin.idea>span{font-size:8px}
.legend{position:absolute;right:8px;bottom:20px;background:rgba(255,255,255,.95);border:1px solid var(--line);border-radius:10px;padding:6px 8px;font-size:10.5px;z-index:500;max-width:46%;line-height:1.5;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.legend b{display:block;font-size:9.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink2);margin-bottom:2px}
.legend i{font-style:normal;display:inline-flex;align-items:center;gap:3px;margin-right:6px}.legend .sw{width:9px;height:9px;border-radius:50%;display:inline-block}
.mapbtn{position:absolute;left:8px;z-index:500;background:rgba(255,255,255,.95);border:1px solid var(--line);border-radius:9px;padding:7px 9px;font-size:11.5px;font-weight:700;color:var(--ink);cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.15)}
#saveArea{bottom:20px}#dlstatus{left:8px;bottom:54px;display:none}
.bmswitch{position:absolute;right:8px;top:8px;z-index:500;display:flex;flex-direction:column;background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:9px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.18)}
.bmswitch button{border:none;background:none;padding:6px 10px;font-size:11px;font-weight:700;color:var(--ink2);cursor:pointer;border-bottom:1px solid var(--line);white-space:nowrap;text-align:left}
.bmswitch button:last-child{border-bottom:none}.bmswitch button.on{background:var(--indigo);color:#fff}
.count{font-size:11px;color:var(--ink2);padding:4px 12px 0;font-weight:600}
.scrollv{flex:1 1 auto;overflow-y:auto;padding:12px 12px 92px;-webkit-overflow-scrolling:touch}
.day{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 13px;margin-bottom:11px}
.day h3{margin:0;font-size:15px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.day .ribbon{width:6px;align-self:stretch;border-radius:4px;min-height:20px}
.day .date{font-size:12px;color:var(--ink2);font-weight:700}
.rbadge{font-size:10px;font-weight:800;padding:2px 7px;border-radius:6px;color:#fff;text-transform:uppercase}
.day .hotel{font-size:12px;color:var(--ink2);margin-top:4px}.day .hotel b{color:var(--ink)}
.evt{display:flex;gap:9px;align-items:flex-start;margin-top:10px;padding-top:10px;border-top:1px dashed var(--line)}
.evt .tm{flex:0 0 auto;width:50px;font-size:12px;font-weight:800}
.evt .ic{flex:0 0 auto;width:24px;height:24px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px}
.evt .body{flex:1 1 auto;min-width:0}.evt .body .t{font-size:13.5px;font-weight:700;line-height:1.25}.evt .body .s{font-size:11.5px;color:var(--ink2);margin-top:2px;line-height:1.35}
.dirbtn{display:inline-block;margin-top:5px;font-size:11.5px;font-weight:700;color:#fff;background:#0a8f6c;padding:5px 9px;border-radius:8px;text-decoration:none}
.dirbtn.resv{background:var(--accent)}
.stops{margin-top:11px;padding-top:9px;border-top:1px dashed var(--line)}
.stops .lbl{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink2);font-weight:800;margin-bottom:6px}
.stopchips{display:flex;flex-wrap:wrap;gap:6px}
.stopchip{font-size:12px;background:#f6f2ea;border:1px solid var(--line);border-radius:8px;padding:5px 8px;cursor:pointer;display:flex;align-items:center;gap:5px}
.stopchip .d{width:8px;height:8px;border-radius:50%}.stopchip.list{border-color:#d9a441;background:#fbf3e0}
.viewmap{margin-top:10px;font-size:12px;font-weight:700;color:var(--indigo);background:none;border:1px solid var(--indigo);border-radius:9px;padding:6px 10px;cursor:pointer}
#sheet{position:absolute;left:0;right:0;bottom:0;background:var(--card);border-radius:18px 18px 0 0;box-shadow:0 -6px 26px rgba(0,0,0,.22);transform:translateY(110%);transition:transform .26s cubic-bezier(.2,.8,.2,1);z-index:1200;max-height:80%;display:flex;flex-direction:column;padding-bottom:var(--safe-b)}
#sheet.open{transform:translateY(0)}
.shbar{display:flex;justify-content:center;padding:8px}.shbar i{width:38px;height:4px;border-radius:3px;background:#d8d2c6}
.shbody{overflow-y:auto;padding:2px 16px 18px}
.shtitle{font-size:18px;font-weight:800;line-height:1.2}.shsub{font-size:12.5px;color:var(--ink2);margin-top:3px;font-weight:600}
.shphoto{width:100%;height:180px;object-fit:cover;border-radius:13px;margin:10px 0 4px;background:#ece7dd;display:block}
.prow img.thumb{width:46px;height:46px;border-radius:8px;object-fit:cover;flex:0 0 auto;background:#ece7dd}
.pickerctrl{display:flex;gap:6px;align-items:center;margin:6px 0 2px;flex-wrap:wrap}
.pickerctrl select{font:inherit;font-size:12.5px;border:1px solid var(--line);border-radius:8px;padding:6px 8px;background:#fff}
.pickerctrl .chip{font-size:12px}
.badges{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0}
.bdg{font-size:11px;font-weight:800;padding:3px 8px;border-radius:7px;color:#fff}.bdg.light{background:#f0ece3;color:var(--ink)}
.shwhy{font-size:13.5px;line-height:1.45;margin:8px 0}.shquote{font-size:13px;font-style:italic;color:#46505e;border-left:3px solid var(--gold);padding:3px 0 3px 10px;margin:8px 0}
.shnote{font-size:12px;color:var(--ink2);line-height:1.4;margin:6px 0}
.shbtns{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.shbtns a,.shbtns button{flex:1 1 auto;text-align:center;text-decoration:none;font-size:13px;font-weight:800;padding:11px 10px;border-radius:11px;border:none;cursor:pointer}
.b-maps{background:var(--indigo);color:#fff}.b-resv{background:var(--accent);color:#fff}.b-more{background:#f0ece3;color:var(--ink)}.b-add{background:#2a9d8f;color:#fff}
#scrim{position:absolute;inset:0;background:rgba(10,15,25,.30);opacity:0;pointer-events:none;transition:opacity .26s;z-index:1100}#scrim.on{opacity:1;pointer-events:auto}
nav{flex:0 0 auto;display:flex;background:var(--card);border-top:1px solid var(--line);padding-bottom:var(--safe-b);z-index:40}
nav button{flex:1;border:none;background:none;padding:8px 0 9px;font-size:10.5px;font-weight:700;color:var(--ink2);display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer}
nav button .ni{font-size:18px;line-height:1}nav button.on{color:var(--accent)}
.info{padding:14px;font-size:13px;line-height:1.5}.info h4{margin:14px 0 6px;font-size:13px}.info code{background:#ece7dd;padding:1px 5px;border-radius:5px;font-size:12px}.info ol{margin:6px 0;padding-left:20px}.info li{margin:4px 0}
/* PLAN */
#planmap{height:230px;border-radius:13px;overflow:hidden;border:1px solid var(--line);margin-bottom:11px;background:#cfe8f5}
.planhead{display:flex;align-items:center;gap:8px;margin-bottom:9px;flex-wrap:wrap}.planhead .t{font-size:16px;font-weight:800}
.btn{font-size:12px;font-weight:700;border-radius:9px;padding:7px 10px;cursor:pointer;border:1px solid var(--line);background:var(--card);color:var(--ink)}
.btn.pri{background:var(--indigo);color:#fff;border-color:transparent}.btn.warn{background:#fff;color:var(--accent);border-color:var(--accent)}
.pday{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:10px 11px;margin-bottom:11px;border-left:5px solid #ccc}
.pday>h4{margin:0 0 8px;font-size:13.5px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.pday.dragover{outline:2px dashed var(--indigo);outline-offset:2px}
.editable{cursor:text;border-bottom:1px dashed transparent;padding:1px 2px;border-radius:3px}.editable:hover{border-bottom-color:#bbb;background:#faf7f0}
.inlineinput{font:inherit;font-weight:700;border:1px solid var(--indigo);border-radius:6px;padding:2px 6px;min-width:120px}
.nbcard{border:1px solid var(--line);border-radius:11px;padding:9px 10px;margin:7px 0;background:#fbfaf6;border-left:4px solid #ccc}
.nbcard.dragover{outline:2px dashed var(--accent)}
.nbcard .nbh{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.nbcard .nbn{font-size:13px;font-weight:800;flex:1 1 auto;min-width:80px}
.nbcard .cnt{font-weight:600;color:var(--ink2)}
.nbcard .mini{font-size:11px;font-weight:700;color:var(--ink2);background:#efe9dd;border:none;border-radius:7px;padding:4px 7px;cursor:pointer}
.mini.draghandle{cursor:grab}
.pl{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.plchip{font-size:12px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:4px 6px 4px 8px;display:flex;align-items:center;gap:5px;cursor:grab}
.plchip .d{width:8px;height:8px;border-radius:50%}.plchip .x{color:#b54;font-weight:800;cursor:pointer;padding:0 3px}.plchip.list{border-color:#d9a441}
.addp{font-size:11.5px;font-weight:700;color:var(--indigo);background:none;border:1px dashed var(--indigo);border-radius:8px;padding:5px 9px;cursor:pointer;margin-top:8px}
.pool{background:#fff7e8;border-left-color:#ecd9a8}
.nbform{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-top:8px;background:#f1ece2;padding:8px;border-radius:9px}
.nbform input,.nbform select{font:inherit;font-size:12.5px;border:1px solid var(--line);border-radius:7px;padding:6px 8px}
.nbform input{flex:1 1 120px}
.delc{display:inline-flex;gap:5px;align-items:center;font-size:11.5px;font-weight:700;color:var(--accent)}
.delc button{font-size:11px;font-weight:800;border:none;border-radius:6px;padding:3px 8px;cursor:pointer}.delc .yes{background:var(--accent);color:#fff}.delc .no{background:#e6e0d4;color:var(--ink)}
#picker{position:absolute;inset:0;z-index:1300;background:var(--bg);display:none;flex-direction:column}#picker.open{display:flex}
#picker .ph{background:var(--indigo);color:#fff;padding:calc(var(--safe-t) + 10px) 12px 10px;display:flex;align-items:center;gap:10px}
#picker .ph b{font-size:15px;flex:1}#picker .ph button{background:rgba(255,255,255,.18);color:#fff;border:none;border-radius:8px;padding:7px 11px;font-weight:700;cursor:pointer}
#picker input{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-size:14px;margin:8px 0}
#pickerlist{flex:1;overflow-y:auto;padding:0 12px 90px}
.prow{display:flex;align-items:center;gap:9px;padding:9px 6px;border-bottom:1px solid var(--line);cursor:pointer}
.prow .d{width:10px;height:10px;border-radius:50%;flex:0 0 auto}.prow .nm{font-size:13.5px;font-weight:600}.prow .mt{font-size:11px;color:var(--ink2)}.prow.added{opacity:.5}
.menu{position:fixed;z-index:1500;background:#fff;border:1px solid var(--line);border-radius:11px;box-shadow:0 6px 24px rgba(0,0,0,.25);padding:5px;display:none;min-width:170px;max-height:62%;overflow:auto}
.menu.open{display:block}.menu button{display:block;width:100%;text-align:left;background:none;border:none;padding:9px 11px;font-size:13px;border-radius:7px;cursor:pointer;color:var(--ink)}.menu button:hover{background:#f3efe6}
.toast{position:absolute;left:50%;bottom:84px;transform:translateX(-50%);background:#10243e;color:#fff;font-size:12.5px;font-weight:600;padding:9px 14px;border-radius:10px;z-index:1600;opacity:0;transition:opacity .2s;pointer-events:none}.toast.on{opacity:.96}

/* ============================================================
   旅手帖 — design layer (appended; overrides the base above).
   Concept: a modern Japanese travel notebook — washi paper,
   sumi-ink indigo, shu vermilion, kin gold; mincho serif display.
   ============================================================ */
:root{
  --bg:#efe9dc; --card:#fffdf7; --line:#e4dccb; --ink:#1b2430; --ink2:#727a89;
  --accent:#c0453a; --indigo:#13294a; --gold:#b9892f;
  --paper2:#f6f1e6; --hair:#e9e1d0;
  --shadow-sm:0 1px 2px rgba(27,36,48,.05), 0 2px 6px -2px rgba(27,36,48,.10);
  --shadow-md:0 2px 8px -2px rgba(27,36,48,.10), 0 14px 30px -16px rgba(19,41,74,.30);
  --shadow-lg:0 24px 60px -24px rgba(19,41,74,.45);
  --r:15px;
  --font-display:"Hiragino Mincho ProN","Yu Mincho",YuMincho,"Songti SC","Shippori Mincho",Georgia,serif;
  --font-body:-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Noto Sans JP","Segoe UI",Roboto,sans-serif;
}
html,body{font-family:var(--font-body);background:var(--bg);color:var(--ink);letter-spacing:.005em}
/* paper atmosphere: a faint grain + a soft top light, both fixed & non-interactive */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.45;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");}
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(120% 80% at 50% -10%, rgba(255,255,255,.55), rgba(255,255,255,0) 60%);}
#app{background:transparent;position:relative;z-index:1}

/* ---- masthead ---- */
header{background:linear-gradient(160deg,#16305a 0%,#11233f 58%,#0d1c33 100%);
  padding:calc(var(--safe-t) + 13px) 16px 13px;box-shadow:0 1px 0 rgba(255,255,255,.04) inset, 0 6px 22px -10px rgba(8,18,34,.7);position:relative;overflow:hidden}
header::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,transparent, var(--gold) 18%, #e7c98a 50%, var(--gold) 82%, transparent)}
.htitle{align-items:center;gap:11px}
.htitle .seal{flex:0 0 auto;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 30% 20%, #d65548, var(--accent));color:#fff;font-family:var(--font-display);
  font-size:18px;line-height:1;box-shadow:0 2px 9px -2px rgba(176,52,40,.8),inset 0 0 0 1px rgba(255,255,255,.18);transform:rotate(-3deg)}
.htitle b{font-family:var(--font-display);font-weight:600;font-size:21px;letter-spacing:.02em;color:#fdfbf5}
.htitle #daterange{font-size:11.5px;color:#b7c4d8;letter-spacing:.06em;text-transform:uppercase;font-weight:600;margin-left:auto}
#nextbar{margin-top:11px;background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.16);border-radius:13px;padding:9px 12px;backdrop-filter:blur(4px);
  box-shadow:0 6px 18px -12px rgba(0,0,0,.7);transition:transform .15s ease}
#nextbar:active{transform:scale(.992)}
#nextbar .lbl{color:#a9bbd4}
#nextbar .go{background:linear-gradient(180deg,#e7c074,var(--gold));color:#3a2a00;box-shadow:0 3px 10px -3px rgba(150,110,20,.7)}

/* ---- filter chips ---- */
#mapfilters{background:linear-gradient(180deg,var(--paper2),var(--bg));border-bottom:1px solid var(--hair);padding:8px 0 7px}
.chip{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .12s ease, box-shadow .15s ease, background .15s ease;border-radius:999px}
.chip:active{transform:scale(.95)}
.chip.on{box-shadow:0 3px 10px -3px rgba(19,41,74,.4)}
.chip.region.on{background:var(--indigo)} .chip.tg.on{background:var(--accent)} .chip.sub.on{background:var(--indigo)}
.fhint{color:var(--ink2);letter-spacing:.08em}
/* calm day chips — color = day, dot + soft tint */
.chip.day{border:1px solid var(--line);background:var(--card);color:var(--ink2);font-weight:600}
.chip.day .dot{box-shadow:0 0 0 2px rgba(255,255,255,.6);transition:filter .12s,opacity .12s}
.chip.day:not(.on) .dot{filter:grayscale(.6);opacity:.5}
.chip.day.on{color:var(--ink);border-color:transparent;background:color-mix(in srgb,var(--day) 15%,var(--card));box-shadow:inset 0 -2px 0 0 var(--day),0 1px 2px rgba(27,36,48,.06)}
.chip .cgi{font-size:12px;line-height:1}

/* ---- map shell + glass controls ---- */
#mapbox{box-shadow:inset 0 1px 0 rgba(0,0,0,.04)}
.mapbtn,.bmswitch,.legend{background:rgba(255,253,247,.82);backdrop-filter:blur(10px) saturate(1.1);
  border:1px solid rgba(255,255,255,.6);box-shadow:var(--shadow-md);border-radius:11px;color:var(--ink)}
.mapbtn{font-weight:700;transition:transform .12s ease}.mapbtn:active{transform:scale(.96)}
.bmswitch button{color:var(--ink2)}.bmswitch button.on{background:var(--indigo);color:#fff}
.legend b{color:var(--ink2)}
#locate{position:absolute;right:8px;top:116px;z-index:500;width:42px;height:42px;display:grid;place-items:center;
  font-size:18px;cursor:pointer;padding:0}
#locate.on{background:var(--indigo);color:#fff}
.count{color:var(--ink2);font-weight:600}
/* "you are here" */
.youdot{width:18px;height:18px;border-radius:50%;background:#2f6fed;border:3px solid #fff;
  box-shadow:0 0 0 2px rgba(47,111,237,.4),0 2px 6px rgba(0,0,0,.4);position:relative}
.youdot::before{content:"";position:absolute;inset:-8px;border-radius:50%;background:rgba(47,111,237,.25);animation:ping 2s ease-out infinite}

/* ---- refined map pins ---- */
.pin{border:2px solid #fff;box-shadow:0 4px 10px -3px rgba(20,28,40,.55),0 1px 2px rgba(0,0,0,.3)}
.pin.poi{width:24px;height:24px}.pin.poi>span{font-size:11px;font-weight:700}
.pin.big{width:32px;height:32px}.pin .num{font-weight:800;font-size:11px;color:#fff}
/* idea pins: neutral paper (color reserved for day); category shown by icon */
.pin.idea{width:20px;height:20px;background:var(--card);border:1.5px solid var(--line);opacity:.96;box-shadow:0 3px 7px -3px rgba(20,28,40,.5)}
.pin.idea>span{font-size:11px}
.legend .gi{display:inline-block;width:13px;text-align:center;margin-right:2px;font-size:11px;line-height:1}

/* ---- cards: itinerary days ---- */
.scrollv{padding:14px 13px 96px}
.day{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-md);padding:14px 15px;margin-bottom:13px;position:relative;overflow:hidden}
.day h3{font-family:var(--font-display);font-weight:600;font-size:16.5px;letter-spacing:.01em}
.day .ribbon{width:5px;border-radius:4px;box-shadow:0 0 0 1px rgba(0,0,0,.04)}
.day .date{font-family:var(--font-body);font-size:11px;color:var(--ink2);text-transform:uppercase;letter-spacing:.07em}
.rbadge{font-weight:700;letter-spacing:.04em;border-radius:999px;box-shadow:var(--shadow-sm)}
.evt{border-top:1px solid var(--hair)}
.evt .ic{border-radius:9px;box-shadow:var(--shadow-sm)}
.evt .body .t{font-weight:700}
.dirbtn{box-shadow:0 3px 9px -3px rgba(10,143,108,.6);border-radius:9px}
.stopchip{background:var(--paper2);border:1px solid var(--line);border-radius:9px;transition:transform .12s ease,box-shadow .15s}
.stopchip:active{transform:scale(.96)}.stopchip.list{background:#fbf1da;border-color:var(--gold)}
.viewmap{border-radius:10px;font-weight:700;transition:background .15s,color .15s}
.viewmap:active{background:var(--indigo);color:#fff}

/* ---- detail sheet ---- */
#sheet{border-radius:22px 22px 0 0;box-shadow:0 -10px 50px -12px rgba(19,41,74,.45);background:var(--card)}
.shbar i{background:#d9d1c2}
.shtitle{font-family:var(--font-display);font-weight:600;font-size:21px;letter-spacing:.01em}
.shphoto{border-radius:14px;box-shadow:var(--shadow-md)}
.bdg{border-radius:999px;box-shadow:var(--shadow-sm);letter-spacing:.02em}
.shquote{border-left:3px solid var(--gold);background:linear-gradient(90deg,rgba(185,137,47,.07),transparent);border-radius:0 8px 8px 0;padding:7px 12px}
.shbtns a,.shbtns button{border-radius:12px;box-shadow:var(--shadow-sm);transition:transform .12s ease}
.shbtns a:active,.shbtns button:active{transform:scale(.97)}
.b-maps{background:var(--indigo)}.b-resv{background:var(--accent)}
/* photo skeleton shimmer (shows until the <img> paints over it) */
.shphoto,.prow .thumb{background:linear-gradient(100deg,#ece6d9 30%,#f6f1e6 50%,#ece6d9 70%);background-size:220% 100%;animation:shimmer 1.4s linear infinite}

/* ---- nav ---- */
nav{background:linear-gradient(180deg,var(--card),#fbf6ec);border-top:1px solid var(--hair);box-shadow:0 -6px 18px -14px rgba(19,41,74,.4)}
nav button{position:relative;color:var(--ink2);transition:color .15s}
nav button .ni{font-size:19px;transition:transform .15s}
nav button.on{color:var(--accent)} nav button.on .ni{transform:translateY(-1px) scale(1.06)}
nav button.on::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:26px;height:3px;border-radius:0 0 4px 4px;background:var(--accent)}

/* ---- plan ---- */
.planhead .t{font-family:var(--font-display);font-weight:600;font-size:18px}
.btn{box-shadow:var(--shadow-sm);transition:transform .12s ease}.btn:active{transform:scale(.97)}
.btn.pri{background:var(--indigo)}.btn.warn{color:var(--accent);border-color:var(--accent)}
.pday{background:var(--card);box-shadow:var(--shadow-md);border-radius:var(--r)}
.pday>h4{font-family:var(--font-display);font-weight:600;font-size:14.5px}
.nbcard{background:var(--paper2);box-shadow:var(--shadow-sm);border-radius:12px}
.nbcard .nbn{font-family:var(--font-display);font-weight:600}
.plchip{background:var(--card);box-shadow:var(--shadow-sm);border-radius:9px;transition:box-shadow .15s}
.plchip.list{border-color:var(--gold)}
.addp{border-radius:9px}
#planmap{height:240px;border-radius:14px;box-shadow:var(--shadow-md);border:1px solid var(--line)}
.planactions{display:flex;gap:7px;flex-wrap:wrap;margin-left:auto}

/* ---- picker ---- */
#picker{background:var(--bg)}
#picker .ph{background:linear-gradient(160deg,#16305a,#0d1c33)}
#picker .ph b{font-family:var(--font-display);font-weight:600}
#pickermap{height:0;opacity:0;border-radius:13px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);
  margin:0 0 2px;transition:height .25s ease,opacity .25s ease,margin .25s ease}
#pickermap.on{height:168px;opacity:1;margin:6px 0 4px}
.pmaptoggle{margin-left:auto}
.prow{border-bottom:1px solid var(--hair);transition:background .12s}
.prow:active{background:var(--paper2)}.prow .nm{font-weight:600}
.menu{border-radius:13px;box-shadow:var(--shadow-lg);border:1px solid var(--line)}
.toast{background:rgba(19,32,43,.96);backdrop-filter:blur(6px);box-shadow:var(--shadow-lg);border-radius:12px}

/* ---- motion ---- */
@keyframes shimmer{from{background-position:140% 0}to{background-position:-40% 0}}
@keyframes ping{0%{transform:scale(.6);opacity:.8}100%{transform:scale(1.5);opacity:0}}
@keyframes viewIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
@keyframes riseIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:no-preference){
  header{animation:fadeDown .6s both}
  .view.active{animation:viewIn .34s ease both}
  #days .day{animation:riseIn .42s ease both}
  #days .day:nth-child(2){animation-delay:.04s}#days .day:nth-child(3){animation-delay:.08s}
  #days .day:nth-child(4){animation-delay:.12s}#days .day:nth-child(5){animation-delay:.15s}
}

/* ============================================================
   Laptop / wide: two-column — map pinned left, list pinned right
   ============================================================ */
@media (min-width:1024px){
  html,body{background:#e7e0d1}
  #app{max-width:1280px;height:100vh;box-shadow:0 0 0 1px var(--line),var(--shadow-lg)}
  .tabwrap{display:grid;grid-template-columns:minmax(0,1.16fr) minmax(0,.84fr);grid-template-rows:minmax(0,1fr);overflow:hidden}
  /* map: always visible in the left column regardless of .active */
  #view-map{display:flex!important;position:relative;inset:auto;grid-column:1;grid-row:1;min-height:0;border-right:1px solid var(--line);animation:none}
  #view-days,#view-plan{position:relative;inset:auto;grid-column:2;grid-row:1;min-height:0}
  #view-days:not(.active),#view-plan:not(.active){display:none}
  .scrollv{padding:18px 18px 28px}
  #days .day,.pday{max-width:none}
  /* nav becomes a slim top segmented control; Map button hidden (map is always shown) */
  nav{order:-1;border-top:none;border-bottom:1px solid var(--hair);justify-content:flex-start;gap:6px;padding:8px 14px;
     background:linear-gradient(180deg,var(--paper2),var(--bg))}
  nav button{flex:0 0 auto;flex-direction:row;gap:7px;padding:8px 16px;border-radius:999px;border:1px solid var(--line);
     background:var(--card);box-shadow:var(--shadow-sm);font-size:13px}
  nav button .ni{font-size:15px}
  nav button.on{background:var(--indigo);color:#fff;border-color:transparent}
  nav button.on::before{display:none} nav button.on .ni{transform:none}
  nav button[data-v="map"]{display:none}
  /* sheet -> centered modal card */
  #sheet{left:50%;right:auto;bottom:auto;top:50%;width:min(460px,42vw);max-height:84vh;border-radius:20px;
     transform:translate(-50%,-46%) scale(.98);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;pointer-events:none;transition:transform .26s cubic-bezier(.2,.8,.2,1),opacity .2s ease,visibility 0s linear .26s}
  #sheet.open{transform:translate(-50%,-50%) scale(1);opacity:1;visibility:visible;pointer-events:auto;transition:transform .26s cubic-bezier(.2,.8,.2,1),opacity .2s ease}
  .shbar{display:none}.shbody{padding-top:18px}
  /* picker -> centered modal */
  #picker{inset:auto;left:50%;top:50%;right:auto;bottom:auto;width:min(620px,80vw);height:auto;max-height:86vh;
     transform:translate(-50%,-50%);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg)}
  #pickerlist{max-height:46vh}
  .legend{max-width:240px}
}
