:root{--color-bg:#f8f5ee;--color-text:#171717;--color-sub-text:#8a7e70;--color-hot:#ff4b2e;--color-go-now:#27b36a;--color-save:#315bff;--color-dark:#15110e;--color-photo-red-soil:#c8543a;--color-photo-old-green:#5e7c6b;--color-photo-ochre:#b5894e;--color-photo-wisteria:#8a6ba8;--color-card:#ffffff94;--color-line:#17171724;--font-heading:"Shippori Mincho", serif;--font-body:"Noto Sans JP", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;color:var(--color-text);background:var(--color-bg);font-family:var(--font-body);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{background:var(--color-bg)}body{background:var(--color-bg);min-width:320px;min-height:100vh;margin:0}#root{min-height:100vh}button,input,textarea,select{font:inherit}.app-layout{background:var(--color-bg);min-height:100vh}.app-layout--immersive{background:var(--color-dark)}.app-layout-header{justify-content:space-between;align-items:center;gap:16px;width:min(100%,1120px);margin:0 auto;padding:18px 20px 0;display:flex}.app-layout-logo-link{color:var(--color-text);text-decoration:none;display:inline-flex}.app-layout-logo-link:focus-visible{outline:3px solid var(--color-hot);outline-offset:4px;border-radius:8px}.app-layout--immersive .app-layout-logo-link{color:var(--color-bg)}.app-layout-login-link{color:var(--color-sub-text);border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:7px 11px;font-size:13px;font-weight:800;line-height:1.3;text-decoration:none;display:inline-flex}.app-layout-login-link:focus-visible,.app-layout-login-link:hover{color:var(--color-hot);border-color:#ff4b2e3d}.app-layout--immersive .logo-mark{--logo-ink:var(--color-bg);--logo-paper:var(--color-dark);background:var(--color-dark);border-color:#f8f5ee33}.app-layout-main{min-height:calc(100svh - 48px);padding-bottom:calc(104px + env(safe-area-inset-bottom))}.app-shell{width:min(100%,1120px);margin:0 auto;padding:32px 20px 72px}.zine-header{max-width:760px;margin-bottom:56px}.logo{width:fit-content;color:var(--color-text);align-items:center;gap:10px;display:inline-flex}.app-layout-logo-link .logo{color:inherit}.logo-mark{--logo-accent:var(--color-hot);--logo-ink:var(--color-text);--logo-paper:var(--color-bg);--logo-road:var(--color-photo-old-green);border:1px solid var(--color-line);background:var(--color-bg);border-radius:8px;flex:none;display:inline-block;position:relative;overflow:hidden}.logo-mark-svg{width:100%;height:100%;display:block;position:absolute;inset:0}.logo-mark-road,.logo-mark-leg,.logo-mark-foot,.logo-mark-arm-outline,.logo-mark-arm-fill,.logo-mark-twist,.logo-mark-hand-line,.logo-mark-face-line,.logo-mark-hand-accent{fill:none;stroke-linecap:round;stroke-linejoin:round}.logo-mark-road{stroke:var(--logo-road);stroke-width:5.5px}.logo-mark-leg,.logo-mark-foot{stroke:var(--logo-ink);stroke-width:5.4px}.logo-mark-body,.logo-mark-head,.logo-mark-palm{fill:var(--logo-paper);stroke:var(--logo-ink);stroke-linejoin:round}.logo-mark-body,.logo-mark-head{stroke-width:3.2px}.logo-mark-palm{stroke-width:2.8px}.logo-mark-arm-outline{stroke:var(--logo-ink);stroke-width:7px}.logo-mark-arm-fill{stroke:var(--logo-paper);stroke-width:3.8px}.logo-mark-twist,.logo-mark-face-line{stroke:var(--logo-ink);stroke-width:2px}.logo-mark-hand-line{stroke:var(--logo-ink);stroke-width:1.8px}.logo-mark-eye,.logo-mark-beard{fill:var(--logo-ink)}.logo-mark-cheek{fill:var(--logo-accent)}.logo-mark-hand-accent{stroke:var(--logo-accent);stroke-width:3px}.logo-text{font-family:var(--font-heading);letter-spacing:0;font-weight:600;line-height:1}.logo--small .logo-mark{width:24px;height:24px}.logo--small .logo-text{font-size:20px}.logo--medium .logo-mark{width:30px;height:30px}.logo--medium .logo-text{font-size:25px}.logo--large .logo-mark{width:36px;height:36px}.logo--large .logo-text{font-size:30px}.bottom-nav{z-index:80;bottom:calc(12px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#f8f5eeeb;border:1px solid #1717171f;border-radius:8px;grid-template-columns:repeat(4,minmax(0,1fr));gap:5px;width:min(456px,100% - 32px);margin:0 auto;padding:7px;display:grid;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 14px 42px #17171729}.bottom-nav-link{min-width:0;min-height:52px;color:var(--color-sub-text);border:1px solid #0000;border-radius:7px;justify-content:center;align-items:center;gap:5px;font-size:12px;font-weight:800;line-height:1.2;text-decoration:none;display:inline-flex}.bottom-nav-link svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px;width:20px;height:20px}.bottom-nav-link:focus-visible,.bottom-nav-link:hover{color:var(--color-hot);border-color:#ff4b2e3d}.bottom-nav-link--active{color:var(--color-hot);background:#ff4b2e1a;border-color:#ff4b2e47}.app-layout-footer{width:min(100%,1120px);padding:18px 20px calc(132px + env(safe-area-inset-bottom));margin:0 auto}.app-layout-footer-links{border-top:1px solid var(--color-line);flex-wrap:wrap;gap:10px 18px;padding-top:18px;display:flex}.app-layout-footer-links a{color:var(--color-sub-text);font-size:12px;font-weight:700;line-height:1.5;text-decoration:none}.app-layout-footer-links a:focus-visible,.app-layout-footer-links a:hover{color:var(--color-hot)}.eyebrow{color:var(--color-hot);letter-spacing:0;margin:0 0 10px;font-size:13px;font-weight:700}.zine-header h1{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:72px;font-weight:600;line-height:1.05}.lead{max-width:560px;color:var(--color-sub-text);margin:20px 0 0;font-size:16px;line-height:1.9}.home-actions{flex-wrap:wrap;gap:12px;margin-top:28px;display:flex}.search-cta{border:1px solid var(--color-hot);color:var(--color-hot);background:#ff4b2e1a;border-radius:999px;justify-content:center;align-items:center;padding:11px 18px;font-size:14px;font-weight:700;line-height:1.3;text-decoration:none;display:inline-flex}.search-cta:focus-visible,.search-cta:hover{background:var(--color-hot);color:var(--color-bg)}.hot-section{border-top:1px solid var(--color-line);padding-top:28px}.section-header{justify-content:space-between;align-items:end;gap:20px;margin-bottom:28px;display:flex}.section-header h2{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:36px;font-weight:600;line-height:1.2}.home-filter-panel{gap:14px;margin:-8px 0 24px;display:grid}.home-search{gap:8px;max-width:520px;display:grid}.home-search-label{color:var(--color-sub-text);font-size:12px;font-weight:800;line-height:1.3}.home-search-control{align-items:center;display:flex;position:relative}.home-search-control input{border:1px solid var(--color-line);width:100%;min-height:48px;color:var(--color-text);font:inherit;background:#ffffff8f;border-radius:999px;padding:12px 44px 12px 16px;font-size:14px;font-weight:700;line-height:1.3}.home-search-control input::placeholder{color:#8a7e70b8}.home-search-control input:focus-visible{border-color:#ff4b2e75;outline:3px solid #ff4b2e24}.home-search-clear{width:32px;height:32px;color:var(--color-sub-text);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;font-size:20px;font-weight:700;line-height:1;display:inline-flex;position:absolute;right:8px}.home-search-clear:focus-visible,.home-search-clear:hover{color:var(--color-hot);background:#ff4b2e14;border-color:#ff4b2e3d}.category-filter{margin:0}.home-view-mode{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.home-view-mode-label{color:var(--color-sub-text);font-size:12px;font-weight:800;line-height:1.3}.home-view-mode-options{gap:8px}.home-view-mode-options .option-chip{padding:6px 11px;font-size:12px}.status{color:var(--color-sub-text);margin:0;padding:24px 0}.status-error{color:var(--color-hot)}.spot-grid{align-items:start;margin:0;padding:0;list-style:none;display:grid}.spot-grid--zine{grid-template-columns:repeat(6,1fr);gap:28px 20px}.spot-card{grid-column:span 3}.spot-card--wide{grid-column:span 4}.spot-card--compact{grid-column:span 2}.spot-card--offset{margin-top:48px}.spot-card article{border:1px solid var(--color-line);background:var(--color-card);border-radius:8px;overflow:hidden}.spot-card-link{color:inherit;text-decoration:none;display:block}.spot-card-link:focus-visible{outline:3px solid var(--color-hot);outline-offset:4px;border-radius:8px}.spot-card-link:hover article{border-color:#ff4b2e75}.photo-placeholder{aspect-ratio:4/5;background:var(--photo-color);position:relative}.photo-placeholder:after{content:"";border:1px solid #f8f5ee6b;position:absolute;inset:12px}.photo-placeholder--red-soil{--photo-color:var(--color-photo-red-soil)}.photo-placeholder--old-green{--photo-color:var(--color-photo-old-green)}.photo-placeholder--ochre{--photo-color:var(--color-photo-ochre)}.photo-placeholder--wisteria{--photo-color:var(--color-photo-wisteria)}.spot-card--tall .photo-placeholder{aspect-ratio:3/4}.spot-card--wide .photo-placeholder{aspect-ratio:16/10}.spot-card--compact .photo-placeholder{aspect-ratio:5/4}.spot-body{padding:18px 18px 20px}.spot-kicker{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.spot-category{color:var(--color-sub-text);font-size:12px;font-weight:700}.hot-badge{border:1px solid var(--color-hot);color:var(--color-hot);background:#ff4b2e14;border-radius:999px;align-items:center;padding:4px 9px;font-size:12px;font-weight:700;line-height:1.3;display:inline-flex}.spot-card h3{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:26px;font-weight:600;line-height:1.28}.spot-name-en{color:var(--color-sub-text);margin:6px 0 0;font-size:13px}.spot-note{color:var(--color-text);margin:14px 0 0;font-size:14px;line-height:1.8}.spot-list-meta{display:none}.spot-grid--grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.spot-grid--grid .spot-card,.spot-grid--grid .spot-card--wide,.spot-grid--grid .spot-card--compact{grid-column:auto}.spot-grid--grid .spot-card--offset{margin-top:0}.spot-grid--grid .photo-placeholder{aspect-ratio:16/9}.spot-grid--grid .spot-body{padding:14px}.spot-grid--grid .spot-kicker{gap:6px;margin-bottom:10px}.spot-grid--grid .spot-card h3{font-size:21px;line-height:1.25}.spot-grid--grid .spot-name-en{font-size:12px}.spot-grid--grid .spot-note{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:10px;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.spot-grid--list{grid-template-columns:1fr;gap:8px}.spot-grid--list .spot-card,.spot-grid--list .spot-card--wide,.spot-grid--list .spot-card--compact{grid-column:auto}.spot-grid--list .spot-card--offset{margin-top:0}.spot-grid--list .photo-placeholder,.spot-grid--list .spot-name-en,.spot-grid--list .spot-note{display:none}.spot-grid--list .spot-body{align-items:center;gap:10px;min-width:0;padding:10px 12px;display:flex}.spot-grid--list .spot-kicker{flex:0 auto;order:2;gap:6px;margin:0}.spot-grid--list .spot-category{white-space:nowrap}.spot-grid--list .hot-badge{white-space:nowrap;padding:3px 8px;font-size:11px}.spot-grid--list .spot-card h3{min-width:120px;font-family:var(--font-body);text-overflow:ellipsis;white-space:nowrap;flex:auto;order:1;font-size:14px;font-weight:800;line-height:1.4;overflow:hidden}.spot-grid--list .spot-list-meta{color:var(--color-sub-text);white-space:nowrap;flex:none;order:3;align-items:center;gap:8px;font-size:12px;font-weight:700;line-height:1.3;display:flex}.spot-detail-shell{padding-top:32px}.back-link{border:1px solid var(--color-line);width:fit-content;color:var(--color-sub-text);background:#ffffff6b;border-radius:999px;align-items:center;gap:6px;margin-bottom:28px;padding:8px 12px;font-size:14px;font-weight:800;line-height:1.3;text-decoration:none;display:inline-flex}.back-link:before{content:"←"}.back-link:focus-visible,.back-link:hover{color:var(--color-hot);border-color:#ff4b2e57}.spot-detail{border-top:1px solid var(--color-line);padding-top:28px}.spot-detail-grid{grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);align-items:center;gap:36px;display:grid}.spot-detail-photo{border-radius:8px;min-height:460px}.spot-detail-main h1,.detail-empty h1{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:56px;font-weight:600;line-height:1.12}.spot-detail-name-en{color:var(--color-sub-text);margin:10px 0 0;font-size:15px}.detail-badges{flex-wrap:wrap;gap:8px;margin-top:24px;display:flex}.spot-detail-note{max-width:520px;color:var(--color-text);margin:28px 0 0;font-size:17px;line-height:2}.save-panel{background:#315bff12;border:1px solid #315bff38;border-radius:8px;margin-top:28px;padding:18px}.save-panel-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.save-panel-header h2{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:24px;font-weight:600;line-height:1.25}.save-button{border:1px solid var(--color-save);color:var(--color-save);cursor:pointer;background:#315bff1a;border-radius:999px;justify-content:center;align-items:center;padding:9px 15px;font-size:13px;font-weight:800;line-height:1.3;display:inline-flex}.save-button:focus-visible,.save-button:hover,.save-button--saved{background:var(--color-save);color:var(--color-bg)}.save-reason-group{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.save-reason-chip{color:var(--color-sub-text);cursor:pointer;background:#ffffff85;border:1px solid #315bff3d;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:800;line-height:1.3}.save-reason-chip:focus-visible,.save-reason-chip:hover{color:var(--color-save);border-color:#315bff8a}.save-reason-chip--selected{border-color:var(--color-save);color:var(--color-save);background:#315bff1f}.detail-section{border-top:1px solid var(--color-line);margin-top:48px;padding-top:24px}.detail-section-header{margin-bottom:18px}.detail-section-header h2{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:30px;font-weight:600;line-height:1.25}.source-layout{gap:16px;display:grid}.source-card{border:1px solid var(--color-line);background:var(--color-card);color:var(--color-text);border-radius:8px;gap:10px;text-decoration:none;display:grid}.source-card:focus-visible,.source-card:hover{border-color:#ff4b2e75}.source-card--large{align-content:end;min-height:220px;padding:24px}.source-card--small{align-content:space-between;min-height:132px;padding:16px}.source-carousel{overscroll-behavior-x:contain;scrollbar-color:#ff4b2e4d transparent;scrollbar-width:thin;scroll-snap-type:x proximity;gap:16px;margin:0 -2px;padding:0 2px 10px;display:flex;overflow-x:auto}.source-carousel::-webkit-scrollbar{height:8px}.source-carousel::-webkit-scrollbar-track{background:0 0}.source-carousel::-webkit-scrollbar-thumb{background:#ff4b2e4d padding-box content-box;border:2px solid #0000;border-radius:999px}.source-carousel .source-card{scroll-snap-align:start;flex:0 0 min(260px,82vw)}.source-label{border:1px solid var(--color-hot);width:fit-content;color:var(--color-hot);border-radius:999px;padding:3px 8px;font-size:12px;font-weight:700;line-height:1.3}.source-title{font-family:var(--font-heading);font-size:24px;font-weight:600;line-height:1.3}.source-card--small .source-title{font-size:18px}.source-account,.detail-muted,.detail-empty p{color:var(--color-sub-text);font-size:14px;line-height:1.8}.reviewed-at{margin:0;font-size:18px;font-weight:700}.feedback-actions{flex-wrap:wrap;gap:10px;display:flex}.feedback-button{border:1px solid var(--color-line);color:var(--color-sub-text);cursor:pointer;background:#ffffff75;border-radius:999px;padding:9px 14px;font-size:13px;font-weight:700;line-height:1.3}.feedback-button:focus-visible,.feedback-button:hover:not(:disabled){color:var(--color-hot);border-color:#ff4b2e75}.feedback-button--featured{border-color:var(--color-hot);color:var(--color-hot);background:#ff4b2e1a}.feedback-button--sent{color:var(--color-go-now);background:#27b36a1a;border-color:#27b36a6b}.feedback-button:disabled{cursor:default;opacity:.64}.feedback-button--sent:disabled{opacity:1}.feedback-status{min-height:24px;margin-top:12px}.feedback-status p{color:var(--color-go-now);margin:0;font-size:14px;font-weight:700;line-height:1.7}.feedback-status .feedback-status-error{color:var(--color-hot)}.detail-empty{border-top:1px solid var(--color-line);padding-top:28px}.plan-shell{padding-top:32px}.plan-header{max-width:740px;margin-bottom:36px}.plan-header h1{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:56px;font-weight:600;line-height:1.12}.plan-panel{border:1px solid var(--color-line);background:var(--color-card);border-radius:8px;padding:24px}.plan-form-header{margin-bottom:24px}.plan-form-header h2{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:30px;font-weight:600;line-height:1.2}.plan-field+.plan-field{margin-top:22px}.plan-field-label{color:var(--color-text);margin:0 0 12px;font-size:14px;font-weight:700}.chip-row{flex-wrap:wrap;gap:10px;display:flex}.option-chip{border:1px solid var(--color-line);color:var(--color-sub-text);cursor:pointer;background:#ffffff75;border-radius:999px;padding:8px 13px;font-size:13px;font-weight:700;line-height:1.3}.option-chip:focus-visible,.option-chip:hover{color:var(--color-hot);border-color:#ff4b2e75}.option-chip--selected{border-color:var(--color-hot);color:var(--color-hot);background:#ff4b2e1a}.primary-action{border:1px solid var(--color-go-now);background:var(--color-go-now);color:var(--color-bg);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;margin-top:28px;padding:12px 20px;font-size:14px;font-weight:700;line-height:1.3;display:inline-flex}.primary-action:disabled{cursor:wait;opacity:.68}.primary-action:focus-visible,.primary-action:hover:not(:disabled){background:#27b36adb}.plan-results{margin-top:36px}.recommend-section{border-top:1px solid var(--color-line);padding-top:28px}.recommend-section+.recommend-section{margin-top:40px}.recommend-section--alternatives{padding-top:24px}.route-plan-card{border:1px solid var(--color-line);background:var(--color-card);border-radius:8px;padding:24px}.route-total{color:var(--color-go-now);background:#27b36a14;border:1px solid #27b36a61;border-radius:999px;align-items:center;padding:6px 11px;font-size:13px;font-weight:700;line-height:1.3;display:inline-flex}.route-plan-note,.route-plan-empty,.route-stop-sub{color:var(--color-sub-text);font-size:13px;line-height:1.8}.route-plan-note,.route-plan-empty{margin:0}.route-timeline{gap:16px;margin:22px 0 0;padding:0;list-style:none;display:grid}.route-timeline-item{grid-template-columns:92px minmax(0,1fr);align-items:start;gap:14px;display:grid}.route-walk{color:var(--color-go-now);text-align:center;background:#27b36a14;border:1px solid #27b36a61;border-radius:999px;padding:6px 10px;font-size:13px;font-weight:700;line-height:1.3}.route-stop{border-left:3px solid var(--color-go-now);min-width:0;padding:1px 0 1px 14px}.route-stop-main{color:var(--color-text);flex-wrap:wrap;align-items:center;gap:8px;font-size:15px;font-weight:700;line-height:1.5;display:flex}.route-time{color:var(--color-go-now)}.route-stop-name{color:var(--color-text);text-decoration:none}.route-stop-name:focus-visible,.route-stop-name:hover{color:var(--color-hot)}.route-stay{color:var(--color-sub-text);font-size:13px}.route-stop-sub{margin:4px 0 0}.route-map-action{border:1px solid var(--color-go-now);background:var(--color-go-now);color:var(--color-bg);border-radius:999px;justify-content:center;align-items:center;margin-top:22px;padding:11px 18px;font-size:14px;font-weight:700;line-height:1.3;text-decoration:none;display:inline-flex}.route-map-action:focus-visible,.route-map-action:hover{background:#27b36adb}.login-shell{place-items:center;min-height:calc(100svh - 48px);padding:44px 20px 96px;display:grid}.login-panel{border-top:1px solid var(--color-line);border-bottom:1px solid var(--color-line);text-align:center;justify-items:center;width:min(100%,420px);padding:34px 0 26px;display:grid}.login-header{margin-top:28px}.login-header h1{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:48px;font-weight:600;line-height:1.1}.login-header p:not(.eyebrow){max-width:320px;color:var(--color-sub-text);margin:16px 0 0;font-size:15px;line-height:1.8}.login-actions{gap:12px;width:100%;margin-top:28px;display:grid}.login-provider-button{cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:10px;min-height:52px;padding:12px 18px;font-size:14px;font-weight:800;line-height:1.3;display:inline-flex}.login-provider-button:focus-visible{outline-offset:3px;outline:3px solid #ff4b2e57}.login-provider-button--google{border:1px solid var(--color-line);color:var(--color-text);background:#fff}.login-provider-button--google:hover{border-color:#ff4b2e4d}.login-provider-button--line{color:#fff;background:#06c755;border:1px solid #06c755}.login-provider-button--line:hover{background:#06c755e0}.login-provider-icon{flex:none;width:22px;height:22px}.login-status{min-height:28px;margin-top:16px}.login-status p{color:var(--color-go-now);background:#27b36a14;border:1px solid #27b36a52;border-radius:999px;margin:0;padding:7px 12px;font-size:13px;font-weight:800;line-height:1.4}.login-note{color:var(--color-sub-text);margin:10px 0 0;font-size:12px;font-weight:700;line-height:1.6}.recommend-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;display:grid}.alternative-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.recommend-card{color:inherit;text-decoration:none;display:block}.recommend-card article{border:1px solid var(--color-line);background:var(--color-card);border-radius:8px;height:100%;overflow:hidden}.recommend-card:focus-visible{outline:3px solid var(--color-go-now);outline-offset:4px;border-radius:8px}.recommend-card:hover article{border-color:#27b36a75}.recommend-photo{aspect-ratio:4/3}.recommend-body{padding:16px}.recommend-body h3{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:24px;font-weight:600;line-height:1.28}.plan-metrics{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.plan-metrics span{color:var(--color-go-now);background:#27b36a14;border:1px solid #27b36a61;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:700;line-height:1.3}.recommend-card--alternative .recommend-photo{aspect-ratio:16/9}.recommend-card--alternative .recommend-body{padding:14px}.recommend-card--alternative .recommend-body h3{font-size:20px}.saved-shell{padding-top:32px}.saved-header{max-width:740px;margin-bottom:36px}.saved-header h1{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:56px;font-weight:600;line-height:1.12}.saved-section{border-top:1px solid var(--color-line);padding-top:28px}.saved-plan-actions{background:#27b36a12;border:1px solid #27b36a47;border-radius:8px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:24px;padding:16px;display:flex}.saved-plan-actions p{color:var(--color-go-now);margin:0;font-size:13px;font-weight:800;line-height:1.5}.saved-plan-button{margin-top:0}.saved-route-section{margin-bottom:28px}.saved-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin:0;padding:0;list-style:none;display:grid}.saved-card article{border:1px solid var(--color-line);background:var(--color-card);border-radius:8px;grid-template-columns:minmax(150px,.82fr) minmax(0,1.18fr);height:100%;display:grid;overflow:hidden}.saved-photo{aspect-ratio:auto;min-height:240px}.saved-card-body{flex-direction:column;min-width:0;padding:18px;display:flex}.saved-card-body h2{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:26px;font-weight:600;line-height:1.28}.saved-metrics{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.saved-metrics span{color:var(--color-go-now);background:#27b36a14;border:1px solid #27b36a61;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:800;line-height:1.3}.saved-plan-toggle{width:fit-content;color:var(--color-go-now);cursor:pointer;background:#ffffff75;border:1px solid #27b36a61;border-radius:999px;align-items:center;gap:7px;margin-top:14px;padding:7px 11px;font-size:13px;font-weight:800;line-height:1.3;display:inline-flex}.saved-plan-toggle input{width:15px;height:15px;accent-color:var(--color-go-now);margin:0}.saved-plan-toggle:focus-within,.saved-plan-toggle:hover,.saved-plan-toggle--selected{border-color:var(--color-go-now);background:#27b36a1f}.saved-reason-tags{flex-wrap:wrap;gap:7px;margin-top:14px;display:flex}.saved-reason-tag{color:var(--color-save);background:#315bff14;border:1px solid #315bff3d;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:800;line-height:1.3}.saved-reason-tag--empty{border-color:var(--color-line);color:var(--color-sub-text);background:#ffffff6b}.saved-card-actions{flex-wrap:wrap;gap:10px;margin-top:auto;padding-top:20px;display:flex}.saved-detail-link,.saved-remove-button{border-radius:999px;justify-content:center;align-items:center;padding:9px 14px;font-size:13px;font-weight:800;line-height:1.3;display:inline-flex}.saved-detail-link{border:1px solid var(--color-save);background:var(--color-save);color:var(--color-bg);text-decoration:none}.saved-detail-link:focus-visible,.saved-detail-link:hover{background:#315bffd6}.saved-remove-button{border:1px solid var(--color-line);color:var(--color-sub-text);cursor:pointer;background:#ffffff75}.saved-remove-button:focus-visible,.saved-remove-button:hover{color:var(--color-hot);border-color:#ff4b2e75}.search-shell{width:100%;min-height:calc(100svh - 48px);color:var(--color-bg);background:0 0;margin:0;padding:8px 20px 44px}.search-layout{width:min(100%,480px);margin:0 auto}.search-header{text-align:right;justify-content:flex-end;align-items:end;gap:18px;margin-bottom:18px;display:flex}.search-header h1{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:44px;font-weight:600;line-height:1.05}.search-filter{margin:-6px 0 14px}.search-filter-toggle{color:#f8f5eec2;cursor:pointer;background:#f8f5ee0f;border:1px solid #f8f5ee24;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;width:100%;min-height:38px;padding:8px 11px;font-size:12px;font-weight:800;line-height:1.3;display:flex}.search-filter-toggle span:last-child{color:#f8f5ee94;text-overflow:ellipsis;white-space:nowrap;font-weight:700;overflow:hidden}.search-filter-toggle:focus-visible,.search-filter-toggle:hover{color:var(--color-bg);border-color:#ff4b2e57}.search-filter-panel{background:#f8f5ee0d;border:1px solid #f8f5ee1f;border-radius:8px;gap:12px;margin-top:8px;padding:12px;display:grid}.search-filter-field{gap:8px;display:grid}.search-filter-label{color:#f8f5eea8;margin:0;font-size:12px;font-weight:800;line-height:1.3}.search-filter .chip-row{gap:7px}.search-filter .option-chip{color:#f8f5eead;background:#f8f5ee12;border-color:#f8f5ee29;padding:6px 10px;font-size:12px}.search-filter .option-chip:focus-visible,.search-filter .option-chip:hover{color:var(--color-bg);border-color:#ff4b2e6b}.search-filter .option-chip--selected{border-color:var(--color-hot);color:var(--color-bg);background:#ff4b2e29}.search-status{color:#f8f5eeb8;text-align:center;margin:42px 0 0}.swipe-progress{color:#f8f5eead;text-align:center;margin-bottom:12px;font-size:13px;font-weight:700}.swipe-deck{width:min(100%,430px);height:min(62vh,590px);min-height:470px;margin:0 auto;position:relative}.swipe-card{color:var(--color-bg);touch-action:pan-y;transform-origin:bottom;-webkit-user-select:none;user-select:none;background:#1f1915;border:1px solid #f8f5ee29;border-radius:8px;grid-template-rows:minmax(0,58%) minmax(0,42%);display:grid;position:absolute;inset:0;overflow:hidden;box-shadow:0 22px 70px #00000057}.swipe-card--top{cursor:grab}.swipe-card--top:active{cursor:grabbing}.swipe-photo{aspect-ratio:auto;width:100%;height:100%}.swipe-story-segments{z-index:2;grid-template-columns:repeat(3,minmax(0,1fr));gap:5px;display:grid;position:absolute;top:12px;left:12px;right:12px}.swipe-story-segments span{background:#f8f5eeb3;border-radius:999px;height:3px}.swipe-direction-layer{z-index:4;pointer-events:none;position:absolute;inset:0}.swipe-direction-hint{background:#15110e9e;border:2px solid;border-radius:999px;padding:7px 12px;font-size:14px;font-weight:900;line-height:1.2;position:absolute}.swipe-gesture-hint{color:#f8f5eec7;text-align:center;background:#15110e94;border-radius:999px;max-width:calc(100% - 36px);padding:7px 11px;font-size:12px;font-weight:800;line-height:1.35;position:absolute;bottom:calc(42% + 14px);left:50%;transform:translate(-50%)}.swipe-direction-hint--like{color:var(--color-hot);top:42px;right:24px;transform:rotate(8deg)}.swipe-direction-hint--skip{color:#f8f5eed1;top:42px;left:24px;transform:rotate(-8deg)}.swipe-card-body{background:linear-gradient(180deg, #1f1915e0, var(--color-dark));flex-direction:column;min-height:0;padding:18px;display:flex}.swipe-card .spot-category{color:#f8f5ee9e}.swipe-card h2{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:31px;font-weight:600;line-height:1.16}.swipe-name-en{color:#f8f5ee94;margin:6px 0 0;font-size:13px}.swipe-note{color:#f8f5eec7;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:12px 0 0;font-size:14px;line-height:1.75;display:-webkit-box;overflow:hidden}.swipe-metrics{flex-wrap:wrap;gap:7px;margin-top:auto;padding-top:16px;display:flex}.swipe-metrics span{color:var(--color-go-now);background:#27b36a1f;border:1px solid #27b36a70;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800;line-height:1.25}.swipe-controls{z-index:50;bottom:calc(92px + env(safe-area-inset-bottom));justify-content:center;gap:13px;margin-top:22px;display:flex;position:sticky}.swipe-icon-button{color:#f8f5eed1;cursor:pointer;background:#f8f5ee14;border:1px solid #f8f5ee33;border-radius:999px;justify-content:center;align-items:center;width:46px;height:46px;display:inline-flex}.swipe-icon-button svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.2px;width:22px;height:22px}.swipe-icon-button--hot{border-color:var(--color-hot);background:var(--color-hot);color:var(--color-bg)}.swipe-icon-button:disabled{cursor:default;opacity:.38}.swipe-icon-button:focus-visible,.swipe-icon-button:hover:not(:disabled){border-color:var(--color-hot);color:var(--color-hot)}.swipe-icon-button--hot:focus-visible,.swipe-icon-button--hot:hover:not(:disabled){color:var(--color-bg);background:#ff4b2ed1}.swipe-result{background:var(--color-bg);color:var(--color-text);border-radius:8px;margin-top:24px;padding:26px}.swipe-result h1{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:38px;font-weight:600;line-height:1.16}.swipe-result-lead,.swipe-result-message{color:var(--color-sub-text);font-size:14px;line-height:1.8}.swipe-result-lead{margin:14px 0 0}.swipe-result-list{gap:12px;margin:22px 0 0;padding:0;list-style:none;display:grid}.swipe-result-item{border:1px solid var(--color-line);background:#ffffff75;border-radius:8px;grid-template-columns:64px minmax(0,1fr);align-items:center;gap:12px;padding:10px;display:grid}.swipe-result-thumb{aspect-ratio:auto;border-radius:6px;width:64px;height:64px}.swipe-result-thumb:after{inset:8px}.swipe-result-name{color:var(--color-text);font-family:var(--font-heading);font-size:20px;font-weight:600;line-height:1.25;text-decoration:none}.swipe-result-name:focus-visible,.swipe-result-name:hover{color:var(--color-hot)}.swipe-result-item p{color:var(--color-sub-text);margin:4px 0 0;font-size:12px;font-weight:700}.swipe-result-button{border:1px solid var(--color-go-now);background:var(--color-go-now);color:var(--color-bg);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;margin-top:22px;padding:12px 18px;font-size:14px;font-weight:800;line-height:1.3;display:inline-flex}.swipe-result-button:focus-visible,.swipe-result-button:hover{background:#27b36adb}.swipe-route-result{border-top:1px solid var(--color-line);flex-wrap:wrap;align-items:center;gap:12px;margin-top:18px;padding-top:18px;display:flex}.swipe-route-result p{color:var(--color-go-now);margin:0;font-size:13px;font-weight:800}.swipe-map-link{border:1px solid var(--color-go-now);color:var(--color-go-now);background:#27b36a1a;border-radius:999px;justify-content:center;align-items:center;padding:9px 14px;font-size:13px;font-weight:800;text-decoration:none;display:inline-flex}.swipe-map-link:focus-visible,.swipe-map-link:hover{background:var(--color-go-now);color:var(--color-bg)}.legal-page{max-width:840px;padding-top:42px}.legal-page-header{border-bottom:1px solid var(--color-line);margin-bottom:34px;padding-bottom:28px}.legal-page-header h1{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:56px;font-weight:600;line-height:1.12}.legal-page-header p:not(.eyebrow){max-width:680px;color:var(--color-sub-text);margin:18px 0 0;font-size:15px;line-height:1.9}.legal-page-body{gap:28px;display:grid}.legal-section{border-bottom:1px solid var(--color-line);padding-bottom:26px}.legal-section h2{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:28px;font-weight:600;line-height:1.3}.legal-section p,.legal-section li{color:var(--color-text);font-size:15px;line-height:2}.legal-section p{margin:14px 0 0}.legal-section ul,.legal-section ol{gap:9px;margin:16px 0 0;padding-left:1.4em;display:grid}.legal-section a{color:var(--color-hot);text-underline-offset:4px;font-weight:800;text-decoration:underline;text-decoration-thickness:1px}.legal-section a:focus-visible,.legal-section a:hover{color:var(--color-text)}.legal-mail-link{font-size:18px}.legal-section .legal-updated{color:var(--color-sub-text);font-size:13px;font-weight:700}.about-shell{padding-top:30px}.about-hero{align-items:center;gap:30px;margin-bottom:60px;display:grid}.about-hero-copy{justify-items:start;display:grid}.about-hero-logo{margin-bottom:20px}.about-hero h1,.about-section h2,.about-final-cta h2{font-family:var(--font-heading);letter-spacing:0;margin:0;font-weight:600}.about-hero h1{max-width:760px;font-size:44px;line-height:1.12}.about-lead,.about-section p,.about-final-cta p:not(.eyebrow){color:var(--color-sub-text);font-size:15px;line-height:1.9}.about-lead{max-width:620px;margin:20px 0 0}.about-actions{gap:10px;width:100%;margin-top:26px;display:grid}.about-primary-link,.about-secondary-link,.about-report-link{border-radius:999px;justify-content:center;align-items:center;min-height:46px;padding:11px 18px;font-size:14px;font-weight:800;line-height:1.3;text-decoration:none;display:inline-flex}.about-primary-link{border:1px solid var(--color-hot);background:var(--color-hot);color:var(--color-bg)}.about-secondary-link,.about-report-link{border:1px solid var(--color-line);color:var(--color-text);background:#ffffff75}.about-primary-link:focus-visible,.about-primary-link:hover{background:#ff4b2edb}.about-secondary-link:focus-visible,.about-secondary-link:hover,.about-report-link:focus-visible,.about-report-link:hover{color:var(--color-hot);border-color:#ff4b2e66}.about-hero-art{min-width:0}.about-hero-visual,.about-flow-visual,.about-product-visual{width:100%;height:auto;display:block;overflow:visible}.about-visual-paper{fill:#ffffff70;stroke:var(--color-line);stroke-width:2px}.about-visual-shadow{fill:#17171712}.about-photo-base,.about-photo-block,.about-hero-side-paper rect,.about-flow-card rect,.about-product-card rect{stroke:var(--color-text);stroke-linejoin:round;stroke-width:3px}.about-photo-base--green{fill:var(--color-photo-old-green)}.about-photo-block--red{fill:var(--color-photo-red-soil)}.about-photo-block--ochre{fill:var(--color-photo-ochre)}.about-photo-block--wisteria{fill:var(--color-photo-wisteria)}.about-photo-block--paper,.about-hero-side-paper rect{fill:var(--color-bg)}.about-photo-road,.about-photo-line,.about-photo-stroke,.about-hero-side-paper path,.about-hero-annotation,.about-flow-route,.about-flow-arrow,.about-flow-card path,.about-product-card path,.about-product-swipe-line{fill:none;stroke-linecap:round;stroke-linejoin:round}.about-photo-road{stroke:#f8f5ee8a;stroke-width:15px}.about-photo-line{stroke:#f8f5ee8a;stroke-width:3px}.about-photo-stroke{stroke:var(--color-bg);stroke-width:4px}.about-photo-light{fill:#f8f5eed1}.about-hero-side-paper path{stroke:var(--color-sub-text);stroke-width:3px}.about-hot-sticker path,.about-flow-stamp path{fill:var(--color-hot);stroke:var(--color-text);stroke-linejoin:round;stroke-width:3px}.about-go-label rect{fill:var(--color-go-now);stroke:var(--color-text);stroke-width:3px}.about-hot-sticker text,.about-go-label text,.about-flow-stamp text{fill:var(--color-bg);font-family:var(--font-body);font-size:26px;font-weight:900}.about-hero-annotation{stroke:var(--color-hot);stroke-width:5px}.about-section,.about-final-cta{border-top:1px solid var(--color-line);padding:34px 0}.about-section-header,.about-section-copy{max-width:720px}.about-section h2,.about-final-cta h2{font-size:34px;line-height:1.22}.about-section p{max-width:720px;margin:16px 0 0}.about-problem h2{max-width:860px;font-size:38px;line-height:1.22}.about-value,.about-usage{gap:24px;display:grid}.about-flow-visual,.about-product-visual{margin-top:4px}.about-flow-route{stroke:var(--color-photo-old-green);stroke-width:9px}.about-flow-arrow{stroke:var(--color-go-now);stroke-width:6px}.about-flow-card rect,.about-product-card rect{fill:var(--color-bg)}.about-flow-card--go rect{fill:#27b36a1a}.about-flow-card--route rect{fill:#b5894e21}.about-flow-card path,.about-product-card path,.about-product-swipe-line{stroke:var(--color-text);stroke-width:4px}.about-flow-card circle{fill:var(--color-photo-wisteria);stroke:var(--color-text);stroke-width:3px}.about-flow-card text,.about-product-card text{fill:var(--color-text);font-family:var(--font-body);font-size:22px;font-weight:900}.about-product-card--zine rect:nth-of-type(2){fill:var(--color-photo-red-soil)}.about-product-card--swipe rect:nth-of-type(2){fill:var(--color-photo-old-green)}.about-product-card--timeline rect{fill:#ffffff80}.about-product-card circle{fill:var(--color-go-now);stroke:var(--color-text);stroke-width:3px}.about-product-gesture{stroke:var(--color-hot);stroke-width:6px}.about-product-swipe-line{stroke:var(--color-photo-wisteria);stroke-width:5px}.about-feature-grid{grid-template-columns:1fr;gap:14px;margin:24px 0 0;padding:0;list-style:none;display:grid}.about-feature-card{border:1px solid var(--color-line);background:#ffffff75;border-radius:8px;align-content:start;gap:12px;padding:18px;display:grid}.about-feature-icon{width:56px;height:56px;color:var(--color-hot);background:#ff4b2e14;border:1px solid #ff4b2e4d;border-radius:8px;place-items:center;display:inline-grid}.about-feature-icon-svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:4px;width:36px;height:36px}.about-icon-accent{fill:#ff4b2e1a;stroke:currentColor}.about-icon-muted{stroke:var(--color-sub-text)}.about-feature-card h3{font-family:var(--font-heading);letter-spacing:0;margin:0;font-size:22px;font-weight:600;line-height:1.3}.about-feature-card p{margin:0;font-size:13px;line-height:1.8}.about-feature-card--go .about-feature-icon,.about-feature-card--route .about-feature-icon{color:var(--color-go-now);background:#27b36a14;border-color:#27b36a52}.about-feature-card--alternate .about-feature-icon{color:var(--color-photo-ochre);background:#b5894e1a;border-color:#b5894e57}.about-feature-card--saved .about-feature-icon{color:var(--color-save);background:#315bff14;border-color:#315bff47}.about-feature-card--go .about-icon-accent,.about-feature-card--route .about-icon-accent{fill:#27b36a1a}.about-feature-card--alternate .about-icon-accent{fill:#b5894e1f}.about-feature-card--saved .about-icon-accent{fill:#315bff1a}.about-usage-grid{align-items:center;gap:20px;display:grid}.about-step-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.about-step-list li{border:1px solid var(--color-line);color:var(--color-text);background:#ffffff75;border-radius:8px;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:12px;padding:13px;font-size:14px;font-weight:800;line-height:1.5;display:grid}.about-step-list span{width:42px;height:42px;color:var(--color-go-now);background:#27b36a17;border:1px solid #27b36a5c;border-radius:999px;justify-content:center;align-items:center;font-weight:900;display:inline-flex}.about-area,.about-trust{gap:18px;display:grid}.about-area{align-items:end}.about-area p{margin-top:0}.about-trust{align-items:center}.about-report-link{width:fit-content}.about-final-cta{margin-top:10px;padding-bottom:0}@media (width>=680px){.about-actions{flex-wrap:wrap;width:auto;display:flex}.about-primary-link,.about-secondary-link{width:auto}.about-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=860px){.about-hero{grid-template-columns:minmax(0,1fr) minmax(320px,.82fr);gap:42px;margin-bottom:74px}.about-hero h1{font-size:64px;line-height:1.08}.about-value{grid-template-columns:minmax(0,.8fr) minmax(360px,1fr);align-items:center}.about-usage-grid{grid-template-columns:minmax(360px,1fr) minmax(260px,.72fr);gap:28px}.about-area,.about-trust{grid-template-columns:minmax(0,.72fr) minmax(280px,1fr)}.about-trust{grid-template-columns:minmax(0,1fr) auto}}@media (width>=1040px){.about-feature-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}@media (width<=760px){.app-layout-header{padding:14px 16px 0}.app-layout-main{padding-bottom:calc(112px + env(safe-area-inset-bottom))}.bottom-nav{width:calc(100% - 24px);padding:6px}.bottom-nav-link{gap:4px;min-height:50px;font-size:11px}.bottom-nav-link svg{width:19px;height:19px}.app-layout-footer{padding:10px 16px calc(126px + env(safe-area-inset-bottom))}.app-layout-footer-links{gap:8px 14px}.app-shell{padding:28px 16px 56px}.zine-header{margin-bottom:40px}.zine-header h1{font-size:48px}.home-actions{display:grid}.plan-header h1{font-size:40px}.section-header{display:block}.section-header h2{font-size:32px}.spot-grid--zine{grid-template-columns:1fr;gap:24px}.spot-grid--grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.spot-grid--list{gap:8px}.spot-card,.spot-card--wide,.spot-card--compact{grid-column:auto}.spot-card--offset{margin-top:0}.spot-grid--grid .spot-body{padding:12px}.spot-grid--grid .spot-card h3{font-size:17px}.spot-grid--grid .spot-name-en,.spot-grid--grid .spot-note{display:none}.spot-grid--list .spot-body{flex-wrap:wrap;align-items:flex-start;gap:6px 8px}.spot-grid--list .spot-card h3{white-space:normal;flex-basis:100%}.spot-detail-shell{padding-top:24px}.spot-detail-grid{grid-template-columns:1fr;gap:24px}.spot-detail-photo{aspect-ratio:4/5;min-height:auto}.spot-detail-main h1,.detail-empty h1{font-size:40px}.spot-detail-note{font-size:15px}.source-carousel .source-card{flex-basis:min(240px,78vw)}.feedback-actions,.save-panel-header{display:grid}.save-button{width:100%}.plan-shell{padding-top:24px}.plan-panel,.route-plan-card{padding:20px}.login-shell{padding:36px 16px 84px}.login-panel{padding-top:28px}.login-header h1{font-size:40px}.route-timeline-item{grid-template-columns:1fr;gap:8px}.route-walk{width:fit-content}.recommend-grid,.alternative-list,.saved-list{grid-template-columns:1fr}.saved-shell{padding-top:24px}.saved-header h1{font-size:40px}.saved-card article{grid-template-columns:1fr}.saved-photo{aspect-ratio:16/10;min-height:auto}.saved-card-actions,.saved-detail-link,.saved-remove-button,.primary-action,.route-map-action{width:100%}.search-shell{padding:8px 14px 42px}.search-header h1{font-size:38px}.swipe-deck{height:62vh;min-height:440px}.swipe-card h2{font-size:28px}.swipe-controls{gap:10px}.swipe-result{padding:22px}.swipe-result-button{width:100%}.legal-page{padding-top:28px}.legal-page-header{margin-bottom:28px;padding-bottom:24px}.legal-page-header h1{font-size:40px}.legal-section h2{font-size:24px}}
