:root{--light-blue: #CDEBF1;--light-green: #DEF1D0;--light-purple: #CBCEEA;--light-pink: #F8E5E5;--light-gray: #F8F6F5;--warm-white: #FDF8E2;--olive-text: #6F7F2F;--calm-green: #A3B565;--pale-orange: #FCDD9D;--soft-apricot: #DFA36F;--tag-rice: #fbf1d7;--tag-peach: #fad6b5;--tag-coral: #faadac;--tag-sakura: #fcdfe5;--tag-mint: #daf1ee;--tag-sky: #b6e3e7;--white: #FEFEFE;--ink: #5F6E2C;--muted: #7E8663;--stone: #5D5D5A;--shadow: 0 24px 70px color-mix(in srgb, var(--olive-text) 16%, transparent);--sans: Avenir Next, Helvetica Neue, PingFang SC, Hiragino Sans GB, Microsoft YaHei, sans-serif;--mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{color:var(--ink);font-family:var(--sans);background:radial-gradient(circle at 16% 6%,color-mix(in srgb,var(--light-blue) 74%,transparent),transparent 28%),radial-gradient(circle at 82% 2%,color-mix(in srgb,var(--light-pink) 74%,transparent),transparent 30%),radial-gradient(circle at 68% 88%,color-mix(in srgb,var(--pale-orange) 46%,transparent),transparent 28%),radial-gradient(circle at 5% 86%,color-mix(in srgb,var(--light-purple) 42%,transparent),transparent 24%),linear-gradient(180deg,var(--light-gray),color-mix(in srgb,var(--light-blue) 22%,var(--light-gray)) 48%,color-mix(in srgb,var(--light-pink) 30%,var(--light-gray)))}body:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.32;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='.22'/%3E%3C/svg%3E");mix-blend-mode:multiply}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer}.shell{position:relative;min-height:100vh}.nav{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px clamp(18px,4vw,54px);background:color-mix(in srgb,var(--light-gray) 76%,transparent);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.brand{display:flex;align-items:center;gap:12px;min-width:230px;font-weight:800;letter-spacing:-.02em}.brand img{width:36px;height:36px;object-fit:contain}.brand small{display:block;margin-top:2px;color:var(--muted);font-size:11px;font-family:var(--mono);font-weight:500;letter-spacing:0}.tabs{display:flex;align-items:center;gap:2px;padding:5px;border-radius:999px;background:color-mix(in srgb,var(--white) 72%,transparent);box-shadow:0 12px 34px color-mix(in srgb,var(--olive-text) 9%,transparent),inset 0 -16px 26px color-mix(in srgb,var(--light-blue) 18%,transparent)}.tabs a{border-radius:999px;padding:9px 18px;color:var(--muted);font-weight:700}.tabs a.active{color:#fff;background:var(--olive-text)}.login-btn,.primary-btn,.plain-btn,.logout-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:0;border-radius:999px;padding:11px 17px;background:var(--soft-apricot);color:#fff;font-weight:700;box-shadow:0 10px 26px color-mix(in srgb,var(--soft-apricot) 28%,transparent);transition:transform .18s ease,box-shadow .18s ease}.plain-btn{background:color-mix(in srgb,var(--white) 74%,transparent);color:var(--ink);box-shadow:none}.account-actions{display:flex;align-items:center;gap:8px;padding:5px;border-radius:999px;background:color-mix(in srgb,var(--white) 68%,transparent);box-shadow:0 12px 34px color-mix(in srgb,var(--olive-text) 8%,transparent),inset 0 -12px 20px color-mix(in srgb,var(--light-blue) 14%,transparent)}.account-link{display:grid;min-width:108px;padding:7px 12px 7px 15px;border-radius:999px}.account-name{max-width:118px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:800}.account-link small{color:var(--muted);font-size:10px;font-family:var(--mono);font-weight:700}.logout-btn{padding:9px 13px;background:color-mix(in srgb,var(--light-pink) 78%,var(--white));color:color-mix(in srgb,#a25f61 60%,var(--ink));box-shadow:none}.login-btn:hover,.primary-btn:hover,.plain-btn:hover,.logout-btn:hover{transform:translateY(-1px);box-shadow:0 16px 34px color-mix(in srgb,var(--soft-apricot) 32%,transparent)}.user-btn{max-width:180px}.kicker{margin:0 0 10px;color:color-mix(in srgb,#4c8ea0 72%,var(--olive-text));font-family:var(--mono);font-size:12px;font-weight:700}.map-page{min-height:calc(100vh - 72px);padding:24px clamp(18px,4vw,54px) 46px}.map-hero{position:relative;min-height:calc(100vh - 140px);border-radius:34px;overflow:hidden;background:radial-gradient(circle at 14% 18%,color-mix(in srgb,var(--light-blue) 55%,transparent),transparent 24%),radial-gradient(circle at 88% 24%,color-mix(in srgb,var(--light-pink) 70%,transparent),transparent 25%),radial-gradient(circle at 76% 82%,color-mix(in srgb,var(--pale-orange) 44%,transparent),transparent 24%),linear-gradient(135deg,color-mix(in srgb,var(--white) 82%,transparent),color-mix(in srgb,var(--warm-white) 72%,transparent)),radial-gradient(circle at 60% 42%,color-mix(in srgb,var(--light-purple) 26%,transparent),transparent 30%);box-shadow:var(--shadow)}.map-hero:before{content:"";position:absolute;inset:10% 7% 9%;clip-path:polygon(17% 33%,25% 20%,43% 19%,58% 24%,70% 18%,86% 30%,80% 48%,91% 61%,73% 75%,52% 72%,38% 82%,24% 70%,10% 62%,18% 47%);background:linear-gradient(140deg,color-mix(in srgb,var(--light-blue) 18%,transparent),color-mix(in srgb,var(--light-purple) 14%,transparent) 48%,color-mix(in srgb,var(--light-pink) 18%,transparent));opacity:.5}.map-copy{position:absolute;left:clamp(24px,5vw,72px);top:clamp(28px,6vw,78px);z-index:2;width:min(36vw,560px);max-width:560px}.map-copy h1{margin:0;font-size:clamp(40px,5vw,76px);line-height:1.12;letter-spacing:0}.map-copy p:not(.kicker){max-width:500px;color:var(--muted);font-weight:700;line-height:1.7}.abstract-map{position:absolute;left:auto;right:clamp(22px,4vw,58px);top:12%;width:min(48vw,820px);aspect-ratio:1.42 / 1;z-index:1;overflow:hidden;border-radius:28px;background:radial-gradient(circle at 56% 44%,color-mix(in srgb,var(--light-blue) 24%,transparent),transparent 44%),color-mix(in srgb,var(--white) 12%,transparent)}.map-tools{position:absolute;right:clamp(34px,6vw,86px);top:9%;z-index:8;display:flex;gap:7px;padding:6px;border-radius:999px;background:color-mix(in srgb,var(--white) 72%,transparent);box-shadow:0 12px 34px color-mix(in srgb,var(--olive-text) 9%,transparent),inset 0 -12px 20px color-mix(in srgb,var(--light-blue) 15%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.map-tools button{min-width:34px;height:34px;border:0;border-radius:999px;background:transparent;color:var(--ink);font-weight:800}.map-tools button:hover{background:var(--olive-text);color:#fff}.echarts-map{position:absolute;inset:0;width:100%;height:100%}.map-loading{position:absolute;right:18%;top:46%;z-index:2;color:var(--muted);font-family:var(--mono);font-size:12px}.map-dot{position:absolute;z-index:3;width:11px;height:11px;border:0;border-radius:999px;background:var(--olive-text);box-shadow:0 0 0 12px color-mix(in srgb,var(--olive-text) 13%,transparent),0 14px 32px color-mix(in srgb,var(--olive-text) 22%,transparent);animation:breathe 2.8s ease-in-out infinite}.dot-1,.dot-want{background:#6fbfd2;box-shadow:0 0 0 12px color-mix(in srgb,#6fbfd2 18%,transparent),0 14px 32px color-mix(in srgb,#6fbfd2 20%,transparent)}.dot-2,.dot-done{background:var(--soft-apricot);box-shadow:0 0 0 12px color-mix(in srgb,var(--soft-apricot) 18%,transparent),0 14px 32px color-mix(in srgb,var(--soft-apricot) 20%,transparent)}.dot-3{background:var(--calm-green)}@keyframes breathe{50%{transform:scale(1.35)}}.hover-card{position:absolute;right:auto;bottom:auto;z-index:12;display:block;width:min(360px,calc(100% - 36px));min-height:150px;padding:20px;border:1px solid color-mix(in srgb,var(--white) 66%,transparent);border-radius:24px;background:color-mix(in srgb,var(--white) 62%,transparent);box-shadow:0 28px 70px color-mix(in srgb,var(--olive-text) 18%,transparent),inset 0 1px color-mix(in srgb,var(--white) 82%,transparent);backdrop-filter:blur(18px) saturate(1.18);-webkit-backdrop-filter:blur(18px) saturate(1.18);cursor:pointer;transform:translateY(0);transition:transform .18s ease,background .18s ease,box-shadow .18s ease}.hover-card h3{margin:0;font-size:24px;line-height:1.05}.hover-card:hover{transform:translateY(-3px);background:color-mix(in srgb,var(--white) 72%,transparent);box-shadow:0 34px 82px color-mix(in srgb,var(--olive-text) 22%,transparent),inset 0 1px color-mix(in srgb,var(--white) 88%,transparent)}.hover-card .kicker{margin-bottom:8px}.hover-card .chip-row{margin-top:13px}.hover-city{margin:8px 0 0;color:var(--muted);font-family:var(--mono);font-size:12px;font-weight:700}.site-intro{display:grid;grid-template-columns:minmax(240px,.72fr) minmax(0,1.08fr) minmax(260px,.8fr);gap:18px;padding:56px 4vw 20px;opacity:0;transform:translateY(28px);pointer-events:none;transition:opacity .45s ease,transform .45s ease}.site-intro.intro-visible{opacity:1;transform:translateY(0);pointer-events:auto}.intro-panel{padding:24px;border-radius:28px;background:color-mix(in srgb,var(--white) 62%,transparent);box-shadow:0 18px 42px color-mix(in srgb,var(--olive-text) 7%,transparent),inset 0 1px color-mix(in srgb,var(--white) 72%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.intro-panel h2,.page-title{margin:0;font-size:clamp(30px,4vw,52px);line-height:1.06}.intro-welcome h2{font-size:clamp(26px,3.1vw,42px)}.intro-concept p,.description{color:var(--muted);line-height:1.68;font-size:16px}.accordion{display:grid;gap:10px;margin-top:18px}.accordion-item{border-radius:20px;background:color-mix(in srgb,var(--white) 62%,transparent);overflow:hidden}.accordion-item button{width:100%;border:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 16px;background:transparent;color:var(--ink);font-weight:800;text-align:left}.accordion-item p{max-height:0;margin:0;padding:0 16px;overflow:hidden;color:var(--muted);line-height:1.6;transition:max-height .24s ease,padding .24s ease}.accordion-item.open p{max-height:90px;padding:0 16px 16px}.workspace{padding:34px clamp(18px,4vw,54px) 70px}.page-head{display:flex;justify-content:space-between;align-items:end;gap:24px;margin:22px 0 28px}.search-wrap{position:relative;display:block}.search-wrap svg{position:absolute;left:22px;top:18px;color:var(--muted)}.search{width:100%;height:54px;border:0;border-radius:999px;padding:0 22px 0 52px;outline:none;color:var(--ink);background:color-mix(in srgb,var(--white) 78%,transparent);box-shadow:0 14px 34px color-mix(in srgb,var(--olive-text) 8%,transparent),inset 0 -16px 28px color-mix(in srgb,var(--light-blue) 15%,transparent)}.filters,.chip-row{display:flex;flex-wrap:wrap;gap:8px}.filters{margin:14px 0 20px}.chip{--chip-fill: color-mix(in srgb, var(--white) 82%, transparent);--chip-text: var(--olive-text);display:inline-flex;align-items:center;border:0;border-radius:999px;padding:8px 12px;background:var(--chip-fill);color:var(--chip-text);font-size:12px;font-weight:700;box-shadow:0 8px 18px color-mix(in srgb,var(--chip-text) 10%,transparent),inset 0 -11px 18px color-mix(in srgb,var(--white) 34%,transparent),inset 0 1px color-mix(in srgb,var(--white) 88%,transparent)}.chip-0{--chip-fill: var(--tag-rice);--chip-text: #7b6426}.chip-1{--chip-fill: var(--tag-peach);--chip-text: #8b5627}.chip-2{--chip-fill: var(--tag-coral);--chip-text: #8f4144}.chip-3{--chip-fill: var(--tag-sakura);--chip-text: #934c61}.chip-4{--chip-fill: var(--tag-mint);--chip-text: #3f746f}.chip-5{--chip-fill: var(--tag-sky);--chip-text: #346d78}.active-chip{background:var(--olive-text);color:#fff}.content-grid{display:grid;grid-template-columns:160px minmax(0,1fr);gap:26px;align-items:start}.cities{position:sticky;top:92px;display:grid;gap:4px;padding:10px;border-radius:24px;background:color-mix(in srgb,var(--white) 50%,transparent)}.cities button{border:0;background:transparent;text-align:left;border-radius:999px;padding:10px 13px;color:var(--muted)}.cities button.active,.record-tabs button.active{background:var(--olive-text);color:#fff}.cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.space-card,.nomad-card,.review-card,.profile,.side-note,.record,.space-row,.empty-state{border-radius:28px;background:color-mix(in srgb,var(--white) 72%,transparent);box-shadow:0 18px 42px color-mix(in srgb,var(--olive-text) 7%,transparent),inset 0 1px color-mix(in srgb,var(--white) 72%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.space-card,.space-row,.record{position:relative;overflow:hidden;transition:transform .2s ease,background .2s ease,box-shadow .2s ease}.space-card{min-height:230px;padding:21px;display:flex;flex-direction:column;justify-content:space-between}.space-card:hover,.space-row:hover,.nomad-card:hover,.record:hover{transform:translateY(-4px);background:color-mix(in srgb,var(--white) 88%,transparent);box-shadow:0 22px 54px color-mix(in srgb,var(--olive-text) 14%,transparent)}.space-card h3,.nomad-card h3{margin:8px 0 0;font-size:22px}.space-card p,.nomad-card p,.review-card p,.side-note p{color:var(--muted);line-height:1.55;margin:12px 0 0;font-size:14px}.meta{color:var(--muted);font-size:12px;font-family:var(--mono)}.space-list{display:grid;gap:12px}.space-row{display:grid;grid-template-columns:minmax(180px,1fr) 90px minmax(240px,1fr);gap:14px;align-items:center;padding:16px 18px}.detail{padding:42px clamp(18px,4vw,54px) 80px}.detail-hero{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:34px;align-items:end;margin-bottom:36px}.detail-hero h1{margin:12px 0 18px;font-size:clamp(38px,6vw,76px);line-height:1.02}.score-box{padding:24px;border-radius:30px;background:var(--olive-text);color:#fff;box-shadow:0 26px 60px color-mix(in srgb,var(--olive-text) 24%,transparent)}.score{font-size:58px;font-weight:800;line-height:.95}.detail-body{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:24px}.activity-block{margin-top:40px}.activity{display:grid;grid-template-columns:minmax(0,1fr) 110px 76px;gap:12px;align-items:center;padding:16px 0;color:var(--muted)}.activity+.activity{border-top:1px solid color-mix(in srgb,var(--olive-text) 10%,transparent)}.side-stack{display:grid;gap:14px}.status{display:grid;grid-template-columns:1fr 1fr;gap:10px}.status button{border:0;border-radius:999px;padding:13px;background:color-mix(in srgb,var(--white) 76%,transparent);color:var(--ink);font-weight:800;box-shadow:0 10px 24px color-mix(in srgb,currentColor 10%,transparent),inset 0 -13px 22px color-mix(in srgb,var(--white) 34%,transparent),inset 0 1px color-mix(in srgb,var(--white) 84%,transparent)}.status .want{color:color-mix(in srgb,#4c8ea0 70%,var(--olive-text));background:color-mix(in srgb,var(--light-blue) 42%,var(--white))}.status .done{color:color-mix(in srgb,#a67834 70%,var(--olive-text));background:color-mix(in srgb,var(--pale-orange) 46%,var(--white))}.status .selected{background:var(--olive-text);color:#fff}.side-note,.review-card{padding:18px}.side-note h2,.activity-block h2{margin:0 0 14px}.review-card+.review-card{margin-top:12px}.review-top{display:flex;justify-content:space-between;gap:12px;color:var(--muted);font-size:13px}.stars{display:flex;gap:2px;margin-top:9px;color:var(--soft-apricot)}.stars.big{margin:0 0 10px}.rating-field{display:grid;gap:8px;margin:0;padding:0;border:0}.rating-field legend{padding:0;color:var(--muted);font-size:13px;font-weight:700}.star-picker{display:flex;gap:6px}.star-picker button{width:38px;height:38px;border:0;border-radius:999px;background:color-mix(in srgb,var(--white) 74%,transparent);color:color-mix(in srgb,var(--soft-apricot) 42%,var(--muted));font-size:24px;line-height:1;box-shadow:inset 0 -9px 16px color-mix(in srgb,var(--pale-orange) 18%,transparent),0 8px 18px color-mix(in srgb,var(--olive-text) 7%,transparent);transition:transform .16s ease,color .16s ease,background .16s ease,box-shadow .16s ease}.star-picker button.selected{background:color-mix(in srgb,var(--pale-orange) 56%,var(--white));color:var(--soft-apricot)}.star-picker button:hover,.star-picker button:focus-visible{transform:translateY(-2px) scale(1.04);outline:none;box-shadow:inset 0 -9px 16px color-mix(in srgb,var(--pale-orange) 22%,transparent),0 12px 24px color-mix(in srgb,var(--soft-apricot) 18%,transparent)}.nomad-layout{columns:3 260px;column-gap:18px}.nomad-card{display:inline-block;width:100%;padding:22px;margin:0 0 18px}.stats{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.stat{border-radius:999px;padding:8px 11px;background:color-mix(in srgb,var(--white) 70%,transparent);font-family:var(--mono);font-size:12px;color:var(--muted)}.profile{display:flex;justify-content:space-between;align-items:end;gap:20px;padding:28px;margin-bottom:24px}.profile h1{margin:0 0 12px;font-size:clamp(36px,5vw,64px);line-height:1.02}.logged-out{align-items:center}.me-grid{display:grid;grid-template-columns:minmax(300px,.9fr) minmax(0,1.1fr);gap:22px}.trail-map{position:relative;min-height:480px;border-radius:34px;overflow:hidden;background:radial-gradient(circle at 55% 46%,color-mix(in srgb,var(--light-blue) 38%,transparent),transparent 30%),color-mix(in srgb,var(--white) 58%,transparent);box-shadow:0 18px 42px color-mix(in srgb,var(--olive-text) 7%,transparent),inset 0 1px color-mix(in srgb,var(--white) 72%,transparent)}.trail-echarts-map{position:absolute;inset:0;width:100%;height:100%}.trail-empty{position:absolute;left:22px;bottom:22px;z-index:3;color:var(--muted);font-weight:700}.trail-legend{position:absolute;left:18px;top:18px;z-index:4;display:flex;gap:8px;padding:8px;border-radius:999px;background:color-mix(in srgb,var(--white) 72%,transparent);box-shadow:0 10px 26px color-mix(in srgb,var(--olive-text) 8%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.trail-legend span{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;font-weight:800}.trail-legend i{width:10px;height:10px;border-radius:999px;box-shadow:0 0 0 3px color-mix(in srgb,currentColor 14%,transparent)}.legend-want{color:#69b8c9;background:#69b8c9}.legend-done{color:var(--soft-apricot);background:var(--soft-apricot)}.record-tabs{display:flex;gap:8px;margin-bottom:14px}.record-tabs button{border:0;border-radius:999px;padding:11px 14px;background:color-mix(in srgb,var(--white) 62%,transparent);color:var(--muted);font-weight:700;box-shadow:0 8px 18px color-mix(in srgb,var(--olive-text) 7%,transparent),inset 0 -10px 18px color-mix(in srgb,var(--light-blue) 15%,transparent)}.record{display:flex;justify-content:space-between;gap:18px;padding:16px;margin-top:12px}.record time{white-space:nowrap;color:var(--muted);font-size:13px}.empty-state{padding:24px;color:var(--muted)}.empty-state p{margin:0 0 14px}.modal-backdrop{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:20px;background:color-mix(in srgb,var(--stone) 24%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.modal{width:min(520px,100%);max-height:90vh;overflow:auto;border-radius:30px;padding:24px;background:color-mix(in srgb,var(--white) 88%,transparent);box-shadow:0 30px 80px color-mix(in srgb,var(--olive-text) 22%,transparent)}.modal-head{display:flex;justify-content:space-between;gap:18px;align-items:start;margin-bottom:18px}.modal-head h2{margin:0;font-size:28px}.icon-btn{width:36px;height:36px;border:0;border-radius:999px;background:color-mix(in srgb,var(--light-pink) 75%,var(--white));color:var(--ink);font-size:22px}.auth-form{display:grid;gap:12px}.auth-form label{display:grid;gap:7px;color:var(--muted);font-size:13px;font-weight:700}.auth-form input,.auth-form select,.auth-form textarea{width:100%;border:0;border-radius:18px;padding:12px 14px;outline:none;color:var(--ink);background:color-mix(in srgb,var(--white) 82%,transparent)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-error{margin:0;color:#b45d54;font-weight:700}.switch-auth{margin-top:14px;border:0;background:transparent;color:var(--muted);font-weight:700}@media(max-width:900px){.nav{flex-wrap:wrap}.brand{min-width:auto}.tabs{order:3;width:100%;justify-content:space-between}.tabs a{padding-inline:12px}.map-copy h1{font-size:44px;line-height:1.1}.map-copy{width:auto;max-width:min(560px,calc(100% - 36px))}.hover-card{right:auto;bottom:auto;width:min(360px,calc(100% - 36px))}.abstract-map{inset:35% 18px auto;width:auto;aspect-ratio:1.34 / 1}.map-tools{top:35%;right:28px}.site-intro,.content-grid,.detail-hero,.detail-body,.me-grid{grid-template-columns:1fr}.cities{position:static;display:flex;overflow:auto}.cards,.space-row{grid-template-columns:1fr}.profile,.record{align-items:start;flex-direction:column}}
