:root{--koko-green: #2F7D5C;--koko-green-dk: #1F5C44;--amber: #E8A23A;--blue: #3A7CA5;--red: #D85C4A;--ink: #1E2420;--stone: #66736D;--mist: #DCE4DF;--paper: #FFFFFF;--soft-map: #F5F7F4;--tag-curious: #E8A23A;--tag-good: #2F7D5C;--tag-revisit: #3A7CA5;--tag-want: var(--tag-curious);--tag-often: var(--tag-revisit);--tag-meh: #7A6F8F;--tag-work: #53636B;--tag-home: #6B8E5A;--tag-trip: #D97B5F;--tag-drink: #9A6A42;--tag-meal: #D88732;--tag-solo: #3F8F8C;--font-jp: "Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",system-ui,sans-serif;--font-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;--shadow-sm: 0 1px 0 rgba(30,36,32,.04), 0 2px 6px -2px rgba(30,36,32,.1);--shadow-md: 0 1px 0 rgba(30,36,32,.05), 0 12px 28px -16px rgba(30,36,32,.25)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}html,body{overflow:hidden;overscroll-behavior:none}body{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;background:#e6ebe7;font-family:var(--font-jp);color:var(--ink)}#root{overflow:hidden}body{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation}input,textarea,[contenteditable=true]{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}.allow-zoom,.allow-zoom *{touch-action:auto;-webkit-user-select:auto;user-select:auto;-webkit-touch-callout:default}.stage{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,#eef2ee,#dde4de)}.phone{width:min(390px,100%);height:min(820px,94vh);border-radius:44px;background:#0c0b0a;padding:10px;box-shadow:0 0 0 1px #00000014,0 24px 60px -24px #00000073;position:relative;flex-shrink:0}.phone-screen{width:100%;height:100%;background:var(--paper);border-radius:40px;overflow:hidden;position:relative;display:flex;flex-direction:column;font-family:var(--font-jp);color:var(--ink);font-size:14px;line-height:1.5;isolation:isolate}.phone-screen *{box-sizing:border-box}@media(max-width:480px){.stage{padding:0;background:#000}.phone{width:100vw;height:100vh;height:100dvh;border-radius:0;padding:0}.phone-screen{border-radius:0;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}}.sb{height:46px;display:flex;align-items:center;justify-content:space-between;padding:0 28px 0 32px;font-family:-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:15px;font-weight:600;color:var(--ink);flex-shrink:0;position:relative}.sb .island{position:absolute;top:11px;left:50%;transform:translate(-50%);width:104px;height:30px;background:#0c0b0a;border-radius:999px}.sb .icons{display:flex;align-items:center;gap:6px}.sb .ico-sig{display:flex;gap:2.5px;align-items:flex-end;height:11px}.sb .ico-sig i{display:block;width:3.5px;background:var(--ink);border-radius:1px}.sb .ico-sig i:nth-child(1){height:3px}.sb .ico-sig i:nth-child(2){height:5px}.sb .ico-sig i:nth-child(3){height:7px}.sb .ico-sig i:nth-child(4){height:10px}.sb .ico-wifi{width:16px;height:11px;background:radial-gradient(circle at 50% 100%,var(--ink) 1.5px,transparent 1.9px),radial-gradient(circle at 50% 100%,transparent 4px,var(--ink) 4.3px,var(--ink) 5px,transparent 5.3px),radial-gradient(circle at 50% 100%,transparent 7px,var(--ink) 7.3px,var(--ink) 8px,transparent 8.3px)}.sb .ico-batt{width:26px;height:12px;border:1.2px solid var(--ink);border-radius:3px;padding:1.5px;position:relative}.sb .ico-batt:after{content:"";position:absolute;right:-3px;top:3px;width:2px;height:5px;background:var(--ink);border-radius:1px}.sb .ico-batt span{display:block;height:100%;width:80%;background:var(--ink);border-radius:1px}.pb{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column}.appbar{height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid var(--mist);background:var(--paper);flex-shrink:0}.appbar .title{font-weight:700;font-size:16px;letter-spacing:.01em}.appbar .back{font-size:18px;color:var(--ink);width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer}.appbar .right{display:flex;align-items:center;gap:14px;font-size:14px;color:var(--koko-green);font-weight:600;cursor:pointer}.appbar .menu{font-size:18px;color:var(--stone);cursor:pointer}.tabbar{height:74px;border-top:1px solid var(--mist);background:var(--paper);display:flex;justify-content:space-around;padding:8px 8px 20px;flex-shrink:0;position:relative}.tabbar:before{content:"";position:absolute;top:0;height:3px;border-radius:0 0 3px 3px;background:var(--koko-green);left:calc(8px + (100% - 16px) / var(--tab-count, 4) * .25);width:calc((100% - 16px) / var(--tab-count, 4) * .5);transform:translate(calc(var(--tab-index, 0) * 200%));transition:transform .28s cubic-bezier(.22,.7,.18,1)}.tabbar.no-active:before{display:none}.tabbar .t{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--stone);font-size:10px;font-weight:500;flex:1;cursor:pointer}.tabbar .t.on{color:var(--koko-green)}.tabbar .t svg{width:22px;height:22px}.tab-icon-wrap{position:relative;display:inline-flex}.unread-dot{position:absolute;right:-3px;top:-3px;width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 2px var(--paper)}.row-unread-title{display:inline-flex;align-items:center;gap:6px}.row-unread-title .unread-dot,.card-unread-dot{position:static;display:inline-block;box-shadow:none;flex-shrink:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:44px;padding:0 18px;border-radius:12px;font-weight:600;font-size:14px;font-family:inherit;border:none;cursor:pointer;transition:filter .12s,background .12s,opacity .12s}.btn:active{filter:brightness(.95)}.btn.prim{background:var(--koko-green);color:var(--paper)}.btn.sec{background:var(--paper);color:var(--ink);border:1px solid var(--mist)}.btn.dang{background:var(--paper);color:var(--red);border:1px solid var(--red)}.btn.text{background:transparent;color:var(--koko-green);height:auto;padding:8px 4px}.btn.full{width:100%}.btn.sm{height:34px;font-size:13px;padding:0 14px;border-radius:10px}.btn.disabled,.btn:disabled{opacity:.4;cursor:default}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12px;color:var(--stone);font-weight:500}.input{height:44px;border:1px solid var(--mist);border-radius:10px;padding:0 14px;display:flex;align-items:center;font-size:14px;color:var(--ink);background:var(--paper)}.input.lg{height:52px;font-size:15px;font-weight:600}.input.click{cursor:pointer}.input input{border:none;outline:none;background:transparent;font:inherit;color:inherit;width:100%}.textarea{min-height:84px;border:1px solid var(--mist);border-radius:10px;padding:12px 14px;font-size:14px;color:var(--ink);background:var(--paper);line-height:1.65;font-family:inherit;resize:none;width:100%;outline:none}.edit-memo-textarea{min-height:188px;height:clamp(188px,28dvh,240px)}.help{font-size:11px;color:var(--stone);line-height:1.55}.chip{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border-radius:999px;background:var(--paper);border:1px solid var(--mist);font-size:12px;font-weight:500;color:var(--ink);cursor:pointer;transition:background .12s,border-color .12s,color .12s}.chip.sm{height:26px;padding:0 10px;font-size:11.5px}.chip.add{background:transparent;border:1px dashed var(--mist);color:var(--stone);padding:0 12px;cursor:pointer;font-family:inherit}.chip .dot{width:8px;height:8px;border-radius:50%}.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}.chip.green-on{background:var(--koko-green);color:#fff;border-color:var(--koko-green)}.scene-chip-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.scene-chip{height:34px;border-radius:999px;border:1px solid var(--mist);background:var(--paper);color:var(--ink);font:inherit;font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0 10px;white-space:nowrap;min-width:0}.scene-chip.on{background:#e8f3ec;border-color:#cfe2d6;color:var(--koko-green)}.scene-chip:disabled{opacity:.5;cursor:default}.scene-tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.scene-tag{min-width:0;max-width:100%;height:24px;padding:0 9px;border-radius:999px;background:#eef5f1;border:1px solid #d7e7de;color:var(--koko-green);font-size:11px;font-weight:800;display:inline-flex;align-items:center}.status-chip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.status-chip-grid .chip{width:100%;justify-content:flex-start;min-width:0;padding:0 10px}.status-chip-grid .chip .label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chip-row{display:flex;gap:6px;overflow-x:auto;padding:10px 16px;background:var(--paper);border-bottom:1px solid var(--mist)}.chip-row-sm{padding:8px 14px}.chip-row::-webkit-scrollbar{display:none}.filt-btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:10px;background:var(--soft-map);border:1px solid var(--mist);font-family:inherit;font-size:12.5px;font-weight:600;color:var(--ink);cursor:pointer}.filt-btn:hover{background:var(--paper)}.filt-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--koko-green);color:#fff;font-family:var(--font-mono);font-size:10.5px;font-weight:700;margin-left:2px}.active-filters{display:flex;align-items:center;gap:6px;padding:8px 14px 10px;background:var(--soft-map);overflow-x:auto;border-bottom:1px solid var(--mist)}.active-filters::-webkit-scrollbar{display:none}.active-pill{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 6px 0 10px;border-radius:999px;background:var(--paper);border:1px solid var(--mist);font-size:11.5px;font-weight:600;color:var(--ink);flex-shrink:0}.active-pill .cdot{width:7px;height:7px}.active-pill .x{width:16px;height:16px;border-radius:50%;background:var(--mist);display:inline-flex;align-items:center;justify-content:center;font-size:11px;color:var(--stone);line-height:1;cursor:pointer}.active-clear{font-family:inherit;font-size:11.5px;font-weight:600;color:var(--stone);background:transparent;border:0;padding:0 4px;cursor:pointer;flex-shrink:0}.active-clear:hover{color:var(--ink)}.iconbtn{width:32px;height:32px;border-radius:10px;background:var(--soft-map);border:1px solid var(--mist);color:var(--stone);display:inline-flex;align-items:center;justify-content:center;font-family:inherit;flex-shrink:0;cursor:pointer;transition:background .15s,color .15s}.iconbtn svg{width:15px;height:15px}.iconbtn:hover{background:var(--paper);color:var(--ink)}.iconbtn.dang{color:var(--red)}.iconbtn+.iconbtn{margin-left:4px}.tag-curious{background:var(--tag-curious)}.tag-good{background:var(--tag-good)}.tag-want{background:var(--tag-want)}.tag-often{background:var(--tag-often)}.tag-revisit{background:var(--tag-revisit)}.tag-meh{background:var(--tag-meh)}.tag-work{background:var(--tag-work)}.tag-home{background:var(--tag-home)}.tag-trip{background:var(--tag-trip)}.tag-drink{background:var(--tag-drink)}.tag-meal{background:var(--tag-meal)}.tag-solo{background:var(--tag-solo)}.av{width:28px;height:28px;border-radius:50%;display:inline-block;flex-shrink:0;background:#9aa1a3}.av-a{background:linear-gradient(135deg,#c9a576,#a37f48)}.av-b{background:linear-gradient(135deg,#7c9c8a,#56776a)}.av-c{background:linear-gradient(135deg,#b06c5a,#7a3f30)}.av-d{background:linear-gradient(135deg,#5b6f8a,#36495c)}.av-e{background:linear-gradient(135deg,#9a8aa6,#6b5e7e)}.av-f{background:linear-gradient(135deg,#caa86c,#806a3e)}.av-me{background:linear-gradient(135deg,#3a7c8c,#1f4a55)}.map{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#eef2ed,#e6ece8)}.map .road{position:absolute;background:#fff;box-shadow:0 0 0 1px #d8e0dc inset}.map .water{position:absolute;background:#cbdbe4;opacity:.85;border-radius:60% 40% 50% 60%/40% 60% 40% 50%}.map .park{position:absolute;background:#d3deca;border-radius:30% 70% 40% 60%/50% 30% 70% 50%}.map .blk{position:absolute;background:#ffffff8c;border-radius:3px}.empty-map-image{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background:#e8eee9}.empty-map-image:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url(/tokyo-empty-map.png) center/cover no-repeat;filter:saturate(.72) contrast(.92);pointer-events:none}.empty-map-image:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:#ffffff5c;pointer-events:none}.pin{position:absolute;width:38px;height:48px;transform:translate(-50%,-100%);filter:drop-shadow(0 4px 6px rgba(0,0,0,.25));cursor:pointer}.pin.advanced-pin{position:relative;transform:none}.pin .head{width:38px;height:38px;border-radius:50%;background:var(--paper);border:3px solid var(--tag-good);display:flex;align-items:center;justify-content:center;overflow:hidden}.pin .head .av{width:100%;height:100%;border-radius:50%;position:relative}.pin .head .av .av-ini{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px;line-height:1}.pin .tail{width:0;height:0;border:7px solid transparent;border-top:10px solid var(--tag-good);margin:-3px auto 0}.pin.want .head{border-color:var(--tag-want)}.pin.want .tail{border-top-color:var(--tag-want)}.pin.often .head{border-color:var(--tag-often)}.pin.often .tail{border-top-color:var(--tag-often)}.pin.curious .head{border-color:var(--tag-curious)}.pin.curious .tail{border-top-color:var(--tag-curious)}.pin.revisit .head{border-color:var(--tag-revisit)}.pin.revisit .tail{border-top-color:var(--tag-revisit)}.pin.meh .head{border-color:var(--tag-meh)}.pin.meh .tail{border-top-color:var(--tag-meh)}.pin.work .head{border-color:var(--tag-work)}.pin.work .tail{border-top-color:var(--tag-work)}.pin.home .head{border-color:var(--tag-home)}.pin.home .tail{border-top-color:var(--tag-home)}.pin.trip .head{border-color:var(--tag-trip)}.pin.trip .tail{border-top-color:var(--tag-trip)}.pin.cluster{width:38px;height:48px}.pin.cluster .head{width:38px;height:38px;border-radius:50%;background:var(--paper);border:3px solid var(--mist);font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--ink);display:flex;align-items:center;justify-content:center}.pin.cluster .tail{border-top-color:var(--paper)}.pin.station-pin .head{opacity:.78;border-style:dashed}.pin.sel .head{box-shadow:0 0 0 3px #2f7d5c59}.avstack{display:flex}.avstack .av{width:18px;height:18px;border:2px solid var(--paper);margin-left:-6px}.avstack .av:first-child{margin-left:0}.fab{position:absolute;right:14px;bottom:90px;z-index:20;width:54px;height:54px;border-radius:50%;background:var(--koko-green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;border:none;cursor:pointer;box-shadow:0 10px 24px -8px #2f7d5c99;transition:bottom .2s cubic-bezier(.2,.7,.3,1)}.fab.empty-highlight{z-index:32;box-shadow:0 12px 28px -8px #2f7d5ca6,0 0 0 8px #2f7d5c2e;animation:emptyFabPulse 1.8s ease-out infinite}@keyframes emptyFabPulse{0%{box-shadow:0 12px 28px -8px #2f7d5ca6,0 0 #2f7d5c52}72%{box-shadow:0 12px 28px -8px #2f7d5ca6,0 0 0 18px #2f7d5c00}to{box-shadow:0 12px 28px -8px #2f7d5ca6,0 0 #2f7d5c00}}.empty-fab-guide{position:absolute;right:18px;bottom:88px;z-index:31;width:214px;padding:12px 14px;border-radius:14px;background:#fffffff5;border:1px solid rgba(220,228,223,.95);box-shadow:0 18px 34px -18px #1e242052;cursor:pointer}.empty-fab-guide:after{content:"";position:absolute;right:18px;bottom:-7px;width:14px;height:14px;background:#fffffff5;border-right:1px solid rgba(220,228,223,.95);border-bottom:1px solid rgba(220,228,223,.95);transform:rotate(45deg)}.empty-fab-guide-title{font-size:13.5px;font-weight:800;color:var(--ink)}.empty-fab-guide-sub{margin-top:3px;font-size:11.5px;line-height:1.55;color:var(--stone)}.fab.gps{bottom:154px;width:44px;height:44px;background:var(--paper);color:var(--ink);border:1px solid var(--mist);font-size:18px;box-shadow:var(--shadow-md)}.fab.gps:before{content:"⊕";font-size:22px;line-height:1}.cdot{width:8px;height:8px;border-radius:50%;display:inline-block}.sheet{position:absolute;left:0;right:0;bottom:0;background:var(--paper);border-radius:18px 18px 0 0;box-shadow:0 -10px 30px -10px #0000002e;padding:8px 18px 22px;animation:sheetUp .22s cubic-bezier(.2,.7,.3,1)}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet .grab{width:36px;height:4px;border-radius:2px;background:var(--mist);margin:6px auto 14px}.row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--mist);background:var(--paper)}.row:last-child{border-bottom:0}.row.click{cursor:pointer;transition:background .12s}.row.click:hover{background:var(--soft-map)}.row .av{width:40px;height:40px}.row .grow{flex:1;min-width:0}.row .nm{font-weight:600;font-size:14px;color:var(--ink)}.row .sub{font-size:12px;color:var(--stone);margin-top:2px}.row .meta{font-size:12px;color:var(--stone)}.bdg{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--soft-map);color:var(--stone);border:1px solid var(--mist)}.bdg.L1{color:var(--stone)}.bdg.L2{color:var(--koko-green);border-color:#cfe2d6;background:#e8f3ec}.bdg.L3{color:var(--blue);border-color:#cdddea;background:#e7f0f6}.bdg.exact{color:var(--ink)}.bdg.station{color:var(--blue)}.bdg.area{color:var(--tag-home)}.sechd{padding:14px 16px 6px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);font-weight:600}.div{height:1px;background:var(--mist)}.tabs{display:flex;border-bottom:1px solid var(--mist);background:var(--paper);flex-shrink:0}.tabs .t{flex:1;text-align:center;padding:14px 0;font-size:13px;color:var(--stone);position:relative;font-weight:500;cursor:pointer}.tabs .t.on{color:var(--ink);font-weight:700}.tabs .t.on:after{content:"";position:absolute;left:25%;right:25%;bottom:-1px;height:2px;background:var(--koko-green);border-radius:2px}.tabs .t .n{display:block;font-family:var(--font-mono);font-size:11px;color:var(--stone);margin:4px auto 0;line-height:1.1}.tabs .t.on .n{color:var(--koko-green)}.tabs.animated{position:relative}.tabs.animated .t:after{display:none}.tabs.animated:after{content:"";position:absolute;bottom:-1px;left:0;height:2px;border-radius:2px;width:calc(100% / var(--tab-count) * .5);margin-left:calc(100% / var(--tab-count) * .25);background:var(--koko-green);transform:translate(calc(var(--tab-index) * 200%));transition:transform .28s cubic-bezier(.22,.7,.18,1)}.mini-map{height:120px;border-radius:12px;background:linear-gradient(180deg,#eef2ed,#e6ece8);position:relative;overflow:hidden;border:1px solid var(--mist)}.mini-map:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(transparent 49%,rgba(0,0,0,.04) 50%,transparent 51%) 0 0/22px 22px,linear-gradient(90deg,transparent 49%,rgba(0,0,0,.04) 50%,transparent 51%) 0 0/22px 22px}.image-picker{width:100%;height:clamp(220px,36dvh,300px);border-radius:12px;border:1px dashed var(--mist);background:var(--soft-map);overflow:hidden;display:grid;place-items:center;cursor:pointer;position:relative;color:var(--stone)}.image-picker.has-image{border-style:solid;background:#eef1ee}.image-picker.disabled{opacity:.58;cursor:default}.image-fit-frame{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#eef1ee}.image-fit-frame img{display:block;width:100%;height:100%;max-width:100%;max-height:100%;object-fit:scale-down;object-position:center center}.image-picker-empty{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:12.5px;font-weight:700}.image-picker-plus{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--paper);border:1px solid var(--mist);color:var(--koko-green);font-size:22px;line-height:1}.place-log-image{margin-top:10px;width:100%;height:168px;border-radius:10px;overflow:hidden;background:#e9efeb;border:1px solid rgba(220,228,223,.9);position:relative;cursor:pointer;display:grid;place-items:center}.place-log-image.detail{height:220px;border-radius:12px;margin-top:12px}.place-log-image.peek{height:112px;margin-top:8px}.place-log-image.loading{min-height:86px}.place-log-image .image-count{position:absolute;right:8px;bottom:8px;min-width:28px;height:22px;padding:0 8px;border-radius:999px;background:#1e2420b8;color:#fff;font-size:11px;font-weight:800;display:inline-flex;align-items:center;justify-content:center}.image-preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#141c18db;display:flex;align-items:center;justify-content:center;padding:18px;animation:imagePreviewBackdropIn .18s ease-out both}.image-preview-backdrop img{max-width:100%;max-height:100%;object-fit:contain;border-radius:12px;box-shadow:0 22px 52px -20px #0009;animation:imagePreviewZoomIn .22s cubic-bezier(.2,.8,.2,1) both}.image-preview-close{position:absolute;right:18px;top:18px;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:#ffffff29;color:#fff;font-size:24px;line-height:1;display:grid;place-items:center;cursor:pointer}.image-preview-backdrop.closing{animation:imagePreviewBackdropOut .18s ease-in both}.image-preview-backdrop.closing img{animation:imagePreviewZoomOut .18s cubic-bezier(.4,0,.7,.2) both}@keyframes imagePreviewBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes imagePreviewBackdropOut{0%{opacity:1}to{opacity:0}}@keyframes imagePreviewZoomIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes imagePreviewZoomOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.96)}}.seg{display:flex;background:var(--soft-map);border-radius:10px;padding:3px;gap:3px;font-size:13px;font-weight:600}.seg .s{flex:1;text-align:center;padding:8px 0;border-radius:8px;color:var(--stone);cursor:pointer;transition:background .12s,color .12s}.seg .s.on{background:var(--paper);color:var(--ink);box-shadow:var(--shadow-sm)}.opt{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--mist);cursor:pointer}.opt:last-child{border-bottom:0}.opt .radio{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--mist);flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center}.opt.on .radio{border-color:var(--koko-green)}.opt.on .radio:after{content:"";width:12px;height:12px;border-radius:50%;background:var(--koko-green)}.opt .nm{font-weight:600;font-size:14px}.opt .ds{font-size:12px;color:var(--stone);margin-top:3px;line-height:1.6}.dlg-back{position:absolute;top:0;right:0;bottom:0;left:0;background:#141c186b;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .15s}@keyframes fade{0%{opacity:0}to{opacity:1}}.dlg{background:var(--paper);border-radius:18px;padding:22px 22px 14px;width:100%;max-width:300px;box-shadow:0 22px 50px -20px #00000080}.dlg h3{font-size:16px;font-weight:700;margin:0 0 10px}.dlg p{font-size:13px;color:var(--stone);line-height:1.7;margin:0 0 18px}.dlg .actions{display:flex;gap:10px}.dlg .actions .btn{flex:1;height:40px}.logcard{background:var(--paper);border:1px solid var(--mist);border-radius:14px;padding:14px;margin:0 16px 12px;position:relative}.logcard.click{cursor:pointer;transition:box-shadow .12s,transform .12s}.logcard.click:active{transform:scale(.995)}.logcard.is-copying{pointer-events:none}.logcard.is-copying>:not(.feed-card-copy-overlay){opacity:.38}.feed-card-copy-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#ffffff2e;z-index:5}.feed-card-spinner{width:32px;height:32px;border-radius:50%;border:3px solid rgba(43,128,99,.18);border-top-color:var(--koko-green);animation:feed-card-spin .72s linear infinite}@keyframes feed-card-spin{to{transform:rotate(360deg)}}.logcard .top{display:flex;align-items:center;gap:10px}.logcard .name{font-weight:700;font-size:13px}.logcard .place{font-weight:700;font-size:15px;margin-top:8px;letter-spacing:-.005em}.logcard .memo{font-size:13px;color:#3a4541;margin-top:6px;line-height:1.65}.logcard .meta{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}.swipe-card-wrap{position:relative;margin:0 16px 12px;overflow:hidden;border-radius:14px}.swipe-card-wrap .logcard{margin:0;position:relative;z-index:2}.swipe-card{transition:transform .18s cubic-bezier(.22,.7,.18,1)}.swipe-action{position:absolute;top:0;bottom:0;width:76px;border:0;color:#fff;font-weight:800;font-size:13px;z-index:1}.swipe-action.edit{left:0;background:var(--koko-green)}.swipe-action.delete{right:0;background:var(--red)}.tpill{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--soft-map);color:var(--ink);display:inline-flex;align-items:center;gap:5px}.tpill .cdot{width:7px;height:7px}.rxbar{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}.feed-card-actions{display:flex;align-items:center;gap:8px;margin-top:12px}.feed-card-actions .rxbar{margin-top:0;flex:1}.share-card-btn{width:34px;height:34px;border-radius:999px;border:1px solid var(--mist);background:var(--soft-map);color:var(--stone);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .12s,color .12s,transform .08s}.share-card-btn svg{width:16px;height:16px}.share-card-btn:hover{background:var(--paper);color:var(--ink)}.share-card-btn:active{transform:scale(.96)}.rxbar .rx{font-size:12px;font-weight:600;padding:6px 11px;border-radius:999px;background:var(--soft-map);border:1px solid var(--mist);color:var(--ink);cursor:pointer;transition:background .12s,color .12s}.rxbar .rx.hot{background:var(--ink);color:var(--paper);border-color:var(--ink)}.curiousbtn{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px;background:var(--soft-map);border:1px solid var(--mist);color:var(--stone);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .12s,color .12s,border-color .12s,transform .08s}.curiousbtn:active{transform:scale(.94)}.curiousbtn:disabled{opacity:.5;cursor:default}.curiousbtn svg{display:block;transition:transform .12s}.curiousbtn .cnt{font-variant-numeric:tabular-nums;min-width:8px;text-align:center}.curiousbtn.on{background:color-mix(in srgb,var(--red) 12%,var(--paper));border-color:color-mix(in srgb,var(--red) 35%,var(--mist));color:var(--red)}.curiousbtn.on svg{transform:scale(1.08)}.curiousbtn.readonly{cursor:default}.curiousbtn.readonly:active{transform:none}.warn{background:#fdf4e3;border:1px solid #f0d99a;color:#6b5114;font-size:12px;padding:10px 12px;border-radius:10px;line-height:1.6}.warn.priv{background:#eaf2ec;border-color:#bbd3c3;color:#214a36}.tgl{width:36px;height:22px;border-radius:999px;position:relative;display:inline-block;cursor:pointer;background:var(--mist);transition:background .15s;flex-shrink:0}.tgl .knob{position:absolute;left:2px;top:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px #0000002e;transition:left .15s}.tgl.on{background:var(--koko-green)}.tgl.on .knob{left:16px}.friend-fly-track{position:fixed;left:0;top:0;z-index:80;pointer-events:none;animation:friendFlyX .68s cubic-bezier(.22,.7,.18,1) both}.friend-fly{width:40px;height:40px;display:grid;place-items:center;padding:0;border-radius:50%;background:var(--paper);border:1px solid #cfe2d6;box-shadow:0 12px 26px -14px #1e242073;pointer-events:none;animation:friendFlyY .68s cubic-bezier(.22,.7,.18,1) both}@keyframes friendFlyX{0%{transform:translate(var(--from-x))}to{transform:translate(var(--to-x))}}@keyframes friendFlyY{0%{opacity:0;transform:translateY(var(--from-y)) scale(.92)}14%{opacity:1;transform:translateY(var(--from-y)) scale(1)}78%{opacity:1;transform:translateY(var(--from-y)) scale(1)}90%{opacity:1;transform:translateY(var(--from-y)) scale(.72)}to{opacity:0;transform:translateY(var(--to-y)) scale(.28)}}.ic{width:18px;height:18px;display:inline-block;vertical-align:middle}.toast-wrap{position:absolute;left:0;right:0;bottom:96px;display:flex;justify-content:center;pointer-events:none;z-index:60}.toast{background:#1e2420eb;color:#fff;font-size:13px;font-weight:600;padding:10px 16px;border-radius:999px;box-shadow:0 8px 24px -8px #00000080;animation:toastUp .2s cubic-bezier(.2,.7,.3,1);max-width:80%;text-align:center}@keyframes toastUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.muted{color:var(--stone)}.mono{font-family:var(--font-mono)}.bold{font-weight:700}.cap{text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--stone);font-weight:600}.flex{display:flex}.spread{display:flex;justify-content:space-between;align-items:center}.gap6{gap:6px}.gap10{gap:10px}.gap12{gap:12px}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt22{margin-top:22px}.p16{padding:16px}.px16{padding-left:16px;padding-right:16px}.scrollY{overflow-y:auto;flex:1;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.scrollY::-webkit-scrollbar{display:none}.clickable{cursor:pointer}.disabled-control{opacity:.48;pointer-events:none;filter:saturate(.65)}.disabled-control input:disabled{color:var(--stone);-webkit-text-fill-color:var(--stone)}.ptr-scroll{position:relative}.ptr-content{transform:translateY(var(--ptr-distance, 0px));transition:transform .18s cubic-bezier(.22,.7,.18,1);will-change:transform}.ptr-indicator{position:absolute;left:0;right:0;top:0;z-index:5;height:46px;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:clamp(0,calc(var(--ptr-distance, 0px) / 36),1);transform:translateY(calc(var(--ptr-distance, 0px) - 46px));transition:opacity .16s,transform .18s cubic-bezier(.22,.7,.18,1)}.ptr-spinner{width:26px;height:26px;border-radius:50%;border:2px solid rgba(47,125,92,.2);border-top-color:var(--koko-green);background:var(--paper);box-shadow:var(--shadow-sm);transform:rotate(calc(var(--ptr-distance, 0px) * 3deg))}.ptr-indicator.refreshing .ptr-spinner{animation:ptrSpin .72s linear infinite}.ptr-indicator.armed .ptr-spinner{border-top-color:var(--amber)}@keyframes ptrSpin{to{transform:rotate(360deg)}}.loadmore{height:46px;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--stone);font-size:12px;font-weight:700}.loadmore-spinner{width:15px;height:15px;border-radius:50%;border:2px solid var(--mist);border-top-color:var(--stone)}.loadmore.loading .loadmore-spinner{animation:ptrSpin .8s linear infinite}.loadmore.armed{color:var(--koko-green)}.loadmore.armed .loadmore-spinner{border-top-color:var(--koko-green)}.ac-list{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:30;background:var(--paper);border:1px solid var(--mist);border-radius:10px;box-shadow:0 12px 28px -10px #1e242040;overflow:hidden}.ac-item{display:flex;flex-direction:column;gap:2px;width:100%;text-align:left;border:0;background:transparent;cursor:pointer;font-family:inherit;padding:9px 12px;border-bottom:1px solid var(--mist)}.ac-item:last-child{border-bottom:0}.ac-item:hover{background:var(--soft-map)}.ac-main{font-size:14px;font-weight:600;color:var(--ink)}.ac-sub{font-size:11px;color:var(--stone)}.ac-clear{flex:0 0 auto;width:26px;height:26px;border-radius:50%;border:0;cursor:pointer;background:var(--soft-map);color:var(--stone);font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:background .12s,color .12s}.ac-clear:hover{background:var(--mist);color:var(--ink)}.route-anim{position:relative;flex:1;display:flex;flex-direction:column;min-height:0;animation:routeIn .26s cubic-bezier(.2,.7,.3,1) both}@keyframes routeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.route-anim.reveal{animation:homeReveal .6s cubic-bezier(.18,.8,.22,1) both;transform-origin:50% 60%}@keyframes homeReveal{0%{opacity:0;transform:scale(.9)}55%{opacity:1;transform:scale(1.015)}to{opacity:1;transform:scale(1)}}.tour-slide.fwd{animation:slideFromR .3s cubic-bezier(.2,.7,.3,1) both}.tour-slide.bwd{animation:slideFromL .3s cubic-bezier(.2,.7,.3,1) both}@keyframes slideFromR{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slideFromL{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}.route-anim.reveal .pop-in{animation:popIn .45s .2s cubic-bezier(.2,.8,.2,1) both}@keyframes popIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@media(prefers-reduced-motion:reduce){.route-anim,.route-anim.reveal,.tour-slide.fwd,.tour-slide.bwd,.route-anim.reveal .pop-in{animation:none}.splash{transition:none}.splash-top>*{animation:none}}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;flex-direction:column;background:#fbf9f2;opacity:1;transition:opacity .4s ease}.splash.hide{opacity:0;pointer-events:none}.splash-top{flex:1.7;background:#fbf9f2;display:flex;flex-direction:column;align-items:center;justify-content:center}.splash-top>*{animation:splashUp .5s cubic-bezier(.2,.7,.3,1) both}@keyframes splashUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.splash-icon{width:104px;height:104px;border-radius:24px;box-shadow:0 14px 34px -12px #00000047;display:block}.splash-word{margin-top:20px;font-size:26px;font-weight:800;letter-spacing:.06em;color:var(--ink)}.splash-sub{margin-top:6px;font-size:11px;letter-spacing:.42em;color:var(--stone)}.splash-bottom{flex:1;background:linear-gradient(180deg,#2f7d5c,#1f5c44);color:#ffffffeb;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.splash-bottom p{margin:0;text-align:center;line-height:2;font-size:14px}.splash-loading{position:absolute;bottom:28px;left:0;right:0;text-align:center;font-size:10px;letter-spacing:.5em;color:#ffffff80}.tour-screen{flex:1;min-height:0;display:flex;flex-direction:column;background:#fbf9f2;padding:14px 0 18px;overflow:hidden}.tour-top{height:38px;display:flex;align-items:center;justify-content:space-between;padding:0 22px;flex-shrink:0}.tour-skip{border:0;background:transparent;color:var(--stone);font-family:inherit;font-size:13px;font-weight:600;padding:6px 0;cursor:pointer}.tour-drag-area{flex:1;min-height:0;display:flex;flex-direction:column;touch-action:pan-y;cursor:grab;user-select:none;-webkit-user-select:none;overflow:hidden}.tour-drag-area:active{cursor:grabbing}.tour-drag-track{flex:1;min-height:0;display:flex;width:100%;transition:transform .34s cubic-bezier(.18,.84,.22,1);will-change:transform}.tour-drag-track.dragging{transition:none}.tour-page{flex:0 0 100%;min-width:0;min-height:0;display:flex;flex-direction:column;transform-origin:50% 56%;transition:opacity .22s ease,transform .34s cubic-bezier(.18,.84,.22,1);will-change:opacity,transform}.tour-drag-track.dragging .tour-page{transition:none}.tour-page.active{pointer-events:auto}.tour-page:not(.active){pointer-events:none}.tour-stage-area{flex:1;min-height:300px;display:flex;align-items:center;justify-content:center;padding:6px 20px 0}.tour-copy{padding:18px 28px 8px;text-align:center;flex-shrink:0}.tour-copy h2{margin:0 0 14px;color:var(--ink);font-size:26px;font-weight:900;letter-spacing:0;line-height:1.32}.tour-copy h2 .em{background:linear-gradient(180deg,transparent 65%,rgba(232,162,58,.35) 65%);padding:0 2px}.tour-copy p{margin:0 auto;max-width:32ch;color:var(--stone);font-size:13.5px;line-height:1.85}.tour-cta{padding:14px 24px 0;flex-shrink:0}.tour-swipe-ind{display:flex;justify-content:center;align-items:center;gap:10px;padding:8px 0 2px}.tour-swipe-ind .pdots{display:flex;gap:6px;align-items:center}.tour-swipe-ind .d{width:6px;height:6px;border-radius:50%;padding:0;border:0;background:var(--mist);transition:all .3s ease;cursor:pointer}.tour-swipe-ind .d.on{width:22px;border-radius:3px;background:var(--koko-green)}.tour-swipe-ind .arrow{border:0;background:transparent;color:#8a938e;font-size:22px;line-height:1;padding:2px 4px;cursor:pointer;animation:tourSlideHint 1.8s ease-in-out infinite}.tour-swipe-ind .arrow.back{transform:scaleX(-1);animation-name:tourSlideHintBack}@keyframes tourSlideHint{0%,to{transform:translate(0);opacity:.5}50%{transform:translate(4px);opacity:.95}}@keyframes tourSlideHintBack{0%,to{transform:scaleX(-1) translate(0);opacity:.5}50%{transform:scaleX(-1) translate(4px);opacity:.95}}.tour-final-actions{display:flex;gap:10px;align-items:center}.tour-prev{height:54px;padding:0 18px;border:0;border-radius:14px;background:transparent;color:var(--stone);font-family:inherit;font-size:14px;font-weight:700;cursor:pointer}.tour-start{flex:1;height:54px;border:0;border-radius:14px;background:var(--koko-green);color:#fff;font-family:inherit;font-size:15.5px;font-weight:800;letter-spacing:0;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 8px 22px -6px #2f7d5c80;cursor:pointer}.tour-start:active{transform:scale(.99)}.tour-map-stage,.tour-memo-stage,.tour-privacy-stage{width:100%;height:100%;min-height:292px;border-radius:22px;position:relative;overflow:hidden;box-shadow:0 22px 40px -22px #0003,0 0 0 1px #0000000d}.tour-map-stage{background:linear-gradient(180deg,#eef3ec,#e3ebe2)}.tour-map-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.5;background-image:linear-gradient(transparent 49%,rgba(31,92,68,.12) 50%,transparent 51%),linear-gradient(90deg,transparent 49%,rgba(31,92,68,.12) 50%,transparent 51%);background-size:28px 28px}.tour-road{position:absolute;background:#fff;box-shadow:0 0 0 1px #cdd7c8 inset}.tour-park{position:absolute;right:10%;bottom:14%;width:30%;height:24%;background:#cad9b3;border-radius:30% 70% 40% 60%/50% 30% 70% 50%;opacity:.7}.tour-water{position:absolute;left:-10%;top:8%;width:34%;height:20%;background:#bfd2dc;border-radius:60% 40% 50% 60%/40% 60% 40% 50%;opacity:.85}.tour-pin{position:absolute;z-index:2;width:38px;height:48px;transform-origin:50% 100%;transform:translate(-50%,-100%) translateY(-8px) scale(.7);opacity:0;transition:transform .42s cubic-bezier(.2,1.4,.3,1),opacity .35s ease-out}.tour-pin.in{transform:translate(-50%,-100%) scale(1);opacity:1;animation:tourPinBounce .42s cubic-bezier(.2,.7,.3,1)}@keyframes tourPinBounce{0%{transform:translate(-50%,-100%) translateY(-12px) scale(.85)}55%{transform:translate(-50%,-100%) scale(1.08)}to{transform:translate(-50%,-100%) scale(1)}}.tour-pin-head{width:38px;height:38px;border-radius:50%;background:linear-gradient(180deg,#fff,#f3eee0);border:3.5px solid var(--koko-green);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 12px -4px #00000040,0 0 0 1px #0000000a}.tour-pin-tail{width:0;height:0;border:7px solid transparent;border-top:10px solid var(--koko-green);margin:-3px auto 0;filter:drop-shadow(0 2px 1px rgba(0,0,0,.18))}.tour-pin.amber .tour-pin-head{border-color:var(--amber)}.tour-pin.amber .tour-pin-tail{border-top-color:var(--amber)}.tour-pin.blue .tour-pin-head{border-color:var(--blue)}.tour-pin.blue .tour-pin-tail{border-top-color:var(--blue)}.tour-avatar{width:24px;height:24px;border-radius:50%;display:block;flex-shrink:0}.tour-avatar.a{background:linear-gradient(135deg,#c9a576,#a37f48)}.tour-avatar.b{background:linear-gradient(135deg,#7c9c8a,#56776a)}.tour-avatar.c{background:linear-gradient(135deg,#b06c5a,#7a3f30)}.tour-avatar.d{background:linear-gradient(135deg,#5b6f8a,#36495c)}.tour-avatar.e{background:linear-gradient(135deg,#9a8aa6,#6b5e7e)}.tour-pin.cluster{width:54px;height:48px}.tour-pin.cluster .tour-pin-head{width:54px;height:36px;border-radius:18px;border-color:var(--ink);padding:0 5px;background:#fff}.tour-pin.cluster .tour-pin-tail{border-top-color:var(--ink)}.tour-pin.cluster .tour-avatar{width:18px;height:18px;border:2px solid #fff;margin-left:-7px}.tour-pin.cluster .tour-avatar:first-child{margin-left:0}.tour-cluster-card{position:absolute;left:50%;top:30%;z-index:3;transform:translate(-50%) translateY(-20px);display:flex;align-items:center;gap:10px;background:#fff;border-radius:14px;padding:10px 14px;box-shadow:0 14px 28px -12px #00000040,0 0 0 1px #0000000d;white-space:nowrap;font-size:12px;color:#2c322e;font-weight:700;opacity:0;transition:opacity .35s ease,transform .35s cubic-bezier(.2,.9,.3,1)}.tour-cluster-card.in{opacity:1;transform:translate(-50%) translateY(0)}.tour-cluster-card span{width:8px;height:8px;border-radius:50%;background:var(--koko-green);box-shadow:0 0 #2f7d5c66;animation:tourPulse 1.8s ease-out infinite}@keyframes tourPulse{0%{box-shadow:0 0 #2f7d5c66}70%{box-shadow:0 0 0 12px #2f7d5c00}to{box-shadow:0 0 #2f7d5c00}}.tour-friend-card{position:absolute;right:14px;bottom:78px;z-index:3;display:flex;align-items:center;gap:10px;max-width:200px;background:#fff;border-radius:14px;padding:11px 13px;box-shadow:0 14px 30px -10px #00000047,0 0 0 1px #0000000d;opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .4s ease}.tour-friend-card.in{opacity:1;transform:translateY(0)}.tour-friend-card .tour-avatar{width:28px;height:28px}.tour-friend-card .who{font-size:11px;color:var(--stone);font-weight:600}.tour-friend-card .place{font-size:12.5px;font-weight:800;color:var(--ink);margin-top:1px}.tour-friend-card .tag{font-size:10px;color:var(--koko-green);font-weight:800;margin-top:3px}.tour-legend{position:absolute;left:14px;right:14px;bottom:14px;z-index:3;display:flex;gap:6px;flex-wrap:wrap;opacity:0;transition:opacity .4s ease}.tour-legend.in{opacity:1}.tour-legend span{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:5px 10px;background:#ffffffeb;font-size:10.5px;font-weight:700;color:#2c322e;box-shadow:0 2px 8px -2px #0000001a}.tour-legend i{width:7px;height:7px;border-radius:50%;display:block}.tour-legend .green{background:var(--koko-green)}.tour-legend .amber{background:var(--amber)}.tour-legend .blue{background:var(--blue)}.tour-memo-stage{padding:18px;display:flex;flex-direction:column;gap:14px;background:radial-gradient(circle at 30% 10%,rgba(232,162,58,.1),transparent 55%),radial-gradient(circle at 80% 95%,rgba(47,125,92,.1),transparent 55%),#fbf8ef}.tour-memo-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(rgba(31,33,30,.04) 1px,transparent 1.2px);background-size:3px 3px;mix-blend-mode:multiply;opacity:.6}.tour-place-row{display:flex;align-items:center;gap:10px;position:relative;z-index:1}.tour-place-row .mini-map{width:42px;height:42px;border-radius:11px;background:linear-gradient(180deg,#eef3ec,#dde6db);border:1px solid rgba(0,0,0,.05);position:relative;flex-shrink:0}.tour-place-row .mini-map:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background:var(--koko-green);box-shadow:0 0 0 3px #fff}.tour-place-row .name{font-size:14.5px;font-weight:900;color:var(--ink)}.tour-place-row .meta{font-size:10.5px;color:var(--stone);margin-top:2px;font-family:var(--font-mono);letter-spacing:.04em}.tour-section-label{position:relative;z-index:1;font-size:10.5px;color:var(--stone);font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;font-weight:600}.tour-tag-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;position:relative;z-index:1}.tour-tag{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 13px;border-radius:999px;background:#fff;border:1px solid var(--mist);font-size:12.5px;font-weight:700;color:#2c322e;white-space:nowrap;transition:all .3s cubic-bezier(.2,.9,.3,1)}.tour-tag i{width:8px;height:8px;border-radius:50%;background:var(--koko-green)}.tour-tag.amber i{background:var(--amber)}.tour-tag.blue i{background:var(--blue)}.tour-tag.purple i{background:var(--tag-meh)}.tour-tag.on{background:var(--koko-green);border-color:var(--koko-green);color:#fff;box-shadow:0 6px 14px -4px #2f7d5c66}.tour-tag.on i{background:#fff;transform:scale(1.15)}.tour-memo-box{margin-top:8px;position:relative;z-index:1;min-height:120px;display:flex;flex-direction:column;background:#fff;border:1px solid var(--mist);border-radius:14px;padding:14px 14px 10px}.tour-memo-text{flex:1;min-height:60px;color:var(--ink);font-size:13.5px;line-height:1.85;font-weight:600}.tour-memo-text .placeholder{color:#8a938e;font-weight:500}.tour-memo-text .caret{display:inline-block;width:2px;height:1.1em;background:var(--koko-green);vertical-align:-3px;margin-left:1px;animation:tourCaret .9s steps(1) infinite}@keyframes tourCaret{50%{opacity:0}}.tour-counter{align-self:flex-end;margin-top:6px;color:#8a938e;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em}.tour-counter.lit{color:var(--koko-green);font-weight:700}.tour-note{position:relative;z-index:1;text-align:center;margin-top:auto;padding-top:6px;color:var(--stone);font-size:11px;letter-spacing:.02em}.tour-note span{color:#2c322e;font-weight:700;text-decoration:line-through;text-decoration-color:#00000040}.tour-privacy-stage{background:radial-gradient(circle at 50% 90%,rgba(47,125,92,.12),transparent 55%),linear-gradient(180deg,#fbf8ef,#f3efe2)}.tour-privacy-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.35;background-image:linear-gradient(transparent 49%,rgba(31,92,68,.1) 50%,transparent 51%),linear-gradient(90deg,transparent 49%,rgba(31,92,68,.1) 50%,transparent 51%);background-size:32px 32px}.tour-range-row{position:absolute;top:14px;left:50%;z-index:3;transform:translate(-50%);display:flex;gap:6px;background:#fff;border-radius:12px;padding:4px;box-shadow:0 6px 16px -4px #00000029,0 0 0 1px #0000000f}.tour-range-row .rng{padding:7px 12px;border-radius:9px;font-size:12px;font-weight:700;color:var(--stone);white-space:nowrap;transition:all .25s ease}.tour-range-row .rng.on{background:var(--ink);color:#fff}.tour-range-row .rng.on.green{background:var(--koko-green)}.tour-range-row .rng.on.amber{background:var(--amber)}.tour-ring{position:absolute;left:50%;top:calc(50% + 28px);border-radius:50%;border:1.5px solid var(--koko-green);transform:translate(-50%,-50%) scale(.4);opacity:0;transition:transform .55s cubic-bezier(.2,.7,.3,1),opacity .55s ease,border-color .3s ease,background .3s ease}.tour-ring.r1{width:60px;height:60px}.tour-ring.r2{width:130px;height:130px}.tour-ring.r3{width:200px;height:200px}.tour-ring.in{transform:translate(-50%,-50%) scale(1);opacity:.85}.tour-ring.dim{opacity:.18}.tour-ring.r1.in{border-color:var(--ink);background:#1e24201a}.tour-ring.r2.in{border-color:var(--koko-green);background:#2f7d5c14}.tour-ring.r3.in{border-color:var(--amber);background:#e8a23a0d}.tour-privacy-pin{position:absolute;left:50%;top:50%;z-index:2;transform:translate(-50%,-54%);width:48px;height:60px;filter:drop-shadow(0 8px 12px rgba(31,92,68,.35))}.tour-privacy-pin .head{width:48px;height:48px;border-radius:50%;background:linear-gradient(180deg,#fff,#f3eee0);border:4px solid var(--koko-green);display:flex;align-items:center;justify-content:center;box-shadow:inset 0 -3px 6px #0000000f}.tour-privacy-pin .head span{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#c9a576,#a37f48)}.tour-privacy-pin .tail{width:0;height:0;border:8px solid transparent;border-top:12px solid var(--koko-green);margin:-3px auto 0;filter:drop-shadow(0 2px 1px rgba(0,0,0,.18))}.devrail{position:fixed;left:18px;top:18px;z-index:50;width:210px;max-height:calc(100vh - 36px);background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--mist);border-radius:14px;box-shadow:0 12px 30px -16px #0006;font-family:var(--font-jp);overflow:hidden;display:flex;flex-direction:column}.devrail.closed{width:auto}.devrail-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:11px 14px;font-size:12px;font-weight:700;color:var(--ink);cursor:pointer;border-bottom:1px solid var(--mist)}.devrail.closed .devrail-head{border-bottom:0}.devrail-body{overflow-y:auto;padding:8px}.devrail-group{margin-bottom:8px}.devrail-grouptitle{font-size:10px;letter-spacing:.08em;color:var(--stone);font-weight:700;padding:4px 6px;text-transform:uppercase}.devrail-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;border:0;background:transparent;cursor:pointer;padding:7px 8px;border-radius:8px;font-family:inherit;font-size:12.5px;color:var(--ink)}.devrail-item:hover{background:var(--soft-map)}.devrail-item.on{background:#e8f3ec;color:var(--koko-green);font-weight:700}.devrail-id{font-family:var(--font-mono);font-size:10px;color:var(--stone);background:var(--soft-map);border:1px solid var(--mist);border-radius:5px;padding:1px 4px;flex-shrink:0}.devrail-item.on .devrail-id{color:var(--koko-green);border-color:#cfe2d6}@media(max-width:900px){.devrail{display:none}}
