*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.18 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:JetBrains Mono,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.-bottom-1\/2{bottom:-50%}.-left-1\/4{left:-25%}.-right-1{right:-.25rem}.-right-1\/4{right:-25%}.-top-1{top:-.25rem}.-top-1\/2{top:-50%}.bottom-0{bottom:0}.bottom-2{bottom:.5rem}.left-0{left:0}.left-3{left:.75rem}.left-6{left:1.5rem}.right-0{right:0}.right-2{right:.5rem}.right-6{right:1.5rem}.top-0{top:0}.top-3{top:.75rem}.top-6{top:1.5rem}.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.col-span-2{grid-column:span 2/span 2}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mx-auto{margin-left:auto;margin-right:auto}.-mt-20{margin-top:-5rem}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.aspect-\[16\/10\]{aspect-ratio:16/10}.aspect-\[16\/9\]{aspect-ratio:16/9}.aspect-\[4\/3\]{aspect-ratio:4/3}.h-1{height:.25rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-20{height:5rem}.h-24{height:6rem}.h-28{height:7rem}.h-3{height:.75rem}.h-32{height:8rem}.h-4{height:1rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-80{height:20rem}.h-96{height:24rem}.h-\[200px\]{height:200px}.h-\[250px\]{height:250px}.h-\[400px\]{height:400px}.h-\[50vh\]{height:50vh}.h-\[60vh\]{height:60vh}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-48{max-height:12rem}.max-h-\[85vh\]{max-height:85vh}.max-h-\[90vh\]{max-height:90vh}.max-h-\[calc\(85vh-120px\)\]{max-height:calc(85vh - 120px)}.min-h-\[200px\]{min-height:200px}.min-h-\[400px\]{min-height:400px}.min-h-\[80vh\]{min-height:80vh}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-20{width:5rem}.w-24{width:6rem}.w-3{width:.75rem}.w-32{width:8rem}.w-4{width:1rem}.w-40{width:10rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-full{width:100%}.min-w-0{min-width:0}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[85\%\]{max-width:85%}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05}.scale-105,.scale-110{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-bounce{animation:bounce 1s infinite}.animate-fade-in{animation:fadeIn .5s ease-in}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in-up{animation:fadeInUp .6s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.animate-scale-in{animation:scaleIn .3s ease-out}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.scroll-smooth{scroll-behavior:smooth}.truncate{overflow:hidden;text-overflow:ellipsis}.truncate,.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.rounded-t-3xl{border-top-left-radius:1.5rem;border-top-right-radius:1.5rem}.rounded-t-lg{border-top-left-radius:.5rem;border-top-right-radius:.5rem}.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l-4{border-left-width:4px}.border-t{border-top-width:1px}.border-t-2{border-top-width:2px}.border-dashed{border-style:dashed}.border-none{border-style:none}.border-\[\#e63946\]{--tw-border-opacity:1;border-color:rgb(230 57 70/var(--tw-border-opacity,1))}.border-\[\#e63946\]\/20{border-color:rgba(230,57,70,.2)}.border-\[var\(--border\)\]{border-color:var(--border)}.border-amber-200{--tw-border-opacity:1;border-color:rgb(253 230 138/var(--tw-border-opacity,1))}.border-blue-100{--tw-border-opacity:1;border-color:rgb(219 234 254/var(--tw-border-opacity,1))}.border-blue-200{--tw-border-opacity:1;border-color:rgb(191 219 254/var(--tw-border-opacity,1))}.border-blue-300{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.border-blue-500{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.border-blue-500\/20{border-color:rgba(59,130,246,.2)}.border-cyan-200{--tw-border-opacity:1;border-color:rgb(165 243 252/var(--tw-border-opacity,1))}.border-cyan-400{--tw-border-opacity:1;border-color:rgb(34 211 238/var(--tw-border-opacity,1))}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-gray-200\/50{border-color:rgba(229,231,235,.5)}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-green-100{--tw-border-opacity:1;border-color:rgb(220 252 231/var(--tw-border-opacity,1))}.border-pink-100{--tw-border-opacity:1;border-color:rgb(252 231 243/var(--tw-border-opacity,1))}.border-pink-200{--tw-border-opacity:1;border-color:rgb(251 207 232/var(--tw-border-opacity,1))}.border-pink-500{--tw-border-opacity:1;border-color:rgb(236 72 153/var(--tw-border-opacity,1))}.border-purple-100{--tw-border-opacity:1;border-color:rgb(243 232 255/var(--tw-border-opacity,1))}.border-purple-400{--tw-border-opacity:1;border-color:rgb(192 132 252/var(--tw-border-opacity,1))}.border-purple-500{--tw-border-opacity:1;border-color:rgb(168 85 247/var(--tw-border-opacity,1))}.border-red-100{--tw-border-opacity:1;border-color:rgb(254 226 226/var(--tw-border-opacity,1))}.border-red-200{--tw-border-opacity:1;border-color:rgb(254 202 202/var(--tw-border-opacity,1))}.border-red-500\/30{border-color:rgba(239,68,68,.3)}.border-red-600{--tw-border-opacity:1;border-color:rgb(220 38 38/var(--tw-border-opacity,1))}.border-transparent{border-color:transparent}.border-white\/10{border-color:hsla(0,0%,100%,.1)}.border-white\/20{border-color:hsla(0,0%,100%,.2)}.border-white\/60{border-color:hsla(0,0%,100%,.6)}.border-yellow-100{--tw-border-opacity:1;border-color:rgb(254 249 195/var(--tw-border-opacity,1))}.border-t-transparent{border-top-color:transparent}.bg-\[\#e63946\]{--tw-bg-opacity:1;background-color:rgb(230 57 70/var(--tw-bg-opacity,1))}.bg-\[\#e63946\]\/5{background-color:rgba(230,57,70,.05)}.bg-\[var\(--accent\)\]{background-color:var(--accent)}.bg-\[var\(--bg\)\]{background-color:var(--bg)}.bg-\[var\(--off-white\)\]{background-color:var(--off-white)}.bg-\[var\(--surface\)\]{background-color:var(--surface)}.bg-amber-50{--tw-bg-opacity:1;background-color:rgb(255 251 235/var(--tw-bg-opacity,1))}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-black\/60{background-color:rgba(0,0,0,.6)}.bg-black\/70{background-color:rgba(0,0,0,.7)}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-blue-50\/70{background-color:rgba(239,246,255,.7)}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-blue-500\/10{background-color:rgba(59,130,246,.1)}.bg-blue-500\/20{background-color:rgba(59,130,246,.2)}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-gray-500{--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity,1))}.bg-gray-500\/20{background-color:hsla(220,9%,46%,.2)}.bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity,1))}.bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-green-500\/20{background-color:rgba(34,197,94,.2)}.bg-pink-50{--tw-bg-opacity:1;background-color:rgb(253 242 248/var(--tw-bg-opacity,1))}.bg-pink-500{--tw-bg-opacity:1;background-color:rgb(236 72 153/var(--tw-bg-opacity,1))}.bg-purple-500{--tw-bg-opacity:1;background-color:rgb(168 85 247/var(--tw-bg-opacity,1))}.bg-purple-500\/20{background-color:rgba(168,85,247,.2)}.bg-red-100{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-red-500\/20{background-color:rgba(239,68,68,.2)}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-rose-50{--tw-bg-opacity:1;background-color:rgb(255 241 242/var(--tw-bg-opacity,1))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/10{background-color:hsla(0,0%,100%,.1)}.bg-white\/5{background-color:hsla(0,0%,100%,.05)}.bg-white\/80{background-color:hsla(0,0%,100%,.8)}.bg-white\/90{background-color:hsla(0,0%,100%,.9)}.bg-white\/95{background-color:hsla(0,0%,100%,.95)}.bg-yellow-200{--tw-bg-opacity:1;background-color:rgb(254 240 138/var(--tw-bg-opacity,1))}.bg-yellow-500{--tw-bg-opacity:1;background-color:rgb(234 179 8/var(--tw-bg-opacity,1))}.bg-yellow-500\/20{background-color:rgba(234,179,8,.2)}.bg-opacity-50{--tw-bg-opacity:0.5}.bg-gradient-radial{background-image:radial-gradient(var(--tw-gradient-stops))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.from-\[\#e63946\]{--tw-gradient-from:#e63946 var(--tw-gradient-from-position);--tw-gradient-to:rgba(230,57,70,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-\[\#e63946\]\/10{--tw-gradient-from:rgba(230,57,70,.1) var(--tw-gradient-from-position);--tw-gradient-to:rgba(230,57,70,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-\[\#e63946\]\/20{--tw-gradient-from:rgba(230,57,70,.2) var(--tw-gradient-from-position);--tw-gradient-to:rgba(230,57,70,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-400{--tw-gradient-from:#fbbf24 var(--tw-gradient-from-position);--tw-gradient-to:rgba(251,191,36,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-50{--tw-gradient-from:#fffbeb var(--tw-gradient-from-position);--tw-gradient-to:rgba(255,251,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-black{--tw-gradient-from:#000 var(--tw-gradient-from-position);--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-black\/40{--tw-gradient-from:rgba(0,0,0,.4) var(--tw-gradient-from-position);--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-black\/80{--tw-gradient-from:rgba(0,0,0,.8) var(--tw-gradient-from-position);--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-500{--tw-gradient-from:#3b82f6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(59,130,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-500\/20{--tw-gradient-from:rgba(59,130,246,.2) var(--tw-gradient-from-position);--tw-gradient-to:rgba(59,130,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-cyan-400{--tw-gradient-from:#22d3ee var(--tw-gradient-from-position);--tw-gradient-to:rgba(34,211,238,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-cyan-50{--tw-gradient-from:#ecfeff var(--tw-gradient-from-position);--tw-gradient-to:rgba(236,254,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-cyan-500{--tw-gradient-from:#06b6d4 var(--tw-gradient-from-position);--tw-gradient-to:rgba(6,182,212,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-gray-50{--tw-gradient-from:#f9fafb var(--tw-gradient-from-position);--tw-gradient-to:rgba(249,250,251,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-gray-500\/20{--tw-gradient-from:hsla(220,9%,46%,.2) var(--tw-gradient-from-position);--tw-gradient-to:hsla(220,9%,46%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-gray-900{--tw-gradient-from:#111827 var(--tw-gradient-from-position);--tw-gradient-to:rgba(17,24,39,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-100\/20{--tw-gradient-from:rgba(224,231,255,.2) var(--tw-gradient-from-position);--tw-gradient-to:rgba(224,231,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-pink-500\/20{--tw-gradient-from:rgba(236,72,153,.2) var(--tw-gradient-from-position);--tw-gradient-to:rgba(236,72,153,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-400{--tw-gradient-from:#c084fc var(--tw-gradient-from-position);--tw-gradient-to:rgba(192,132,252,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-500\/20{--tw-gradient-from:rgba(168,85,247,.2) var(--tw-gradient-from-position);--tw-gradient-to:rgba(168,85,247,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-900{--tw-gradient-from:#581c87 var(--tw-gradient-from-position);--tw-gradient-to:rgba(88,28,135,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-50{--tw-gradient-from:#fef2f2 var(--tw-gradient-from-position);--tw-gradient-to:hsla(0,86%,97%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-500{--tw-gradient-from:#ef4444 var(--tw-gradient-from-position);--tw-gradient-to:rgba(239,68,68,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-rose-100\/30{--tw-gradient-from:rgba(255,228,230,.3) var(--tw-gradient-from-position);--tw-gradient-to:rgba(255,228,230,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-rose-50{--tw-gradient-from:#fff1f2 var(--tw-gradient-from-position);--tw-gradient-to:rgba(255,241,242,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-rose-500{--tw-gradient-from:#f43f5e var(--tw-gradient-from-position);--tw-gradient-to:rgba(244,63,94,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-50{--tw-gradient-from:#f8fafc var(--tw-gradient-from-position);--tw-gradient-to:rgba(248,250,252,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-transparent{--tw-gradient-from:transparent var(--tw-gradient-from-position);--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-white{--tw-gradient-from:#fff var(--tw-gradient-from-position);--tw-gradient-to:hsla(0,0%,100%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-yellow-500\/20{--tw-gradient-from:rgba(234,179,8,.2) var(--tw-gradient-from-position);--tw-gradient-to:rgba(234,179,8,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-amber-50{--tw-gradient-to:rgba(255,251,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#fffbeb var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-amber-50\/30{--tw-gradient-to:rgba(255,251,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),rgba(255,251,235,.3) var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-black\/20{--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),rgba(0,0,0,.2) var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-black\/30{--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),rgba(0,0,0,.3) var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-black\/50{--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),rgba(0,0,0,.5) var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-blue-50{--tw-gradient-to:rgba(239,246,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#eff6ff var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-blue-900{--tw-gradient-to:rgba(30,58,138,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1e3a8a var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-gray-200{--tw-gradient-to:rgba(229,231,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#e5e7eb var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-gray-50{--tw-gradient-to:rgba(249,250,251,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#f9fafb var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-gray-800{--tw-gradient-to:rgba(31,41,55,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1f2937 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-pink-500{--tw-gradient-to:rgba(236,72,153,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#ec4899 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-red-500{--tw-gradient-to:rgba(239,68,68,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#ef4444 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-rose-50{--tw-gradient-to:rgba(255,241,242,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#fff1f2 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),transparent var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-white{--tw-gradient-to:hsla(0,0%,100%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#fff var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-\[\#ff6b7a\]{--tw-gradient-to:#ff6b7a var(--tw-gradient-to-position)}.to-\[\#ff6b7a\]\/10{--tw-gradient-to:rgba(255,107,122,.1) var(--tw-gradient-to-position)}.to-\[\#ff6b7a\]\/20{--tw-gradient-to:rgba(255,107,122,.2) var(--tw-gradient-to-position)}.to-amber-50{--tw-gradient-to:#fffbeb var(--tw-gradient-to-position)}.to-blue-50{--tw-gradient-to:#eff6ff var(--tw-gradient-to-position)}.to-blue-600\/30{--tw-gradient-to:rgba(37,99,235,.3) var(--tw-gradient-to-position)}.to-cyan-500\/20{--tw-gradient-to:rgba(6,182,212,.2) var(--tw-gradient-to-position)}.to-cyan-900{--tw-gradient-to:#164e63 var(--tw-gradient-to-position)}.to-gray-100\/50{--tw-gradient-to:rgba(243,244,246,.5) var(--tw-gradient-to-position)}.to-gray-50{--tw-gradient-to:#f9fafb var(--tw-gradient-to-position)}.to-gray-600\/30{--tw-gradient-to:rgba(75,85,99,.3) var(--tw-gradient-to-position)}.to-gray-700{--tw-gradient-to:#374151 var(--tw-gradient-to-position)}.to-gray-900{--tw-gradient-to:#111827 var(--tw-gradient-to-position)}.to-indigo-50{--tw-gradient-to:#eef2ff var(--tw-gradient-to-position)}.to-indigo-500\/20{--tw-gradient-to:rgba(99,102,241,.2) var(--tw-gradient-to-position)}.to-orange-50{--tw-gradient-to:#fff7ed var(--tw-gradient-to-position)}.to-orange-500{--tw-gradient-to:#f97316 var(--tw-gradient-to-position)}.to-pink-500{--tw-gradient-to:#ec4899 var(--tw-gradient-to-position)}.to-purple-500{--tw-gradient-to:#a855f7 var(--tw-gradient-to-position)}.to-purple-500\/20{--tw-gradient-to:rgba(168,85,247,.2) var(--tw-gradient-to-position)}.to-purple-600\/30{--tw-gradient-to:rgba(147,51,234,.3) var(--tw-gradient-to-position)}.to-red-500\/20{--tw-gradient-to:rgba(239,68,68,.2) var(--tw-gradient-to-position)}.to-rose-50{--tw-gradient-to:#fff1f2 var(--tw-gradient-to-position)}.to-rose-50\/30{--tw-gradient-to:rgba(255,241,242,.3) var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position)}.to-white{--tw-gradient-to:#fff var(--tw-gradient-to-position)}.to-yellow-400{--tw-gradient-to:#facc15 var(--tw-gradient-to-position)}.to-yellow-500{--tw-gradient-to:#eab308 var(--tw-gradient-to-position)}.to-yellow-600\/30{--tw-gradient-to:rgba(202,138,4,.3) var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-12{padding:3rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-14{padding-top:3.5rem;padding-bottom:3.5rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-12{padding-bottom:3rem}.pb-4{padding-bottom:1rem}.pb-8{padding-bottom:2rem}.pt-2{padding-top:.5rem}.pt-20{padding-top:5rem}.pt-24{padding-top:6rem}.pt-32{padding-top:8rem}.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:JetBrains Mono,monospace}.font-serif{font-family:Merriweather,Georgia,serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-8xl{font-size:6rem;line-height:1}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-\[0\.35em\]{letter-spacing:.35em}.tracking-\[0\.3em\]{letter-spacing:.3em}.tracking-\[0\.4em\]{letter-spacing:.4em}.tracking-wide{letter-spacing:.025em}.tracking-widest{letter-spacing:.1em}.text-\[\#e63946\]{--tw-text-opacity:1;color:rgb(230 57 70/var(--tw-text-opacity,1))}.text-\[var\(--accent\)\]{color:var(--accent)}.text-\[var\(--japan-red\)\]{color:var(--japan-red)}.text-\[var\(--muted\)\]{color:var(--muted)}.text-\[var\(--text\)\]{color:var(--text)}.text-amber-800{--tw-text-opacity:1;color:rgb(146 64 14/var(--tw-text-opacity,1))}.text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.text-blue-300{--tw-text-opacity:1;color:rgb(147 197 253/var(--tw-text-opacity,1))}.text-blue-400{--tw-text-opacity:1;color:rgb(96 165 250/var(--tw-text-opacity,1))}.text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.text-blue-900{--tw-text-opacity:1;color:rgb(30 58 138/var(--tw-text-opacity,1))}.text-cyan-100{--tw-text-opacity:1;color:rgb(207 250 254/var(--tw-text-opacity,1))}.text-cyan-300{--tw-text-opacity:1;color:rgb(103 232 249/var(--tw-text-opacity,1))}.text-cyan-400{--tw-text-opacity:1;color:rgb(34 211 238/var(--tw-text-opacity,1))}.text-cyan-600{--tw-text-opacity:1;color:rgb(8 145 178/var(--tw-text-opacity,1))}.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-green-400{--tw-text-opacity:1;color:rgb(74 222 128/var(--tw-text-opacity,1))}.text-green-500{--tw-text-opacity:1;color:rgb(34 197 94/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-orange-500{--tw-text-opacity:1;color:rgb(249 115 22/var(--tw-text-opacity,1))}.text-pink-600{--tw-text-opacity:1;color:rgb(219 39 119/var(--tw-text-opacity,1))}.text-purple-300{--tw-text-opacity:1;color:rgb(216 180 254/var(--tw-text-opacity,1))}.text-purple-400{--tw-text-opacity:1;color:rgb(192 132 252/var(--tw-text-opacity,1))}.text-purple-600{--tw-text-opacity:1;color:rgb(147 51 234/var(--tw-text-opacity,1))}.text-red-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-red-600\/80{color:rgba(220,38,38,.8)}.text-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity,1))}.text-rose-600{--tw-text-opacity:1;color:rgb(225 29 72/var(--tw-text-opacity,1))}.text-transparent{color:transparent}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-white\/90{color:hsla(0,0%,100%,.9)}.text-yellow-400{--tw-text-opacity:1;color:rgb(250 204 21/var(--tw-text-opacity,1))}.text-yellow-500{--tw-text-opacity:1;color:rgb(234 179 8/var(--tw-text-opacity,1))}.text-yellow-600{--tw-text-opacity:1;color:rgb(202 138 4/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.placeholder-gray-300::-moz-placeholder{--tw-placeholder-opacity:1;color:rgb(209 213 219/var(--tw-placeholder-opacity,1))}.placeholder-gray-300::placeholder{--tw-placeholder-opacity:1;color:rgb(209 213 219/var(--tw-placeholder-opacity,1))}.placeholder-gray-400::-moz-placeholder{--tw-placeholder-opacity:1;color:rgb(156 163 175/var(--tw-placeholder-opacity,1))}.placeholder-gray-400::placeholder{--tw-placeholder-opacity:1;color:rgb(156 163 175/var(--tw-placeholder-opacity,1))}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-2xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px rgba(0,0,0,.25);--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color)}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 rgba(0,0,0,.05);--tw-shadow-colored:inset 0 2px 4px 0 var(--tw-shadow-color)}.shadow-inner,.shadow-lg{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color)}.shadow-md,.shadow-none{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-sm,.shadow-xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color)}.shadow-\[\#e63946\]\/30{--tw-shadow-color:rgba(230,57,70,.3);--tw-shadow:var(--tw-shadow-colored)}.shadow-\[\#e63946\]\/5{--tw-shadow-color:rgba(230,57,70,.05);--tw-shadow:var(--tw-shadow-colored)}.shadow-black\/10{--tw-shadow-color:rgba(0,0,0,.1);--tw-shadow:var(--tw-shadow-colored)}.shadow-red-500\/30{--tw-shadow-color:rgba(239,68,68,.3);--tw-shadow:var(--tw-shadow-colored)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring,.ring-2{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-2{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-4{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-\[\#e63946\]{--tw-ring-opacity:1;--tw-ring-color:rgb(230 57 70/var(--tw-ring-opacity,1))}.ring-white\/20{--tw-ring-color:hsla(0,0%,100%,.2)}.ring-offset-2{--tw-ring-offset-width:2px}.blur{--tw-blur:blur(8px)}.blur,.blur-3xl{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-3xl{--tw-blur:blur(64px)}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px rgba(0,0,0,.1)) drop-shadow(0 1px 1px rgba(0,0,0,.06))}.drop-shadow,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-md{--tw-backdrop-blur:blur(12px)}.backdrop-blur-md,.backdrop-blur-sm{backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px)}.backdrop-blur-xl{--tw-backdrop-blur:blur(24px)}.backdrop-blur-xl,.backdrop-filter{backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-150,.transition-transform{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.duration-700{transition-duration:.7s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Noto+Serif+JP:wght@400;600&display=swap");:root{--white:#fff;--off-white:#f8f7ff;--black:#0f1424;--ink:#06070f;--japan-red:#e63946;--japan-red-hover:#d62839;--gray-50:#fdfcff;--gray-100:#f4f4fb;--gray-200:#e4e6f1;--gray-300:#cdd1e2;--gray-400:#9aa0ba;--gray-500:#7a8099;--gray-600:#5a5f75;--gray-700:#3c4154;--gray-800:#242838;--gray-900:#111323;--surface-strong:hsla(0,0%,100%,.97);--surface-muted:hsla(0,0%,100%,.9);--border-soft:rgba(15,23,42,.08);--border-strong:rgba(15,23,42,.18);--shadow-sm:0 18px 45px -30px rgba(6,7,15,.2);--shadow-md:0 45px 100px -55px rgba(6,7,15,.45);--shadow-lg:0 55px 120px -60px rgba(5,6,12,.55);--radius-sm:6px;--radius:12px;--radius-lg:18px;--radius-xl:28px;--blur-strong:32px;--sidebar-width:300px;--right-rail:320px;--content-max:1180px;--app-padding:clamp(1rem,3vw,2.5rem);--z-background:-2;--z-base:0;--z-dropdown:10;--z-sticky:20;--z-nav:30;--z-overlay:40;--z-modal:50;--z-tooltip:60}[data-theme=dark]{--white:#0f1424;--off-white:#151b2e;--black:#f8f9fa;--ink:#fff;--japan-red:#ff6b7a;--japan-red-hover:#ff8591;--gray-50:#0a0e1a;--gray-100:#111829;--gray-200:#1a2238;--gray-300:#2d3548;--gray-400:#5a5f75;--gray-500:#7a8099;--gray-600:#9aa0ba;--gray-700:#cdd1e2;--gray-800:#e4e6f1;--gray-900:#f4f4fb;--surface-strong:rgba(15,20,36,.97);--surface-muted:rgba(21,27,46,.9);--border-soft:hsla(0,0%,100%,.08);--border-strong:hsla(0,0%,100%,.15);--shadow-sm:0 18px 45px -30px rgba(0,0,0,.5);--shadow-md:0 45px 100px -55px rgba(0,0,0,.7);--shadow-lg:0 55px 120px -60px rgba(0,0,0,.8)}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth}body,html{overflow-x:hidden;overflow-y:auto;height:100%;-webkit-overflow-scrolling:touch}body{margin:0;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at 12% 18%,rgba(255,165,195,.22),transparent 45%),radial-gradient(circle at 85% 8%,rgba(146,189,255,.18),transparent 40%),linear-gradient(180deg,#090a18,#0f1224 55%,#171b32);color:var(--black);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:pan-y}body:after,body:before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none}body:before{background:radial-gradient(circle at 20% 20%,hsla(0,0%,100%,.08),transparent 45%),radial-gradient(circle at 80% 0,hsla(0,0%,100%,.06),transparent 40%)}body:after{background-image:url("data:image/svg+xml,%3Csvg width='240' height='240' viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.06)' stroke-width='0.6'%3E%3Cpath d='M0 120h240M120 0v240'/%3E%3C/g%3E%3C/svg%3E");mix-blend-mode:soft-light;opacity:.6}[data-theme=dark] body{background:radial-gradient(circle at 12% 18%,rgba(139,92,246,.15),transparent 45%),radial-gradient(circle at 85% 8%,rgba(59,130,246,.12),transparent 40%),linear-gradient(180deg,#050710,#0a0e1a 55%,#0f1424)}[data-theme=dark] body:before{background:radial-gradient(circle at 20% 20%,rgba(139,92,246,.05),transparent 45%),radial-gradient(circle at 80% 0,rgba(59,130,246,.04),transparent 40%)}[data-theme=dark] body:after{opacity:.3}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button,input,textarea{font:inherit}button{cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}button:active{transform:scale(.98)}button:disabled{opacity:.6;cursor:not-allowed}input:focus,textarea:focus{outline:none;ring:2px;ring-color:rgba(230,57,70,.5)}*{scroll-behavior:smooth}::selection{background-color:rgba(230,57,70,.3);color:#fff}::-moz-selection{background-color:rgba(230,57,70,.3);color:#fff}.global-stage{position:relative;min-height:100vh;width:100%;overflow-x:hidden;overflow-y:auto}.global-aurora,.global-gradient,.global-noise{position:fixed;inset:0;z-index:-1;pointer-events:none;will-change:transform;transform:translateZ(0);backface-visibility:hidden}.global-gradient{background:radial-gradient(circle at 10% 25%,rgba(255,189,211,.32),transparent 55%),radial-gradient(circle at 85% 20%,rgba(145,180,255,.25),transparent 45%),linear-gradient(135deg,rgba(20,24,46,.9),rgba(4,6,18,.85));filter:blur(8px)}.global-aurora{background:radial-gradient(circle at 70% 60%,rgba(99,102,241,.35),transparent 55%),radial-gradient(circle at 30% 80%,rgba(16,185,129,.2),transparent 55%);filter:blur(40px);opacity:.5}.global-noise{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='320' viewBox='0 0 320 320'%3E%3Cg fill='rgba(255,255,255,0.04)'%3E%3Ccircle cx='1' cy='1' r='1'/%3E%3C/g%3E%3C/svg%3E");mix-blend-mode:screen;opacity:.6}.app-frame{position:relative;width:100%;max-width:1800px;margin:0 auto;padding:var(--app-padding);will-change:transform;transform:translateZ(0)}.app-layout{display:grid;grid-template-columns:clamp(240px,18vw,var(--sidebar-width)) minmax(0,1fr) clamp(260px,20vw,var(--right-rail));grid-template-areas:"explorer center profile";gap:clamp(1rem,2vw,1.75rem);border-radius:36px;border:1px solid hsla(0,0%,100%,.08);background:radial-gradient(circle at 10% 20%,hsla(0,0%,100%,.35),hsla(0,0%,100%,.15)),hsla(0,0%,100%,.08);box-shadow:var(--shadow-md);padding:clamp(1rem,2vw,1.75rem);position:relative;overflow:hidden}.app-layout:after{content:"";position:absolute;inset:0;background:linear-gradient(145deg,hsla(0,0%,100%,.22),transparent 60%);pointer-events:none}.app-layout>*{position:relative;z-index:1}.app-layout>:only-child{grid-column:1/-1}@media (max-width:1440px){.app-layout{grid-template-columns:clamp(220px,24vw,var(--sidebar-width)) minmax(0,1fr) clamp(240px,24vw,var(--right-rail))}}@media (max-width:1200px){.app-layout{grid-template-columns:1fr;grid-template-areas:"center" "profile" "explorer"}.left-explorer,.right-panel{position:static;height:auto;max-height:none}.right-panel{display:block}}@media (max-width:992px){.app-layout{gap:1.25rem}.center-feed{padding:clamp(1rem,4vw,1.5rem)}.page-shell{gap:1.25rem}}@media (max-width:768px){.app-frame{padding:clamp(.75rem,4vw,1.25rem)}.center-feed,.left-explorer,.right-panel{border-radius:22px}}.left-explorer{grid-area:explorer;position:sticky;top:clamp(1rem,3vw,2rem);height:calc(100vh - clamp(2rem, 6vw, 4rem));overflow-y:auto;border-radius:28px;padding:clamp(1.25rem,2vw,1.75rem);background:var(--surface-muted);border:1px solid hsla(0,0%,100%,.35);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px)}.center-feed,.left-explorer{box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1.5rem}.center-feed{grid-area:center;background:var(--surface-strong);border-radius:32px;border:1px solid hsla(0,0%,100%,.45);padding:clamp(1.25rem,3vw,2.75rem);min-height:100%;position:relative;z-index:0}.center-feed:before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at 20% 20%,hsla(0,0%,100%,.3),transparent 55%);opacity:.4;pointer-events:none;z-index:0}.center-feed>*{position:relative;z-index:1}.right-panel{grid-area:profile;top:clamp(1rem,3vw,2rem);border-radius:28px;background:var(--surface-muted);border:1px solid hsla(0,0%,100%,.35);box-shadow:var(--shadow-sm)}.page-shell{width:100%;max-width:var(--content-max);margin:0 auto;display:flex;flex-direction:column;gap:1.75rem}.home-page-shell{gap:2rem}.city-page-shell,.map-page-shell{gap:1.5rem}.panel-stack{display:flex;flex-direction:column;gap:1.25rem}.panel-card,.section-panel{background:var(--surface-strong);border-radius:24px;border:1px solid var(--border-soft);padding:clamp(1.25rem,2vw,1.75rem);box-shadow:var(--shadow-sm)}.profile-panel{gap:1.2rem}.profile-card,.profile-panel{display:flex;flex-direction:column}.profile-card{gap:1rem}.profile-cover{border-radius:18px;height:110px;background-size:cover;background-position:50%;border:1px solid rgba(15,23,42,.08)}.profile-cover.placeholder{background:linear-gradient(120deg,rgba(230,57,70,.15),rgba(255,107,122,.12));border:1px solid rgba(230,57,70,.1)}.profile-identity{display:flex;gap:1rem;align-items:center}.profile-avatar{width:64px;height:64px;border-radius:20px;-o-object-fit:cover;object-fit:cover;border:2px solid hsla(0,0%,100%,.8);box-shadow:0 12px 24px -18px rgba(6,7,15,.5)}.profile-avatar.placeholder{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e63946,#ff6b7a);color:#fff;font-weight:700;font-size:1.25rem;box-shadow:0 4px 16px rgba(230,57,70,.25)}.profile-basics h3{margin:0;font-size:1.15rem;color:var(--black)}.profile-name-row{display:flex;align-items:center;gap:.5rem}.profile-badge{border-radius:999px;padding:.2rem .6rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.3);color:#065f46;font-weight:600}.profile-handle{margin:.15rem 0 0;color:var(--gray-500);font-size:.9rem}.profile-contact{margin:.15rem 0 0;color:var(--gray-400);font-size:.85rem}.profile-pills{display:flex;flex-wrap:wrap;gap:.4rem}.profile-pill{border-radius:999px;border:1px solid rgba(15,23,42,.08);padding:.35rem .8rem;font-size:.8rem;color:var(--gray-600);background:rgba(15,23,42,.02)}.profile-meta{display:flex;flex-wrap:wrap;gap:.6rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.2em;color:var(--gray-400)}.profile-bio{margin:0;padding:.9rem 1rem;border-left:3px solid var(--japan-red);background:rgba(15,23,42,.03);font-size:.9rem;color:var(--gray-600)}.profile-actions{display:flex;gap:.75rem}.profile-action-ghost{border:1px solid rgba(15,23,42,.1);background:transparent;color:var(--gray-600);border-radius:14px;padding:.55rem 1.1rem;font-weight:600}.profile-loading{gap:.75rem;text-align:center;color:var(--gray-500)}.profile-loading-ring{width:32px;height:32px;border-radius:50%;border:3px solid rgba(15,23,42,.1);border-top:3px solid var(--japan-red);animation:spin 1s linear infinite}.profile-guest{text-align:center;display:flex;flex-direction:column;gap:.9rem}.profile-guest h3{margin:0;font-size:1.25rem}.profile-guest p{margin:0;color:var(--gray-600)}.profile-guest-icon{font-size:2.8rem}.profile-guest-links{display:flex;justify-content:space-between;gap:.65rem;font-size:.85rem;color:var(--gray-500)}.profile-panel-heading{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.profile-panel-heading h4{margin:.15rem 0 0;font-size:1rem}.profile-panel-link{font-size:.85rem;color:var(--gray-500)}.profile-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.profile-stat-card{border-radius:18px;padding:1rem 1.1rem;color:var(--ink);display:flex;flex-direction:column;gap:.2rem;border:1px solid hsla(0,0%,100%,.6)}.profile-stat-label{font-size:.8rem;letter-spacing:.2em}.profile-shortcut-list{display:flex;flex-direction:column;gap:.65rem}.profile-shortcut-item{border-radius:16px;border:1px solid rgba(15,23,42,.08);padding:.75rem .95rem;justify-content:space-between}.profile-shortcut-item,.profile-shortcut-item>div{display:flex;align-items:center;gap:.75rem}.profile-shortcut-item p{margin:0;font-weight:600}.profile-shortcut-item span{font-size:.8rem;color:var(--gray-500)}.profile-shortcut-icon{font-size:1.2rem}.profile-shortcut-caret{font-size:1rem;color:var(--gray-400)}.profile-map-card{display:flex;flex-direction:column;gap:1rem}.profile-map-body{display:flex;gap:1rem;align-items:center;padding:1rem;border-radius:20px;background:linear-gradient(135deg,rgba(255,212,230,.4),rgba(208,235,255,.4))}.profile-map-orb{width:52px;height:52px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;font-size:1.8rem;background:#fff}.profile-map-title{margin:0;font-weight:600}.profile-map-copy{margin:.25rem 0 0;color:var(--gray-600);font-size:.9rem}.profile-map-actions{display:flex;gap:.75rem;flex-wrap:wrap}.accent-iris{background:linear-gradient(135deg,#c4d4ff,#e0e7ff)}.accent-citrus{background:linear-gradient(135deg,#ffe8c2,#fff2df)}.accent-sakura{background:linear-gradient(135deg,#ffd1dc,#ffe1ec)}.accent-emerald{background:linear-gradient(135deg,#c7f9cc,#e0ffe3)}.panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.panel-meta{font-size:.78rem;text-transform:uppercase;letter-spacing:.24em;color:var(--gray-500)}.glass-nav{position:sticky;top:clamp(.5rem,2vw,1rem);z-index:20;display:flex;align-items:center;gap:1.25rem;padding:.85rem 1.75rem;border-radius:999px;background:hsla(0,0%,100%,.92);border:1px solid hsla(0,0%,100%,.65);box-shadow:0 30px 80px -45px rgba(5,6,12,.65);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.glass-nav.compact{border-radius:28px;padding:.75rem 1.25rem}.nav-brand{display:flex;align-items:center;gap:.75rem}.nav-logo{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#e63946,#ff6b7a);display:inline-flex;align-items:center;justify-content:center;font-size:1.25rem;color:#fff;box-shadow:0 4px 12px rgba(230,57,70,.3)}.nav-copy{display:flex;flex-direction:column;gap:.2rem}.nav-title{font-weight:600;font-size:1rem;color:var(--black)}.nav-subtitle{font-size:.72rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gray-500)}.nav-links{gap:1rem;margin-left:auto}.nav-link,.nav-links{display:flex;align-items:center}.nav-link{gap:.5rem;font-size:.85rem;font-weight:600;color:var(--gray-500);padding:.5rem .75rem;border-radius:8px;transition:all .2s ease}.nav-link .nav-icon{display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s ease,transform .2s ease}.nav-link .nav-icon svg{display:block}.nav-link .nav-label{letter-spacing:.02em}.nav-link:hover{color:var(--black);background:rgba(0,0,0,.04)}.nav-link:hover .nav-icon{opacity:1;transform:scale(1.1)}.nav-link.active{color:var(--japan-red);background:rgba(230,57,70,.08)}.nav-link.active .nav-icon{opacity:1}.nav-actions{gap:.75rem}.nav-actions,.nav-auth{display:flex;align-items:center}.nav-auth{gap:.35rem;font-size:.85rem;color:var(--gray-500)}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid var(--border-soft);background:var(--surface-muted);color:var(--gray-700);cursor:pointer;transition:all .2s ease}.theme-toggle:hover{background:var(--surface-strong);border-color:var(--border-strong);color:var(--black);transform:translateY(-1px)}.theme-toggle:active{transform:translateY(0)}.nav-mobile-toggle{display:none;border:1px solid rgba(15,23,42,.15);border-radius:999px;padding:.4rem .55rem;background:transparent;color:var(--black)}@media (max-width:1024px){.glass-nav{padding:.75rem 1.25rem;gap:1rem}.nav-links{gap:.5rem}.nav-link{font-size:.8rem;padding:.45rem .65rem}.nav-link .nav-icon{width:16px;height:16px}.nav-actions{gap:.5rem}.nav-auth{font-size:.8rem}.btn-share{padding:.6rem 1rem;font-size:.85rem}}@media (max-width:768px){.glass-nav{position:sticky;top:.5rem;border-radius:16px;padding:.65rem .85rem;gap:.75rem;margin:0 .5rem;width:calc(100% - 1rem);left:.5rem;right:.5rem}.nav-logo{width:36px;height:36px;font-size:1.1rem;border-radius:11px}.nav-copy{gap:.15rem}.nav-title{font-size:.9rem}.nav-subtitle{font-size:.65rem;letter-spacing:.28em}.nav-actions,.nav-links{display:none}.nav-mobile-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:.6rem .8rem;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.nav-mobile-toggle:active{transform:scale(.95);background:rgba(0,0,0,.05)}.nav-mobile-toggle svg{width:20px;height:20px}.nav-brand{flex:1}.nav-drawer{position:fixed;inset:0;background:rgba(4,6,18,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:50}.nav-drawer-panel{width:min(340px,90vw);height:100vh;background:hsla(0,0%,100%,.98);backdrop-filter:blur(20px);border-radius:24px 0 0 24px;padding:1.5rem;gap:1.25rem;max-height:100vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.nav-drawer-panel>.flex{margin-bottom:.5rem}.nav-drawer-links,.nav-drawer-panel>.flex{padding-bottom:1rem;border-bottom:1px solid rgba(0,0,0,.08)}.nav-drawer-links{gap:.5rem}.nav-drawer-link{padding:.85rem 1rem;border-radius:14px;font-size:.95rem;-webkit-tap-highlight-color:transparent;transition:all .2s ease}.nav-drawer-link:active{transform:scale(.98);background:rgba(15,23,42,.08)}.nav-drawer-link .nav-icon{width:36px;height:36px;border-radius:10px}.nav-drawer-actions{gap:.75rem;margin-top:auto}.nav-drawer-actions .btn{width:100%;justify-content:center;padding:.85rem 1rem;font-size:.9rem;min-height:44px;-webkit-tap-highlight-color:transparent}.nav-drawer-actions .btn:active{transform:scale(.98)}.nav-drawer-actions .flex{padding:.75rem 0;border-top:1px solid rgba(0,0,0,.08);border-bottom:1px solid rgba(0,0,0,.08);margin:.5rem 0}}@media (max-width:480px){.glass-nav{padding:.6rem .75rem;gap:.65rem;margin:0 .35rem;width:calc(100% - .7rem);left:.35rem;right:.35rem}.nav-logo{width:32px;height:32px;font-size:1rem;border-radius:9px}.nav-title{font-size:.85rem}.nav-subtitle{font-size:.6rem;letter-spacing:.25em}.nav-mobile-toggle{padding:.4rem .55rem}.nav-mobile-toggle svg{width:18px;height:18px}.nav-drawer-panel{width:min(340px,90vw);padding:1.25rem}.nav-drawer-link{padding:.75rem .85rem;font-size:.9rem}.nav-drawer-link .nav-icon{width:32px;height:32px}}.nav-drawer{position:fixed;inset:0;background:rgba(4,6,18,.75);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:none;align-items:flex-start;justify-content:flex-end;z-index:40}.nav-drawer.open{display:flex}.nav-drawer-panel{width:min(340px,90vw);background:hsla(0,0%,100%,.98);border-radius:28px 0 0 28px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.nav-drawer-links{display:flex;flex-direction:column;gap:.35rem}.nav-drawer-link{gap:.75rem;padding:.75rem 1rem;border-radius:12px;font-weight:600;color:var(--gray-700)}.nav-drawer-link,.nav-drawer-link .nav-icon{display:flex;align-items:center;transition:all .2s ease}.nav-drawer-link .nav-icon{justify-content:center;width:32px;height:32px;background:rgba(0,0,0,.04);border-radius:8px;color:var(--gray-600)}.nav-drawer-link .nav-icon svg{display:block}.nav-drawer-link:hover{background:rgba(15,23,42,.06)}.nav-drawer-link:hover .nav-icon{background:rgba(230,57,70,.1);color:var(--japan-red)}.nav-drawer-actions{display:flex;flex-direction:column;gap:.65rem}.explorer-hero{position:relative;border-radius:24px;padding:2rem;background:linear-gradient(145deg,#1a1a2e,#16213e 50%,#0f3460);box-shadow:0 20px 60px -20px rgba(0,0,0,.4),inset 0 1px 0 hsla(0,0%,100%,.1);display:flex;flex-direction:column;gap:1rem;overflow:hidden;border:1px solid hsla(0,0%,100%,.08)}.explorer-hero:before{content:"";position:absolute;top:-50%;right:-30%;width:300px;height:300px;background:radial-gradient(circle,rgba(230,57,70,.15) 0,transparent 70%);pointer-events:none}.explorer-hero:after{content:"🌸";position:absolute;top:1rem;right:1.5rem;font-size:2.5rem;opacity:.3;animation:float 6s ease-in-out infinite}.explorer-hero h2{color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin:0;background:linear-gradient(135deg,#fff,#fda4af);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.explorer-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:#fda4af;font-weight:600}.explorer-eyebrow:before{content:"";width:24px;height:2px;background:linear-gradient(90deg,#e63946,#fda4af);border-radius:2px}.explorer-hero-copy{color:hsla(0,0%,100%,.7);font-size:.9rem;line-height:1.6;max-width:90%}.explorer-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}.explorer-btn{border-radius:12px;padding:.65rem 1.35rem;font-size:.85rem;font-weight:600;border:none;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-decoration:none}.explorer-btn.primary{background:linear-gradient(135deg,#e63946,#d62839);color:#fff;box-shadow:0 8px 24px -8px rgba(230,57,70,.5),inset 0 1px 0 hsla(0,0%,100%,.2)}.explorer-btn.primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px -8px rgba(230,57,70,.6),inset 0 1px 0 hsla(0,0%,100%,.2)}.explorer-btn.ghost{border:1px solid hsla(0,0%,100%,.2);color:hsla(0,0%,100%,.9);background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px)}.explorer-btn.ghost:hover{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.3)}.explorer-meta{display:flex;flex-wrap:wrap;gap:1.5rem;border-top:1px solid hsla(0,0%,100%,.1);padding-top:1.25rem;margin-top:.5rem}.explorer-meta-item{display:flex;flex-direction:column;gap:.25rem}.explorer-meta-value{font-size:1.25rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#fda4af,#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.explorer-meta-label{font-size:.72rem;color:hsla(0,0%,100%,.5);text-transform:uppercase;letter-spacing:.1em}.explorer-card{position:relative;border-radius:20px;padding:1.5rem;background:linear-gradient(165deg,hsla(0,0%,100%,.95),hsla(0,100%,99%,.9));box-shadow:0 4px 24px -4px rgba(0,0,0,.08),0 0 0 1px rgba(230,57,70,.05);display:flex;flex-direction:column;gap:1rem;transition:all .3s ease;overflow:hidden}.explorer-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#e63946,#fda4af,#fecdd3);opacity:0;transition:opacity .3s ease}.explorer-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px -8px rgba(0,0,0,.12),0 0 0 1px rgba(230,57,70,.1)}.explorer-card:hover:before{opacity:1}.explorer-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.explorer-card-header h3{font-size:1.1rem;font-weight:700;color:#1a1a2e;margin:.25rem 0 0;letter-spacing:-.01em}.explorer-card-label{display:inline-flex;align-items:center;gap:.4rem;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:#e63946;font-weight:700}.explorer-card-label:before{content:"";width:6px;height:6px;background:#e63946;border-radius:50%}.explorer-card-copy{font-size:.88rem;color:var(--gray-600);margin-top:.4rem;line-height:1.5}.explorer-card-pill{border-radius:20px;padding:.4rem .9rem;font-size:.72rem;font-weight:700;background:linear-gradient(135deg,rgba(230,57,70,.1),rgba(230,57,70,.15));color:#b91c1c;border:1px solid rgba(230,57,70,.2);white-space:nowrap}.explorer-chip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.6rem}.explorer-chip{position:relative;border-radius:14px;border:1px solid rgba(26,26,46,.08);padding:.6rem .9rem;display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;color:var(--gray-700);background:linear-gradient(135deg,#fff,#fafafa);transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;text-decoration:none;overflow:hidden}.explorer-chip:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(230,57,70,.08),rgba(253,164,175,.08));opacity:0;transition:opacity .25s ease}.explorer-chip:hover{border-color:rgba(230,57,70,.3);transform:translateY(-1px);box-shadow:0 4px 12px -4px rgba(230,57,70,.2)}.explorer-chip:hover:before{opacity:1}.explorer-chip:hover .chip-text{color:#c53030}.explorer-chip.active{background:linear-gradient(135deg,#e63946,#d62839);border-color:transparent;color:#fff;box-shadow:0 8px 20px -8px rgba(230,57,70,.5),inset 0 1px 0 hsla(0,0%,100%,.2)}.explorer-chip.active .chip-text{color:#fff}.chip-icon{font-size:1.15rem}.chip-icon,.chip-text{position:relative;z-index:1}.chip-text{transition:color .25s ease}.explorer-card-note{font-size:.82rem;color:var(--gray-600);background:linear-gradient(135deg,rgba(26,26,46,.03),rgba(230,57,70,.03));border-radius:12px;padding:.85rem 1rem;border-left:3px solid #fda4af;line-height:1.5}.explorer-card-note:before{content:"💡 "}.quick-share-card{display:flex;flex-direction:column;gap:1rem}.quick-share-moods{display:flex;flex-wrap:wrap;gap:.55rem}.mood-pill{border-radius:999px;padding:.4rem .95rem;border:1px solid rgba(15,23,42,.08);font-size:.85rem;color:var(--gray-600);background:rgba(15,23,42,.02);display:inline-flex;align-items:center;gap:.35rem;transition:all .2s ease}.mood-pill.active{background:linear-gradient(135deg,#e63946,#ff6b7a);border-color:transparent;color:#fff;font-weight:600;box-shadow:0 8px 20px -8px rgba(230,57,70,.6)}.quick-share-textarea{min-height:110px;resize:vertical}.quick-share-media{display:flex;flex-direction:column;gap:.75rem}.quick-share-preview{position:relative;width:100%;height:180px;border-radius:20px;overflow:hidden;border:1px solid rgba(15,23,42,.08)}.quick-share-clear{position:absolute;top:.65rem;right:.65rem;border-radius:999px;padding:.3rem .9rem;font-size:.78rem;background:rgba(0,0,0,.7);color:#fff}.quick-share-hint{font-size:.85rem;color:var(--gray-500)}.quick-share-actions{display:flex;gap:.75rem;flex-wrap:wrap}.city-hero{border-radius:var(--radius-xl);border:1px solid rgba(15,23,42,.08);background:linear-gradient(135deg,rgba(230,57,70,.06),hsla(0,0%,100%,.95));padding:clamp(1.5rem,3vw,2.5rem);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1.5rem}.city-hero-top{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.9fr);gap:1.5rem;align-items:stretch}.city-hero-actions{gap:.75rem;margin-top:1rem}.city-hero-pillboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.city-pillboard-card{border-radius:var(--radius-lg);border:1px solid rgba(15,23,42,.08);padding:1.25rem;background:hsla(0,0%,100%,.92);display:flex;flex-direction:column;gap:.65rem}.city-pillboard-card h3{margin:0;font-size:1.05rem}.city-pillboard-list{display:flex;flex-direction:column;gap:.4rem;padding-left:1rem;color:var(--gray-600)}.city-hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1rem}.city-hero-stat{border-radius:18px;padding:1rem;border:1px solid rgba(15,23,42,.08);background:hsla(0,0%,100%,.92);gap:.3rem}.city-hero-stat .value{font-size:1.65rem;font-weight:700;color:var(--black)}.city-hero-stat .label{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-600)}.cities-feed-grid{display:grid;grid-template-columns:minmax(0,1.65fr) minmax(260px,.9fr);gap:1.25rem;align-items:flex-start}.cities-feed-columns{display:flex;flex-direction:column;gap:1.25rem}.cities-feed-right{position:sticky;top:0}@media (max-width:1180px){.cities-feed-grid,.city-hero-top{grid-template-columns:1fr}.cities-feed-right{position:static}}.city-overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.city-overview-card{border-radius:var(--radius-lg);border:1px solid rgba(15,23,42,.08);background:hsla(0,0%,100%,.95);padding:1.25rem 1.5rem;box-shadow:0 10px 25px rgba(15,23,42,.08)}.city-overview-card h3{margin:.35rem 0}.city-overview-list{display:flex;flex-direction:column;gap:.4rem;margin-top:.75rem;color:var(--gray-600);font-size:.9rem}.city-loop-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.city-loop-card{border-radius:var(--radius-lg);border:1px solid rgba(15,23,42,.08);background:hsla(0,0%,100%,.93);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.city-loop-meta h4{margin-top:.25rem}.city-loop-steps{display:flex;flex-direction:column;gap:.5rem}.city-loop-step{display:flex;gap:.6rem;font-size:.95rem;color:var(--gray-700)}.city-loop-step span{width:1.5rem;height:1.5rem;border-radius:999px;background:rgba(229,57,70,.12);color:var(--japan-red);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600}.city-loop-tip{font-size:.85rem;color:var(--gray-600)}.city-featured-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.city-featured-card{border-radius:var(--radius-lg);border:1px solid rgba(15,23,42,.08);background:#fff;overflow:hidden;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 12px 25px rgba(15,23,42,.08)}.city-featured-media{height:180px;border-radius:0;background-size:cover;background-position:50%;padding:1.25rem;display:flex;flex-direction:column;justify-content:space-between;color:#fff}.city-featured-title{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600}.city-featured-card p:last-child{color:var(--gray-600);padding:0 1.25rem 1.25rem}.city-regional-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.city-regional-card{border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-lg);padding:1.1rem 1.25rem;background:hsla(0,0%,100%,.96);display:flex;flex-direction:column;gap:.65rem}.city-regional-cities{display:flex;flex-wrap:wrap;gap:.4rem}.city-regional-cities a{font-size:.85rem;padding:.35rem .75rem;border-radius:999px;border:1px solid rgba(229,57,70,.2);color:var(--japan-red);transition:background .15s ease}.city-regional-cities a:hover{background:rgba(229,57,70,.08)}.city-regional-note{font-size:.85rem;color:var(--gray-600)}.city-directory-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.city-directory-column{display:flex;flex-direction:column;gap:.75rem}.city-directory-item{display:flex;justify-content:space-between;gap:.75rem;padding:.65rem .85rem;border-radius:var(--radius);border:1px solid var(--gray-200);background:#fff;transition:border-color .15s ease,transform .15s ease}.city-directory-item:hover{border-color:var(--japan-red);transform:translateY(-2px)}.city-directory-meta{font-size:.8rem;color:var(--gray-500)}.city-directory-pill{font-size:.75rem;color:var(--gray-600);background:var(--gray-100);border-radius:999px;padding:.2rem .7rem;white-space:nowrap}.city-signal-list{display:flex;flex-direction:column;gap:.85rem}.city-signal-card{display:flex;gap:.75rem;border-radius:var(--radius);border:1px solid var(--gray-200);padding:.85rem 1rem;background:rgba(248,249,251,.95)}.city-signal-icon{font-size:1.5rem}.city-signal-header{display:flex;justify-content:space-between;gap:.5rem;align-items:baseline}.city-signal-header span{font-size:.75rem;text-transform:uppercase;color:var(--gray-500)}.city-signal-card p{margin-top:.35rem;font-size:.9rem;color:var(--gray-600)}.city-playlist-grid{display:flex;flex-direction:column;gap:.75rem}.city-playlist-card{border-radius:var(--radius);border:1px solid var(--gray-200);padding:.9rem 1rem;background:#fff;box-shadow:var(--shadow-sm)}.city-playlist-card h4{margin-bottom:.35rem}.city-playlist-card p{color:var(--gray-600);font-size:.9rem}.city-playlist-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.65rem}.city-playlist-tags a{font-size:.8rem;padding:.25rem .65rem;border-radius:999px;background:var(--gray-100);color:var(--gray-700)}.map-page-shell{gap:1.5rem}.map-hero{background:linear-gradient(135deg,rgba(230,57,70,.08),hsla(0,0%,100%,.95));border-radius:var(--radius-xl);border:1px solid rgba(15,23,42,.08);padding:clamp(1.5rem,2.5vw,2.5rem);box-shadow:0 18px 38px rgba(15,23,42,.08);display:flex;flex-direction:column;gap:1.25rem}.map-hero-top{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-start}.map-hero-content{flex:1;min-width:260px}.map-hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.map-grid{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(280px,.9fr);gap:1.25rem;align-items:flex-start}.map-visual-panel{border-radius:var(--radius-xl);border:1px solid var(--gray-200);background:#fff;padding:1.5rem;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:1rem}.map-visual-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.map-status{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .75rem;border-radius:999px;background:var(--gray-100);color:var(--gray-600)}.map-status.live{background:rgba(16,185,129,.15);color:#047857}.map-status.syncing{background:rgba(245,158,11,.2);color:#b45309}.map-visual-body{border-radius:var(--radius-lg);overflow:hidden;min-height:420px;background:var(--gray-50)}.map-loading-state{height:420px;color:var(--gray-600);font-weight:500}.map-side-panel{gap:1rem}.map-side-card,.map-side-panel{display:flex;flex-direction:column}.map-side-card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;padding:1.25rem;box-shadow:var(--shadow-sm);gap:.85rem}.map-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.map-stat-card{padding:.75rem .9rem;border-radius:var(--radius);background:var(--gray-50)}.map-stat-value{font-size:1.4rem;font-weight:700;color:var(--japan-red)}.map-stat-label{font-size:.85rem;color:var(--gray-600)}.map-side-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.45rem;color:var(--gray-600);font-size:.9rem}.map-lists{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(240px,.9fr);gap:1.25rem}.map-list-card{border:1px solid var(--gray-200);border-radius:var(--radius-xl);background:#fff;padding:1.5rem;box-shadow:var(--shadow-sm);gap:1rem}.map-list-card,.map-visited-list{display:flex;flex-direction:column}.map-visited-list{gap:.65rem}.map-visited-item{display:flex;flex-direction:column;gap:.2rem;padding:.85rem 1rem;border-radius:var(--radius);border:1px solid var(--gray-200);background:var(--gray-50);transition:border-color .15s ease,transform .15s ease}.map-visited-item:hover{border-color:var(--japan-red);transform:translateY(-2px)}.map-empty-state{text-align:center;padding:2.5rem 1.5rem;border-radius:var(--radius-lg);border:1px dashed var(--gray-300);background:rgba(248,249,251,.6)}.map-itinerary-list{display:flex;flex-direction:column;gap:.75rem}.map-itinerary-item{border:1px solid var(--gray-200);border-radius:var(--radius);padding:.9rem 1rem}.map-itinerary-meta{font-size:.8rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.08em}@media (max-width:1024px){.city-featured-grid,.city-hero-pillboard,.city-loop-grid,.city-regional-grid,.map-grid,.map-lists{grid-template-columns:1fr}}.hero-banner{background:linear-gradient(135deg,rgba(230,57,70,.08),rgba(12,14,33,.95));border-radius:var(--radius-xl);margin:1.5rem auto 0;padding:2.5rem 2rem;color:var(--black);max-width:960px;box-shadow:var(--shadow-lg);display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}.hero-content{color:#0f172a}.hero-content h1{color:#0f172a;font-size:clamp(2rem,4vw,2.75rem);margin-bottom:.75rem}.hero-description{color:var(--gray-700);font-size:1rem;line-height:1.7;margin-bottom:1.25rem}.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap}.hero-highlights{display:grid;gap:1rem}.hero-highlight-card{background:#fff;border-radius:var(--radius-lg);padding:1rem 1.25rem;border:1px solid rgba(15,23,42,.08);box-shadow:var(--shadow-sm)}.hero-highlight-value{font-size:1.75rem;font-weight:700;color:var(--japan-red)}.hero-highlight-label{font-size:.875rem;font-weight:600;color:var(--gray-600)}.hero-highlight-detail{font-size:.875rem;color:var(--gray-500)}.section-heading{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem}.featured-section{background:#fff;margin:1.5rem auto 0;max-width:960px;border-radius:var(--radius-xl);padding:1.75rem 2rem;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100)}.city-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.city-card{background:linear-gradient(180deg,rgba(230,57,70,.1),hsla(0,0%,100%,.9));border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-sm);border:1px solid rgba(229,57,70,.15)}.city-card h3{margin-bottom:.5rem;font-size:1.25rem}.city-card p{color:var(--gray-600);line-height:1.5;margin-bottom:.75rem}.city-pill{display:inline-flex;padding:.35rem .85rem;font-size:.75rem;border-radius:999px;background:rgba(230,57,70,.15);color:#b91c1c;font-weight:600}.tips-section{background:#fff;margin:1.5rem auto 2rem;max-width:960px;border-radius:var(--radius-xl);padding:1.75rem 2rem;border:1px solid var(--gray-100);box-shadow:var(--shadow-sm)}.tip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.tip-card{border-radius:var(--radius-lg);padding:1.25rem;background:var(--gray-50);border:1px solid rgba(0,0,0,.05)}.tip-card h3{margin-bottom:.35rem}.tip-card p{color:var(--gray-600);line-height:1.6}.tip-badge{border-radius:999px;padding:.35rem .9rem;background:rgba(15,23,42,.08);font-size:.875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-600)}.btn-secondary{background:transparent;border:1px solid var(--gray-900);color:var(--gray-900)}.btn-outline{border:1px solid rgba(15,23,42,.2);color:var(--black);padding:.6rem 1.25rem;font-size:.85rem}.eyebrow{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-500);margin-bottom:.65rem}.pulse-section,.spotlight-section{background:#fff;margin:1.5rem auto 0;max-width:960px;border-radius:var(--radius-xl);padding:1.75rem 2rem;border:1px solid var(--gray-100);box-shadow:var(--shadow-sm)}.pulse-grid,.spotlight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.pulse-card,.spotlight-card{border-radius:var(--radius-lg);padding:1.35rem;border:1px solid rgba(15,23,42,.05);background:var(--gray-50);box-shadow:var(--shadow-sm)}.pulse-card h3,.spotlight-card h3{font-size:1.1rem;margin-bottom:.35rem;color:var(--gray-800)}.pulse-card p,.spotlight-card p{color:var(--gray-600);line-height:1.6}.spotlight-type{display:inline-flex;padding:.35rem .75rem;border-radius:999px;background:rgba(229,57,70,.08);color:#b91c1c;font-size:.75rem;font-weight:600;margin-bottom:.65rem;text-transform:uppercase;letter-spacing:.08em}.daily-section{background:#fff;margin:1.5rem auto 2rem;max-width:960px;border-radius:var(--radius-xl);padding:1.75rem 2rem;border:1px solid var(--gray-100);box-shadow:var(--shadow-sm)}.daily-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.daily-card{border-radius:var(--radius-lg);padding:1.25rem;border:1px solid rgba(15,23,42,.05);background:var(--gray-50);box-shadow:var(--shadow-sm)}.daily-card h3{margin:.35rem 0;font-size:1.15rem}.daily-card p{color:var(--gray-600);line-height:1.45}.daily-card-header{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;text-transform:uppercase;letter-spacing:.06em}.daily-date{color:var(--gray-500)}.daily-tag{padding:.25rem .75rem;border-radius:999px;background:rgba(15,23,42,.08);color:var(--gray-700)}.daily-author{margin-top:.75rem;font-size:.85rem;color:var(--gray-600)}.daily-empty{font-size:.95rem;color:var(--gray-500)}.feed-header{background:hsla(0,0%,100%,.92);border:1px solid var(--border-soft);border-radius:24px;padding:1.5rem;position:sticky;top:clamp(4.5rem,6vw,5.75rem);z-index:15;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 30px 80px -50px rgba(0,0,0,.65)}.feed-tabs-layout{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:1.25rem;align-items:stretch}.feed-tabs-left{grid-column:span 4;border-radius:20px;border:1px solid rgba(15,23,42,.08);padding:1rem 1.25rem;background:hsla(0,0%,100%,.85);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.6)}.feed-tabs-center{grid-column:span 4;display:flex;flex-direction:column;gap:.75rem}.feed-tabs-right{grid-column:span 4;display:flex;align-items:stretch}.feed-tabs-eyebrow{font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gray-500);margin-bottom:.5rem}.feed-tabs-title{margin:0;font-size:1.45rem;color:var(--ink);line-height:1.3}.feed-tabs-checklist{list-style:none;padding:0;margin:.9rem 0 0;display:flex;flex-direction:column;gap:.4rem}.feed-tabs-checklist li{font-size:.9rem;color:var(--gray-600);display:flex;align-items:center;gap:.5rem}.feed-tabs-checklist li span:first-child{color:var(--japan-red);font-size:.85rem}.feed-mode-card{border-radius:22px;border:1px solid rgba(15,23,42,.06);padding:1rem 1.25rem;background:linear-gradient(135deg,hsla(0,0%,100%,.95),rgba(243,246,255,.9));display:flex;align-items:center;gap:.85rem;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.feed-mode-card:hover{transform:translateY(-4px);box-shadow:0 25px 60px -40px rgba(0,0,0,.8)}.feed-mode-card.active{border-color:rgba(230,57,70,.4);background:linear-gradient(135deg,rgba(230,57,70,.12),hsla(0,0%,100%,.95));box-shadow:0 35px 80px -45px rgba(230,57,70,.6)}.feed-mode-icon{font-size:1.75rem}.feed-mode-copy{flex:1;display:flex;flex-direction:column;gap:.2rem}.feed-mode-title{font-weight:600;color:var(--black)}.feed-mode-sub{font-size:.85rem;color:var(--gray-600)}.feed-mode-meta{font-size:.8rem;text-transform:uppercase;letter-spacing:.2em;color:var(--gray-500)}.feed-tabs-right .feed-cta-card{border-radius:24px;border:1px solid rgba(15,23,42,.08);padding:1.25rem;background:radial-gradient(circle at 10% 20%,rgba(230,57,70,.08),transparent 50%),hsla(0,0%,100%,.94);display:flex;flex-direction:column;gap:.6rem;width:100%;box-shadow:var(--shadow-sm)}.feed-cta-pill{font-size:.75rem;text-transform:uppercase;letter-spacing:.3em;color:var(--japan-red)}.feed-cta-card h4{margin:0;font-size:1.3rem;color:var(--ink)}.feed-cta-card p{margin:0;color:var(--gray-600);font-size:.9rem}.feed-insights-grid{margin-top:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.feed-insight{border-radius:18px;border:1px solid rgba(15,23,42,.08);padding:1rem 1.2rem;background:hsla(0,0%,100%,.9);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.5)}.feed-insight .value{display:block;font-size:1.65rem;font-weight:700;color:var(--black)}.feed-insight .label{display:block;font-size:.8rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gray-500);margin-top:.4rem}.feed-insight .hint{display:block;font-size:.85rem;color:var(--gray-600);margin-top:.2rem}@media (max-width:1100px){.feed-tabs-layout{grid-template-columns:repeat(6,minmax(0,1fr))}.feed-tabs-center,.feed-tabs-left,.feed-tabs-right{grid-column:span 6}}@media (max-width:640px){.feed-header{padding:1.1rem}.feed-mode-card{flex-direction:row}}@media (max-width:768px){.app-frame{padding:1rem}.app-layout{gap:1rem}.app-layout,.center-feed{padding:1rem;border-radius:24px}.left-explorer,.right-panel{position:static;height:auto;overflow-y:visible;border-radius:20px;padding:1rem;margin-top:1rem}.profile-panel{display:none}.section-heading{flex-direction:column;align-items:flex-start}.featured-section,.hero-banner,.pulse-section,.spotlight-section,.tips-section{padding:1.25rem;border-radius:22px}.hero-actions{flex-direction:column;align-items:stretch}.feed-tabs-layout{grid-template-columns:1fr}.feed-tabs-center,.feed-tabs-left,.feed-tabs-right{grid-column:span 1}.feed-tabs-right{order:3}.feed-content{padding:0 .5rem 1.5rem}.profile-stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.profile-stat-card{min-width:0;padding:1rem}.profile-shortcut-item{min-height:44px;padding:.85rem 1rem}.profile-action-card a,.profile-action-card button{min-height:44px;padding:.75rem 1.25rem}}.feed-content{padding:0 1.5rem 2rem;max-width:min(1100px,100%);width:100%;margin:0 auto;display:flex;flex-direction:column;gap:1.75rem}.right-panel{background:var(--surface-strong);border:1px solid var(--border-soft);border-radius:24px;position:sticky;top:clamp(1rem,3vw,2.5rem);height:calc(100vh - clamp(2rem, 6vw, 4rem));overflow-y:auto;padding:clamp(1.25rem,2vw,1.75rem);box-shadow:var(--shadow-md);background-image:radial-gradient(circle at 80% 20%,rgba(129,140,248,.12),transparent 55%)}.post-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.75rem;margin-bottom:1rem;border:1px solid var(--gray-100);transition:box-shadow .2s ease;width:100%}.post-card:hover{box-shadow:var(--shadow)}.post-author{gap:.75rem;margin-bottom:1rem}.post-avatar{width:40px;height:40px;border-radius:50%;background:var(--gray-200);flex-shrink:0}.post-author-name{font-weight:600;font-size:.9375rem;color:var(--black)}.post-author-time{font-size:.875rem;color:var(--gray-500)}.post-title{font-size:1.5rem;font-weight:700;color:var(--black);margin-bottom:.75rem;line-height:1.4}.post-content{color:var(--gray-700);font-size:1.0625rem;line-height:1.7;margin-bottom:1rem}.post-images{display:grid;gap:.5rem;margin:1rem 0;border-radius:var(--radius);overflow:hidden}.post-images.single{grid-template-columns:1fr}.post-images.double{grid-template-columns:1fr 1fr}.post-images.triple{grid-template-columns:2fr 1fr;grid-template-rows:repeat(2,1fr)}.post-images.multiple{grid-template-columns:repeat(2,1fr)}.post-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;background:var(--gray-100)}.post-image.first-triple{grid-row:1/3}.post-emotion{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:999px;font-size:.9375rem;color:var(--gray-700);margin-bottom:.75rem}.post-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0}.post-tag{padding:.375rem .75rem;background:var(--gray-100);color:var(--gray-700);font-size:.9375rem;border-radius:var(--radius-sm);transition:all .15s ease}.post-tag:hover{background:var(--gray-200)}.post-location{display:flex;align-items:center;gap:.5rem;color:var(--japan-red);font-size:.9375rem;margin:.75rem 0}.post-actions{gap:1rem;padding-top:1rem;border-top:1px solid var(--gray-100)}.post-action-btn{display:flex;align-items:center;gap:.375rem;padding:.625rem .875rem;background:transparent;border:none;border-radius:var(--radius);font-size:.9375rem;color:var(--gray-600);transition:all .15s ease}.post-action-btn:hover{background:var(--gray-50);color:var(--black)}.post-action-btn.active{color:var(--japan-red)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:600;border-radius:var(--radius);border:none;transition:all .15s ease;cursor:pointer}.btn-primary{background:var(--japan-red);color:#fff}.btn-primary:hover{background:var(--japan-red-hover)}.btn-secondary{background:var(--gray-100);color:var(--black)}.btn-secondary:hover{background:var(--gray-200)}.btn-outline{background:transparent;border:1px solid var(--gray-300);color:var(--gray-700)}.btn-outline:hover{background:var(--gray-50)}.btn.text-xs{font-size:.75rem;padding:.5rem 1rem}.btn.text-sm{font-size:.85rem;padding:.65rem 1.25rem}@media (max-width:768px){.btn{padding:.7rem 1.25rem;font-size:.9rem;min-height:44px;-webkit-tap-highlight-color:transparent}.btn.text-xs{font-size:.7rem;padding:.45rem .85rem;min-height:36px}.btn.text-sm{font-size:.8rem;padding:.6rem 1rem;min-height:40px}.btn:active{transform:scale(.98)}.input,.textarea{font-size:16px;padding:.75rem .85rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}.textarea{min-height:100px}}@media (max-width:480px){.btn{padding:.65rem 1rem;font-size:.85rem}.btn.text-xs{padding:.4rem .75rem}.btn.text-sm{padding:.55rem .9rem}.right-panel{padding:.75rem;margin-top:.75rem;border-radius:16px}.app-frame{padding:.5rem}.section-subtitle{padding:0 .5rem}.profile-action-card{padding:1rem}.featured-profile-stats{gap:.75rem}.nav-drawer-panel{width:min(85vw,300px);height:100dvh}.glass-nav{margin:0 .25rem;width:calc(100% - .5rem);top:.25rem}}.input{width:100%;padding:.75rem 1rem;font-size:.9375rem;border:1px solid var(--gray-300);border-radius:var(--radius);background:#fff;color:var(--black);transition:all .15s ease}.input:focus{outline:none;border-color:var(--japan-red);box-shadow:0 0 0 3px rgba(230,57,70,.1)}.textarea{min-height:120px;resize:vertical;font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-50)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.font-editorial{font-family:Playfair Display,Georgia,serif}.editorial-display{font-size:clamp(3rem,8vw,6rem);font-weight:700;line-height:1.05;letter-spacing:-.02em}.editorial-display,.editorial-headline{font-family:Playfair Display,Georgia,serif;color:var(--ink)}.editorial-headline{font-size:clamp(2rem,5vw,3.5rem);font-weight:600;line-height:1.15;letter-spacing:-.01em}.editorial-title{font-family:Playfair Display,Georgia,serif;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:600;line-height:1.25;color:var(--black)}.editorial-subtitle{font-size:clamp(1rem,2vw,1.25rem);font-weight:400;line-height:1.6;color:var(--gray-600);max-width:65ch}.editorial-body,.editorial-subtitle{font-family:Inter,system-ui,sans-serif}.editorial-body{font-size:1.125rem;line-height:1.8;color:var(--gray-700)}.editorial-eyebrow{font-size:.75rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--japan-red)}.editorial-caption,.editorial-eyebrow{font-family:Inter,system-ui,sans-serif}.editorial-caption{font-size:.875rem;font-weight:500;color:var(--gray-500)}.editorial-section{padding:clamp(3rem,8vw,6rem) 0}.editorial-container{max-width:1400px;margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem)}.editorial-hero{position:relative;min-height:70vh;display:flex;flex-direction:column;justify-content:center;padding:clamp(4rem,10vw,8rem) clamp(2rem,5vw,4rem);background:linear-gradient(135deg,hsla(0,0%,100%,.98),rgba(248,247,255,.95));border-radius:32px;overflow:hidden}.editorial-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:80%;height:150%;background:radial-gradient(circle,rgba(230,57,70,.08) 0,transparent 70%);pointer-events:none}.editorial-hero-content{position:relative;z-index:1;max-width:900px}.infographic-card{background:#fff;border-radius:24px;padding:2rem;border:1px solid var(--border-soft);box-shadow:0 4px 24px rgba(0,0,0,.04);transition:transform .3s ease,box-shadow .3s ease}.infographic-card:hover{transform:translateY(-4px);box-shadow:0 12px 48px rgba(0,0,0,.08)}.infographic-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}.stat-value{font-family:Playfair Display,Georgia,serif;font-size:clamp(2.5rem,5vw,4rem);font-weight:700;line-height:1;color:var(--ink)}.stat-value.accent{color:var(--japan-red)}.stat-label{font-family:Inter,system-ui,sans-serif;font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--gray-500);margin-top:.5rem}.stat-description{font-size:.9375rem;color:var(--gray-600);margin-top:.25rem}.progress-ring{position:relative;display:inline-flex;align-items:center;justify-content:center}.progress-ring-circle{transform:rotate(-90deg);transform-origin:center}.progress-ring-bg{fill:none;stroke:var(--gray-100);stroke-width:8}.progress-ring-progress{fill:none;stroke:var(--japan-red);stroke-width:8;stroke-linecap:round;stroke-dasharray:283;stroke-dashoffset:283;transition:stroke-dashoffset 1.5s ease-out}.progress-ring-value{position:absolute;font-family:Playfair Display,Georgia,serif;font-size:1.5rem;font-weight:700;color:var(--ink)}.bar-chart{display:flex;flex-direction:column;gap:1rem}.bar-chart-item{display:flex;align-items:center;gap:1rem}.bar-chart-label{min-width:100px;font-weight:500;color:var(--gray-700)}.bar-chart-track{flex:1;height:12px;background:var(--gray-100);border-radius:6px;overflow:hidden}.bar-chart-fill{height:100%;background:linear-gradient(90deg,var(--japan-red),#ff6b7a);border-radius:6px;transform-origin:left;transform:scaleX(0)}.bar-chart-fill.animate{animation:barGrow 1s ease-out forwards}.bar-chart-value{min-width:50px;text-align:right;font-weight:600;color:var(--japan-red)}.scroll-reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}.scroll-reveal.visible{opacity:1;transform:translateY(0)}.scroll-reveal.delay-1{transition-delay:.1s}.scroll-reveal.delay-2{transition-delay:.2s}.scroll-reveal.delay-3{transition-delay:.3s}.scroll-reveal.delay-4{transition-delay:.4s}.stagger-container>*{opacity:0;transform:translateY(20px);transition:opacity .5s ease-out,transform .5s ease-out}.stagger-container.visible>:first-child{transition-delay:0s;opacity:1;transform:translateY(0)}.stagger-container.visible>:nth-child(2){transition-delay:.1s;opacity:1;transform:translateY(0)}.stagger-container.visible>:nth-child(3){transition-delay:.2s;opacity:1;transform:translateY(0)}.stagger-container.visible>:nth-child(4){transition-delay:.3s;opacity:1;transform:translateY(0)}.stagger-container.visible>:nth-child(5){transition-delay:.4s;opacity:1;transform:translateY(0)}.stagger-container.visible>:nth-child(6){transition-delay:.5s;opacity:1;transform:translateY(0)}.editorial-divider{height:1px;background:linear-gradient(90deg,transparent,var(--gray-200),transparent);margin:clamp(2rem,5vw,4rem) 0}.editorial-divider.accent{background:linear-gradient(90deg,transparent,var(--japan-red),transparent);opacity:.3}.editorial-quote{position:relative;padding:2rem 3rem;font-size:1.5rem;font-style:italic;color:var(--gray-700);border-left:4px solid var(--japan-red);background:linear-gradient(135deg,rgba(230,57,70,.03),transparent);border-radius:0 16px 16px 0}.editorial-quote,.editorial-quote:before{font-family:Playfair Display,Georgia,serif}.editorial-quote:before{content:'"';position:absolute;top:-10px;left:20px;font-size:4rem;color:var(--japan-red);opacity:.2}.stats-row{display:flex;flex-wrap:wrap;gap:3rem;padding:2rem 0}.stats-row .stat-item{display:flex;flex-direction:column;gap:.25rem}.seasonal-timeline{display:flex;align-items:center;justify-content:space-between;padding:2rem 0;position:relative}.seasonal-timeline:before{content:"";position:absolute;top:50%;left:0;right:0;height:2px;background:var(--gray-200)}.seasonal-node{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.75rem}.seasonal-node-dot{width:24px;height:24px;border-radius:50%;background:#fff;border:3px solid var(--gray-300);transition:all .3s ease}.seasonal-node.active .seasonal-node-dot{background:var(--japan-red);border-color:var(--japan-red);box-shadow:0 0 0 6px rgba(230,57,70,.2)}.seasonal-node-label{font-size:.875rem;font-weight:600;color:var(--gray-600)}.seasonal-node.active .seasonal-node-label{color:var(--japan-red)}.magazine-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem}.magazine-grid .span-4{grid-column:span 4}.magazine-grid .span-6{grid-column:span 6}.magazine-grid .span-8{grid-column:span 8}.magazine-grid .span-12{grid-column:span 12}@media (max-width:1024px){.magazine-grid .span-4,.magazine-grid .span-6,.magazine-grid .span-8{grid-column:span 12}}.animated-number{display:inline-block;font-variant-numeric:tabular-nums}.hover-lift:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,.1)}.gradient-text{background:linear-gradient(135deg,var(--japan-red),#ff6b7a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.feature-card{background:#fff;border-radius:24px;padding:2.5rem;border:1px solid var(--border-soft);position:relative;overflow:hidden}.feature-card:after{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--japan-red),#ff6b7a);opacity:0;transition:opacity .3s ease}.feature-card:hover:after{opacity:1}.nav-link.travel-link{background:linear-gradient(135deg,rgba(230,57,70,.1),rgba(255,107,122,.05));border-radius:10px;padding:.5rem 1rem}.nav-link.travel-link:hover{background:linear-gradient(135deg,rgba(230,57,70,.15),rgba(255,107,122,.1))}.nav-link.travel-link .nav-icon{color:var(--japan-red);opacity:1}.btn-share{display:inline-flex;align-items:center;gap:.5rem}.btn-share .btn-icon{display:flex;align-items:center;justify-content:center}.btn-share .btn-icon svg{display:block}.travel-mode-toggle-container{position:relative}.travel-mode-toggle{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#fff;border:2px solid var(--gray-200);border-radius:20px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.travel-mode-toggle:hover{border-color:var(--japan-red);box-shadow:0 8px 24px rgba(230,57,70,.15)}.travel-mode-toggle.active{border-color:var(--japan-red);background:linear-gradient(135deg,rgba(230,57,70,.05),#fff)}.travel-mode-toggle .toggle-content{display:flex;align-items:center;gap:.75rem}.travel-mode-toggle .toggle-emoji{font-size:1.75rem}.travel-mode-toggle .toggle-info{display:flex;flex-direction:column;align-items:flex-start}.travel-mode-toggle .toggle-title{font-weight:600;color:var(--ink)}.travel-mode-toggle .toggle-subtitle{font-size:.875rem;color:var(--gray-500)}.travel-mode-toggle .toggle-pulse{position:absolute;top:50%;right:1rem;transform:translateY(-50%);width:12px;height:12px;background:var(--japan-red);border-radius:50%;animation:pulse-soft 2s infinite}.toggle-error{margin-top:.75rem;padding:.75rem 1rem;background:rgba(220,38,38,.1);border-radius:12px;color:#dc2626}.toggle-error,.travel-mode-toggle-navbar{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.travel-mode-toggle-navbar{padding:.5rem 1rem;background:#fff;border:1px solid var(--gray-200);border-radius:12px;cursor:pointer;transition:all .2s ease;font-weight:500}.travel-mode-toggle-navbar:hover{border-color:var(--japan-red)}.travel-mode-toggle-navbar.active{background:linear-gradient(135deg,rgba(230,57,70,.1),#fff);border-color:var(--japan-red)}.travel-mode-toggle-navbar .toggle-indicator{width:8px;height:8px;background:var(--japan-red);border-radius:50%;animation:pulse-soft 2s infinite}.travel-page{min-height:100vh;display:flex;flex-direction:column}.travel-page-main{flex:1;padding:1rem}.travel-welcome{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;max-width:1200px;margin:2rem auto;padding:3rem;background:#fff;border-radius:32px;border:1px solid var(--border-soft)}.welcome-content{display:flex;flex-direction:column;gap:1rem}.welcome-eyebrow{font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--japan-red)}.welcome-title{font-family:Playfair Display,Georgia,serif;font-size:2.5rem;font-weight:700;line-height:1.2;color:var(--ink)}.welcome-description{font-size:1.125rem;line-height:1.7;color:var(--gray-600);max-width:50ch}.welcome-features{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}.welcome-features .feature{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--gray-50);border-radius:16px}.welcome-features .feature-emoji{font-size:1.5rem}.welcome-features .feature-text{display:flex;flex-direction:column}.welcome-features .feature-text strong{font-weight:600;color:var(--ink);font-size:.9375rem}.welcome-features .feature-text span{font-size:.875rem;color:var(--gray-500)}.btn-start-travel{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem 2rem;background:linear-gradient(135deg,var(--japan-red),#ff6b7a);color:#fff;font-size:1.125rem;font-weight:600;border:none;border-radius:16px;cursor:pointer;transition:all .3s ease;margin-top:1.5rem}.btn-start-travel:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(230,57,70,.3)}.btn-start-travel:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-start-travel .loading-spinner{width:20px;height:20px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.welcome-error{display:flex;align-items:center;gap:.5rem;padding:1rem;background:rgba(220,38,38,.1);border-radius:12px;margin-top:1rem}.welcome-error .error-icon{font-size:1.25rem}.welcome-error .error-text{font-size:.9375rem;color:#dc2626}.welcome-note{font-size:.875rem;color:var(--gray-500);margin-top:1rem}.welcome-map-preview{position:relative;height:400px;border-radius:24px;overflow:hidden;background:var(--gray-100)}.map-preview-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:1}.map-preview-overlay .overlay-text{color:#fff;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;background:rgba(0,0,0,.5);border-radius:12px}.map-preview-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.travel-active-view{position:relative;height:calc(100vh - 8rem);border-radius:24px;overflow:hidden}.travel-map-container{position:absolute;inset:0}.travel-map-container .full-map,.travel-mode-map{width:100%;height:100%}.travel-mode-map{position:relative}.travel-mode-map .map-container{width:100%;height:100%}.travel-mode-map .map-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--gray-50)}.travel-mode-map .loading-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--japan-red);border-radius:50%;animation:spin .8s linear infinite}.travel-mode-map .map-no-location{top:50%;left:50%;transform:translate(-50%,-50%);align-items:center;padding:1.5rem 2rem;border-radius:16px;box-shadow:0 8px 24px rgba(0,0,0,.15)}.travel-mode-map .map-legend,.travel-mode-map .map-no-location{position:absolute;display:flex;flex-direction:column;gap:.5rem;background:#fff}.travel-mode-map .map-legend{bottom:1rem;left:1rem;padding:1rem;border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.1);font-size:.875rem}.travel-mode-map .legend-item{display:flex;align-items:center;gap:.5rem}.travel-mode-map .legend-marker{width:12px;height:12px;border-radius:50%}.travel-mode-map .legend-marker.user{background:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.3)}.travel-mode-map .legend-marker.destination{background:var(--japan-red);box-shadow:0 0 0 3px rgba(230,57,70,.3)}.travel-mode-map .legend-marker.story{background:#10b981}.travel-mode-map .legend-line{width:24px;height:4px;border-radius:2px}.travel-mode-map .legend-line.story-route{background:#2563eb}.travel-mode-map .legend-line.dest-route{background:repeating-linear-gradient(90deg,#10b981,#10b981 8px,transparent 0,transparent 12px)}.user-location-marker .user-marker{position:relative;width:24px;height:24px}.user-location-marker .user-marker-pulse{position:absolute;inset:0;background:rgba(59,130,246,.3);border-radius:50%;animation:pulse-soft 2s infinite}.user-location-marker .user-marker-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#3b82f6;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px rgba(59,130,246,.4)}.destination-marker .dest-marker{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.destination-marker .dest-marker-pulse{position:absolute;inset:0;background:rgba(230,57,70,.2);border-radius:50%;animation:pulse-soft 2s infinite}.destination-marker .dest-emoji{font-size:1.5rem;z-index:1}.story-point-marker .story-marker{width:32px;height:32px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.2)}.story-point-marker .story-letter{color:#fff;font-weight:700;font-size:.875rem}.travel-mode-panel{position:absolute;top:1rem;right:1rem;width:340px;max-height:calc(100% - 2rem);background:#fff;border-radius:24px;box-shadow:0 16px 48px rgba(0,0,0,.15);overflow-y:auto;display:flex;flex-direction:column}.travel-mode-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-100);background:linear-gradient(135deg,rgba(230,57,70,.05),#fff)}.travel-mode-panel .header-left{display:flex;align-items:center;gap:.5rem}.travel-mode-panel .header-icon{font-size:1.25rem}.travel-mode-panel .header-title{font-weight:600;color:var(--ink)}.travel-mode-panel .btn-minimize{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:8px;cursor:pointer;font-size:1rem}.current-destination{padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-100)}.current-destination .destination-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.current-destination .dest-label{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500)}.current-destination .btn-skip-small{font-size:.75rem;color:var(--gray-500);background:none;border:none;cursor:pointer}.current-destination .btn-skip-small:hover{color:var(--japan-red)}.current-destination .destination-info{display:flex;align-items:flex-start;gap:1rem}.current-destination .dest-emoji{font-size:2rem}.current-destination .dest-details{flex:1}.current-destination .dest-name{font-weight:600;font-size:1.125rem;color:var(--ink);margin:0 0 .25rem}.current-destination .dest-meta{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--gray-500)}.current-destination .dest-description{font-size:.9375rem;color:var(--gray-600);line-height:1.5;margin-top:.75rem}.current-destination .dest-tip{display:flex;align-items:flex-start;gap:.5rem;margin-top:.75rem;padding:.75rem;background:rgba(250,204,21,.1);border-radius:12px;font-size:.875rem}.current-destination .tip-icon{flex-shrink:0}.current-destination .tip-text{color:var(--gray-700)}.btn-add-story{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:1rem 1.5rem;padding:1rem;background:linear-gradient(135deg,var(--japan-red),#ff6b7a);color:#fff;font-weight:600;border:none;border-radius:16px;cursor:pointer;transition:all .2s ease}.btn-add-story:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(230,57,70,.3)}.story-points-summary{padding:1rem 1.5rem;border-bottom:1px solid var(--gray-100)}.story-points-summary .summary-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;font-size:.875rem}.story-points-summary .summary-header span:first-child{font-weight:600;color:var(--ink)}.story-points-summary .summary-count{color:var(--gray-500)}.story-points-mini-list{display:flex;flex-direction:column;gap:.5rem}.story-points-mini-list .mini-point{display:flex;align-items:center;gap:.75rem;font-size:.875rem}.story-points-mini-list .point-letter{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#10b981;color:#fff;font-weight:600;font-size:.75rem;border-radius:50%}.story-points-mini-list .point-name{color:var(--gray-700)}.story-points-mini-list .more-points{font-size:.875rem;color:var(--gray-500);padding-left:2.5rem}.suggestion-card{background:#fff;border-radius:20px;padding:1.5rem;border:1px solid var(--gray-100);box-shadow:0 4px 16px rgba(0,0,0,.04)}.suggestion-card.active{border-color:var(--japan-red)}.suggestion-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:.75rem}.suggestion-emoji{font-size:2rem}.suggestion-title h4{font-weight:600;font-size:1.125rem;color:var(--ink);margin:0}.suggestion-category{font-size:.75rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.suggestion-description{font-size:.9375rem;color:var(--gray-600);line-height:1.5;margin-bottom:1rem}.suggestion-transport{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--gray-50);border-radius:12px;margin-bottom:.75rem}.suggestion-transport .transport-emoji{font-size:1.25rem}.suggestion-transport .transport-info{flex:1;font-weight:500;color:var(--gray-700)}.suggestion-transport .transport-mode{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500)}.suggestion-tip{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;background:rgba(250,204,21,.1);border-radius:12px;margin-bottom:1rem;font-size:.875rem}.suggestion-actions{display:flex;gap:.75rem}.suggestion-actions .btn-skip{flex:1;padding:.75rem;background:var(--gray-100);border:none;border-radius:12px;font-weight:500;cursor:pointer;transition:background .2s ease}.suggestion-actions .btn-skip:hover{background:var(--gray-200)}.suggestion-actions .btn-accept{flex:2;padding:.75rem;background:var(--japan-red);color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.suggestion-actions .btn-accept:hover{background:var(--japan-red-hover)}.suggestion-list-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:#fff;border:1px solid var(--gray-100);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left}.suggestion-list-item:hover{border-color:var(--gray-300)}.suggestion-list-item.selected{border-color:var(--japan-red);background:rgba(230,57,70,.05)}.suggestion-list-item .item-emoji{font-size:1.25rem}.suggestion-list-item .item-info{flex:1;display:flex;flex-direction:column}.suggestion-list-item .item-name{font-weight:500;color:var(--ink)}.suggestion-list-item .item-meta{font-size:.75rem;color:var(--gray-500)}.suggestion-list-item .item-check{color:var(--japan-red);font-weight:600}.food-suggestions-list{padding:1rem 1.5rem;border-bottom:1px solid var(--gray-100)}.food-suggestions-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.food-suggestions-header .header-emoji{font-size:1.25rem}.food-suggestions-header .header-text{font-weight:600;font-size:.875rem;color:var(--ink)}.food-suggestions-items{display:flex;flex-direction:column;gap:.5rem}.food-suggestion-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--gray-50);border:none;border-radius:12px;cursor:pointer;transition:background .2s ease;text-align:left;width:100%}.food-suggestion-card:hover{background:var(--gray-100)}.food-suggestion-card .food-emoji{font-size:1.25rem}.food-suggestion-card .food-info{flex:1;display:flex;flex-direction:column}.food-suggestion-card .food-name{font-weight:500;font-size:.875rem;color:var(--ink)}.food-suggestion-card .food-distance,.food-suggestion-card .food-specialty{font-size:.75rem;color:var(--gray-500)}.btn-more-suggestions{display:block;width:calc(100% - 3rem);margin:0 1.5rem;padding:.75rem;background:none;border:1px dashed var(--gray-300);border-radius:12px;color:var(--gray-500);font-size:.875rem;cursor:pointer;transition:all .2s ease}.btn-more-suggestions:hover{border-color:var(--japan-red);color:var(--japan-red)}.all-suggestions{padding:1rem 1.5rem;border-bottom:1px solid var(--gray-100)}.all-suggestions .suggestions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.all-suggestions .suggestions-header span{font-weight:600;color:var(--ink)}.all-suggestions .btn-close-suggestions{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:6px;cursor:pointer}.all-suggestions .suggestions-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.btn-refresh-suggestions{width:100%;padding:.75rem;background:var(--gray-100);border:none;border-radius:12px;font-size:.875rem;cursor:pointer;transition:background .2s ease}.btn-refresh-suggestions:hover{background:var(--gray-200)}.btn-refresh-suggestions:disabled{opacity:.6;cursor:not-allowed}.trip-stats{display:flex;justify-content:space-around;padding:1rem 1.5rem;border-bottom:1px solid var(--gray-100)}.trip-stats .stat{display:flex;flex-direction:column;align-items:center}.trip-stats .stat-value{font-family:Playfair Display,Georgia,serif;font-size:1.5rem;font-weight:700;color:var(--ink)}.trip-stats .stat-label{font-size:.75rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.btn-end-trip{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:1rem 1.5rem;padding:1rem;background:var(--gray-900);color:#fff;font-weight:600;border:none;border-radius:16px;cursor:pointer;transition:all .2s ease}.btn-end-trip:hover{background:var(--black)}.btn-view-map{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:0 1.5rem 1.5rem;padding:.75rem;background:none;border:1px solid var(--gray-200);border-radius:12px;color:var(--gray-600);font-size:.875rem;text-decoration:none;transition:all .2s ease}.btn-view-map:hover{border-color:var(--japan-red);color:var(--japan-red)}.travel-panel-minimized{position:absolute;top:1rem;right:1rem}.travel-panel-minimized .panel-expand-btn{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:#fff;border:none;border-radius:16px;box-shadow:0 8px 24px rgba(0,0,0,.15);cursor:pointer;transition:all .2s ease}.travel-panel-minimized .panel-expand-btn:hover{transform:scale(1.02)}.travel-panel-minimized .expand-icon{font-size:1.25rem}.travel-panel-minimized .expand-text{font-weight:600;color:var(--ink)}.travel-panel-minimized .expand-stats{font-size:.75rem;color:var(--gray-500)}.story-point-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.story-point-modal{width:100%;max-width:480px;max-height:90vh;background:#fff;border-radius:24px;overflow:hidden;display:flex;flex-direction:column}.story-point-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--gray-100);flex-shrink:0}.story-point-modal .modal-header h3{margin:0;font-size:1.25rem;font-weight:600}.story-point-modal .modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:8px;font-size:1.25rem;cursor:pointer}.story-point-modal .modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1}.photo-upload-section{display:flex;justify-content:center}.photo-upload-section .photo-preview{position:relative;width:100%;max-width:200px;aspect-ratio:4/3;border-radius:16px;overflow:hidden}.photo-upload-section .photo-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.photo-upload-section .remove-photo{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);color:#fff;border:none;border-radius:50%;cursor:pointer}.photo-upload-section .upload-button{padding:2rem 3rem;background:var(--gray-50);border:2px dashed var(--gray-300);border-radius:16px;font-size:1rem;color:var(--gray-600);cursor:pointer;transition:all .2s ease}.photo-upload-section .upload-button:hover{border-color:var(--japan-red);color:var(--japan-red)}.story-point-modal .form-field{display:flex;flex-direction:column;gap:.5rem}.story-point-modal .form-field label{font-weight:500;font-size:.875rem;color:var(--gray-700)}.story-point-modal .form-field .char-count{font-weight:400;color:var(--gray-400)}.story-point-modal .form-field input,.story-point-modal .form-field textarea{padding:.875rem 1rem;border:1px solid var(--gray-200);border-radius:12px;font-size:1rem;transition:border-color .2s ease}.story-point-modal .form-field input:focus,.story-point-modal .form-field textarea:focus{outline:none;border-color:var(--japan-red)}.category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.category-button{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:var(--gray-50);border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease}.category-button:hover{background:var(--gray-100)}.category-button.selected{border-color:var(--japan-red);background:rgba(230,57,70,.05)}.category-button .cat-emoji{font-size:1.25rem}.category-button .cat-label{font-size:.75rem;font-weight:500;color:var(--gray-600)}.transport-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.transport-button{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:var(--gray-50);border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease}.transport-button:hover{background:var(--gray-100)}.transport-button.selected{border-color:#2563eb;background:rgba(37,99,235,.05)}.transport-button .transport-emoji{font-size:1.5rem}.transport-button .transport-label{font-size:.75rem;font-weight:500;color:var(--gray-600)}.transport-button.selected .transport-label{color:#2563eb}.location-info{align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--gray-50);border-radius:12px;font-size:.875rem;color:var(--gray-500)}.story-point-modal .modal-footer{display:flex;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid var(--gray-100);flex-shrink:0;background:#fff}.story-point-modal .btn-cancel{flex:1;background:var(--gray-100);font-weight:500}.story-point-modal .btn-cancel,.story-point-modal .btn-save{padding:.875rem;border:none;border-radius:12px;cursor:pointer}.story-point-modal .btn-save{flex:2;background:var(--japan-red);color:#fff;font-weight:600;transition:background .2s ease}.story-point-modal .btn-save:hover{background:var(--japan-red-hover)}.story-point-modal .btn-save:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.story-point-modal-overlay{padding:.5rem;align-items:flex-end}.story-point-modal{max-height:85vh;border-radius:20px 20px 0 0}.story-point-modal .modal-header{padding:1rem 1.25rem}.story-point-modal .modal-body{padding:1rem 1.25rem;gap:1rem}.story-point-modal .modal-footer{padding:1rem 1.25rem;gap:.5rem;box-shadow:0 -2px 8px rgba(0,0,0,.05)}.story-point-modal .btn-cancel,.story-point-modal .btn-save{padding:1rem;font-size:1rem}}.travel-confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.travel-confirm-modal{width:100%;max-width:400px;background:#fff;border-radius:24px;overflow:hidden}.travel-confirm-content{padding:2rem;text-align:center}.travel-confirm-content h4{margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.travel-confirm-content p{margin:0;color:var(--gray-600)}.travel-confirm-stats{display:flex;justify-content:center;gap:2rem;margin:1.5rem 0}.travel-confirm-stats .stat{display:flex;flex-direction:column;align-items:center}.travel-confirm-stats .value{font-family:Playfair Display,Georgia,serif;font-size:1.75rem;font-weight:700;color:var(--japan-red)}.travel-confirm-stats .label{font-size:.75rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.travel-confirm-actions{display:flex;gap:.75rem}.travel-confirm-actions .btn-cancel{flex:1;padding:.875rem;background:var(--gray-100);border:none;border-radius:12px;font-weight:500;cursor:pointer}.travel-confirm-actions .btn-confirm{flex:1;padding:.875rem;background:var(--japan-red);color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer}.trip-summary{max-width:800px;margin:0 auto;padding:2rem}.trip-summary .summary-header{text-align:center;margin-bottom:2rem}.trip-summary .summary-header h2{font-family:Playfair Display,Georgia,serif;font-size:2rem;font-weight:700;color:var(--ink);margin:0 0 .5rem}.trip-summary .summary-date{color:var(--gray-500)}.summary-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}.summary-stats .stat-card{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background:#fff;border-radius:20px;border:1px solid var(--gray-100)}.summary-stats .stat-emoji{font-size:1.5rem;margin-bottom:.5rem}.summary-stats .stat-value{font-family:Playfair Display,Georgia,serif;font-size:1.75rem;font-weight:700;color:var(--ink)}.summary-stats .stat-label{font-size:.75rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.journey-timeline{position:relative;padding:1rem 0;margin-bottom:2rem}.journey-timeline .timeline-item{position:relative;display:flex;gap:1.5rem;padding:1rem 0}.journey-timeline .timeline-connector{position:absolute;left:15px;top:0;bottom:0;width:2px;display:flex;flex-direction:column;align-items:center}.journey-timeline .connector-line{flex:1;width:2px;background:var(--gray-200)}.journey-timeline .connector-transport{font-size:.875rem;padding:.25rem;background:#fff}.journey-timeline .timeline-marker{position:relative;z-index:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;flex-shrink:0}.journey-timeline .marker-icon{font-size:1.25rem}.journey-timeline .marker-letter{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#10b981;color:#fff;font-weight:700;border-radius:50%}.journey-timeline .timeline-content{flex:1;padding-top:.25rem}.journey-timeline .point-header{display:flex;align-items:center;gap:.5rem}.journey-timeline .point-emoji{font-size:1.25rem}.journey-timeline .point-name{font-weight:600;color:var(--ink);margin:0}.journey-timeline .point-note{font-style:italic;color:var(--gray-600);margin:.5rem 0}.journey-timeline .point-photo{margin:.75rem 0;max-width:300px;border-radius:16px;overflow:hidden}.journey-timeline .point-photo img{width:100%;display:block}.journey-timeline .point-time{font-size:.75rem;color:var(--gray-500)}.journey-timeline .timeline-label{font-weight:600;color:var(--gray-600)}.summary-actions{gap:1rem;margin:2rem 0}.btn-save-trip,.summary-actions{display:flex;justify-content:center}.btn-save-trip{align-items:center;gap:.5rem;padding:1rem 2rem;background:var(--japan-red);color:#fff;font-weight:600;border:none;border-radius:16px;cursor:pointer;transition:all .2s ease}.btn-save-trip:hover{background:var(--japan-red-hover)}.btn-save-trip:disabled{opacity:.7;cursor:not-allowed}.btn-share-trip{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:var(--gray-100);border:none;border-radius:16px;font-weight:500;cursor:pointer;transition:background .2s ease}.btn-share-trip:hover{background:var(--gray-200)}.save-success{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:rgba(16,185,129,.1);border-radius:16px}.save-success .success-icon{color:#10b981;font-weight:700}.save-success .success-message{color:#047857;font-weight:500}.save-error{display:flex;align-items:center;gap:.5rem;padding:1rem;background:rgba(220,38,38,.12);border:1px solid rgba(220,38,38,.25);border-radius:12px;margin-top:1rem}.save-error .error-message{color:#b91c1c;font-weight:500}.share-link{margin-top:1rem;padding:1rem;background:var(--gray-50);border-radius:12px;text-align:center}.share-link .link-label{font-size:.875rem;color:var(--gray-500);display:block;margin-bottom:.5rem}.share-link .link-url{color:var(--japan-red);word-break:break-all}.create-post-cta{text-align:center;padding:2rem;background:linear-gradient(135deg,rgba(230,57,70,.05),#fff);border-radius:24px;border:1px solid var(--gray-100);margin-top:2rem}.create-post-cta h4{margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.create-post-cta p{margin:0 0 1.5rem;color:var(--gray-600)}.btn-create-post{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:var(--japan-red);color:#fff;font-weight:600;text-decoration:none;border-radius:16px;transition:all .2s ease}.btn-create-post:hover{background:var(--japan-red-hover);transform:translateY(-2px)}.trip-summary-empty{text-align:center;padding:4rem 2rem}.trip-summary-empty .empty-icon{font-size:4rem;margin-bottom:1rem}.trip-summary-empty h3{margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.trip-summary-empty p{margin:0 0 1.5rem;color:var(--gray-600)}.btn-start-exploring{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:var(--japan-red);color:#fff;font-weight:600;text-decoration:none;border-radius:16px}.trip-summary-mini{padding:1rem;background:var(--gray-50);border-radius:16px}.trip-summary-mini .mini-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.trip-summary-mini .mini-icon{font-size:1rem}.trip-summary-mini .mini-title{font-weight:600;font-size:.875rem}.trip-summary-mini .mini-points{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.trip-summary-mini .mini-point{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.trip-summary-mini .point-letter{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#10b981;color:#fff;font-size:.7rem;font-weight:600;border-radius:50%}.trip-summary-mini .more-count{font-size:.75rem;color:var(--gray-500);padding-left:1.75rem}.trip-summary-mini .mini-stats{display:flex;gap:.5rem;font-size:.75rem;color:var(--gray-500)}.travel-summary-view{max-width:900px;margin:2rem auto;padding:2rem;background:#fff;border-radius:32px;border:1px solid var(--border-soft)}.travel-summary-view .summary-actions{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.btn-go-home,.btn-new-trip{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;border-radius:16px;font-weight:500;text-decoration:none;transition:all .2s ease}.btn-new-trip{background:var(--japan-red);color:#fff;border:none;cursor:pointer}.btn-new-trip:hover{background:var(--japan-red-hover)}.btn-go-home{background:var(--gray-100);color:var(--ink)}.btn-go-home:hover{background:var(--gray-200)}@media (max-width:1024px){.travel-welcome{grid-template-columns:1fr}.welcome-map-preview{height:300px}}@media (max-width:768px){.travel-mode-panel{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;max-height:70vh;border-radius:24px 24px 0 0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:1rem}.travel-panel-minimized{position:fixed;top:auto;bottom:1rem;right:1rem}.btn-add-story{margin:.75rem 1rem;padding:1rem;font-size:1rem;font-weight:700;box-shadow:0 4px 12px rgba(230,57,70,.25)}.travel-mode-panel .panel-header{padding:1rem 1.25rem;position:sticky;top:0;background:#fff;z-index:10}.current-destination{padding:.75rem 1rem}.welcome-features{grid-template-columns:1fr}.category-grid{grid-template-columns:repeat(2,1fr)}.summary-stats{grid-template-columns:1fr}.travel-confirm-stats{gap:1rem}}@keyframes pulse-soft{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.feed-nav-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.feed-nav-card{padding:2rem;background:#fff;border:2px solid var(--border-soft);border-radius:24px;text-decoration:none;color:inherit}.feed-nav-card:hover{border-color:var(--japan-red);background:var(--rose-50,#fff1f2);transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,.08)}.feed-nav-icon{font-size:3rem;flex-shrink:0}.feed-nav-title{font-size:1.5rem;font-weight:700;font-family:var(--font-editorial);margin-bottom:.5rem;color:var(--ink)}.feed-nav-description{font-size:.95rem;color:var(--gray-600);line-height:1.5}.feed-nav-arrow{color:var(--gray-400);transition:all .3s ease}.feed-nav-card:hover .feed-nav-arrow{color:var(--japan-red);transform:translateX(4px)}.feed-page-shell{padding:2rem;max-width:900px;margin:0 auto}.feed-header{text-align:center;margin-bottom:2rem}.feed-header .editorial-headline{margin-bottom:.5rem}.feed-header .editorial-subtitle{max-width:600px;margin:0 auto}.feed-tabs{margin-bottom:2rem;position:sticky;top:0;background:hsla(0,0%,100%,.95);backdrop-filter:blur(10px);padding:1rem 0;z-index:10;border-bottom:1px solid var(--border-soft)}.feed-tab,.feed-tabs{display:flex;gap:1rem}.feed-tab{align-items:center;padding:1rem 1.5rem;background:#fff;border:2px solid var(--border-soft);border-radius:16px;text-decoration:none;color:inherit;transition:all .2s ease;flex:1}.feed-tab:hover{border-color:var(--gray-300);background:var(--gray-50)}.feed-tab.active{border-color:var(--japan-red);background:var(--rose-50,#fff1f2)}.feed-tab .tab-emoji{font-size:1.75rem}.feed-tab .tab-content{display:flex;flex-direction:column}.feed-tab .tab-title{font-weight:600;font-size:1rem;color:var(--ink)}.feed-tab .tab-description{font-size:.8rem;color:var(--gray-500)}.feed-tab.active .tab-title{color:var(--japan-red)}.feed-content-area{min-height:50vh}.feed-posts{gap:1.5rem}.feed-loading{text-align:center}.feed-loading .loading-spinner{width:48px;height:48px;border:4px solid var(--gray-200);border-top-color:var(--japan-red);border-radius:50%;animation:spin .8s linear infinite}.feed-loading p{margin-top:1rem;color:var(--gray-500)}.feed-empty{background:var(--gray-50);border-radius:24px}.feed-empty .empty-illustration{font-size:5rem;margin-bottom:1.5rem}.feed-empty h3{font-size:1.5rem;font-weight:700;font-family:var(--font-editorial);margin-bottom:.5rem;color:var(--ink)}.feed-empty p{color:var(--gray-600);margin-bottom:1.5rem;max-width:400px}.feed-auth-required{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:linear-gradient(180deg,var(--rose-50,#fff1f2) 0,#fff 100%);border-radius:24px;border:2px solid var(--border-soft)}.feed-auth-required .auth-illustration{font-size:5rem;margin-bottom:1.5rem}.feed-auth-required h3{font-size:1.75rem;font-weight:700;font-family:var(--font-editorial);margin-bottom:.75rem;color:var(--ink)}.feed-auth-required p{color:var(--gray-600);margin-bottom:2rem;max-width:450px;line-height:1.6}.feed-auth-required .auth-actions{display:flex;gap:1rem;margin-bottom:1.5rem}.feed-auth-required .auth-divider{display:flex;align-items:center;gap:1rem;color:var(--gray-400);font-size:.85rem;margin-bottom:1rem}.feed-auth-required .auth-divider:after,.feed-auth-required .auth-divider:before{content:"";width:40px;height:1px;background:var(--gray-300)}.feed-load-more{padding:2rem 0}@media (max-width:768px){.feed-nav-cards{grid-template-columns:1fr;gap:1rem}.feed-nav-card{padding:1.5rem;gap:1rem}.feed-nav-icon{font-size:2.5rem}.feed-nav-title{font-size:1.25rem}.feed-page-shell{padding:1rem}.feed-tabs{flex-direction:column;gap:.75rem}.feed-tab{padding:1rem}.feed-auth-required .auth-actions{flex-direction:column;width:100%;max-width:280px}.feed-auth-required .auth-actions .btn{width:100%;justify-content:center}}.travel-page-container{min-height:100vh;background:linear-gradient(180deg,#fef7f7,#fff 50%,#f8fafc)}.travel-main{padding-top:80px;min-height:calc(100vh - 80px)}.travel-welcome-screen{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:2rem}.welcome-inner{max-width:600px;width:100%;text-align:center}.hero-section{margin-bottom:2rem}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--japan-red);color:#fff;padding:.5rem 1rem;border-radius:999px;font-size:.9rem;font-weight:600;margin-bottom:1.5rem}.hero-title{font-size:3rem;font-weight:800;font-family:var(--font-editorial);line-height:1.1;margin-bottom:1rem;color:var(--ink)}.title-accent{color:var(--japan-red)}.hero-subtitle{font-size:1.1rem;color:var(--gray-600);line-height:1.6;max-width:500px;margin:0 auto}.features-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:2rem 0}.feature-box{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#fff;border-radius:16px;border:1px solid var(--border-soft)}.feature-box .feature-icon{font-size:1.75rem}.feature-box .feature-name{font-size:.8rem;font-weight:600;color:var(--gray-700)}.start-section{margin:2.5rem 0}.start-trip-btn{display:inline-flex;align-items:center;justify-content:center;gap:1rem;background:linear-gradient(135deg,var(--japan-red) 0,#d62828 100%);color:#fff;font-size:1.5rem;font-weight:700;padding:1.25rem 3rem;border-radius:999px;border:none;cursor:pointer;box-shadow:0 8px 32px rgba(230,57,70,.35);transition:all .3s ease;min-width:280px}.start-trip-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 40px rgba(230,57,70,.45)}.start-trip-btn:disabled{opacity:.7;cursor:not-allowed}.start-trip-btn .btn-icon{font-size:1.75rem}.start-trip-btn .spinner{width:24px;height:24px;border:3px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.error-message{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;padding:.75rem 1.5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626}.location-note{margin-top:1rem;font-size:.85rem;color:var(--gray-500)}.route-preview-card{background:#fff;border-radius:24px;border:1px solid var(--border-soft);padding:1.5rem;margin-top:2rem;text-align:left;box-shadow:0 4px 20px rgba(0,0,0,.05)}.preview-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-soft)}.preview-icon{font-size:1.5rem}.preview-title{font-weight:700;font-size:1rem;color:var(--ink)}.preview-route{display:flex;flex-direction:column}.route-item{gap:1rem}.route-marker{width:36px;height:36px;border-radius:50%;background:var(--japan-red);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.route-marker.start{background:#10b981}.route-marker.end{background:#6366f1;font-size:1rem}.route-content{display:flex;flex-direction:column}.route-name{font-weight:600}.route-type{font-size:.8rem;color:var(--gray-500)}.route-connector{display:flex;align-items:center;gap:.75rem;padding-left:17px;margin:.25rem 0}.connector-line{width:2px;height:24px;background:var(--japan-red)}.connector-line.dashed{background:repeating-linear-gradient(to bottom,var(--gray-300) 0,var(--gray-300) 4px,transparent 4px,transparent 8px)}.connector-info{font-size:.75rem;color:var(--gray-500);background:var(--gray-100);padding:.25rem .5rem;border-radius:8px}.route-connector.last .connector-line{height:16px}.travel-active-screen{position:relative;height:calc(100vh - 80px);display:flex}.map-wrapper{flex:1;position:relative}.travel-map{width:100%;height:100%}.map-top-bar{position:absolute;top:1rem;left:1rem;right:1rem;justify-content:space-between;z-index:1000}.map-top-bar,.top-bar-left{display:flex;align-items:center}.top-bar-left{gap:.5rem;background:#fff;padding:.75rem 1rem;border-radius:999px;box-shadow:0 4px 16px rgba(0,0,0,.1)}.status-dot{width:10px;height:10px;background:#10b981;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}.status-text{font-weight:600;font-size:.9rem;color:var(--ink)}.end-trip-btn{display:flex;align-items:center;gap:.5rem;background:#fff;color:var(--japan-red);border:2px solid var(--japan-red);padding:.75rem 1.5rem;border-radius:999px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px rgba(0,0,0,.1)}.end-trip-btn:hover{background:var(--japan-red);color:#fff}.map-stats-bar{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);gap:1.5rem;background:#fff;padding:1rem 2rem;border-radius:999px;box-shadow:0 4px 20px rgba(0,0,0,.15);z-index:1000}.map-stats-bar,.stat-item{display:flex;align-items:center}.stat-item{flex-direction:column}.stat-item .stat-value{font-size:1.5rem;font-weight:800;color:var(--japan-red)}.stat-item .stat-label{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase}.stat-divider{height:30px;background:var(--gray-200)}.floating-guide-panel{position:absolute;right:1rem;top:5rem;width:380px;max-height:calc(100vh - 200px);overflow-y:auto;z-index:1000}.travel-summary-screen{padding:2rem;max-width:800px;margin:0 auto}.summary-buttons{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.home-btn,.new-trip-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:999px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;text-decoration:none}.new-trip-btn{background:var(--japan-red);color:#fff;border:none}.new-trip-btn:hover{background:var(--japan-red-hover);transform:translateY(-2px)}.home-btn{background:var(--gray-100);color:var(--ink);border:none}.home-btn:hover{background:var(--gray-200)}@media (max-width:768px){.hero-title{font-size:2rem}.features-row{grid-template-columns:repeat(2,1fr)}.start-trip-btn{font-size:1.2rem;padding:1rem 2rem;min-width:auto;width:100%}.floating-guide-panel{position:fixed;right:0;left:0;bottom:0;top:auto;width:100%;max-height:60vh;border-radius:24px 24px 0 0}.map-top-bar{flex-direction:column;gap:.5rem;align-items:flex-start}.map-stats-bar{left:1rem;right:1rem;transform:none;justify-content:space-around;padding:.75rem 1rem}.summary-buttons{flex-direction:column}}.trip-detail-page{max-width:900px;margin:0 auto;padding:2rem}.trip-detail-header{text-align:center;margin-bottom:2rem}.trip-detail-header .back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--gray-500);text-decoration:none;font-size:.9rem;margin-bottom:1rem;transition:color .2s}.trip-detail-header .back-link:hover{color:var(--japan-red)}.trip-detail-header .trip-title{font-family:var(--font-editorial);font-size:2.5rem;font-weight:700;color:var(--ink);margin:0 0 .5rem}.trip-detail-header .trip-date{color:var(--gray-500);font-size:1rem}.trip-stats-bar{display:flex;justify-content:center;gap:3rem;padding:1.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 16px rgba(0,0,0,.08);margin-bottom:2rem}.trip-stat{text-align:center}.trip-stat .stat-value{display:block;font-size:2rem;font-weight:800;color:var(--japan-red)}.trip-stat .stat-label{font-size:.85rem;color:var(--gray-500);text-transform:uppercase;font-weight:600}.trip-stat-divider{width:1px;background:var(--gray-200)}.trip-map-container{position:relative;height:400px;border-radius:16px;overflow:hidden;margin-bottom:2rem;box-shadow:0 4px 16px rgba(0,0,0,.1)}.trip-map{width:100%;height:100%}.map-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.8)}.trip-timeline{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 16px rgba(0,0,0,.08);margin-bottom:2rem}.timeline-title{font-family:var(--font-editorial);font-size:1.5rem;font-weight:700;margin:0 0 1.5rem;color:var(--ink)}.timeline-list{display:flex;flex-direction:column;gap:1.5rem}.timeline-item{display:flex;gap:1rem;position:relative}.timeline-marker{width:36px;height:36px;background:var(--japan-red);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0;z-index:1}.timeline-connector{position:absolute;left:18px;top:36px;width:2px;height:calc(100% + 1.5rem);background:var(--gray-200)}.timeline-item:last-child .timeline-connector{display:none}.timeline-content{flex:1;padding-bottom:1rem}.timeline-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.timeline-emoji{font-size:1.25rem}.timeline-name{font-weight:600;font-size:1.1rem;color:var(--ink);margin:0;flex:1}.timeline-time{color:var(--gray-500);font-size:.85rem}.timeline-note{color:var(--gray-600);font-style:italic;margin:.5rem 0;font-size:.95rem}.timeline-photo{max-width:100%;max-height:200px;border-radius:12px;margin-top:.5rem;-o-object-fit:cover;object-fit:cover}.trip-actions{display:flex;justify-content:center;gap:1rem}.trip-error,.trip-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.trip-error .error-icon{font-size:4rem;margin-bottom:1rem}.trip-error h2{font-size:1.5rem;margin:0 0 .5rem;color:var(--ink)}.trip-error p{color:var(--gray-500);margin:0 0 1.5rem}@media (max-width:768px){.trip-detail-page{padding:1rem}.trip-detail-header .trip-title{font-size:1.75rem}.trip-stats-bar{gap:1.5rem;padding:1rem}.trip-stat .stat-value{font-size:1.5rem}.trip-map-container{height:300px}.trip-actions{flex-direction:column}.trip-actions .btn{width:100%;justify-content:center}}.cities-page-container{min-height:100vh;background:linear-gradient(180deg,#fef7f0,#fff 30%)}.cities-main{max-width:1200px;margin:0 auto;padding:0 1.5rem 4rem}.cities-welcome-screen{padding:4rem 0;text-align:center}.cities-welcome-inner{max-width:700px;margin:0 auto}.cities-hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:#fff;padding:.5rem 1rem;border-radius:999px;font-size:.9rem;font-weight:600;color:var(--japan-red);box-shadow:0 4px 16px rgba(230,57,70,.15);margin-bottom:1.5rem}.cities-hero-title{font-family:var(--font-editorial);font-size:clamp(2.5rem,6vw,4rem);font-weight:700;line-height:1.1;color:var(--ink);margin:0 0 1.5rem}.cities-hero-title .title-accent{background:linear-gradient(135deg,var(--japan-red) 0,#ff6b6b 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cities-hero-subtitle{font-size:1.2rem;color:var(--gray-600);line-height:1.6;margin:0 0 2rem}.cities-stats-row{display:flex;justify-content:center;gap:2.5rem;margin-bottom:2rem}.cities-stat-item{text-align:center}.cities-stat-value{display:block;font-size:2rem;font-weight:800;color:var(--japan-red)}.cities-stat-label{font-size:.85rem;color:var(--gray-500);text-transform:uppercase;font-weight:600}.cities-action-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.cities-primary-btn{display:inline-flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,var(--japan-red) 0,#d63031 100%);color:#fff;padding:1rem 2rem;border-radius:999px;font-size:1.1rem;font-weight:700;text-decoration:none;box-shadow:0 8px 24px rgba(230,57,70,.3);transition:all .3s ease}.cities-primary-btn:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(230,57,70,.4)}.cities-secondary-btn{display:inline-flex;align-items:center;gap:.5rem;background:#fff;color:var(--ink);padding:1rem 2rem;border-radius:999px;font-size:1.1rem;font-weight:600;text-decoration:none;border:2px solid var(--gray-200);transition:all .3s ease}.cities-secondary-btn:hover{border-color:var(--japan-red);color:var(--japan-red)}.cities-section{padding:3rem 0}.section-badge{gap:.5rem;background:rgba(230,57,70,.1);padding:.4rem 1rem;border-radius:999px;font-size:.85rem;font-weight:600;color:var(--japan-red)}.section-title{font-family:var(--font-editorial);font-weight:700;color:var(--ink)}.section-subtitle{color:var(--gray-500)}.regions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}.region-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 4px 20px rgba(0,0,0,.06);border:1px solid var(--gray-100);transition:all .3s ease}.region-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.1)}.region-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.region-emoji{font-size:2rem}.region-name{font-size:1.25rem;font-weight:700;color:var(--ink);margin:0}.region-description{color:var(--gray-600);font-size:.95rem;margin:0 0 1rem}.region-cities{display:flex;flex-wrap:wrap;gap:.5rem}.region-city-link{background:var(--gray-100);color:var(--ink);padding:.4rem .8rem;border-radius:999px;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s}.region-city-link:hover{background:var(--japan-red);color:#fff}.cities-featured-section{background:linear-gradient(180deg,#f8f9fa,#fff);margin:0 -1.5rem;padding:3rem 1.5rem}.featured-cities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.featured-city-card{background:#fff;border-radius:20px;overflow:hidden;text-decoration:none;box-shadow:0 4px 20px rgba(0,0,0,.08);transition:all .3s ease}.featured-city-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.15)}.featured-city-image{height:180px;background-size:cover;background-position:50%;position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:1rem}.featured-city-badge{font-size:2rem;width:48px;height:48px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center}.featured-city-info{color:#fff}.featured-city-name{font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.featured-city-stats{font-size:.85rem;opacity:.9}.featured-city-content{padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center}.featured-city-highlight{color:var(--gray-600);font-size:.9rem;margin:0;flex:1}.featured-city-arrow{color:var(--japan-red);font-weight:600;font-size:.9rem}.routes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.route-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 4px 20px rgba(0,0,0,.06);border:1px solid var(--gray-100)}.route-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.route-name{font-size:1.25rem;font-weight:700;color:var(--ink);margin:0}.route-duration{color:var(--japan-red);padding:.3rem .75rem;border-radius:999px;font-size:.8rem;font-weight:600}.route-description{color:var(--gray-600);font-size:.95rem;margin:0 0 1.25rem}.route-stops{flex-wrap:wrap;gap:.5rem}.route-stop,.route-stops{display:flex;align-items:center}.route-stop{gap:.4rem}.route-stop-marker{width:24px;height:24px;background:var(--japan-red);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.route-stop-name{font-weight:600;color:var(--ink)}.route-stop-connector{color:var(--gray-400);margin:0 .25rem}.cities-seasonal-section{background:linear-gradient(135deg,#fff5f5,#fef7f0);margin:0 -1.5rem;padding:3rem 1.5rem}.seasonal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.seasonal-card{background:#fff;padding:1.5rem;box-shadow:0 4px 20px rgba(0,0,0,.06)}.seasonal-name{font-weight:700;color:var(--ink);margin:0 0 .25rem}.seasonal-city{color:var(--japan-red);font-weight:600;font-size:.9rem;margin:0 0 .5rem}.seasonal-highlight{color:var(--gray-600);font-size:.85rem;margin:0}.cities-directory{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.city-directory-card{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1rem 1.25rem;border-radius:12px;text-decoration:none;border:1px solid var(--gray-100);transition:all .2s ease}.city-directory-card:hover{border-color:var(--japan-red);box-shadow:0 4px 12px rgba(230,57,70,.1)}.city-directory-name{font-weight:600;color:var(--ink);margin:0;font-size:1rem}.city-directory-prefecture{color:var(--gray-500);font-size:.85rem}.city-directory-time{background:var(--gray-100);color:var(--gray-600);padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:500}.cities-cta-section{background:linear-gradient(135deg,var(--japan-red) 0,#d63031 100%);margin:3rem -1.5rem 0;padding:4rem 1.5rem;border-radius:24px 24px 0 0}.cities-cta-content{text-align:center;max-width:500px;margin:0 auto}.cities-cta-emoji{font-size:3rem;display:block;margin-bottom:1rem}.cities-cta-title{font-family:var(--font-editorial);font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem}.cities-cta-subtitle{color:hsla(0,0%,100%,.9);font-size:1rem;margin:0 0 2rem}.cities-cta-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.cities-cta-section .cities-primary-btn{background:#fff;color:var(--japan-red);box-shadow:0 8px 24px rgba(0,0,0,.2)}.cities-cta-section .cities-secondary-btn{background:transparent;color:#fff;border-color:hsla(0,0%,100%,.5)}.cities-cta-section .cities-secondary-btn:hover{background:#fff;color:var(--japan-red);border-color:#fff}@media (max-width:768px){.cities-hero-title{font-size:2rem}.cities-stats-row{gap:1.5rem}.cities-stat-value{font-size:1.5rem}.cities-action-buttons{flex-direction:column;align-items:center}.cities-primary-btn,.cities-secondary-btn{width:100%;max-width:280px;justify-content:center}.seasonal-grid{grid-template-columns:repeat(2,1fr)}.featured-cities-grid,.routes-grid{grid-template-columns:1fr}.cities-cta-buttons{flex-direction:column;align-items:center}}.explore-page-container{min-height:100vh;background:linear-gradient(180deg,#090a18,#0f1224 55%,#171b32)}.explore-main{padding:0 var(--app-padding);max-width:1600px;margin:0 auto}.explore-hero{padding:4rem 0 3rem;text-align:center}.explore-hero-content{max-width:700px;margin:0 auto}.explore-hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.15);border-radius:50px;font-size:.85rem;color:hsla(0,0%,100%,.9);margin-bottom:1.5rem;backdrop-filter:blur(8px)}.explore-hero-title{font-family:"Noto Serif JP",serif;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:600;color:#fff;margin:0 0 1rem;line-height:1.2}.explore-hero-title .title-accent{color:var(--japan-red)}.explore-hero-subtitle{font-size:1.1rem;color:hsla(0,0%,100%,.7);line-height:1.6;margin:0 0 2rem}.explore-stats{display:flex;justify-content:center;gap:3rem}.explore-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.explore-stat-value{font-size:1.8rem;font-weight:700;color:#fff}.explore-stat-label{font-size:.85rem;color:hsla(0,0%,100%,.6);text-transform:uppercase;letter-spacing:.5px}.explore-filters{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;backdrop-filter:blur(12px)}.explore-search{display:flex;align-items:center;gap:.75rem;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.12);border-radius:var(--radius);padding:.75rem 1rem;margin-bottom:1rem}.search-icon{font-size:1.1rem;opacity:.6}.search-input{flex:1;background:transparent;border:none;color:#fff;font-size:1rem;outline:none}.search-input::-moz-placeholder{color:hsla(0,0%,100%,.6)}.search-input::placeholder{color:hsla(0,0%,100%,.6)}.explore-categories{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.category-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.1);border-radius:50px;color:hsla(0,0%,100%,.8);font-size:.9rem;cursor:pointer;transition:all .2s ease}.category-btn:hover{background:hsla(0,0%,100%,.12);border-color:hsla(0,0%,100%,.2)}.category-btn.active{background:var(--japan-red);border-color:var(--japan-red);color:#fff}.explore-quick-filters{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.quick-filter-label{font-size:.85rem;color:hsla(0,0%,100%,.5);margin-right:.25rem}.quick-filter-btn{display:flex;align-items:center;gap:.35rem;padding:.4rem .8rem;background:transparent;border:1px solid hsla(0,0%,100%,.15);border-radius:50px;color:hsla(0,0%,100%,.7);font-size:.85rem;cursor:pointer;transition:all .2s ease}.quick-filter-btn:hover{background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.25)}.quick-filter-btn.active{background:rgba(230,57,70,.2);border-color:var(--japan-red);color:var(--japan-red)}.explore-content{display:grid;grid-template-columns:1fr 380px;gap:2rem;margin-bottom:3rem}.explore-map-section{display:flex;flex-direction:column;gap:1rem}.explore-map-container{border-radius:var(--radius-lg);overflow:hidden;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);height:500px}.explore-map-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:hsla(0,0%,100%,.6);gap:1rem}.explore-map-info{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius)}.map-count{font-size:.9rem;color:hsla(0,0%,100%,.7)}.map-travel-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--japan-red);border-radius:50px;color:#fff;font-size:.85rem;font-weight:500;transition:all .2s ease}.map-travel-btn:hover{background:var(--japan-red-hover);transform:translateY(-1px)}.explore-sidebar{display:flex;flex-direction:column;gap:1.5rem}.explore-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);padding:1.5rem;backdrop-filter:blur(12px)}.card-header{margin-bottom:1rem}.card-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;background:hsla(0,0%,100%,.1);border-radius:50px;font-size:.75rem;color:hsla(0,0%,100%,.8);margin-bottom:.5rem}.card-title{font-family:"Noto Serif JP",serif;font-size:1.25rem;font-weight:600;color:#fff;margin:0}.featured-list{display:flex;flex-direction:column;gap:.75rem}.featured-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius);transition:all .2s ease}.featured-item:hover{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.15);transform:translateX(4px)}.featured-item-content{flex:1;min-width:0}.featured-item-title{font-size:.95rem;font-weight:500;color:#fff;margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.featured-item-location{font-size:.8rem;color:hsla(0,0%,100%,.5);margin:0}.featured-item-claps{font-size:.85rem;color:hsla(0,0%,100%,.6);white-space:nowrap}.no-stories{text-align:center;color:hsla(0,0%,100%,.5);font-size:.9rem;padding:1rem}.action-buttons{flex-direction:column;gap:.75rem}.action-btn{display:flex;justify-content:center;padding:.75rem 1rem;font-size:.9rem;font-weight:500;cursor:pointer}.action-btn.primary{border:none}.action-btn.primary:hover{transform:translateY(-2px)}.action-btn.secondary{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15)}.action-btn.secondary:hover{background:hsla(0,0%,100%,.12);border-color:hsla(0,0%,100%,.25)}.tips-card{text-align:center;padding:2rem 1.5rem}.tips-emoji{font-size:2rem;display:block;margin-bottom:.75rem}.tips-title{font-family:"Noto Serif JP",serif;font-size:1.1rem;font-weight:600;color:#fff;margin:0 0 .5rem}.tips-text{font-size:.9rem;color:hsla(0,0%,100%,.6);line-height:1.5;margin:0}.explore-cta{text-align:center;padding:4rem 2rem;margin-bottom:2rem}.explore-cta-content{max-width:500px;margin:0 auto}.explore-cta-emoji{font-size:3rem;display:block;margin-bottom:1rem}.explore-cta-title{font-family:"Noto Serif JP",serif;font-size:2rem;font-weight:600;color:#fff;margin:0 0 .75rem}.explore-cta-subtitle{font-size:1.1rem;color:hsla(0,0%,100%,.6);margin:0 0 2rem}.explore-cta-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.cta-primary-btn,.cta-secondary-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.75rem;border-radius:50px;font-size:1rem;font-weight:500;transition:all .25s ease}.cta-primary-btn:hover{box-shadow:0 8px 25px -8px rgba(230,57,70,.5)}.cta-secondary-btn{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2)}.cta-secondary-btn:hover{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.3)}@media (max-width:1024px){.explore-content{grid-template-columns:1fr}.explore-sidebar{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.explore-card.tips-card{grid-column:span 2}}@media (max-width:768px){.explore-hero-title{font-size:2rem}.explore-stats{gap:1.5rem}.explore-stat-value{font-size:1.4rem}.explore-categories{justify-content:center}.explore-map-container{height:350px}.explore-sidebar{grid-template-columns:1fr}.explore-card.tips-card{grid-column:span 1}.explore-cta-title{font-size:1.5rem}.explore-cta-buttons{flex-direction:column;align-items:center}.cta-primary-btn,.cta-secondary-btn{width:100%;max-width:280px;justify-content:center}}.blog-page-container{min-height:100vh;background:linear-gradient(180deg,#090a18,#0f1224 55%,#171b32)}.blog-main{padding:0 var(--app-padding);max-width:1400px;margin:0 auto}.blog-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;color:hsla(0,0%,100%,.6);gap:1rem}.blog-hero{padding:4rem 0 3rem;text-align:center}.blog-hero-content{max-width:700px;margin:0 auto}.blog-hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.15);border-radius:50px;font-size:.85rem;color:hsla(0,0%,100%,.9);margin-bottom:1.5rem;backdrop-filter:blur(8px)}.blog-hero-title{font-family:"Noto Serif JP",serif;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:600;color:#fff;margin:0 0 1rem;line-height:1.2}.blog-hero-title .title-accent{color:var(--japan-red)}.blog-hero-subtitle{font-size:1.1rem;color:hsla(0,0%,100%,.7);line-height:1.6;margin:0 0 2rem}.blog-stats{display:flex;justify-content:center;gap:3rem}.blog-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.blog-stat-value{font-size:1.8rem;font-weight:700;color:#fff}.blog-stat-label{font-size:.85rem;color:hsla(0,0%,100%,.6);text-transform:uppercase;letter-spacing:.5px}.blog-filters{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;backdrop-filter:blur(12px)}.blog-search-row{display:flex;gap:1rem;margin-bottom:1rem}.blog-search{flex:1;display:flex;align-items:center;gap:.75rem;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.12);border-radius:var(--radius);padding:.75rem 1rem}.blog-sort{display:flex;gap:.5rem}.sort-btn{padding:.75rem 1.25rem;background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius);color:hsla(0,0%,100%,.7);font-size:.9rem;cursor:pointer;transition:all .2s ease}.sort-btn:hover{background:hsla(0,0%,100%,.1)}.sort-btn.active{background:var(--japan-red);border-color:var(--japan-red);color:#fff}.blog-categories{display:flex;flex-wrap:wrap;gap:.5rem}.blog-results-info{margin-bottom:1.5rem}.results-count{font-size:.9rem;color:hsla(0,0%,100%,.6)}.blog-posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:3rem}.blog-card{display:flex;flex-direction:column;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);overflow:hidden;transition:all .3s ease}.blog-card:hover{background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.2);transform:translateY(-4px);box-shadow:0 20px 40px -15px rgba(0,0,0,.4)}.blog-card-image{position:relative;height:200px;background:hsla(0,0%,100%,.05);overflow:hidden}.blog-card-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.blog-card:hover .blog-card-image img{transform:scale(1.05)}.blog-card-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:3rem;background:linear-gradient(135deg,rgba(230,57,70,.2),rgba(230,57,70,.05))}.blog-card-tags{position:absolute;top:.75rem;left:.75rem;display:flex;gap:.5rem;flex-wrap:wrap}.blog-card-tag{padding:.25rem .6rem;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);border-radius:50px;font-size:.75rem;color:#fff}.blog-card-content{flex:1;display:flex;flex-direction:column;padding:1.25rem}.blog-card-meta{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;font-size:.8rem;color:hsla(0,0%,100%,.5)}.blog-card-location{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.blog-card-title{font-family:"Noto Serif JP",serif;font-size:1.15rem;font-weight:600;color:#fff;line-height:1.3;-webkit-line-clamp:2}.blog-card-subtitle,.blog-card-title{margin:0 0 .5rem;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.blog-card-subtitle{font-size:.9rem;color:hsla(0,0%,100%,.6);-webkit-line-clamp:1}.blog-card-excerpt{flex:1;font-size:.85rem;color:hsla(0,0%,100%,.5);line-height:1.5;margin:0 0 1rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:1rem;border-top:1px solid hsla(0,0%,100%,.08)}.blog-card-author{display:flex;align-items:center;gap:.5rem}.author-avatar-placeholder{font-size:.9rem}.author-name{font-size:.8rem;color:hsla(0,0%,100%,.7)}.blog-card-claps{font-size:.85rem;color:hsla(0,0%,100%,.6)}.no-posts{grid-column:1/-1;text-align:center;padding:4rem 2rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg)}.no-posts-emoji{font-size:3rem;display:block;margin-bottom:1rem}.no-posts h3{font-family:"Noto Serif JP",serif;font-size:1.5rem;color:#fff;margin:0 0 .5rem}.no-posts p{color:hsla(0,0%,100%,.6);margin:0 0 1.5rem}.create-story-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--japan-red);border-radius:50px;color:#fff;font-size:.9rem;font-weight:500;transition:all .2s ease}.create-story-btn:hover{background:var(--japan-red-hover);transform:translateY(-2px)}.blog-cta{text-align:center;padding:4rem 2rem;margin-bottom:2rem}.blog-cta-content{max-width:500px;margin:0 auto}.blog-cta-emoji{font-size:3rem;display:block;margin-bottom:1rem}.blog-cta-title{font-family:"Noto Serif JP",serif;font-size:2rem;font-weight:600;color:#fff;margin:0 0 .75rem}.blog-cta-subtitle{font-size:1.1rem;color:hsla(0,0%,100%,.6);margin:0 0 2rem}.blog-cta-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}@media (max-width:768px){.blog-hero-title{font-size:2rem}.blog-stats{gap:1.5rem}.blog-stat-value{font-size:1.4rem}.blog-search-row{flex-direction:column}.blog-categories,.blog-sort{justify-content:center}.blog-posts-grid{grid-template-columns:1fr}.blog-cta-title{font-size:1.5rem}.blog-cta-buttons{flex-direction:column;align-items:center}}.profile-hero{padding:4rem 0 3rem;text-align:center}.profile-hero-content{max-width:700px;margin:0 auto}.profile-hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.15);border-radius:50px;font-size:.85rem;color:hsla(0,0%,100%,.9);margin-bottom:1.5rem;backdrop-filter:blur(8px)}.profile-hero-title{font-family:"Noto Serif JP",serif;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:600;color:#fff;margin:0 0 1rem;line-height:1.2}.profile-hero-title .title-accent{color:var(--japan-red)}.profile-hero-subtitle{font-size:1.1rem;color:hsla(0,0%,100%,.7);line-height:1.6;margin:0 0 2rem}.profile-stats{display:flex;justify-content:center;gap:3rem}.profile-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.profile-stat-value{font-size:1.8rem;font-weight:700;color:#fff}.profile-stat-label{font-size:.85rem;color:hsla(0,0%,100%,.6);text-transform:uppercase;letter-spacing:.5px}.profile-actions-section{margin-bottom:4rem}.profile-action-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.profile-action-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);padding:2rem;text-align:left;backdrop-filter:blur(12px);transition:all .3s ease}.profile-action-card:hover{background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.2)}.action-card-icon{font-size:2.5rem;margin-bottom:1rem}.action-card-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:hsla(0,0%,100%,.5);margin-bottom:.5rem}.action-card-title{font-family:"Noto Serif JP",serif;font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 .75rem}.action-card-description{font-size:.95rem;color:hsla(0,0%,100%,.6);line-height:1.5;margin:0 0 1.5rem}.action-card-buttons{margin-bottom:1rem}.action-card-note{font-size:.85rem;color:hsla(0,0%,100%,.5);margin:0}.note-link{color:var(--japan-red);font-weight:500;transition:color .2s}.note-link:hover{color:var(--japan-red-hover)}.section-header{text-align:center;margin-bottom:2.5rem}.section-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;background:hsla(0,0%,100%,.1);border-radius:50px;font-size:.75rem;color:hsla(0,0%,100%,.8);margin-bottom:1rem}.section-title{font-family:"Noto Serif JP",serif;font-size:2rem;font-weight:600;color:#fff;margin:0 0 .5rem}.section-subtitle{font-size:1rem;color:hsla(0,0%,100%,.6);margin:0}.profile-featured-section{margin-bottom:4rem}.featured-profiles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.featured-profile-card{display:flex;flex-direction:column;align-items:center;text-align:center;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);padding:2rem 1.5rem;transition:all .3s ease}.featured-profile-card:hover{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.2);transform:translateY(-4px)}.featured-profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--japan-red),rgba(230,57,70,.6));display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin-bottom:1rem}.featured-profile-name{font-family:"Noto Serif JP",serif;font-size:1.2rem;font-weight:600;color:#fff;margin:0 0 .25rem}.featured-profile-username{font-size:.85rem;color:hsla(0,0%,100%,.5);margin:0 0 .75rem}.featured-profile-bio{font-size:.9rem;color:hsla(0,0%,100%,.7);line-height:1.4;margin:0 0 1rem}.featured-profile-stats{display:flex;gap:2rem;margin-bottom:1rem}.mini-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem}.mini-stat-value{font-size:1.1rem;font-weight:700;color:#fff}.mini-stat-label{font-size:.7rem;color:hsla(0,0%,100%,.5);text-transform:uppercase}.featured-profile-cta{font-size:.85rem;color:var(--japan-red);font-weight:500}.profile-features-section{margin-bottom:4rem}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.feature-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;transition:all .3s ease}.feature-card:hover{background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.2)}.feature-icon{font-size:2rem;margin-bottom:1rem}.feature-title{font-family:"Noto Serif JP",serif;font-size:1.1rem;font-weight:600;color:#fff;margin:0 0 .5rem}.feature-description{font-size:.85rem;color:hsla(0,0%,100%,.6);line-height:1.4;margin:0}.profile-cta{text-align:center;padding:4rem 2rem;margin-bottom:2rem}.profile-cta-content{max-width:500px;margin:0 auto}.profile-cta-emoji{font-size:3rem;display:block;margin-bottom:1rem}.profile-cta-title{font-family:"Noto Serif JP",serif;font-size:2rem;font-weight:600;color:#fff;margin:0 0 .75rem}.profile-cta-subtitle{font-size:1.1rem;color:hsla(0,0%,100%,.6);margin:0 0 2rem}.profile-cta-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.profile-page-container{min-height:100vh;background:linear-gradient(180deg,#090a18,#0f1224 55%,#171b32)}.profile-main{max-width:1200px;margin:0 auto;padding:0 var(--app-padding)}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:hsla(0,0%,100%,.7)}.action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:600;text-decoration:none;transition:all .2s ease;font-size:.95rem}.action-btn.primary{background:var(--japan-red);color:#fff}.action-btn.primary:hover{background:var(--japan-red-hover);transform:translateY(-1px)}.action-btn.secondary{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);color:#fff}.action-btn.secondary:hover{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.3)}.cta-primary-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;background:var(--japan-red);color:#fff;border-radius:var(--radius);font-weight:600;font-size:1rem;text-decoration:none;transition:all .2s ease}.cta-primary-btn:hover{background:var(--japan-red-hover);transform:translateY(-2px);box-shadow:0 8px 20px rgba(230,57,70,.3)}.cta-secondary-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;background:transparent;border:1px solid hsla(0,0%,100%,.3);color:#fff;border-radius:var(--radius);font-weight:600;font-size:1rem;text-decoration:none;transition:all .2s ease}.cta-secondary-btn:hover{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.5)}@media (max-width:1024px){.profile-main{padding:0 1.5rem}.featured-profiles-grid,.features-grid{grid-template-columns:repeat(2,1fr)}.profile-action-cards{gap:1.25rem}}@media (max-width:768px){.profile-main{padding:0 1rem}.profile-hero{padding:2.5rem 0 2rem}.profile-hero-content{padding:0 .5rem}.profile-hero-badge{padding:.4rem .85rem;font-size:.8rem;margin-bottom:1rem}.profile-hero-title{font-size:1.85rem;margin-bottom:.85rem}.profile-hero-subtitle{font-size:.95rem;line-height:1.5;margin-bottom:1.5rem;padding:0 .5rem}.profile-stats{flex-wrap:wrap;gap:1.25rem;justify-content:center}.profile-stat{min-width:calc(50% - .75rem)}.profile-stat-value{font-size:1.5rem}.profile-stat-label{font-size:.75rem}.profile-actions-section{margin-bottom:3rem}.profile-action-cards{grid-template-columns:1fr;gap:1rem}.profile-action-card{padding:1.5rem;border-radius:var(--radius)}.action-card-icon{font-size:2rem;margin-bottom:.85rem}.action-card-label{font-size:.7rem;margin-bottom:.4rem}.action-card-title{font-size:1.25rem;margin-bottom:.65rem}.action-card-description{font-size:.9rem;margin-bottom:1.25rem;line-height:1.5}.action-card-buttons{margin-bottom:.85rem}.action-btn{width:100%;justify-content:center;padding:.75rem 1.25rem;font-size:.9rem;min-height:44px}.action-card-note{font-size:.8rem;text-align:center}.section-header{margin-bottom:1.75rem}.section-badge{padding:.3rem .65rem;font-size:.7rem;margin-bottom:.85rem}.section-title{font-size:1.5rem;margin-bottom:.5rem}.section-subtitle{font-size:.9rem;padding:0 1rem}.profile-featured-section{margin-bottom:3rem}.featured-profiles-grid{grid-template-columns:1fr;gap:1rem}.featured-profile-card{padding:1.5rem 1.25rem;border-radius:var(--radius)}.featured-profile-avatar{width:70px;height:70px;font-size:2rem;margin-bottom:.85rem}.featured-profile-name{font-size:1.1rem;margin-bottom:.25rem}.featured-profile-username{font-size:.8rem;margin-bottom:.65rem}.featured-profile-bio{font-size:.85rem;margin-bottom:.85rem;line-height:1.4}.featured-profile-stats{gap:1.25rem;margin-bottom:.85rem}.mini-stat-value{font-size:1rem}.mini-stat-label{font-size:.65rem}.featured-profile-cta{font-size:.8rem}.profile-features-section{margin-bottom:3rem}.features-grid{grid-template-columns:1fr;gap:1rem}.feature-card{padding:1.25rem;border-radius:var(--radius)}.feature-icon{font-size:1.75rem;margin-bottom:.85rem}.feature-title{font-size:1rem;margin-bottom:.45rem}.feature-description{font-size:.8rem;line-height:1.4}.profile-cta{padding:3rem 1rem;margin-bottom:1.5rem}.profile-cta-content{padding:0 .5rem}.profile-cta-emoji{font-size:2.5rem;margin-bottom:.85rem}.profile-cta-title{font-size:1.5rem;margin-bottom:.65rem}.profile-cta-subtitle{font-size:.95rem;margin-bottom:1.5rem;line-height:1.5}.profile-cta-buttons{flex-direction:column;align-items:stretch;gap:.75rem}.cta-primary-btn,.cta-secondary-btn{width:100%;justify-content:center;padding:.85rem 1.5rem;font-size:.95rem;min-height:48px}}@media (max-width:480px){.profile-main{padding:0 .75rem}.profile-hero{padding:2rem 0 1.5rem}.profile-hero-title{font-size:1.65rem}.profile-hero-subtitle{font-size:.9rem;padding:0 .25rem}.profile-stats{gap:1rem}.profile-stat-value{font-size:1.35rem}.profile-action-card{padding:1.25rem}.action-card-title{font-size:1.15rem}.action-card-description{font-size:.85rem}.section-title{font-size:1.35rem}.section-subtitle{font-size:.85rem;padding:0 .5rem}.featured-profile-card{padding:1.25rem 1rem}.featured-profile-avatar{width:60px;height:60px;font-size:1.75rem}.feature-card{padding:1rem}.profile-cta{padding:2.5rem .75rem}.profile-cta-emoji{font-size:2rem}.profile-cta-title{font-size:1.35rem}.profile-cta-subtitle{font-size:.9rem}.cta-primary-btn,.cta-secondary-btn{padding:.75rem 1.25rem;font-size:.9rem;min-height:44px}}.user-profile-container{min-height:100vh;background:linear-gradient(180deg,#090a18,#0f1224 55%,#171b32)}.user-profile-main{position:relative;max-width:1200px;margin:0 auto;padding:0 var(--app-padding)}.profile-error,.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;color:hsla(0,0%,100%,.7);gap:1rem}.profile-error .error-emoji{font-size:4rem}.profile-error h2{font-family:"Noto Serif JP",serif;font-size:1.5rem;color:#fff;margin:0}.profile-error p{color:hsla(0,0%,100%,.5);margin:0 0 1.5rem}.profile-error .back-btn{display:inline-flex;padding:.75rem 1.5rem;background:var(--japan-red);border-radius:50px;color:#fff;font-weight:500;transition:all .2s ease}.profile-error .back-btn:hover{background:var(--japan-red-hover)}.profile-hero-cover{position:absolute;top:0;left:0;right:0;height:280px;overflow:hidden}.profile-hero-gradient{position:absolute;inset:0;background:linear-gradient(135deg,rgba(230,57,70,.4),rgba(230,57,70,.1) 50%,transparent)}.profile-hero-pattern{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.5}.profile-header-card{position:relative;margin-top:120px;padding-top:80px}.profile-header-content{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-xl);padding:2rem;backdrop-filter:blur(20px);display:flex;flex-direction:column;align-items:center;text-align:center}.profile-avatar-wrapper{position:relative;margin-top:-100px;margin-bottom:1.5rem}.profile-avatar-img{width:140px;height:140px;border-radius:50%;border:4px solid hsla(0,0%,100%,.2);-o-object-fit:cover;object-fit:cover}.profile-avatar-placeholder{width:140px;height:140px;border-radius:50%;background:linear-gradient(135deg,var(--japan-red),rgba(230,57,70,.6));border:4px solid hsla(0,0%,100%,.2);font-size:3.5rem;font-weight:700}.profile-avatar-placeholder,.verified-badge{display:flex;align-items:center;justify-content:center;color:#fff}.verified-badge{position:absolute;bottom:8px;right:8px;width:32px;height:32px;background:#3b82f6;border-radius:50%;font-size:1rem;border:3px solid #0f1224}.user-profile-main .profile-info{margin-bottom:2rem}.user-profile-main .profile-name{font-family:"Noto Serif JP",serif;font-size:2rem;font-weight:600;color:#fff;margin:0 0 .25rem}.user-profile-main .profile-username{font-size:1rem;color:hsla(0,0%,100%,.5);margin:0 0 1rem}.user-profile-main .profile-bio{font-size:1rem;color:hsla(0,0%,100%,.7);line-height:1.5;max-width:500px;margin:0 auto 1.5rem}.user-profile-main .profile-actions{display:flex;gap:.75rem;justify-content:center}.follow-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:50px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.follow-btn.primary{background:var(--japan-red);color:#fff}.follow-btn.primary:hover{background:var(--japan-red-hover);transform:translateY(-1px)}.follow-btn.secondary{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);color:#fff}.follow-btn.secondary:hover{background:hsla(0,0%,100%,.15)}.profile-stats-ring{display:flex;align-items:center;gap:1.5rem;padding:1.5rem 2rem;background:hsla(0,0%,100%,.05);border-radius:var(--radius-lg);border:1px solid hsla(0,0%,100%,.08)}.profile-stats-ring .stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:0 1rem}.profile-stats-ring .stat-value{font-size:1.5rem;font-weight:700;color:#fff}.profile-stats-ring .stat-label{font-size:.75rem;color:hsla(0,0%,100%,.5);text-transform:uppercase;letter-spacing:.5px}.profile-badges-section{margin-top:2rem;padding:1.5rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg)}.badges-title{align-items:center;gap:.5rem;font-size:1rem;color:hsla(0,0%,100%,.8);margin:0 0 1rem}.badges-grid,.badges-title{display:flex;justify-content:center}.badges-grid{flex-wrap:wrap;gap:.75rem}.badge-card{flex-direction:column;align-items:center;gap:.25rem;padding:1rem 1.5rem;border-radius:var(--radius);transition:all .2s ease}.badge-card:hover{background:hsla(0,0%,100%,.1);transform:translateY(-2px)}.badge-icon{font-size:1.5rem}.badge-label{font-size:.85rem;font-weight:600;color:#fff}.badge-desc{font-size:.7rem;color:hsla(0,0%,100%,.5)}.profile-tabs{display:flex;justify-content:center;gap:.5rem;margin-top:2rem;padding:.5rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg)}.tab-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:none;border-radius:var(--radius);color:hsla(0,0%,100%,.6);font-size:.9rem;cursor:pointer;transition:all .2s ease}.tab-btn:hover{background:hsla(0,0%,100%,.05);color:#fff}.tab-btn.active{background:var(--japan-red);color:#fff}.tab-count{padding:.15rem .5rem;background:hsla(0,0%,100%,.15);border-radius:50px;font-size:.75rem}.tab-btn.active .tab-count{background:hsla(0,0%,100%,.25)}.profile-content{margin-top:2rem;margin-bottom:4rem}.user-profile-main .empty-state{text-align:center;padding:4rem 2rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg)}.empty-emoji{font-size:3rem;display:block;margin-bottom:1rem}.user-profile-main .empty-state h3{font-family:"Noto Serif JP",serif;font-size:1.25rem;color:#fff;margin:0 0 .5rem}.user-profile-main .empty-state p{color:hsla(0,0%,100%,.5);margin:0}.stories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.story-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);transition:all .3s ease}.story-card:hover{background:hsla(0,0%,100%,.08);transform:translateY(-4px)}.story-image{position:relative;height:180px;background:hsla(0,0%,100%,.05);overflow:hidden}.story-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.story-card:hover .story-image img{transform:scale(1.05)}.story-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:3rem;background:linear-gradient(135deg,rgba(230,57,70,.2),rgba(230,57,70,.05))}.story-overlay{position:absolute;top:.75rem;right:.75rem}.story-claps{padding:.35rem .75rem;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);border-radius:50px;font-size:.8rem;color:#fff}.story-content{padding:1.25rem}.story-title{font-family:"Noto Serif JP",serif;font-size:1.1rem;font-weight:600;color:#fff;margin:0 0 .5rem;-webkit-line-clamp:2}.story-subtitle,.story-title{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.story-subtitle{font-size:.85rem;color:hsla(0,0%,100%,.6);margin:0 0 .75rem;-webkit-line-clamp:1}.story-location{font-size:.8rem;color:hsla(0,0%,100%,.5)}.locations-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.locations-header h3{font-family:"Noto Serif JP",serif;font-size:1.25rem;color:#fff;margin:0}.locations-count{font-size:.85rem;color:hsla(0,0%,100%,.5)}.locations-grid{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2rem}.location-card{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:50px;color:#fff;font-size:.9rem;transition:all .2s ease}.location-card:hover{background:rgba(230,57,70,.2);border-color:var(--japan-red)}.location-pin{font-size:.9rem}.location-name{color:hsla(0,0%,100%,.9)}.location-arrow{color:hsla(0,0%,100%,.6);margin-left:.25rem}.categories-section{padding-top:2rem;border-top:1px solid hsla(0,0%,100%,.08)}.categories-section h3{font-family:"Noto Serif JP",serif;font-size:1.1rem;color:#fff;margin:0 0 1.5rem}.categories-bars{display:flex;flex-direction:column;gap:1rem}.category-bar-item{display:flex;flex-direction:column;gap:.5rem}.category-bar-label{display:flex;justify-content:space-between;font-size:.85rem}.category-bar-label span:first-child{color:#fff}.category-bar-label span:last-child{color:hsla(0,0%,100%,.5)}.category-bar-track{height:8px;background:hsla(0,0%,100%,.1);border-radius:4px;overflow:hidden}.category-bar-fill{height:100%;background:linear-gradient(90deg,var(--japan-red),rgba(230,57,70,.6));border-radius:4px;transition:width 1s ease}.about-card{background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);padding:2rem}.about-card h3{font-family:"Noto Serif JP",serif;font-size:1.5rem;color:#fff;margin:0 0 1rem}.about-bio{font-size:1rem;color:hsla(0,0%,100%,.7);line-height:1.6;margin:0 0 2rem}.about-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.about-stat{display:flex;align-items:center;gap:1rem;padding:1rem;background:hsla(0,0%,100%,.05);border-radius:var(--radius)}.about-stat-icon{font-size:1.5rem}.about-stat-value{display:block;font-size:1.25rem;font-weight:700;color:#fff}.about-stat-label{display:block;font-size:.8rem;color:hsla(0,0%,100%,.5)}.about-links h4{font-size:1rem;color:#fff;margin:0 0 1rem}.links-grid{display:flex;flex-wrap:wrap;gap:.75rem}.link-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius);color:#fff;font-size:.85rem;transition:all .2s ease}.link-btn:hover{background:hsla(0,0%,100%,.1);border-color:hsla(0,0%,100%,.2)}@media (max-width:1024px){.user-profile-main{padding:0 1.5rem}.profile-header-content{padding:1.5rem}.profile-stats-ring{flex-wrap:wrap;gap:1rem}.stories-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width:768px){body,html{overflow-x:hidden;max-width:100vw}.user-profile-container{max-width:100vw}.user-profile-container,.user-profile-main{overflow-x:hidden;width:100%;box-sizing:border-box}.user-profile-main{padding:0 1rem;max-width:100%}.user-profile-main *{max-width:100%;box-sizing:border-box}.user-profile-main img{max-width:100%;height:auto}.profile-hero-cover{height:180px;width:100%}.profile-header-card{margin-top:70px;padding-top:50px;width:100%}.profile-header-content{padding:1.25rem 1rem;border-radius:var(--radius-lg);width:100%;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;text-align:center}.profile-avatar-wrapper{margin-top:-75px;margin-bottom:1rem;display:flex;justify-content:center;align-items:center;position:relative}.profile-avatar-img,.profile-avatar-placeholder{width:90px;height:90px;border-width:3px;display:block;margin:0 auto}.profile-avatar-placeholder{font-size:2.25rem}.verified-badge{width:26px;height:26px;font-size:.85rem;border-width:2px;bottom:4px;right:4px}.user-profile-main .profile-info{width:100%;max-width:100%;display:flex;flex-direction:column;align-items:center}.user-profile-main .profile-name{font-size:1.4rem;margin-bottom:.35rem;hyphens:auto;line-height:1.3}.user-profile-main .profile-name,.user-profile-main .profile-username{word-wrap:break-word;overflow-wrap:break-word;max-width:100%;text-align:center}.user-profile-main .profile-username{font-size:.9rem;margin-bottom:.85rem}.user-profile-main .profile-bio{font-size:.9rem;padding:0 .75rem;margin:0 auto 1.25rem;max-width:100%;word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap;line-height:1.6;text-align:center}.user-profile-main .profile-actions{display:flex;flex-direction:column;width:100%;max-width:100%;gap:.75rem;padding:0;box-sizing:border-box}.follow-btn{width:100%;max-width:100%;justify-content:center;align-items:center;padding:.85rem 1rem;min-height:48px;font-size:.95rem;box-sizing:border-box;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.follow-btn:active{transform:scale(.97)}.profile-stats-ring{flex-wrap:wrap;justify-content:center;gap:1rem;padding:1rem .75rem}.stat-divider{display:none}.profile-stats-ring .stat-item{flex:0 1 calc(50% - 0.5rem);padding:.5rem;min-width:80px}.profile-stats-ring .stat-value{font-size:1.35rem}.profile-stats-ring .stat-label{font-size:.7rem}.profile-badges-section{padding:1.25rem 1rem}.badges-title{font-size:.95rem;margin-bottom:1rem}.badges-grid{gap:.5rem;justify-content:center}.badge-card{padding:.75rem 1rem;min-width:100px}.badge-icon{font-size:1.35rem}.badge-label{font-size:.8rem}.badge-desc{font-size:.65rem}.profile-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start;scrollbar-width:none;margin-left:-1rem;margin-right:-1rem;padding:.5rem 1rem}.profile-tabs::-webkit-scrollbar{display:none}.tab-btn{padding:.65rem 1rem;font-size:.85rem;white-space:nowrap;flex-shrink:0}.tab-btn span:first-child{font-size:1.1rem}.tab-count{padding:.1rem .4rem;font-size:.7rem}.profile-content{margin-top:1.5rem;margin-bottom:3rem}.user-profile-main .empty-state{padding:3rem 1.5rem}.empty-emoji{font-size:2.5rem}.user-profile-main .empty-state h3{font-size:1.1rem}.user-profile-main .empty-state p{font-size:.9rem}.cta-link{display:inline-block;margin-top:1rem;padding:.65rem 1.25rem;background:var(--japan-red);color:#fff;border-radius:50px;font-size:.85rem;text-decoration:none;transition:all .2s ease}.cta-link:hover{background:var(--japan-red-hover)}.stories-grid{grid-template-columns:1fr;gap:1rem}.story-card{border-radius:var(--radius)}.story-image{height:160px}.story-content{padding:1rem}.story-title{font-size:1rem;margin-bottom:.35rem}.story-subtitle{font-size:.8rem;margin-bottom:.5rem}.story-location{font-size:.75rem}.locations-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1.25rem}.locations-header h3{font-size:1.1rem}.locations-count{font-size:.8rem}.locations-grid{gap:.5rem}.location-card{font-size:.85rem;padding:.5rem .85rem}.categories-section{padding-top:1.5rem}.categories-section h3{font-size:1rem;margin-bottom:1.25rem}.category-bar-label{font-size:.8rem}.category-bar-track{height:6px}.badges-tab .badges-grid{grid-template-columns:1fr;gap:1rem}.badges-tab .badge-card{flex-direction:row;padding:1rem;text-align:left;gap:1rem}.badges-tab .badge-icon{font-size:2rem;min-width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius)}.badges-tab .badge-info{flex:1;display:flex;flex-direction:column;gap:.35rem}.badges-tab .badge-info h4{font-size:.95rem;margin:0;color:#fff}.badges-tab .badge-info .badge-desc{font-size:.8rem}.badge-meta{display:flex;gap:.75rem;margin-top:.5rem}.badge-rarity{padding:.2rem .5rem;background:hsla(0,0%,100%,.1);border-radius:4px;font-size:.65rem;text-transform:uppercase}.badge-points{font-size:.75rem;color:hsla(0,0%,100%,.7)}.badge-date{font-size:.7rem;color:hsla(0,0%,100%,.5);margin-top:.35rem}.locked-badges-section{margin-top:2rem;padding-top:2rem;border-top:1px solid hsla(0,0%,100%,.08)}.locked-badges-section h3{font-size:.95rem;color:hsla(0,0%,100%,.7);margin-bottom:1rem}.locked-badges-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.locked-badge-card{display:flex;flex-direction:column;align-items:center;padding:1rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius);text-align:center;gap:.5rem}.locked-badge-card .badge-icon{font-size:1.75rem;opacity:.4}.badge-name{font-size:.8rem;color:hsla(0,0%,100%,.5);font-weight:600}.badge-hint{font-size:.7rem;color:hsla(0,0%,100%,.6)}.checkins-timeline{display:flex;flex-direction:column;gap:1rem}.checkin-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius);overflow:hidden;transition:all .2s ease}.checkin-card:active{transform:scale(.98)}.checkin-photo{height:160px;overflow:hidden}.checkin-photo img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.checkin-content{padding:1rem}.checkin-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.75rem;gap:.5rem}.checkin-header h4{font-size:1rem;font-weight:600;color:#fff;margin:0;line-height:1.3}.checkin-header .verified-badge{position:static;width:auto;height:auto;padding:.2rem .5rem;background:rgba(59,130,246,.2);border:1px solid rgba(59,130,246,.3);border-radius:4px;font-size:.7rem;color:#60a5fa;white-space:nowrap;flex-shrink:0}.checkin-meta{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.checkin-location{font-size:.85rem;color:hsla(0,0%,100%,.7)}.checkin-date{font-size:.75rem;color:hsla(0,0%,100%,.5)}.checkin-note{font-size:.85rem;color:hsla(0,0%,100%,.7);line-height:1.5;margin:0 0 .75rem}.checkin-rating{font-size:.9rem;margin-bottom:.5rem}.checkin-duration{font-size:.75rem;color:hsla(0,0%,100%,.5)}.memories-timeline{display:flex;flex-direction:column;gap:1.25rem}.memory-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius);overflow:hidden;transition:all .2s ease}.memory-card:active{transform:scale(.98)}.memory-photos{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.25rem;background:rgba(0,0,0,.2)}.memory-photos img{width:100%;height:140px;-o-object-fit:cover;object-fit:cover}.memory-content{padding:1rem}.memory-header{margin-bottom:.75rem}.memory-header h4{font-size:1rem;font-weight:600;color:#fff;margin:0 0 .35rem;line-height:1.3}.memory-date{font-size:.75rem;color:hsla(0,0%,100%,.5)}.memory-description{font-size:.85rem;color:hsla(0,0%,100%,.7);line-height:1.5;margin:0 0 .75rem}.memory-location{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:hsla(0,0%,100%,.6);margin-bottom:.75rem}.memory-tags{display:flex;flex-wrap:wrap;gap:.35rem}.memory-tag{padding:.25rem .65rem;background:hsla(0,0%,100%,.08);border-radius:50px;font-size:.7rem;color:hsla(0,0%,100%,.7)}.about-card{padding:1.25rem}.about-card h3{font-size:1.25rem;margin-bottom:1rem}.about-bio{font-size:.9rem;margin-bottom:1.5rem}.about-stats{grid-template-columns:1fr;gap:.75rem;margin-bottom:1.5rem}.about-stat{padding:.85rem}.about-stat-icon{font-size:1.35rem}.about-stat-value{font-size:1.1rem}.about-stat-label{font-size:.75rem}.about-links h4{font-size:.95rem;margin-bottom:.85rem}.links-grid{gap:.5rem}.link-btn{font-size:.8rem;padding:.5rem .85rem}}@media (max-width:480px){.user-profile-container{position:relative}.user-profile-container,.user-profile-main{overflow-x:hidden!important;width:100vw;max-width:100vw}.user-profile-main{padding:0 .85rem;box-sizing:border-box}.user-profile-main>*{max-width:calc(100vw - 1.7rem)!important;box-sizing:border-box}.badges-grid,.locations-grid,.profile-stats-ring,.stories-grid{max-width:100%!important;overflow-x:hidden}.profile-actions{width:100%!important;max-width:100%!important}.profile-hero-cover{height:140px;width:100%}.profile-header-card{margin-top:55px;padding-top:42px;width:100%}.profile-header-content{padding:1rem .85rem;width:100%;box-sizing:border-box}.profile-avatar-wrapper{margin-top:-62px;margin-bottom:.85rem;display:flex;justify-content:center;width:100%}.profile-avatar-img,.profile-avatar-placeholder{width:75px;height:75px;border-width:2.5px}.profile-avatar-placeholder{font-size:1.85rem}.verified-badge{width:22px;height:22px;font-size:.75rem;border-width:2px;bottom:2px;right:2px}.user-profile-main .profile-name{font-size:1.2rem;line-height:1.25;padding:0 .5rem;word-break:break-word;max-width:100%}.user-profile-main .profile-username{font-size:.85rem;margin-bottom:.75rem;word-break:break-word}.user-profile-main .profile-bio{font-size:.85rem;padding:0 .5rem;line-height:1.5;margin-bottom:1rem;max-width:100%}.follow-btn{padding:.8rem 1rem;font-size:.9rem;min-height:46px;width:100%;box-sizing:border-box}.profile-stats-ring{gap:.65rem;padding:.85rem .5rem}.profile-stats-ring .stat-item{min-width:65px;flex:0 1 calc(50% - 0.35rem);padding:.4rem .25rem}.profile-stats-ring .stat-value{font-size:1.15rem}.profile-stats-ring .stat-label{font-size:.65rem;letter-spacing:.3px}.profile-tabs{margin-left:-.85rem;margin-right:-.85rem;padding:.4rem .85rem}.tab-btn{padding:.55rem .75rem;font-size:.75rem;min-height:42px}.tab-btn span:first-child{font-size:1rem}.tab-count{padding:.08rem .35rem;font-size:.65rem}.profile-content{margin-top:1.25rem;margin-bottom:2.5rem;width:100%;overflow-x:hidden}.story-card{width:100%;box-sizing:border-box}.story-image{height:140px}.story-content{padding:.85rem}.story-title{font-size:.95rem;line-height:1.3}.story-subtitle{font-size:.75rem}.badge-card{padding:.65rem .85rem;min-width:90px}.badge-icon{font-size:1.2rem}.badge-label{font-size:.75rem}.locked-badges-grid{grid-template-columns:1fr;gap:.65rem}.about-stats{gap:.5rem}.about-stat{padding:.75rem}.about-stat-value{font-size:1rem}.about-stat-label{font-size:.7rem}}@media (max-width:360px){.user-profile-main{padding:0 .65rem;width:calc(100vw - 1.3rem);max-width:calc(100vw - 1.3rem)}.profile-hero-cover{height:120px}.profile-header-card{margin-top:50px;padding-top:38px}.profile-header-content{padding:.85rem .65rem}.profile-avatar-wrapper{margin-top:-55px}.profile-avatar-img,.profile-avatar-placeholder{width:68px;height:68px}.profile-avatar-placeholder{font-size:1.65rem}.user-profile-main .profile-name{font-size:1.1rem}.user-profile-main .profile-bio{font-size:.8rem}.follow-btn{padding:.75rem .85rem;font-size:.85rem;min-height:44px}.profile-stats-ring .stat-item{min-width:60px}.profile-stats-ring .stat-value{font-size:1.05rem}.tab-btn{padding:.5rem .65rem;font-size:.7rem;min-height:40px}.profile-stats-grid{grid-template-columns:1fr;gap:.5rem}.featured-profile-stats{gap:.5rem}}@media (max-width:768px) and (orientation:landscape){.profile-hero-cover{height:120px}.profile-header-card{margin-top:50px;padding-top:35px}.profile-avatar-wrapper{margin-top:-50px;margin-bottom:.75rem}.profile-avatar-img,.profile-avatar-placeholder{width:70px;height:70px}.profile-avatar-placeholder{font-size:1.75rem}.profile-header-content{padding:1rem 1.5rem}.user-profile-main .profile-name{font-size:1.2rem}.user-profile-main .profile-bio{font-size:.85rem;margin-bottom:1rem}.profile-stats-ring{padding:.75rem}.profile-stats-ring .stat-item{min-width:65px}}.city-detail-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.city-detail-main{padding-top:80px}.city-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:2rem}.city-not-found .not-found-emoji{font-size:4rem;margin-bottom:1.5rem}.city-not-found h1{font-family:var(--font-editorial),serif;font-size:2.5rem;color:#fff;margin-bottom:.5rem}.city-not-found p{color:hsla(0,0%,100%,.6);margin-bottom:2rem}.back-to-cities-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:rgba(230,57,70,.2);border:1px solid rgba(230,57,70,.3);border-radius:12px;color:#e63946;font-weight:600;transition:all .3s ease}.back-to-cities-btn:hover{background:rgba(230,57,70,.3);transform:translateX(-4px)}.city-detail-hero{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:4rem 2rem}.city-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at top,rgba(230,57,70,.15) 0,transparent 60%),radial-gradient(ellipse at bottom right,rgba(69,123,157,.1) 0,transparent 50%)}.city-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0,rgba(15,15,26,.8))}.city-hero-content{position:relative;z-index:1;max-width:900px;text-align:center}.city-hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:hsla(0,0%,100%,.1);backdrop-filter:blur(10px);border-radius:50px;border:1px solid hsla(0,0%,100%,.15);font-size:.875rem;color:hsla(0,0%,100%,.8);margin-bottom:1.5rem}.city-hero-title{font-family:var(--font-editorial),serif;font-size:clamp(3rem,8vw,5rem);color:#fff;margin-bottom:1.5rem;letter-spacing:-.02em;line-height:1.1}.city-hero-description{font-size:1.125rem;color:hsla(0,0%,100%,.7);line-height:1.8;max-width:700px;margin:0 auto 2.5rem}.city-hero-stats{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:2.5rem}.city-hero-stat{display:flex;flex-direction:column;align-items:center;padding:1rem 1.5rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:16px;border:1px solid hsla(0,0%,100%,.1);min-width:100px}.city-hero-stat .stat-value{font-family:var(--font-editorial),serif;font-size:1.75rem;font-weight:700;color:#fff}.city-hero-stat .stat-label{font-size:.75rem;color:hsla(0,0%,100%,.5);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem}.city-hero-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.city-action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:12px;font-weight:600;transition:all .3s ease}.city-action-btn.primary{background:linear-gradient(135deg,#e63946,#c62828);color:#fff;box-shadow:0 4px 15px rgba(230,57,70,.3)}.city-action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 25px rgba(230,57,70,.4)}.city-action-btn.secondary{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);color:#fff}.city-action-btn.secondary:hover{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.3)}.city-section{padding:4rem 2rem;max-width:1200px;margin:0 auto}.city-section .section-header{text-align:center;margin-bottom:3rem}.city-section .section-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(230,57,70,.15);border-radius:50px;font-size:.875rem;color:#e63946;margin-bottom:1rem}.city-section .section-title{font-family:var(--font-editorial),serif;font-size:2.25rem;color:#fff;margin-bottom:.5rem}.city-section .section-subtitle{color:hsla(0,0%,100%,.6);font-size:1rem}.best-time-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem 2rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:20px;border:1px solid hsla(0,0%,100%,.1);margin-bottom:2rem}.best-time-icon{font-size:2.5rem}.best-time-content{flex:1}.best-time-content h3{font-size:1.125rem;font-weight:600;color:#fff;margin-bottom:.25rem}.best-time-content p{color:hsla(0,0%,100%,.7);font-size:.95rem;line-height:1.6}.current-season-badge{padding:.5rem 1rem;background:rgba(230,57,70,.2);border-radius:50px;font-size:.875rem;font-weight:600;color:#e63946;white-space:nowrap}.seasons-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.season-card{padding:1.5rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:16px;border:1px solid hsla(0,0%,100%,.1);text-align:center;transition:all .3s ease}.season-card:hover{transform:translateY(-4px);background:hsla(0,0%,100%,.08);border-color:rgba(230,57,70,.3)}.season-emoji{font-size:2rem;display:block;margin-bottom:.75rem}.season-name{font-size:1rem;font-weight:600;color:#fff;margin-bottom:.5rem}.season-detail{font-size:.8rem;color:hsla(0,0%,100%,.6);line-height:1.5}.city-attractions-section{background:hsla(0,0%,100%,.02);padding:4rem 2rem;margin:0;max-width:none}.attractions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto}.attraction-card{position:relative;padding:2rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:20px;border:1px solid hsla(0,0%,100%,.1);transition:all .3s ease;overflow:hidden}.attraction-card:hover{transform:translateY(-4px);background:hsla(0,0%,100%,.08);border-color:rgba(230,57,70,.3)}.attraction-number{position:absolute;top:1rem;right:1rem;font-family:var(--font-editorial),serif;font-size:2.5rem;font-weight:700;color:rgba(230,57,70,.15)}.attraction-content{position:relative;z-index:1}.attraction-name{font-family:var(--font-editorial),serif;font-size:1.25rem;color:#fff;margin-bottom:.75rem}.attraction-description{font-size:.95rem;color:hsla(0,0%,100%,.7);line-height:1.6;margin-bottom:1rem}.attraction-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:rgba(230,57,70,.15);border-radius:50px;font-size:.75rem;color:#e63946}.food-specialties{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:2.5rem}.food-tag{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:rgba(230,57,70,.15);border-radius:50px;font-weight:500;color:#fff;transition:all .3s ease}.food-tag:hover{background:rgba(230,57,70,.25);transform:translateY(-2px)}.food-categories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.food-category-card{padding:1.5rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:16px;border:1px solid hsla(0,0%,100%,.1);text-align:center;transition:all .3s ease}.food-category-card:hover{transform:translateY(-4px);background:hsla(0,0%,100%,.08);border-color:rgba(230,57,70,.3)}.food-emoji{font-size:2.5rem;display:block;margin-bottom:.75rem}.food-name{font-size:1rem;font-weight:600;color:#fff;margin-bottom:.25rem}.food-note{font-size:.75rem;color:hsla(0,0%,100%,.5)}.city-tips-section{background:hsla(0,0%,100%,.02);padding:4rem 2rem;margin:0;max-width:none}.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;max-width:1200px;margin:0 auto}.tip-card{display:flex;gap:1rem;padding:1.25rem 1.5rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:16px;border:1px solid hsla(0,0%,100%,.1);transition:all .3s ease}.tip-card:hover{background:hsla(0,0%,100%,.08);transform:translateX(4px)}.tip-number{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(230,57,70,.2);border-radius:50%;font-weight:700;font-size:.875rem;color:#e63946}.tip-text{font-size:.95rem;color:hsla(0,0%,100%,.8);line-height:1.6}.related-cities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.related-city-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:16px;border:1px solid hsla(0,0%,100%,.1);transition:all .3s ease}.related-city-card:hover{background:hsla(0,0%,100%,.1);border-color:rgba(230,57,70,.3);transform:translateY(-2px)}.related-city-emoji{font-size:2rem}.related-city-info{flex:1}.related-city-name{font-weight:600;color:#fff;margin-bottom:.125rem}.related-city-meta,.related-city-prefecture{font-size:.8rem;color:hsla(0,0%,100%,.5)}.related-city-meta{display:flex;align-items:center;gap:.5rem}.related-city-meta span:last-child{color:#e63946;font-size:1rem}.view-all-cities{text-align:center;margin-top:2rem}.view-all-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:12px;color:#fff;font-weight:500;transition:all .3s ease}.view-all-btn:hover{background:hsla(0,0%,100%,.15);border-color:rgba(230,57,70,.3)}.city-cta{padding:4rem 2rem;max-width:1200px;margin:0 auto}.city-cta-content{text-align:center;padding:4rem 3rem;background:linear-gradient(135deg,rgba(230,57,70,.15),rgba(69,123,157,.1));border-radius:32px;border:1px solid hsla(0,0%,100%,.1)}.city-cta-emoji{font-size:3rem;display:block;margin-bottom:1.5rem}.city-cta-title{font-family:var(--font-editorial),serif;font-size:2rem;color:#fff;margin-bottom:.75rem}.city-cta-subtitle{color:hsla(0,0%,100%,.7);font-size:1.125rem;max-width:500px;margin:0 auto 2rem;line-height:1.6}.city-cta-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}@media (max-width:768px){.city-detail-hero{min-height:80vh;padding:3rem 1.5rem}.city-hero-title{font-size:2.5rem}.city-hero-description{font-size:1rem}.city-hero-stats{gap:1rem}.city-hero-stat{padding:.75rem 1rem;min-width:80px}.city-hero-stat .stat-value{font-size:1.5rem}.city-hero-actions{flex-direction:column}.city-action-btn{width:100%;justify-content:center}.city-section{padding:3rem 1.5rem}.city-section .section-title{font-size:1.75rem}.best-time-card{flex-direction:column;text-align:center;gap:1rem}.seasons-grid{grid-template-columns:repeat(2,1fr)}.attractions-grid{grid-template-columns:1fr}.food-categories-grid{grid-template-columns:repeat(2,1fr)}.related-cities-grid,.tips-grid{grid-template-columns:1fr}.city-cta-content{padding:3rem 1.5rem}.city-cta-title{font-size:1.5rem}.city-cta-buttons{flex-direction:column}.city-cta-buttons .cta-primary-btn,.city-cta-buttons .cta-secondary-btn{width:100%;justify-content:center}}.profile-edit-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.profile-edit-main{padding:100px 1.5rem 4rem;max-width:700px;margin:0 auto}.profile-edit-header{text-align:center;margin-bottom:2rem}.edit-header-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(230,57,70,.15);border-radius:50px;font-size:.875rem;color:#e63946;margin-bottom:1rem}.edit-header-title{font-family:var(--font-editorial),serif;font-size:2rem;color:#fff;margin-bottom:.5rem}.edit-header-subtitle{color:hsla(0,0%,100%,.6);font-size:1rem}.profile-edit-card{background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:24px;border:1px solid hsla(0,0%,100%,.1);padding:2rem}.edit-form{display:flex;flex-direction:column;gap:1.5rem}.edit-message{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:12px;font-weight:500}.edit-message.success{background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.3);color:#22c55e}.edit-message.error{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);color:#ef4444}.edit-field{display:flex;flex-direction:column;gap:.5rem}.edit-label{font-weight:600;color:#fff;font-size:.95rem}.edit-input,.edit-textarea{width:100%;padding:.875rem 1rem;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15);border-radius:12px;color:#fff;font-size:1rem;transition:all .3s ease}.edit-input:focus,.edit-textarea:focus{outline:none;border-color:rgba(230,57,70,.5);background:hsla(0,0%,100%,.1);box-shadow:0 0 0 3px rgba(230,57,70,.1)}.edit-input::-moz-placeholder,.edit-textarea::-moz-placeholder{color:hsla(0,0%,100%,.6)}.edit-input::placeholder,.edit-textarea::placeholder{color:hsla(0,0%,100%,.6)}.edit-textarea{resize:none;min-height:120px}.edit-hint{font-size:.8rem;color:hsla(0,0%,100%,.5)}.avatar-preview-row{display:flex;gap:1.5rem;align-items:flex-start}.avatar-preview{flex-shrink:0}.avatar-preview .avatar-img{width:100px;height:100px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:3px solid hsla(0,0%,100%,.2)}.avatar-preview .avatar-placeholder{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#e63946,#c62828);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:#fff}.avatar-input-wrapper{flex:1;display:flex;flex-direction:column;gap:.5rem}.username-input-wrapper{display:flex;align-items:center;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15);border-radius:12px;transition:all .3s ease}.username-input-wrapper:focus-within{border-color:rgba(230,57,70,.5);background:hsla(0,0%,100%,.1);box-shadow:0 0 0 3px rgba(230,57,70,.1)}.username-prefix{padding:0 .75rem;color:hsla(0,0%,100%,.5);font-weight:500}.username-input{border:none;background:transparent;padding-left:0}.username-input:focus{box-shadow:none}.edit-actions{display:flex;gap:1rem;margin-top:1rem}.edit-submit-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#e63946,#c62828);color:#fff;border:none;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease}.edit-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 25px rgba(230,57,70,.4)}.edit-submit-btn:disabled{opacity:.7;cursor:not-allowed}.edit-cancel-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.5rem;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:12px;color:#fff;font-weight:500;font-size:1rem;transition:all .3s ease}.edit-cancel-btn:hover{background:hsla(0,0%,100%,.15)}.loading-spinner-small{width:18px;height:18px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff}@media (max-width:640px){.profile-edit-main{padding:90px 1rem 3rem}.profile-edit-card{padding:1.5rem}.avatar-preview-row{flex-direction:column;align-items:center}.avatar-input-wrapper{width:100%}.edit-actions{flex-direction:column}}.home-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.home-main{padding-top:80px}.home-hero{position:relative;min-height:85vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:4rem 2rem}.home-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at top,rgba(230,57,70,.2) 0,transparent 50%),radial-gradient(ellipse at bottom right,rgba(69,123,157,.15) 0,transparent 50%)}.home-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0,rgba(15,15,26,.9))}.home-hero-content{position:relative;z-index:1;max-width:900px;text-align:center}.home-hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:hsla(0,0%,100%,.1);backdrop-filter:blur(10px);border-radius:50px;border:1px solid hsla(0,0%,100%,.15);font-size:.875rem;color:hsla(0,0%,100%,.8);margin-bottom:1.5rem}.home-hero-title{font-family:var(--font-editorial),serif;font-size:clamp(2.5rem,7vw,4.5rem);color:#fff;margin-bottom:1.5rem;letter-spacing:-.02em;line-height:1.1}.home-hero-subtitle{font-size:1.125rem;color:hsla(0,0%,100%,.7);line-height:1.8;max-width:650px;margin:0 auto 2.5rem}.home-hero-stats{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:2.5rem}.home-stat{display:flex;flex-direction:column;align-items:center;padding:1rem 1.5rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:16px;border:1px solid hsla(0,0%,100%,.1);min-width:100px}.home-stat-value{font-family:var(--font-editorial),serif;font-size:1.75rem;font-weight:700;color:#fff}.home-stat-label{font-size:.75rem;color:hsla(0,0%,100%,.5);text-transform:uppercase;letter-spacing:.1em}.home-hero-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.home-action-btn{display:inline-flex;align-items:center;gap:.75rem;padding:1.1rem 2.25rem;border-radius:14px;font-weight:600;font-size:1rem;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1)}.home-action-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,hsla(0,0%,100%,.2),transparent);opacity:0;transition:opacity .4s ease}.home-action-btn:hover:before{opacity:1}.home-action-btn.primary{background:linear-gradient(135deg,#e63946,#ff6b7a 50%,#e63946);background-size:200% 200%;color:#fff;box-shadow:0 4px 15px rgba(230,57,70,.3),0 0 30px rgba(230,57,70,.2),inset 0 1px 0 hsla(0,0%,100%,.2);animation:gradientShift 3s ease infinite}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.home-action-btn.primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 30px rgba(230,57,70,.5),0 0 50px rgba(230,57,70,.3),inset 0 1px 0 hsla(0,0%,100%,.3)}.home-action-btn.secondary{background:linear-gradient(145deg,hsla(0,0%,100%,.12),hsla(0,0%,100%,.08));border:1px solid hsla(0,0%,100%,.25);color:#fff;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.home-action-btn.secondary:hover{background:linear-gradient(145deg,hsla(0,0%,100%,.18),hsla(0,0%,100%,.12));border-color:hsla(0,0%,100%,.4);transform:translateY(-3px) scale(1.02);box-shadow:0 8px 30px hsla(0,0%,100%,.15)}.home-section{padding:4rem 2rem;max-width:1200px;margin:0 auto}.home-section .section-header{text-align:center;margin-bottom:3rem}.home-section .section-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(230,57,70,.15);border-radius:50px;font-size:.875rem;color:#e63946;margin-bottom:1rem}.home-section .section-title{font-family:var(--font-editorial),serif;font-size:2.25rem;color:#fff;margin-bottom:.5rem}.home-section .section-subtitle{color:hsla(0,0%,100%,.6);font-size:1rem}.quick-actions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:800px;margin:0 auto}.quick-action-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:16px;border:1px solid hsla(0,0%,100%,.1);transition:all .3s ease}.quick-action-card:hover{background:hsla(0,0%,100%,.1);border-color:rgba(230,57,70,.3);transform:translateY(-4px)}.quick-action-card.primary{background:linear-gradient(135deg,rgba(230,57,70,.2),rgba(198,40,40,.2));border-color:rgba(230,57,70,.3)}.quick-action-icon{font-size:2rem}.quick-action-label{font-size:.875rem;font-weight:600;color:#fff;text-align:center}.home-experiences-section{background:hsla(0,0%,100%,.02);padding:4rem 2rem;margin:0;max-width:none}.experience-rings-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;max-width:1000px;margin:0 auto}.experience-ring-card{display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:20px;border:1px solid hsla(0,0%,100%,.1);transition:all .3s ease}.experience-ring-card:hover{transform:translateY(-4px);background:hsla(0,0%,100%,.08)}.experience-icon{font-size:2rem;margin-bottom:1rem}.experience-name{font-size:.9rem;font-weight:600;color:#fff;margin-top:1rem;text-align:center}.trending-cities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.trending-city-card{padding:1.5rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:20px;border:1px solid hsla(0,0%,100%,.1);transition:all .3s ease}.trending-city-card:hover{background:hsla(0,0%,100%,.1);border-color:rgba(230,57,70,.3);transform:translateY(-4px)}.city-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.city-emoji{font-size:2.5rem}.city-stories{text-align:right}.city-stories span:first-child{font-family:var(--font-editorial),serif;font-size:1.5rem;font-weight:700;color:#e63946;display:block}.city-stories span:last-child{font-size:.7rem;color:hsla(0,0%,100%,.5);text-transform:uppercase}.city-name{font-family:var(--font-editorial),serif;font-size:1.25rem;color:#fff;margin-bottom:.5rem}.city-highlight{font-size:.875rem;color:hsla(0,0%,100%,.6);margin-bottom:1rem;line-height:1.5}.city-arrow{font-size:.875rem;color:#e63946;font-weight:600}.section-cta{text-align:center;margin-top:2rem}.section-cta-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:12px;color:#fff;font-weight:500;transition:all .3s ease}.section-cta-btn:hover{background:hsla(0,0%,100%,.15);border-color:rgba(230,57,70,.3)}.home-seasonal-section{background:hsla(0,0%,100%,.02);padding:4rem 2rem;margin:0;max-width:none}.seasonal-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;max-width:1200px;margin:0 auto}.seasonal-card{padding:2rem 1.5rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:20px;border:1px solid hsla(0,0%,100%,.1);text-align:center;transition:all .3s ease}.seasonal-card:hover{transform:translateY(-4px);background:hsla(0,0%,100%,.08);border-color:rgba(230,57,70,.3)}.seasonal-emoji{font-size:2.5rem;display:block;margin-bottom:.75rem}.seasonal-name{font-family:var(--font-editorial),serif;font-size:1.25rem;color:#fff;margin-bottom:.25rem}.seasonal-months{font-size:.8rem;color:hsla(0,0%,100%,.5);margin-bottom:.75rem}.seasonal-highlight{font-size:.9rem;color:hsla(0,0%,100%,.7);margin-bottom:.75rem}.seasonal-stories{font-size:.8rem;color:#e63946;font-weight:600}.feed-nav-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.feed-nav-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem 2rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border-radius:20px;border:1px solid hsla(0,0%,100%,.1);transition:all .3s ease}.feed-nav-card:hover{background:hsla(0,0%,100%,.1);border-color:rgba(230,57,70,.3);transform:translateX(4px)}.feed-nav-icon{font-size:2.5rem}.feed-nav-content{flex:1}.feed-nav-title{font-size:1.125rem;font-weight:600;color:#fff;margin-bottom:.25rem}.feed-nav-description{font-size:.875rem;color:hsla(0,0%,100%,.6)}.feed-nav-arrow{font-size:1.5rem;color:#e63946}.home-cta{padding:4rem 2rem;max-width:1200px;margin:0 auto}.home-cta-content{text-align:center;padding:4rem 3rem;background:linear-gradient(135deg,rgba(230,57,70,.15),rgba(69,123,157,.1));border-radius:32px;border:1px solid hsla(0,0%,100%,.1)}.home-cta-emoji{font-size:3rem;display:block;margin-bottom:1.5rem}.home-cta-title{font-family:var(--font-editorial),serif;font-size:2rem;color:#fff;margin-bottom:.75rem}.home-cta-subtitle{color:hsla(0,0%,100%,.7);font-size:1.125rem;max-width:500px;margin:0 auto 2rem;line-height:1.6}.home-cta-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}@media (max-width:1024px){.experience-rings-grid,.quick-actions-grid,.seasonal-cards-grid,.trending-cities-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.home-hero{min-height:90vh;padding:3rem 1.5rem}.home-hero-title{font-size:2rem}.home-hero-subtitle{font-size:1rem}.home-hero-stats{gap:1rem}.home-stat{padding:.75rem 1rem;min-width:70px}.home-stat-value{font-size:1.25rem}.home-hero-actions{flex-direction:column}.home-action-btn{width:100%;justify-content:center}.home-section{padding:3rem 1.5rem}.home-section .section-title{font-size:1.75rem}.quick-actions-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.quick-action-card{padding:1rem}.quick-action-icon{font-size:1.5rem}.quick-action-label{font-size:.75rem}.experience-rings-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.experience-ring-card{padding:1.5rem 1rem}.trending-cities-grid{grid-template-columns:1fr}.seasonal-cards-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.seasonal-card{padding:1.5rem 1rem}.feed-nav-grid{grid-template-columns:1fr}.home-cta-content{padding:3rem 1.5rem}.home-cta-title{font-size:1.5rem}.home-cta-buttons{flex-direction:column}.home-cta-buttons .cta-primary-btn,.home-cta-buttons .cta-secondary-btn{width:100%;justify-content:center}}.create-post-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.create-post-main{max-width:900px;margin:0 auto;padding:2rem var(--app-padding);padding-top:100px}.create-post-header{text-align:center;margin-bottom:2.5rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:hsla(0,0%,100%,.6);font-size:.9rem;margin-bottom:1.5rem;transition:color .2s ease}.back-link:hover{color:hsla(0,0%,100%,.9)}.create-header-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);padding:.5rem 1rem;border-radius:2rem;font-size:.85rem;color:#e63946;margin-bottom:1rem}.create-header-title{font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700;color:#fff;margin:0 0 .75rem;font-family:"Noto Serif JP",serif}.create-header-subtitle{color:hsla(0,0%,100%,.6);font-size:1rem;margin:0}.create-post-card{background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);padding:2rem;backdrop-filter:blur(10px)}.create-form{gap:1.75rem}.create-form,.form-field{display:flex;flex-direction:column}.form-field{gap:.75rem}.form-label{font-size:.95rem;font-weight:600;color:hsla(0,0%,100%,.9);display:flex;align-items:center;gap:.25rem}.form-label .required{color:#e63946}.form-input{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius);padding:.875rem 1rem;font-size:1rem;color:#fff;transition:all .2s ease}.form-input:focus{outline:none;border-color:rgba(230,57,70,.5);background:hsla(0,0%,100%,.08);box-shadow:0 0 0 3px rgba(230,57,70,.1)}.form-input::-moz-placeholder{color:hsla(0,0%,100%,.6)}.form-input::placeholder{color:hsla(0,0%,100%,.6)}.form-textarea{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius);padding:1rem;font-size:1rem;color:#fff;resize:vertical;min-height:180px;line-height:1.6;transition:all .2s ease}.form-textarea:focus{outline:none;border-color:rgba(230,57,70,.5);background:hsla(0,0%,100%,.08);box-shadow:0 0 0 3px rgba(230,57,70,.1)}.form-textarea::-moz-placeholder{color:hsla(0,0%,100%,.6)}.form-textarea::placeholder{color:hsla(0,0%,100%,.6)}.idea-prompts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.idea-prompt-card{background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius);padding:1rem;text-align:left;cursor:pointer;transition:all .2s ease}.idea-prompt-card:hover{background:hsla(0,0%,100%,.06);border-color:rgba(230,57,70,.3);transform:translateY(-2px)}.idea-prompt-card h4{margin:0 0 .5rem;font-size:.95rem;font-weight:600;color:#fff}.idea-prompt-card p{margin:0 0 .75rem;font-size:.8rem;color:hsla(0,0%,100%,.5);line-height:1.5}.idea-tags{display:flex;flex-wrap:wrap;gap:.375rem}.idea-tags span{font-size:.7rem;color:#e63946;background:rgba(230,57,70,.1);padding:.2rem .5rem;border-radius:1rem}.emotions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.75rem}.emotion-btn{display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.75rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.emotion-btn:hover{background:hsla(0,0%,100%,.06);transform:translateY(-2px)}.emotion-btn.active{background:rgba(230,57,70,.15);border-color:rgba(230,57,70,.4)}.emotion-emoji{font-size:1.5rem}.emotion-label{font-size:.75rem;color:hsla(0,0%,100%,.7)}.emotion-btn.active .emotion-label{color:#e63946}.image-previews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;margin-bottom:1rem}.image-preview{position:relative;aspect-ratio:1;border-radius:var(--radius);overflow:hidden}.image-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.remove-image-btn{position:absolute;top:.375rem;right:.375rem;width:24px;height:24px;background:rgba(0,0,0,.7);border:none;border-radius:50%;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.remove-image-btn:hover{background:#e63946}.upload-zone{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;background:hsla(0,0%,100%,.02);border:2px dashed hsla(0,0%,100%,.1);border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.upload-zone:hover{background:hsla(0,0%,100%,.04);border-color:rgba(230,57,70,.3)}.upload-icon{font-size:2rem}.upload-text{font-size:.9rem;color:hsla(0,0%,100%,.5)}.hidden{display:none}.locations-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.location-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius)}.location-icon{font-size:1.25rem}.location-info{flex:1;display:flex;flex-direction:column;gap:.125rem}.location-name{font-size:.9rem;color:#fff;font-weight:500}.location-coords{font-size:.75rem;color:hsla(0,0%,100%,.6)}.remove-location-btn{width:28px;height:28px;background:hsla(0,0%,100%,.05);border:none;border-radius:50%;color:hsla(0,0%,100%,.5);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.remove-location-btn:hover{background:rgba(230,57,70,.2);color:#e63946}.location-buttons{display:flex;gap:.75rem;flex-wrap:wrap}.location-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.location-btn.primary{background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);color:#e63946}.location-btn.primary:hover:not(:disabled){background:rgba(230,57,70,.25)}.location-btn.primary:disabled{opacity:.6;cursor:not-allowed}.location-btn.secondary{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);color:hsla(0,0%,100%,.8)}.location-btn.secondary:hover{background:hsla(0,0%,100%,.1)}.loading-spinner-small{width:16px;height:16px;border:2px solid hsla(0,0%,100%,.2);border-top-color:currentcolor;border-radius:50%;animation:spin .8s linear infinite}.error-message{background:rgba(230,57,70,.1);border:1px solid rgba(230,57,70,.3);border-radius:var(--radius);padding:.75rem 1rem;color:#e63946;font-size:.9rem}.form-actions{display:flex;gap:1rem;padding-top:.5rem}.submit-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,#e63946,#d62839);border:none;border-radius:var(--radius);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;flex:1}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px -8px rgba(230,57,70,.5)}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.cancel-btn{padding:.875rem 1.5rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius);color:hsla(0,0%,100%,.7);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-btn:hover{background:hsla(0,0%,100%,.1);color:#fff}.map-picker-modal{position:fixed;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.map-picker-content{width:100%;max-width:800px;max-height:90vh;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.map-picker-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid hsla(0,0%,100%,.08)}.map-picker-header h3{margin:0;font-size:1.1rem;color:#fff}.close-btn{width:32px;height:32px;background:hsla(0,0%,100%,.05);border:none;border-radius:50%;color:hsla(0,0%,100%,.6);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:hover{background:hsla(0,0%,100%,.1);color:#fff}.map-picker-body{flex:1;height:500px}@media (max-width:768px){.create-post-main{padding-top:80px}.create-post-card{padding:1.25rem}.idea-prompts-grid{grid-template-columns:1fr}.emotions-grid{grid-template-columns:repeat(4,1fr)}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%;justify-content:center}.location-buttons{flex-direction:column}.location-btn{width:100%;justify-content:center}}@media (max-width:480px){.emotions-grid{grid-template-columns:repeat(2,1fr)}.image-previews-grid{grid-template-columns:repeat(3,1fr)}}.map-page-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.map-page-main{max-width:1200px;margin:0 auto;padding:2rem var(--app-padding);padding-top:100px}.map-loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;color:hsla(0,0%,100%,.6)}.map-hero-section{text-align:center;margin-bottom:2.5rem}.map-hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);padding:.5rem 1rem;border-radius:2rem;font-size:.85rem;color:#e63946;margin-bottom:1rem}.map-hero-title{font-size:clamp(2rem,5vw,3rem);font-weight:700;color:#fff;margin:0 0 .75rem;font-family:"Noto Serif JP",serif}.map-hero-subtitle{color:hsla(0,0%,100%,.6);font-size:1.1rem;max-width:600px;margin:0 auto 2rem}.map-hero-stats{justify-content:center;gap:1.5rem;flex-wrap:wrap;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);padding:1.25rem 2rem;backdrop-filter:blur(10px)}.map-hero-stat,.map-hero-stats{display:flex;align-items:center}.map-hero-stat{flex-direction:column;gap:.25rem}.map-hero-stat .stat-value{font-size:1.75rem;font-weight:700;color:#fff}.map-hero-stat .stat-label{font-size:.8rem;color:hsla(0,0%,100%,.5);text-transform:uppercase;letter-spacing:.5px}.stat-divider{width:1px;height:40px;background:hsla(0,0%,100%,.1)}.map-container-card{background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:2rem}.map-card-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid hsla(0,0%,100%,.08)}.map-card-title{display:flex;align-items:center;gap:.75rem}.map-card-title .map-icon{font-size:1.5rem}.map-card-title h2{margin:0;font-size:1.25rem;font-weight:600;color:#fff}.map-card-title p{margin:0;font-size:.85rem;color:hsla(0,0%,100%,.5)}.map-status{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:2rem;font-size:.8rem;font-weight:500}.map-status.live{background:rgba(46,204,113,.15);color:#2ecc71}.map-status.syncing{background:rgba(241,196,15,.15);color:#f1c40f}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.map-visual{height:450px;position:relative}.map-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:hsla(0,0%,100%,.5)}.map-content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.map-content-card{background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);padding:1.5rem}.card-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem}.card-icon{font-size:1.5rem}.card-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#fff}.card-header p{margin:0;font-size:.85rem;color:hsla(0,0%,100%,.5)}.visited-places-list{display:flex;flex-direction:column;gap:.5rem}.visited-place-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:hsla(0,0%,100%,.02);border:1px solid hsla(0,0%,100%,.05);border-radius:var(--radius);transition:all .2s ease}.visited-place-item:hover{background:hsla(0,0%,100%,.05);border-color:rgba(230,57,70,.3)}.place-number{width:24px;height:24px;background:rgba(230,57,70,.15);font-size:.75rem}.place-info{flex:1;gap:.125rem}.place-name{font-size:.9rem;color:#fff;font-weight:500}.place-region{font-size:.75rem;color:hsla(0,0%,100%,.6)}.place-arrow{color:hsla(0,0%,100%,.3);font-size:.9rem;transition:color .2s ease}.visited-place-item:hover .place-arrow{color:#e63946}.view-more-places{text-align:center;padding:.75rem;font-size:.85rem;color:hsla(0,0%,100%,.5)}.empty-places-state{text-align:center;padding:1.5rem 1rem}.empty-icon{font-size:3rem}.empty-places-state h4{margin:0 0 .5rem;font-size:1.1rem;color:#fff}.empty-places-state p{margin:0 0 1.25rem;font-size:.9rem;color:hsla(0,0%,100%,.5)}.add-location-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,#e63946,#d62839);border-radius:var(--radius);color:#fff;font-size:.9rem;font-weight:500;transition:all .2s ease}.add-location-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px -8px rgba(230,57,70,.5)}.routes-list{display:flex;flex-direction:column;gap:.75rem}.route-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:hsla(0,0%,100%,.02);border:1px solid hsla(0,0%,100%,.05);border-radius:var(--radius);transition:all .2s ease}.route-item:hover{background:hsla(0,0%,100%,.05)}.route-icon{font-size:1.5rem}.route-info{flex:1}.route-info h4{margin:0;font-size:.9rem;color:#fff;font-weight:500}.route-info p{margin:0;font-size:.75rem;color:hsla(0,0%,100%,.6)}.route-duration{font-size:.75rem;color:#e63946;background:rgba(230,57,70,.1);padding:.25rem .5rem;border-radius:1rem}.tips-list{flex-direction:column}.tip-item,.tips-list{display:flex;gap:.75rem}.tip-item{align-items:flex-start;padding:.5rem 0}.tip-icon{font-size:1.1rem}.tip-text{font-size:.9rem;color:hsla(0,0%,100%,.7);line-height:1.5}.map-cta-section{margin-top:2rem}.map-cta-content{text-align:center;padding:3rem 2rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-xl)}.map-cta-content .cta-emoji{font-size:2.5rem;display:block;margin-bottom:1rem}.map-cta-content h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:#fff}.map-cta-content p{margin:0 0 1.5rem;font-size:1rem;color:hsla(0,0%,100%,.6)}.map-cta-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.cta-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:var(--radius);font-size:.95rem;font-weight:600;transition:all .2s ease}.cta-btn.primary{background:linear-gradient(135deg,#e63946,#d62839);color:#fff}.cta-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px -8px rgba(230,57,70,.5)}.cta-btn.secondary{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);color:hsla(0,0%,100%,.8)}.cta-btn.secondary:hover{background:hsla(0,0%,100%,.1);color:#fff}@media (max-width:768px){.map-page-main{padding-top:80px}.map-hero-stats{padding:1rem;gap:1rem}.map-hero-stat .stat-value{font-size:1.5rem}.stat-divider{display:none}.map-visual{height:350px}.map-content-grid{grid-template-columns:1fr}.map-cta-buttons{flex-direction:column}.cta-btn{width:100%;justify-content:center}}.following-page-container,.food-page-container,.my-posts-container,.saved-page-container,.settings-page-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.following-page-main,.food-page-main,.my-posts-main,.saved-page-main,.settings-page-main{max-width:800px;margin:0 auto;padding:2rem var(--app-padding);padding-top:100px}.following-loading,.my-posts-loading,.saved-loading,.settings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;color:hsla(0,0%,100%,.6)}.following-header,.food-header,.my-posts-header,.saved-header,.settings-header{text-align:center;margin-bottom:2.5rem}.following-badge,.food-badge,.my-posts-badge,.saved-badge,.settings-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);padding:.5rem 1rem;border-radius:2rem;font-size:.85rem;color:#e63946;margin-bottom:1rem}.following-title,.food-title,.my-posts-title,.saved-title,.settings-title{font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700;color:#fff;margin:0 0 .75rem;font-family:"Noto Serif JP",serif}.following-subtitle,.food-subtitle,.my-posts-subtitle,.saved-subtitle,.settings-subtitle{color:hsla(0,0%,100%,.6);font-size:1rem;margin:0}.following-stats,.my-posts-stats,.saved-stats{display:inline-flex;align-items:center;gap:1.5rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);padding:1rem 2rem;margin-top:1.5rem}.following-stat,.my-posts-stat,.saved-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.following-stat .stat-value,.my-posts-stat .stat-value,.saved-stat .stat-value{font-size:1.5rem;font-weight:700;color:#fff}.following-stat .stat-label,.my-posts-stat .stat-label,.saved-stat .stat-label{font-size:.8rem;color:hsla(0,0%,100%,.5);text-transform:uppercase}.settings-content{display:flex;flex-direction:column;gap:1.5rem}.settings-card{background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);padding:1.5rem}.settings-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid hsla(0,0%,100%,.05)}.settings-card-icon{font-size:1.5rem}.settings-card-header h2{margin:0;font-size:1.1rem;font-weight:600;color:#fff}.settings-card-header p{margin:0;font-size:.85rem;color:hsla(0,0%,100%,.5)}.settings-list{display:flex;flex-direction:column;gap:.5rem}.setting-toggle-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:var(--radius);transition:background .2s ease}.setting-toggle-item:hover{background:hsla(0,0%,100%,.02)}.toggle-info{display:flex;flex-direction:column;gap:.125rem}.toggle-label{font-size:.9rem;color:#fff;font-weight:500}.toggle-desc{font-size:.75rem;color:hsla(0,0%,100%,.5)}.toggle-switch{width:44px;height:24px;background:hsla(0,0%,100%,.15);border:none;border-radius:12px;cursor:pointer}.toggle-switch.active{background:#e63946}.toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s ease}.toggle-switch.active .toggle-knob{transform:translateX(20px)}.account-actions{display:flex;flex-direction:column;gap:.5rem}.account-action-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:hsla(0,0%,100%,.02);border:1px solid hsla(0,0%,100%,.05);border-radius:var(--radius);cursor:pointer;transition:all .2s ease;width:100%;text-align:left}.account-action-item:hover{background:hsla(0,0%,100%,.05);border-color:hsla(0,0%,100%,.1)}.account-action-item.danger{background:rgba(230,57,70,.05);border-color:rgba(230,57,70,.15)}.account-action-item.danger:hover{background:rgba(230,57,70,.1);border-color:rgba(230,57,70,.3)}.action-icon{font-size:1.25rem}.action-info{flex:1;display:flex;flex-direction:column;gap:.125rem}.action-label{font-size:.9rem;color:#fff;font-weight:500}.account-action-item.danger .action-label{color:#e63946}.action-desc{font-size:.75rem;color:hsla(0,0%,100%,.5)}.action-arrow{color:hsla(0,0%,100%,.3);font-size:.9rem}.preference-summary{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid hsla(0,0%,100%,.05)}.preference-summary h3{margin:0 0 1rem;font-size:.95rem;font-weight:600;color:hsla(0,0%,100%,.7);text-transform:uppercase;letter-spacing:.5px}.preference-items{display:flex;flex-direction:column;gap:.75rem}.preference-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.pref-label{color:hsla(0,0%,100%,.6)}.pref-label,.pref-value{font-size:.85rem;font-weight:500}.pref-value{color:#fff;text-align:right;text-transform:capitalize}.settings-actions{display:flex;flex-direction:column;align-items:center;gap:1rem}.save-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:rgba(46,204,113,.15);border:1px solid rgba(46,204,113,.3);border-radius:var(--radius);color:#2ecc71;font-size:.9rem}.action-buttons{display:flex;gap:1rem;width:100%}.save-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,#e63946,#d62839);border:none;border-radius:var(--radius);color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.save-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px -8px rgba(230,57,70,.5)}.cancel-link{display:flex;align-items:center;justify-content:center;padding:.875rem 1.5rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius);color:hsla(0,0%,100%,.7);font-size:1rem;font-weight:500;transition:all .2s ease}.cancel-link:hover{background:hsla(0,0%,100%,.1);color:#fff}.following-content,.my-posts-content,.saved-content{margin-top:2rem}.following-loading-state,.my-posts-loading-state,.saved-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem;color:hsla(0,0%,100%,.5)}.following-empty-state,.my-posts-empty-state,.saved-empty-state{text-align:center;padding:3rem 2rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg)}.following-empty-state .empty-icon,.my-posts-empty-state .empty-icon,.saved-empty-state .empty-icon{font-size:4rem;display:block;margin-bottom:1rem}.following-empty-state h3,.my-posts-empty-state h3,.saved-empty-state h3{margin:0 0 .5rem;font-size:1.25rem;color:#fff}.following-empty-state p,.my-posts-empty-state p,.saved-empty-state p{margin:0 0 1.5rem;color:hsla(0,0%,100%,.5)}.create-btn,.discover-btn,.explore-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,#e63946,#d62839);border-radius:var(--radius);color:#fff;font-size:.9rem;font-weight:500;transition:all .2s ease}.create-btn:hover,.discover-btn:hover,.explore-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px -8px rgba(230,57,70,.5)}.new-post-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#e63946,#d62839);border-radius:var(--radius);color:#fff;font-size:.95rem;font-weight:600;margin-top:1.5rem;transition:all .2s ease}.new-post-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px -8px rgba(230,57,70,.5)}.my-posts-grid,.saved-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.my-post-card,.saved-card{background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s ease}.my-post-card:hover,.saved-card:hover{border-color:rgba(230,57,70,.3);transform:translateY(-4px)}.my-post-image,.saved-card-image{position:relative;aspect-ratio:16/10;overflow:hidden}.my-post-image img,.saved-card-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.my-post-placeholder,.saved-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.02);font-size:3rem}.unsave-btn{position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;background:rgba(0,0,0,.5);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease}.unsave-btn:hover{background:#e63946}.my-post-overlay{position:absolute;bottom:0;left:0;right:0;padding:.5rem .75rem;background:linear-gradient(transparent,rgba(0,0,0,.6))}.post-stats{font-size:.8rem;color:#fff}.my-post-content,.saved-card-content{padding:1rem}.my-post-content h4,.saved-card-content h4{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#fff}.my-post-content p,.saved-card-content p{margin:0 0 .75rem;font-size:.85rem;color:hsla(0,0%,100%,.6);line-height:1.5}.saved-card-meta{display:flex;justify-content:space-between}.post-date,.saved-card-meta{font-size:.75rem;color:hsla(0,0%,100%,.6)}.my-post-actions{display:flex;border-top:1px solid hsla(0,0%,100%,.05)}.delete-btn,.edit-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.75rem;background:transparent;border:none;color:hsla(0,0%,100%,.6);font-size:.85rem;cursor:pointer;transition:all .2s ease}.edit-btn:hover{background:hsla(0,0%,100%,.05);color:#fff}.delete-btn:hover{background:rgba(230,57,70,.1);color:#e63946}.following-posts-list{display:flex;flex-direction:column;gap:1rem}.following-post-card{display:flex;gap:1rem;padding:1rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);transition:all .2s ease}.following-post-card:hover{border-color:rgba(230,57,70,.3);background:hsla(0,0%,100%,.05)}.following-post-card .post-image{width:120px;height:90px;border-radius:var(--radius);overflow:hidden;flex-shrink:0}.following-post-card .post-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.following-post-card .post-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.02);font-size:2rem}.following-post-card .post-content{flex:1;min-width:0}.post-author{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.author-avatar{width:24px;height:24px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.author-avatar-placeholder{width:24px;height:24px;border-radius:50%;background:rgba(230,57,70,.2);color:#e63946;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600}.post-author span{font-size:.8rem;color:hsla(0,0%,100%,.6)}.following-post-card .post-content h4{margin:0 0 .375rem;font-size:.95rem;font-weight:600;color:#fff}.following-post-card .post-content p{margin:0 0 .5rem;font-size:.8rem;color:hsla(0,0%,100%,.5);line-height:1.4}.post-meta{display:flex;gap:1rem;font-size:.75rem;color:hsla(0,0%,100%,.6)}.post-likes{color:#e63946}@media (max-width:768px){.following-page-main,.food-page-main,.my-posts-main,.saved-page-main,.settings-page-main{padding-top:80px}.action-buttons{flex-direction:column}.my-posts-grid,.saved-grid{grid-template-columns:1fr}.following-post-card{flex-direction:column}.following-post-card .post-image{width:100%;height:150px}}.feed-layout-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.feed-layout-main{max-width:800px;margin:0 auto;padding:2rem var(--app-padding);padding-top:100px}.feed-layout-header{text-align:center;margin-bottom:2rem}.feed-layout-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);padding:.5rem 1rem;border-radius:2rem;font-size:.85rem;color:#e63946;margin-bottom:1rem}.feed-layout-title{font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700;color:#fff;margin:0 0 .75rem;font-family:"Noto Serif JP",serif}.feed-layout-subtitle{color:hsla(0,0%,100%,.6);font-size:1rem;margin:0}.feed-layout-tabs{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.feed-tab-btn{display:flex;align-items:center;gap:.75rem;padding:1rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius-lg);transition:all .2s ease}.feed-tab-btn:hover{background:hsla(0,0%,100%,.05);border-color:hsla(0,0%,100%,.15)}.feed-tab-btn.active{background:rgba(230,57,70,.1);border-color:rgba(230,57,70,.3)}.feed-tab-btn .tab-icon{font-size:1.5rem}.feed-tab-btn .tab-text{display:flex;flex-direction:column;gap:.125rem;text-align:left}.feed-tab-btn .tab-name{font-size:.95rem;font-weight:600;color:#fff}.feed-tab-btn .tab-desc{font-size:.75rem;color:hsla(0,0%,100%,.5)}.feed-tab-btn.active .tab-name{color:#e63946}.feed-layout-content{margin-top:1rem}.food-content{gap:1.5rem}.food-card{border-radius:var(--radius-lg)}.food-card-header{padding-bottom:1rem;border-bottom:1px solid hsla(0,0%,100%,.05)}.food-card-header .food-icon{font-size:1.5rem}.food-card-header h2{font-size:1.1rem}.food-description{line-height:1.6;margin-bottom:1rem}.food-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.food-meta-item{display:flex;flex-direction:column;gap:.25rem}.food-meta-item .label{font-size:.75rem;color:hsla(0,0%,100%,.5);text-transform:uppercase;letter-spacing:.5px}.food-meta-item .value{font-size:.9rem;color:hsla(0,0%,100%,.8)}.food-places-list{display:flex;flex-direction:column;gap:.75rem}.food-place-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background:hsla(0,0%,100%,.02);border-radius:var(--radius)}.food-place-item .place-icon{font-size:1.25rem}.food-place-item .place-info h3{margin:0 0 .25rem;font-size:.9rem;color:#fff;font-weight:500}.food-place-item .place-info p{margin:0;font-size:.8rem;color:hsla(0,0%,100%,.5)}.food-list{display:flex;flex-direction:column;gap:.5rem}.food-list-item{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem 0;color:hsla(0,0%,100%,.7);font-size:.9rem;line-height:1.5}.food-list-item .bullet{color:#e63946;font-weight:600}.food-tags{display:flex;flex-wrap:wrap;gap:.5rem}.food-tag{padding:.375rem .75rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.08);border-radius:2rem;font-size:.8rem;color:hsla(0,0%,100%,.7)}.food-pairing-tag{padding:.5rem 1rem;background:rgba(241,196,15,.1);border:1px solid rgba(241,196,15,.2);border-radius:var(--radius);font-size:.85rem;color:hsla(0,0%,100%,.8)}.food-etiquette-card{background:rgba(230,57,70,.05);border-color:rgba(230,57,70,.15)}.food-etiquette-card h2{color:#e63946}.food-etiquette-list{display:flex;flex-direction:column;gap:.75rem}.food-etiquette-item{display:flex;align-items:flex-start;gap:.75rem;color:hsla(0,0%,100%,.7);font-size:.9rem;line-height:1.5}.food-etiquette-item .check{color:#e63946;font-weight:600}.food-cta-card{text-align:center;padding:2rem}.food-cta-card h3{margin:0 0 .5rem;font-size:1.1rem;color:#fff}.food-cta-card p{margin:0 0 1.25rem;font-size:.9rem;color:hsla(0,0%,100%,.5)}.food-cta-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#e63946,#d62839);border-radius:var(--radius);color:#fff;font-size:.9rem;font-weight:500;transition:all .2s ease}.food-cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px -8px rgba(230,57,70,.5)}@media (max-width:768px){.feed-layout-main{padding-top:80px}.feed-layout-tabs,.food-meta-grid{grid-template-columns:1fr}}.followers-page-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.followers-page-main{max-width:800px;margin:0 auto;padding:100px 1.5rem 3rem}.followers-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:hsla(0,0%,100%,.6)}.followers-header{margin-bottom:2rem}.followers-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(230,57,70,.1);border:1px solid rgba(230,57,70,.3);border-radius:999px;font-size:.85rem;color:#e63946;margin-bottom:1rem}.followers-title{font-size:clamp(2rem,5vw,2.75rem);font-weight:700;color:#fff;margin:0 0 .5rem;line-height:1.2}.followers-subtitle{font-size:1rem;color:hsla(0,0%,100%,.6);margin:0;line-height:1.5}.followers-stats{display:flex;gap:2rem;margin-top:1.5rem;padding:1.25rem 1.5rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius);backdrop-filter:blur(10px)}.followers-stat{display:flex;flex-direction:column;gap:.25rem}.followers-stat .stat-value{font-size:1.75rem;font-weight:700;color:#e63946}.followers-stat .stat-label{font-size:.85rem;color:hsla(0,0%,100%,.5);text-transform:uppercase;letter-spacing:.05em}.followers-content{display:flex;flex-direction:column;gap:1rem}.followers-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:hsla(0,0%,100%,.6)}.followers-empty-state,.followers-loading-state{padding:4rem 2rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius)}.followers-empty-state{text-align:center}.followers-empty-state .empty-icon{font-size:4rem;display:block;margin-bottom:1rem}.followers-empty-state h3{font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 .75rem}.followers-empty-state p{font-size:1rem;color:hsla(0,0%,100%,.6);max-width:350px;margin:0 auto 1.5rem}.followers-list{display:flex;flex-direction:column;gap:.75rem}.follower-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius);transition:all .2s ease}.follower-card:hover{background:hsla(0,0%,100%,.05);border-color:rgba(230,57,70,.3);transform:translateX(4px)}.follower-avatar{flex-shrink:0}.follower-avatar .avatar-image{-o-object-fit:cover;object-fit:cover}.follower-avatar .avatar-image,.follower-avatar .avatar-placeholder{width:56px;height:56px;border-radius:50%;border:2px solid rgba(230,57,70,.3)}.follower-avatar .avatar-placeholder{background:linear-gradient(135deg,rgba(230,57,70,.2),rgba(230,57,70,.1));display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;color:#e63946}.follower-info{flex:1;min-width:0}.follower-name-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.follower-name{font-weight:600;color:#fff;font-size:1rem}.verified-badge{font-size:.7rem;padding:.2rem .5rem;background:linear-gradient(135deg,rgba(230,57,70,.2),rgba(230,57,70,.1));border:1px solid rgba(230,57,70,.3);border-radius:999px;color:#e63946}.follower-username{font-size:.85rem;color:hsla(0,0%,100%,.5);display:block;margin-top:.15rem}.follower-bio{font-size:.85rem;color:hsla(0,0%,100%,.6);margin:.5rem 0 0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.follower-meta{text-align:right;flex-shrink:0}.follow-date{font-size:.8rem;color:hsla(0,0%,100%,.6);display:block}.follower-location{display:flex;align-items:center;gap:.25rem;font-size:.8rem;color:hsla(0,0%,100%,.5);margin-top:.25rem;justify-content:flex-end}.food-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;padding:2rem}.food-not-found .not-found-icon{font-size:4rem;margin-bottom:1rem}.food-not-found h1{font-size:1.5rem;color:#fff;margin:0 0 .5rem}.food-not-found p{color:hsla(0,0%,100%,.6);margin:0 0 1.5rem}.food-not-found .back-home-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#e63946,#d62839);border-radius:var(--radius);color:#fff;font-weight:500;transition:all .2s ease}.food-not-found .back-home-btn:hover{transform:translateY(-2px)}.food-header{margin-bottom:2rem}.food-hero{display:flex;align-items:center;gap:1.5rem;margin-top:1.5rem}.food-emoji{font-size:5rem;line-height:1}.food-hero-info{flex:1}.food-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:rgba(230,57,70,.1);border:1px solid rgba(230,57,70,.3);border-radius:999px;font-size:.8rem;color:#e63946;margin-bottom:.75rem}.food-title{font-size:clamp(2rem,5vw,3rem);font-weight:700;color:#fff;margin:0 0 .5rem;line-height:1.1}.food-origin{font-size:.95rem;color:hsla(0,0%,100%,.6);margin:0;line-height:1.4}.food-content{display:flex;flex-direction:column;gap:1.25rem}.food-card{background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius);padding:1.5rem;transition:all .2s ease}.food-card:hover{background:hsla(0,0%,100%,.05);border-color:hsla(0,0%,100%,.12)}.food-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.food-card-header .card-icon{font-size:1.5rem}.food-card-header h2{font-size:1.25rem;font-weight:600;color:#fff;margin:0}.food-description{font-size:.95rem;color:hsla(0,0%,100%,.7);line-height:1.7;margin:0 0 1.25rem}.food-details{gap:1rem;padding-top:1rem;border-top:1px solid hsla(0,0%,100%,.08)}.food-detail-item,.food-details{display:flex;flex-direction:column}.food-detail-item{gap:.25rem}.food-detail-item .detail-label{font-size:.8rem;color:hsla(0,0%,100%,.5);text-transform:uppercase;letter-spacing:.05em}.food-detail-item .detail-value{font-size:.95rem;color:hsla(0,0%,100%,.8);line-height:1.5}.food-detail-item .detail-value.price{color:#e63946;font-weight:600}.places-list{display:flex;flex-direction:column;gap:.75rem}.place-item{display:flex;align-items:flex-start;gap:1rem;padding:.75rem;background:hsla(0,0%,100%,.03);border-radius:calc(var(--radius) - 4px);transition:all .2s ease}.place-item:hover{background:hsla(0,0%,100%,.05)}.place-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(230,57,70,.2),rgba(230,57,70,.1));border:1px solid rgba(230,57,70,.3);border-radius:50%;font-size:.85rem;font-weight:600;color:#e63946;flex-shrink:0}.place-info{display:flex;flex-direction:column;gap:.2rem}.place-city{font-weight:600;color:#fff;font-size:.95rem}.place-spot{font-size:.85rem;color:hsla(0,0%,100%,.6);line-height:1.4}.variations-list{display:flex;flex-direction:column;gap:.6rem}.variation-item{display:flex;align-items:flex-start;gap:.75rem}.variation-bullet{color:#e63946;font-weight:700;font-size:1.2rem;line-height:1.3}.variation-text{font-size:.95rem;color:hsla(0,0%,100%,.7);line-height:1.5}.food-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.tags-container{display:flex;flex-wrap:wrap;gap:.5rem}.food-tag{padding:.4rem .75rem;border-radius:999px;font-size:.85rem;transition:all .2s ease}.food-tag.ingredient{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);color:hsla(0,0%,100%,.7)}.food-tag.ingredient:hover{border-color:rgba(230,57,70,.3);color:#fff}.food-tag.pairing{background:rgba(230,57,70,.1);border:1px solid rgba(230,57,70,.2);color:#e63946}.food-tag.pairing:hover{background:rgba(230,57,70,.15)}.etiquette-card{background:linear-gradient(135deg,rgba(230,57,70,.05),rgba(230,57,70,.02));border-color:rgba(230,57,70,.2)}.etiquette-list{display:flex;flex-direction:column;gap:.75rem}.etiquette-item{display:flex;align-items:flex-start;gap:.75rem}.etiquette-check{color:#e63946;font-weight:700;font-size:1rem;margin-top:.1rem}.etiquette-text{font-size:.95rem;color:hsla(0,0%,100%,.7);line-height:1.5}.food-cta{text-align:center;padding:2.5rem 2rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius)}.food-cta .cta-emoji{font-size:2.5rem;display:block;margin-bottom:1rem}.food-cta h3{font-size:1.25rem;font-weight:600;color:#fff;margin:0 0 .5rem}.food-cta p{font-size:.95rem;color:hsla(0,0%,100%,.6);margin:0 0 1.5rem}.food-cta .create-post-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#e63946,#d62839);border-radius:var(--radius);color:#fff;font-weight:500;transition:all .2s ease}.food-cta .create-post-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px -8px rgba(230,57,70,.5)}@media (max-width:768px){.followers-page-main{padding-top:80px}.follower-card{flex-direction:column;align-items:flex-start;gap:.75rem}.follower-meta{text-align:left;display:flex;gap:1rem;align-items:center;width:100%;padding-top:.75rem;border-top:1px solid hsla(0,0%,100%,.08)}.follower-location{justify-content:flex-start;margin-top:0}.food-page-main{padding-top:80px}.food-hero{flex-direction:column;align-items:flex-start;text-align:left}.food-emoji{font-size:4rem}.food-grid{grid-template-columns:1fr}}.feed-stories-section{margin-bottom:1.5rem}.stories-section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:0 .5rem}.stories-icon{font-size:1.25rem}.stories-title{font-size:.95rem;font-weight:600;color:#fff}.stories-container{position:relative;display:flex;align-items:center;padding:1rem;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius);overflow:hidden}.stories-row{display:flex;gap:1rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth;padding:.5rem 0;flex:1}.stories-row::-webkit-scrollbar{display:none}.stories-scroll-btn{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);color:#fff;font-size:1.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all .2s ease;backdrop-filter:blur(10px)}.stories-scroll-btn:hover{background:hsla(0,0%,100%,.2);transform:translateY(-50%) scale(1.1)}.stories-scroll-btn.left{left:.5rem}.stories-scroll-btn.right{right:.5rem}.story-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;padding:0;min-width:72px;transition:transform .2s ease}.story-item:hover{transform:scale(1.05)}.story-avatar-wrapper{position:relative;width:64px;height:64px;border-radius:50%;padding:3px;background:linear-gradient(135deg,#e63946,#ff6b6b,#feca57,#e63946);background-size:300% 300%;animation:gradient-rotate 3s ease infinite}.story-avatar-wrapper.viewed{background:hsla(0,0%,100%,.2);animation:none}.story-avatar-wrapper.add{background:hsla(0,0%,100%,.1);border:2px dashed hsla(0,0%,100%,.3);animation:none}@keyframes gradient-rotate{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.story-avatar{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center;overflow:hidden;border:3px solid #0f0f1a}.story-avatar .avatar-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.story-avatar .avatar-initial{font-size:1.25rem;font-weight:600;color:#e63946}.story-avatar.add-avatar{background:rgba(230,57,70,.1);border-color:transparent}.story-avatar.add-avatar span{font-size:1.5rem;color:#e63946;font-weight:300}.story-username{font-size:.7rem;color:hsla(0,0%,100%,.7);text-align:center;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.story-viewer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem}.story-viewer{position:relative;width:100%;max-width:420px;height:90vh;max-height:750px;border-radius:16px;overflow:hidden;background:#000;box-shadow:0 25px 50px -12px rgba(0,0,0,.5)}.story-progress-container{position:absolute;top:0;left:0;right:0;display:flex;gap:4px;padding:12px 12px 8px;z-index:20;background:linear-gradient(180deg,rgba(0,0,0,.5),transparent)}.story-progress-bar{flex:1;height:3px;background:hsla(0,0%,100%,.3);border-radius:2px;overflow:hidden}.story-progress-fill{height:100%;background:#fff;border-radius:2px;transition:width .1s linear}.story-header{position:absolute;top:24px;left:0;right:0;justify-content:space-between;padding:0 12px;z-index:20}.story-header,.story-user-info{display:flex;align-items:center}.story-user-info{gap:10px}.story-viewer-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,rgba(230,57,70,.3),rgba(230,57,70,.1));border:2px solid hsla(0,0%,100%,.3);display:flex;align-items:center;justify-content:center;overflow:hidden}.story-viewer-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.story-viewer-avatar span{font-size:.9rem;font-weight:600;color:#fff}.story-user-details{display:flex;flex-direction:column}.story-viewer-username{font-size:.85rem;font-weight:600;color:#fff}.story-location{font-size:.75rem;color:hsla(0,0%,100%,.7);display:flex;align-items:center;gap:4px}.story-close-btn{width:32px;height:32px;border-radius:50%;background:hsla(0,0%,100%,.1);border:none;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.story-close-btn:hover{background:hsla(0,0%,100%,.2);transform:scale(1.1)}.story-content{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center}.story-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.story-caption{position:absolute;bottom:0;left:0;right:0;padding:60px 16px 24px;background:linear-gradient(0deg,rgba(0,0,0,.8),transparent)}.story-caption p{color:#fff;font-size:.95rem;line-height:1.5;text-shadow:0 1px 3px rgba(0,0,0,.5)}.story-nav-next,.story-nav-prev{position:absolute;top:80px;bottom:100px;width:30%;cursor:pointer;z-index:15}.story-nav-prev{left:0}.story-nav-next{right:0}.feed-loading{gap:1rem;color:hsla(0,0%,100%,.6)}.feed-empty,.feed-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem}.feed-empty{text-align:center;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--radius)}.feed-empty .empty-illustration{font-size:4rem;margin-bottom:1rem}.feed-empty h3{font-size:1.25rem;color:#fff;margin:0 0 .5rem}.feed-empty p{font-size:.95rem;color:hsla(0,0%,100%,.6);margin:0 0 1.5rem}.feed-posts{display:flex;flex-direction:column;gap:1rem}.feed-load-more{display:flex;justify-content:center;padding:1.5rem}.feed-load-more .btn{padding:.75rem 2rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius);color:#fff;cursor:pointer;transition:all .2s ease}.feed-load-more .btn:hover{background:hsla(0,0%,100%,.1);border-color:rgba(230,57,70,.3)}.feed-load-more .btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.stories-container{padding:.75rem}.stories-scroll-btn{display:none}.story-avatar-wrapper{width:56px;height:56px}.story-item{min-width:64px}.story-viewer{max-width:100%;height:100vh;max-height:none;border-radius:0}}.travel-blog-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.travel-blog-main{max-width:1000px;margin:0 auto;padding:90px 1.5rem 60px}.travel-blog-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;color:hsla(0,0%,100%,.6)}.travel-blog-hero{text-align:center;padding:2rem 0 2.5rem}.travel-blog-hero .hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);border-radius:50px;color:#ff6b6b;font-size:.85rem;font-weight:500;margin-bottom:1rem}.travel-blog-hero .hero-title{font-family:"Noto Serif JP",serif;font-size:clamp(2rem,5vw,3rem);font-weight:600;color:#fff;margin:0 0 .75rem;line-height:1.2}.travel-blog-hero .hero-subtitle{font-size:1.05rem;color:hsla(0,0%,100%,.6);max-width:500px;margin:0 auto;line-height:1.6}.travel-blog-tabs{display:flex;align-items:center;gap:.75rem;padding:1rem 0;border-bottom:1px solid hsla(0,0%,100%,.08);flex-wrap:wrap}.travel-blog-tabs .tab-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:50px;color:hsla(0,0%,100%,.7);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease}.travel-blog-tabs .tab-btn:hover{background:hsla(0,0%,100%,.08);color:#fff}.travel-blog-tabs .tab-btn.active{background:rgba(230,57,70,.2);border-color:rgba(230,57,70,.4);color:#ff6b6b}.travel-blog-tabs .create-story-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#e63946,#ff6b6b);border:none;border-radius:50px;color:#fff;font-size:.9rem;font-weight:500;margin-left:auto;transition:all .3s ease}.travel-blog-tabs .create-story-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(230,57,70,.4)}.travel-blog-actions{display:flex;justify-content:center;padding:1.5rem 0;border-bottom:1px solid hsla(0,0%,100%,.08)}.travel-blog-actions .create-story-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 2rem;background:linear-gradient(135deg,#e63946,#ff6b6b);border:none;border-radius:50px;color:#fff;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s ease}.travel-blog-actions .create-story-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(230,57,70,.4)}.travel-blog-stories{padding:1.25rem 0;border-bottom:1px solid hsla(0,0%,100%,.08)}.travel-blog-stories .stories-header{margin-bottom:.75rem}.travel-blog-stories .stories-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:hsla(0,0%,100%,.5)}.travel-blog-feed{padding:2rem 0}.travel-blog-feed .feed-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.travel-blog-feed .feed-title{font-family:"Noto Serif JP",serif;font-size:1.5rem;font-weight:600;color:#fff;margin:0}.travel-blog-feed .feed-count{font-size:.85rem;color:hsla(0,0%,100%,.5)}.travel-blog-feed .feed-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:hsla(0,0%,100%,.02);border-radius:16px;border:1px dashed hsla(0,0%,100%,.1)}.travel-blog-feed .feed-empty .empty-icon{font-size:4rem;margin-bottom:1rem}.travel-blog-feed .feed-empty h3{margin:0 0 .5rem;font-size:1.25rem;color:#fff}.travel-blog-feed .feed-empty p{margin:0 0 1.5rem;color:hsla(0,0%,100%,.6)}.travel-blog-feed .feed-empty .empty-cta{padding:.75rem 1.5rem;background:linear-gradient(135deg,#e63946,#ff6b6b);border-radius:8px;color:#fff;font-weight:500;transition:all .3s ease}.travel-blog-feed .feed-empty .empty-cta:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(230,57,70,.4)}.travel-blog-feed .feed-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.story-card{display:flex;flex-direction:column;background:linear-gradient(145deg,hsla(0,0%,100%,.04),hsla(0,0%,100%,.02));border:1px solid hsla(0,0%,100%,.08);border-radius:20px;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative}.story-card:before{content:"";position:absolute;inset:0;border-radius:20px;padding:1px;background:linear-gradient(135deg,rgba(230,57,70,.3),rgba(255,107,122,.1));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s ease}.story-card:hover{transform:translateY(-8px) scale(1.01);border-color:hsla(0,0%,100%,.2);box-shadow:0 25px 50px -12px rgba(0,0,0,.5),0 0 40px rgba(230,57,70,.15),inset 0 1px 0 hsla(0,0%,100%,.1);background:linear-gradient(145deg,hsla(0,0%,100%,.06),hsla(0,0%,100%,.03))}.story-card:hover:before{opacity:1}.story-card .card-image{position:relative;aspect-ratio:16/10;overflow:hidden;background:rgba(0,0,0,.2)}.story-card .card-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .4s ease}.story-card:hover .card-image img{transform:scale(1.05)}.story-card .card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);font-size:3rem}.story-card .card-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.7) 0,transparent 50%);display:flex;align-items:flex-end;justify-content:center;padding-bottom:1rem;opacity:0;transition:opacity .3s ease}.story-card:hover .card-overlay{opacity:1}.story-card .card-overlay .read-more{background:hsla(0,0%,100%,.2);backdrop-filter:blur(10px);font-size:.85rem}.story-card .card-location,.story-card .card-overlay .read-more{padding:.5rem 1rem;border-radius:50px;color:#fff;font-weight:500}.story-card .card-location{position:absolute;top:.75rem;left:.75rem;display:flex;align-items:center;gap:.35rem;background:rgba(0,0,0,.7);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid hsla(0,0%,100%,.1);font-size:.75rem;box-shadow:0 4px 12px rgba(0,0,0,.3)}.story-card .card-content{padding:1.25rem;display:flex;flex-direction:column;flex:1}.story-card .card-author{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.story-card .author-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#e63946,#ff6b6b);display:flex;align-items:center;justify-content:center;flex-shrink:0}.story-card .author-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.story-card .author-avatar span{color:#fff;font-weight:600;font-size:.9rem}.story-card .author-info{display:flex;flex-direction:column;gap:.125rem}.story-card .author-name{font-weight:600;font-size:.9rem;color:#fff}.story-card .post-date{font-size:.75rem;color:hsla(0,0%,100%,.5)}.story-card .card-title{font-family:"Noto Serif JP",serif;font-size:1.15rem;font-weight:600;color:#fff;margin:0 0 .75rem;line-height:1.4;-webkit-line-clamp:2}.story-card .card-excerpt,.story-card .card-title{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.story-card .card-excerpt{font-size:.875rem;color:hsla(0,0%,100%,.6);line-height:1.6;margin:0 0 1rem;-webkit-line-clamp:3;flex:1}.story-card .card-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.story-card .card-tags .tag{padding:.35rem .85rem;background:linear-gradient(135deg,rgba(110,181,255,.2),rgba(110,181,255,.1));border:1px solid rgba(110,181,255,.3);border-radius:50px;color:#6eb5ff;font-size:.75rem;font-weight:500;transition:all .3s ease;cursor:pointer}.story-card .card-tags .tag:hover{background:linear-gradient(135deg,#e63946,#ff6b7a);border-color:#e63946;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px rgba(230,57,70,.4)}.story-card .card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:1rem;border-top:1px solid hsla(0,0%,100%,.08);margin-top:auto}.story-card .card-stats{display:flex;align-items:center;gap:1rem}.story-card .card-stats .stat{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:hsla(0,0%,100%,.6)}.story-card .card-stats .stat-icon{font-size:.9rem}.story-card .read-time{font-size:.75rem;color:hsla(0,0%,100%,.6)}.travel-blog-cta{padding:2rem 0}.travel-blog-cta .cta-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,rgba(230,57,70,.1),rgba(230,57,70,.05));border:1px solid rgba(230,57,70,.2);border-radius:20px}.travel-blog-cta .cta-icon{font-size:2.5rem;margin-bottom:1rem}.travel-blog-cta h3{font-family:"Noto Serif JP",serif;font-size:1.5rem;font-weight:600;color:#fff;margin:0 0 .5rem}.travel-blog-cta p{font-size:1rem;color:hsla(0,0%,100%,.6);margin:0 0 1.5rem}.travel-blog-cta .cta-btn{padding:.875rem 2rem;background:linear-gradient(135deg,#e63946,#ff6b6b);border-radius:50px;color:#fff;font-weight:600;font-size:1rem;transition:all .3s ease}.travel-blog-cta .cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(230,57,70,.4)}@media (max-width:768px){.travel-blog-main{padding:80px 1rem 40px}.travel-blog-hero{padding:1.5rem 0 2rem}.travel-blog-tabs{gap:.5rem}.travel-blog-tabs .tab-btn{padding:.5rem 1rem;font-size:.85rem}.travel-blog-tabs .create-story-btn{width:100%;justify-content:center;margin-top:.5rem;margin-left:0}.travel-blog-feed .feed-grid{grid-template-columns:1fr}.story-card .card-image{aspect-ratio:16/9}}@media (max-width:480px){.travel-blog-hero .hero-title{font-size:1.75rem}.travel-blog-hero .hero-subtitle{font-size:.95rem}}.blog-post-container{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e 50%,#16213e)}.blog-post-main{padding-top:70px}.blog-post-loading{gap:1rem;color:hsla(0,0%,100%,.6)}.blog-post-loading,.blog-post-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh}.blog-post-not-found{text-align:center;padding:2rem}.blog-post-not-found .not-found-icon{font-size:4rem;margin-bottom:1rem}.blog-post-not-found h1{font-family:Playfair Display,Georgia,serif;font-size:2rem;color:#fff;margin:0 0 .5rem}.blog-post-not-found p{color:hsla(0,0%,100%,.6);margin:0 0 2rem}.blog-post-not-found .back-to-blog-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:var(--japan-red);color:#fff;border-radius:50px;font-weight:600;text-decoration:none;transition:all .3s ease}.blog-post-not-found .back-to-blog-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(230,57,70,.4)}.blog-post-hero{position:relative;width:100%;height:50vh;min-height:400px;max-height:600px;overflow:hidden}.blog-post-hero img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.blog-post-hero .hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,15,26,.3) 0,rgba(15,15,26,.6) 60%,#0f0f1a)}.blog-post-article{max-width:800px;padding:0 1.5rem 4rem;position:relative;margin:-100px auto 0;z-index:10}.blog-post-article .back-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:hsla(0,0%,100%,.05);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.1);border-radius:50px;color:hsla(0,0%,100%,.8);font-size:.9rem;text-decoration:none;margin-bottom:2rem;transition:all .3s ease}.blog-post-article .back-link:hover{background:hsla(0,0%,100%,.1);color:#fff}.blog-post-header{margin-bottom:2.5rem}.blog-post-header .location-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.blog-post-header .location-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;background:rgba(230,57,70,.15);border:1px solid rgba(230,57,70,.3);border-radius:50px;color:#e63946;font-size:.85rem;font-weight:500}.blog-post-header .location-badge .badge-icon{font-size:.9rem}.blog-post-header .post-title{font-family:Playfair Display,Georgia,serif;font-size:clamp(2rem,5vw,3rem);font-weight:700;color:#fff;line-height:1.2;margin:0 0 1rem}.blog-post-header .post-subtitle{font-size:1.25rem;color:hsla(0,0%,100%,.7);line-height:1.6;margin:0 0 1.5rem}.blog-post-header .post-meta{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.blog-post-header .author-info{display:flex;align-items:center;gap:.875rem}.blog-post-header .author-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#e63946,#ff6b6b);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;font-size:1.1rem;overflow:hidden}.blog-post-header .author-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.blog-post-header .author-details{display:flex;flex-direction:column;gap:.25rem}.blog-post-header .author-name{font-weight:600;color:#fff;font-size:1rem}.blog-post-header .post-date{font-size:.875rem;color:hsla(0,0%,100%,.5)}.blog-post-header .post-tags{display:flex;flex-wrap:wrap;gap:.5rem}.blog-post-header .post-tags .tag{padding:.4rem .875rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:50px;color:hsla(0,0%,100%,.7);font-size:.8rem}.blog-post-content{background:hsla(0,0%,100%,.03);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.08);border-radius:24px;padding:2.5rem;margin-bottom:2rem}.blog-post-content div{color:hsla(0,0%,100%,.85);font-size:1.1rem;line-height:1.8}.blog-post-content h1,.blog-post-content h2,.blog-post-content h3,.blog-post-content h4,.blog-post-content h5,.blog-post-content h6{font-family:Playfair Display,Georgia,serif;color:#fff;margin:1.5rem 0 1rem}.blog-post-content h2{font-size:1.75rem}.blog-post-content h3{font-size:1.4rem}.blog-post-content p{margin:0 0 1.25rem}.blog-post-content a{color:#e63946;text-decoration:underline}.blog-post-content img{max-width:100%;border-radius:16px;margin:1.5rem 0}.blog-post-content blockquote{border-left:4px solid #e63946;padding-left:1.5rem;margin:1.5rem 0;font-style:italic;color:hsla(0,0%,100%,.7)}.blog-post-content ol,.blog-post-content ul{padding-left:1.5rem;margin:1rem 0}.blog-post-content li{margin:.5rem 0}.blog-post-content code{background:hsla(0,0%,100%,.1);padding:.2rem .5rem;border-radius:4px;font-size:.9em}.blog-post-content pre{background:rgba(0,0,0,.3);padding:1.5rem;border-radius:12px;overflow-x:auto}.post-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:2rem}.post-gallery .gallery-image{border-radius:16px;overflow:hidden;aspect-ratio:4/3}.post-gallery .gallery-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.post-gallery .gallery-image:hover img{transform:scale(1.05)}.post-actions{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:hsla(0,0%,100%,.03);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.08);border-radius:16px;margin-bottom:3rem}.post-actions .action-btn,.post-actions .actions-left{display:flex;align-items:center;gap:.5rem}.post-actions .action-btn{padding:.625rem 1rem;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:50px;color:hsla(0,0%,100%,.7);font-size:.9rem;cursor:pointer;transition:all .2s ease}.post-actions .action-btn:hover{background:hsla(0,0%,100%,.1);color:#fff}.post-actions .action-btn.liked{background:rgba(230,57,70,.15);border-color:rgba(230,57,70,.3);color:#e63946}.post-actions .action-btn.saved{background:rgba(255,193,7,.15);border-color:rgba(255,193,7,.3);color:#ffc107}.related-posts{margin-bottom:3rem}.related-posts .related-title{font-family:Playfair Display,Georgia,serif;font-size:1.5rem;color:#fff;margin:0 0 1.5rem}.related-posts .related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.related-posts .related-card{display:block;background:hsla(0,0%,100%,.03);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.08);border-radius:16px;overflow:hidden;text-decoration:none;transition:all .3s ease}.related-posts .related-card:hover{transform:translateY(-4px);border-color:rgba(230,57,70,.3);box-shadow:0 12px 40px rgba(0,0,0,.3)}.related-posts .related-image{aspect-ratio:16/9;overflow:hidden}.related-posts .related-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.related-posts .related-card:hover .related-image img{transform:scale(1.05)}.related-posts .related-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(230,57,70,.2),rgba(230,57,70,.1));font-size:2rem}.related-posts .related-content{padding:1rem}.related-posts .related-content h4{font-family:Playfair Display,Georgia,serif;font-size:1rem;font-weight:600;color:#fff;margin:0 0 .5rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.related-posts .related-meta{font-size:.8rem;color:hsla(0,0%,100%,.5)}.blog-post-cta{padding:0 1.5rem 4rem}.blog-post-cta .cta-content{max-width:600px;margin:0 auto;text-align:center;padding:3rem;background:hsla(0,0%,100%,.03);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.08);border-radius:24px}.blog-post-cta .cta-icon{font-size:2.5rem;margin-bottom:1rem;display:block}.blog-post-cta .cta-content h3{font-family:Playfair Display,Georgia,serif;font-size:1.75rem;color:#fff;margin:0 0 .5rem}.blog-post-cta .cta-content p{color:hsla(0,0%,100%,.6);margin:0 0 1.5rem}.blog-post-cta .cta-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 2rem;background:var(--japan-red);border-radius:50px;color:#fff;font-weight:600;text-decoration:none;transition:all .3s ease}.blog-post-cta .cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(230,57,70,.4)}@media (max-width:768px){.blog-post-hero{height:40vh;min-height:300px}.blog-post-article{padding:0 1rem 3rem;margin-top:-60px}.blog-post-content{padding:1.5rem}.blog-post-content div{font-size:1rem}.post-actions{flex-direction:column;gap:1rem}.post-actions .actions-left{width:100%;justify-content:center}.related-posts .related-grid{grid-template-columns:1fr}}@media (max-width:480px){.blog-post-header .post-title{font-size:1.75rem}.blog-post-header .author-info{flex-direction:column;align-items:flex-start;gap:.75rem}.post-actions .action-btn{padding:.5rem .75rem;font-size:.85rem}}.onboarding-container{min-height:100vh;background:linear-gradient(180deg,var(--off-white) 0,var(--gray-100) 100%);display:flex;flex-direction:column;padding:2rem}.onboarding-progress{max-width:600px;margin:0 auto 2rem;width:100%}.progress-bar{height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:var(--japan-red);border-radius:3px;transition:width .4s ease}.progress-text{font-size:.85rem;color:var(--gray-500);text-align:center;display:block}.onboarding-content{flex:1;max-width:800px;margin:0 auto;width:100%}.onboarding-step{animation:fadeIn .4s ease}.step-header{text-align:center;margin-bottom:2rem}.step-header h1{font-family:Playfair Display,Georgia,serif;font-size:2.25rem;color:var(--ink);margin:0 0 .5rem}.step-header h2{font-size:1.5rem;color:var(--ink);margin:.5rem 0;font-weight:600}.step-header p{color:var(--gray-600);margin:.5rem 0}.step-hint{font-size:.9rem;color:var(--gray-500);display:block;margin-top:.5rem}.options-grid{display:grid;gap:1rem}.options-grid.travel-styles{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.options-grid.foods,.options-grid.interests,.options-grid.trip-type{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.options-grid.budget,.options-grid.pace{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.option-card{background:var(--white);border:2px solid var(--border-soft);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem}.option-card:hover{border-color:var(--gray-300);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.option-card.selected{border-color:var(--japan-red);background:rgba(230,57,70,.05);box-shadow:0 0 0 3px rgba(230,57,70,.1)}.option-card.horizontal{flex-direction:row;text-align:left}.option-card.small{padding:1rem}.option-emoji{font-size:2rem;margin-bottom:.25rem}.option-label{font-weight:600;color:var(--ink);font-size:1rem}.option-desc{font-size:.85rem;color:var(--gray-500)}.option-text{display:flex;flex-direction:column;gap:.25rem}.option-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--white);border:2px solid var(--border-soft);border-radius:50px;font-size:.95rem;cursor:pointer;transition:all .2s ease}.option-chip:hover{border-color:var(--gray-300)}.option-chip.selected{border-color:var(--japan-red);background:rgba(230,57,70,.08);color:var(--japan-red)}.sub-section{margin-bottom:2rem}.sub-section h3{font-size:1rem;color:var(--gray-600);margin:0 0 1rem;text-align:center}.toggle-options{display:flex;flex-direction:column;gap:1rem;max-width:500px;margin:0 auto}.toggle-option{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;background:var(--white);border-radius:var(--radius);cursor:pointer;transition:all .2s ease;border:1px solid var(--border-soft)}.toggle-option:hover{border-color:var(--gray-300)}.toggle-content{display:flex;align-items:center;gap:1rem}.toggle-emoji{font-size:1.5rem}.toggle-text{display:flex;flex-direction:column;gap:.25rem}.toggle-label{font-weight:600;color:var(--ink)}.toggle-desc{font-size:.85rem;color:var(--gray-500)}.toggle-input{display:none}.toggle-switch{width:48px;height:28px;background:var(--gray-300);border-radius:14px;position:relative;transition:background .2s ease}.toggle-switch:after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 2px 4px rgba(0,0,0,.2)}.toggle-input:checked+.toggle-switch{background:var(--japan-red)}.toggle-input:checked+.toggle-switch:after{transform:translateX(20px)}.summary-preview{margin-top:2rem;padding:1.5rem;background:var(--white);border-radius:var(--radius);max-width:400px;margin-left:auto;margin-right:auto}.summary-preview h3{font-size:1rem;color:var(--gray-600);margin:0 0 1rem;text-align:center}.summary-items{display:flex;flex-direction:column;gap:.5rem}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-soft)}.summary-item:last-child{border-bottom:none}.summary-label{color:var(--gray-500);font-size:.9rem}.summary-value{font-weight:600;color:var(--ink)}.onboarding-nav{display:flex;align-items:center;justify-content:center;gap:1rem;padding:2rem;max-width:600px;margin:0 auto;width:100%}.nav-spacer{flex:1}@media (max-width:640px){.onboarding-container{padding:1rem}.step-header h1{font-size:1.75rem}.step-header h2{font-size:1.25rem}.option-card{padding:1rem}.option-emoji{font-size:1.5rem}.options-grid.travel-styles{grid-template-columns:1fr 1fr}.option-chip{padding:.625rem 1rem;font-size:.9rem}}.gems-container{min-height:100vh;background:var(--off-white)}.gems-main{padding:2rem var(--app-padding);max-width:var(--content-max);margin:0 auto}.gems-header{text-align:center;margin-bottom:3rem}.gems-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,var(--japan-red) 0,#ff6b7a 100%);color:#fff;border-radius:999px;font-size:.875rem;font-weight:600;margin-bottom:1rem}.gems-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--black);margin-bottom:.5rem}.gems-subtitle{font-size:1.125rem;color:var(--gray-600);max-width:600px;margin:0 auto}.gems-stats{display:flex;align-items:center;justify-content:center;gap:2rem;margin-top:2rem;padding:1.5rem;background:var(--surface-strong);border-radius:var(--radius-lg);border:1px solid var(--border-soft);box-shadow:var(--shadow-sm)}.gems-stat{gap:.25rem}.gems-loading,.gems-stat{display:flex;flex-direction:column;align-items:center}.gems-loading,.gems-loading-state{justify-content:center;padding:4rem 2rem;gap:1rem}.gems-loading-state{display:flex;flex-direction:column;align-items:center;color:var(--gray-500)}.gems-empty-state{text-align:center;padding:4rem 2rem}.gems-empty-state .empty-icon{font-size:4rem;margin-bottom:1rem;display:block}.gems-empty-state h3{font-size:1.5rem;font-weight:600;color:var(--black);margin-bottom:.5rem}.gems-empty-state p{color:var(--gray-600)}.gems-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:3rem}.gem-card{background:var(--surface-strong);border-radius:var(--radius-lg);border:1px solid var(--border-soft);overflow:hidden;cursor:pointer;transition:all .3s ease}.gem-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}.gem-card.locked{opacity:.85}.gem-card.ready{border-color:var(--japan-red);box-shadow:0 0 0 2px var(--japan-red) inset}.gem-image{position:relative;width:100%;height:220px;overflow:hidden}.gem-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.gem-locked-overlay{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(0,0,0,.3),rgba(0,0,0,.5));backdrop-filter:blur(8px)}.lock-icon{font-size:3rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.gem-rarity{position:absolute;top:.75rem;right:.75rem;padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}.gem-content{padding:1.5rem}.gem-content h3{font-size:1.25rem;font-weight:600;color:var(--black);margin-bottom:.5rem}.gem-content p{font-size:.9375rem;color:var(--gray-600);line-height:1.5;margin-bottom:1rem}.gem-location{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--gray-500);margin-bottom:1rem}.gem-conditions{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-soft)}.conditions-title{font-size:.875rem;font-weight:600;color:var(--gray-700);margin-bottom:.75rem}.condition-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--gray-50);border-radius:var(--radius-sm);font-size:.875rem;color:var(--gray-600);margin-bottom:.5rem}.unlock-btn{width:100%;margin-top:1rem;padding:.75rem;background:linear-gradient(135deg,var(--japan-red) 0,#ff6b7a 100%);color:#fff;border:none;border-radius:var(--radius);font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s ease}.unlock-btn:hover{transform:translateY(-2px);box-shadow:0 8px 16px rgba(230,57,70,.3)}.gem-unlocked-badge{justify-content:space-between;padding:.75rem;background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(22,163,74,.15));border-radius:var(--radius);font-size:.875rem;font-weight:600;color:#15803d;margin-top:1rem}.gem-modal,.gem-unlocked-badge{display:flex;align-items:center}.gem-modal{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);justify-content:center;padding:2rem;z-index:1000;animation:fadeIn .2s ease}.gem-modal-content{background:var(--surface-strong);border-radius:var(--radius-xl);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s ease}.modal-close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;border:none;font-size:1.5rem;cursor:pointer;z-index:10;transition:all .2s ease}.modal-close:hover{background:rgba(0,0,0,.7);transform:rotate(90deg)}.modal-image{width:100%;height:300px;-o-object-fit:cover;object-fit:cover}.modal-body{padding:2rem}.modal-body .gem-rarity{position:static;display:inline-block;margin-bottom:1rem}.modal-body h2{font-size:2rem;font-weight:700;color:var(--black);margin-bottom:.5rem}.modal-subtitle{font-size:1.125rem;color:var(--gray-600);margin-bottom:1rem}.modal-description{line-height:1.6;margin-bottom:1.5rem}.modal-content,.modal-description{font-size:1rem;color:var(--gray-700)}.modal-content{line-height:1.7}.modal-conditions{margin-top:2rem;padding:1.5rem;background:var(--gray-50);border-radius:var(--radius-lg)}.modal-conditions h3{font-size:1.125rem;font-weight:600;color:var(--black);margin-bottom:1rem}.condition-detail{padding:.75rem;background:#fff;border-radius:var(--radius);margin-bottom:.75rem;font-size:.9375rem;color:var(--gray-700)}.unlock-btn-large{width:100%;margin-top:1.5rem;padding:1rem;background:linear-gradient(135deg,var(--japan-red) 0,#ff6b7a 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease}.unlock-btn-large:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(230,57,70,.4)}@media (max-width:768px){.gems-grid{grid-template-columns:1fr}.gems-stats{flex-direction:column;gap:1rem}.stat-divider{display:none}.gem-modal{padding:1rem}.modal-body{padding:1.5rem}}.ai-assistant{background:var(--surface-strong);border-radius:var(--radius-lg);border:1px solid var(--border-soft);overflow:hidden;box-shadow:var(--shadow-md)}.ai-assistant.compact{position:sticky;top:100px}.ai-assistant-header{padding:1.5rem;background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(59,130,246,.1));border-bottom:1px solid var(--border-soft);cursor:pointer;display:flex;align-items:center;justify-content:space-between}.ai-header-content{display:flex;align-items:center;gap:1rem}.ai-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.ai-assistant-header h3{font-size:1.25rem;font-weight:600;color:var(--black);margin:0}.ai-subtitle{font-size:.875rem;color:var(--gray-600);margin:.25rem 0 0}.ai-toggle{width:32px;height:32px;border-radius:50%;background:var(--surface-muted);border:1px solid var(--border-soft);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;color:var(--gray-700);cursor:pointer;transition:all .2s ease}.ai-toggle:hover{background:var(--surface-strong);border-color:var(--border-strong)}.ai-empty,.ai-loading{padding:2rem;text-align:center;color:var(--gray-600)}.ai-loading{display:flex;flex-direction:column;align-items:center;gap:1rem}.ai-empty-hint{font-size:.875rem;margin-top:.5rem;color:var(--gray-500)}.ai-recommendations{padding:1rem;display:flex;flex-direction:column;gap:1rem;max-height:600px;overflow-y:auto}.ai-assistant.compact .ai-recommendations{max-height:400px}.ai-recommendation-card{display:flex;gap:1rem;padding:1rem;background:var(--surface-muted);border-radius:var(--radius);border:1px solid var(--border-soft);transition:all .2s ease;cursor:pointer}.ai-recommendation-card:hover{transform:translateX(4px);box-shadow:var(--shadow-sm);border-color:var(--border-strong)}.ai-rec-image{position:relative;width:80px;height:80px;flex-shrink:0;border-radius:var(--radius-sm);overflow:hidden}.ai-rec-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.ai-rec-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--gray-200),var(--gray-300));font-size:2rem}.ai-rec-type{position:absolute;bottom:.25rem;left:.25rem;padding:.25rem .5rem;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);color:#fff;font-size:.625rem;font-weight:600;text-transform:uppercase;border-radius:4px;letter-spacing:.5px}.ai-rec-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.ai-rec-content h4{font-size:1rem;font-weight:600;color:var(--black);margin:0;line-height:1.3}.ai-rec-reason{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--gray-600);margin:0}.reason-icon{font-size:.75rem}.ai-rec-location{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--gray-500)}.ai-rec-distance{padding:.125rem .5rem;background:var(--gray-100);border-radius:999px;font-weight:600;color:var(--gray-700);font-size:.75rem}.ai-rec-rating{font-size:.875rem}.ai-assistant-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-soft);background:var(--gray-50)}.ai-refresh-btn{width:100%;padding:.75rem;background:var(--surface-strong);border:1px solid var(--border-soft);border-radius:var(--radius);font-weight:600;font-size:.9375rem;color:var(--gray-700);cursor:pointer;transition:all .2s ease}.ai-refresh-btn:hover{background:var(--surface-muted);border-color:var(--border-strong);transform:translateY(-1px)}.ai-assistant.collapsed .ai-assistant-footer,.ai-assistant.collapsed .ai-recommendations{display:none}@media (max-width:768px){.ai-assistant.compact{position:static}.ai-recommendation-card{flex-direction:column}.ai-rec-image{width:100%;height:150px}}.badges-tab{padding:2rem 0}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:3rem}.badge-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:16px;padding:1.5rem;display:flex;gap:1rem;transition:all .3s ease}.badge-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.2);border-color:hsla(0,0%,100%,.2)}.badge-card.bronze{border-color:rgba(205,127,50,.3);background:linear-gradient(135deg,rgba(205,127,50,.1),hsla(0,0%,100%,.05))}.badge-card.silver{border-color:hsla(0,0%,75%,.3);background:linear-gradient(135deg,hsla(0,0%,75%,.1),hsla(0,0%,100%,.05))}.badge-card.gold{border-color:rgba(255,215,0,.3);background:linear-gradient(135deg,rgba(255,215,0,.1),hsla(0,0%,100%,.05))}.badge-card.platinum{border-color:hsla(40,5%,89%,.3);background:linear-gradient(135deg,hsla(40,5%,89%,.1),hsla(0,0%,100%,.05))}.badge-card.diamond{border-color:rgba(185,242,255,.3);background:linear-gradient(135deg,rgba(185,242,255,.1),hsla(0,0%,100%,.05))}.badge-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}.badge-icon.locked{background:hsla(0,0%,100%,.05);font-size:1.5rem}.badge-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.badge-info h4{font-size:1.1rem;font-weight:600;color:#fff;margin:0}.badge-desc{font-size:.9rem;color:hsla(0,0%,100%,.7);line-height:1.5}.badge-meta{display:flex;gap:1rem;align-items:center;margin-top:.5rem}.badge-rarity{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-rarity.bronze{background:rgba(205,127,50,.2);color:#cd7f32}.badge-rarity.silver{background:hsla(0,0%,75%,.2);color:silver}.badge-rarity.gold{background:rgba(255,215,0,.2);color:gold}.badge-rarity.platinum{background:hsla(40,5%,89%,.2);color:#e5e4e2}.badge-rarity.diamond{background:rgba(185,242,255,.2);color:#b9f2ff}.badge-points{font-size:.85rem;color:#4ade80;font-weight:600}.badge-date{font-size:.8rem;color:hsla(0,0%,100%,.5);margin-top:.5rem}.locked-badges-section{margin-top:3rem;padding-top:2rem;border-top:1px solid hsla(0,0%,100%,.1)}.locked-badges-section h3{font-size:1.2rem;margin-bottom:1.5rem;color:hsla(0,0%,100%,.8)}.locked-badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.locked-badge-card{background:hsla(0,0%,100%,.03);border:1px dashed hsla(0,0%,100%,.1);border-radius:12px;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.badge-name{font-size:.9rem;color:hsla(0,0%,100%,.5);font-weight:600}.badge-hint{font-size:.75rem;color:hsla(0,0%,100%,.6);line-height:1.4}.checkins-tab{padding:2rem 0}.checkins-timeline{display:flex;flex-direction:column;gap:1.5rem}.checkin-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:16px;overflow:hidden;display:flex;gap:1.5rem;transition:all .3s ease}.checkin-card:hover{transform:translateX(8px);box-shadow:0 8px 24px rgba(0,0,0,.2);border-color:hsla(0,0%,100%,.2)}.checkin-photo{width:200px;height:200px;flex-shrink:0}.checkin-photo img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.checkin-content{flex:1;padding:1.5rem 1.5rem 1.5rem 0;display:flex;flex-direction:column;gap:.75rem}.checkin-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.checkin-header h4{font-size:1.3rem;font-weight:600;color:#fff;margin:0}.verified-badge{background:rgba(74,222,128,.2);color:#4ade80;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.checkin-meta{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.9rem;color:hsla(0,0%,100%,.6)}.checkin-date,.checkin-location{display:flex;align-items:center;gap:.5rem}.checkin-note{font-size:.95rem;color:hsla(0,0%,100%,.8);line-height:1.6;margin:.5rem 0}.checkin-rating{font-size:1rem}.checkin-duration{font-size:.85rem;color:hsla(0,0%,100%,.6);display:flex;align-items:center;gap:.5rem}.memories-tab{padding:2rem 0}.memories-timeline{display:flex;flex-direction:column;gap:2rem}.memory-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:16px;overflow:hidden;transition:all .3s ease}.memory-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.3);border-color:hsla(0,0%,100%,.2)}.memory-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;height:250px}.memory-photos img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.memory-photos img:first-child:last-child{grid-column:1/-1;height:400px}.memory-photos img:first-child:nth-last-child(2),.memory-photos img:first-child:nth-last-child(2)~img{grid-column:span 1;height:250px}.memory-content{padding:1.5rem}.memory-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.memory-header h4{font-size:1.4rem;font-weight:600;color:#fff;margin:0;flex:1}.memory-date{font-size:.85rem;color:hsla(0,0%,100%,.5);white-space:nowrap}.memory-description{font-size:1rem;color:hsla(0,0%,100%,.8);line-height:1.6;margin-bottom:1rem}.memory-location{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:hsla(0,0%,100%,.7);margin-bottom:1rem}.memory-tags{display:flex;flex-wrap:wrap;gap:.5rem}.memory-tag{padding:.25rem .75rem;background:hsla(0,0%,100%,.1);border-radius:20px;font-size:.8rem;color:hsla(0,0%,100%,.7)}.cta-link{display:inline-block;margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:all .3s ease}.cta-link:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(102,126,234,.4)}@media (max-width:768px){.badges-grid{grid-template-columns:1fr}.locked-badges-grid{grid-template-columns:repeat(2,1fr)}.checkin-card{flex-direction:column}.checkin-photo{width:100%;height:250px}.checkin-content{padding:1.5rem}.memory-photos{height:200px}.memory-photos img:first-child:last-child{height:300px}}.missions-container{min-height:100vh;background:linear-gradient(135deg,#0f0c29,#302b63 50%,#24243e)}.missions-main{max-width:1400px;margin:0 auto;padding:100px 2rem 2rem}.missions-header{text-align:center;margin-bottom:3rem}.missions-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(102,126,234,.2);border:1px solid rgba(102,126,234,.3);padding:.5rem 1rem;border-radius:50px;font-size:.9rem;color:#667eea;margin-bottom:1rem}.missions-title{font-size:3rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem}.missions-subtitle{font-size:1.2rem;color:hsla(0,0%,100%,.7);max-width:600px;margin:0 auto}.missions-stats{justify-content:center;gap:2rem;padding:2rem;background:hsla(0,0%,100%,.05);border-radius:16px;max-width:500px;margin:2rem auto}.mission-stat,.missions-stats{display:flex;align-items:center}.mission-stat{flex-direction:column;gap:.5rem}.missions-filters{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}.filter-select{padding:.75rem 1.5rem;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:8px;color:#fff;font-size:.9rem;cursor:pointer;transition:all .3s ease}.filter-select:hover{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.3)}.filter-select:focus{outline:none;border-color:#667eea}.filter-select option{background:#1a1a2e;color:#fff}.missions-content{margin-top:3rem}.spots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.spot-card{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:16px;overflow:hidden;transition:all .3s ease}.spot-card:hover{transform:translateY(-8px);box-shadow:0 12px 32px rgba(0,0,0,.3);border-color:hsla(0,0%,100%,.2)}.spot-card.visited{border-color:rgba(74,222,128,.3)}.spot-image{position:relative;width:100%;height:250px;overflow:hidden}.spot-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.spot-card:hover .spot-image img{transform:scale(1.1)}.spot-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(102,126,234,.2),rgba(118,75,162,.2));font-size:4rem}.spot-featured-badge{left:1rem;background:rgba(255,215,0,.9)}.spot-featured-badge,.spot-visited-badge{position:absolute;top:1rem;color:#000;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.spot-visited-badge{right:1rem;background:rgba(74,222,128,.9)}.spot-difficulty{position:absolute;bottom:1rem;right:1rem;background:rgba(0,0,0,.7);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.spot-content{padding:1.5rem}.spot-header{margin-bottom:.75rem}.spot-header h3{font-size:1.4rem;font-weight:700;color:#fff;margin:0 0 .25rem}.spot-japanese{font-size:.9rem;color:hsla(0,0%,100%,.6)}.spot-location{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:hsla(0,0%,100%,.7);margin-bottom:1rem}.spot-description{font-size:.95rem;color:hsla(0,0%,100%,.8);line-height:1.6;margin-bottom:1.5rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.spot-missions{margin:1.5rem 0;padding:1rem;background:hsla(0,0%,100%,.05);border-radius:8px}.spot-missions h4{font-size:.9rem;color:hsla(0,0%,100%,.6);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.5px}.missions-list{display:flex;flex-direction:column;gap:.5rem}.mission-item{justify-content:space-between;padding:.5rem;background:hsla(0,0%,100%,.05);border-radius:6px}.mission-info,.mission-item{display:flex;align-items:center}.mission-info{gap:.75rem;flex:1}.mission-title{font-size:.85rem;color:hsla(0,0%,100%,.9)}.mission-points{font-size:.75rem;color:#4ade80;font-weight:600}.mission-progress{display:flex;align-items:center}.mission-status{font-size:1rem}.mission-status.completed{color:#4ade80}.mission-status.active{color:#fbbf24}.missions-more{font-size:.8rem;color:hsla(0,0%,100%,.5);text-align:center;padding:.5rem}.spot-stats{display:flex;gap:1.5rem;margin:1.5rem 0;font-size:.85rem;color:hsla(0,0%,100%,.6)}.spot-stat{display:flex;align-items:center;gap:.5rem}.spot-btn{display:block;width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;text-decoration:none;border-radius:8px;font-weight:600;transition:all .3s ease}.spot-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(102,126,234,.4)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid hsla(0,0%,100%,.1);border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:4rem 2rem}.empty-icon{font-size:4rem;display:block;margin-bottom:1rem}.empty-state h3{font-size:1.5rem;color:#fff;margin-bottom:.5rem}.empty-state p{font-size:1rem;color:hsla(0,0%,100%,.7)}@media (max-width:768px){.missions-title{font-size:2rem}.missions-subtitle{font-size:1rem}.missions-filters{flex-direction:column}.filter-select{width:100%}.spots-grid{grid-template-columns:1fr}.missions-stats{flex-direction:column}.stat-divider{display:none}body{overflow-x:hidden}.main-container,main{padding:0 1rem;width:100%;max-width:100%}h1{font-size:clamp(1.75rem,5vw,2.25rem);line-height:1.2}h2{font-size:clamp(1.5rem,4vw,1.875rem);line-height:1.25}h3{font-size:clamp(1.25rem,3vw,1.5rem);line-height:1.3}h4{font-size:clamp(1.1rem,2.5vw,1.25rem)}p{font-size:clamp(.9rem,2vw,1rem);line-height:1.6}.card,.glass-card{border-radius:var(--radius);padding:1rem}.grid,[class*=-grid]{grid-template-columns:1fr!important;gap:1rem}.flex-row{flex-direction:column;gap:1rem}.section{padding:2.5rem 1rem}.section-padding{padding:2rem 1rem}img{max-width:100%;height:auto}.dialog,.modal{width:calc(100vw - 2rem);max-width:calc(100vw - 2rem);margin:1rem;border-radius:var(--radius)}table{display:block}.tabs,[role=tablist],table{overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs,[role=tablist]{scrollbar-width:none}}@media (max-width:768px){.tabs::-webkit-scrollbar,[role=tablist]::-webkit-scrollbar{display:none}ol,ul{padding-left:1.5rem}a:active{opacity:.7}.desktop-only,.hide-mobile{display:none!important}.mobile-only,.show-mobile{display:block!important}.show-mobile-flex{display:flex!important}.clickable,[role=button],a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.clickable:active,[role=button]:active,button:active{transform:scale(.98)}.stack-mobile{flex-direction:column!important}.full-width-mobile{width:100%!important}.center-mobile{text-align:center!important;align-items:center!important;justify-content:center!important}.gap-reduce-mobile{gap:.75rem!important}}@media (max-width:480px){.main-container,main{padding:0 .75rem}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.card,.glass-card{padding:.85rem}.section{padding:2rem .75rem}.section-padding{padding:1.5rem .75rem}.dialog,.modal{width:calc(100vw - 1.5rem);max-width:calc(100vw - 1.5rem);margin:.75rem}}@media (max-height:768px) and (orientation:landscape){.section{padding:1.5rem 1rem}h1{font-size:1.5rem}h2{font-size:1.25rem}.dialog,.modal{max-height:90vh;overflow-y:auto}}@media (min-width:769px) and (max-width:1024px){.main-container,main{padding:0 1.5rem}.grid,[class*=-grid]{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))!important}.section{padding:3rem 1.5rem}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px rgba(230,57,70,.4)}50%{box-shadow:0 0 40px rgba(230,57,70,.6)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes rotateIn{0%{opacity:0;transform:rotate(-10deg) scale(.9)}to{opacity:1;transform:rotate(0) scale(1)}}.animate-float{animation:float 3s ease-in-out infinite}.animate-pulse-glow{animation:pulse-glow 2s ease-in-out infinite}.animate-shimmer{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.1),transparent);background-size:1000px 100%;animation:shimmer 2s infinite}.animate-slide-up{animation:slideUp .6s ease-out}.animate-scale-in{animation:scaleFadeIn .5s ease-out}.animate-rotate-in{animation:rotateIn .6s ease-out}.hover-lift{transition:transform .3s ease,box-shadow .3s ease}.hover-lift:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,.2)}.hover-glow:hover{box-shadow:0 0 30px rgba(230,57,70,.5);border-color:rgba(230,57,70,.8)}.glass{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2)}.glass,.glass-dark{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.glass-dark{background:rgba(0,0,0,.3);border:1px solid hsla(0,0%,100%,.1)}.gradient-text-japan{background:linear-gradient(135deg,#e63946,#ff6b7a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.page-transition{animation:fadeIn .3s ease-in}@keyframes spin{to{transform:rotate(1turn)}}.spinner{animation:spin 1s linear infinite}@media print{.btn,.glass-nav,.nav-drawer,.sidebar,button{display:none!important}body{background:#fff!important;color:#000!important}main{padding:0!important;max-width:100%!important}a{color:#000!important;text-decoration:underline!important}img{max-width:100%!important;page-break-inside:avoid}h1,h2,h3,h4,h5,h6{page-break-after:avoid}}@media (prefers-contrast:high){.card,.glass-card,.glass-nav{border-width:2px}.btn,button{border:2px solid}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media (max-width:768px){[data-theme=dark]{--app-padding:1rem}[data-theme=dark] .glass-nav{background:rgba(15,20,36,.95);border-color:hsla(0,0%,100%,.15)}[data-theme=dark] .card,[data-theme=dark] .glass-card{background:rgba(21,27,46,.95);border-color:hsla(0,0%,100%,.1)}}.last\:border-b-0:last-child{border-bottom-width:0}.hover\:-translate-y-2:hover{--tw-translate-y:-0.5rem}.hover\:-translate-y-2:hover,.hover\:scale-105:hover{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:scale-105:hover{--tw-scale-x:1.05;--tw-scale-y:1.05}.hover\:scale-\[1\.02\]:hover{--tw-scale-x:1.02;--tw-scale-y:1.02;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-\[\#e63946\]:hover{--tw-border-opacity:1;border-color:rgb(230 57 70/var(--tw-border-opacity,1))}.hover\:border-amber-300:hover{--tw-border-opacity:1;border-color:rgb(252 211 77/var(--tw-border-opacity,1))}.hover\:border-amber-400:hover{--tw-border-opacity:1;border-color:rgb(251 191 36/var(--tw-border-opacity,1))}.hover\:border-blue-300:hover{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.hover\:border-gray-300:hover{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.hover\:border-gray-400:hover{--tw-border-opacity:1;border-color:rgb(156 163 175/var(--tw-border-opacity,1))}.hover\:border-green-300:hover{--tw-border-opacity:1;border-color:rgb(134 239 172/var(--tw-border-opacity,1))}.hover\:border-pink-300:hover{--tw-border-opacity:1;border-color:rgb(249 168 212/var(--tw-border-opacity,1))}.hover\:border-purple-300:hover{--tw-border-opacity:1;border-color:rgb(216 180 254/var(--tw-border-opacity,1))}.hover\:border-red-300:hover{--tw-border-opacity:1;border-color:rgb(252 165 165/var(--tw-border-opacity,1))}.hover\:border-yellow-300:hover{--tw-border-opacity:1;border-color:rgb(253 224 71/var(--tw-border-opacity,1))}.hover\:bg-\[\#d62839\]:hover{--tw-bg-opacity:1;background-color:rgb(214 40 57/var(--tw-bg-opacity,1))}.hover\:bg-\[\#e63946\]:hover{--tw-bg-opacity:1;background-color:rgb(230 57 70/var(--tw-bg-opacity,1))}.hover\:bg-\[\#e63946\]\/5:hover{background-color:rgba(230,57,70,.05)}.hover\:bg-blue-50:hover{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.hover\:bg-blue-600:hover{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-green-600:hover{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.hover\:bg-pink-100:hover{--tw-bg-opacity:1;background-color:rgb(252 231 243/var(--tw-bg-opacity,1))}.hover\:bg-pink-600:hover{--tw-bg-opacity:1;background-color:rgb(219 39 119/var(--tw-bg-opacity,1))}.hover\:bg-purple-100:hover{--tw-bg-opacity:1;background-color:rgb(243 232 255/var(--tw-bg-opacity,1))}.hover\:bg-purple-600:hover{--tw-bg-opacity:1;background-color:rgb(147 51 234/var(--tw-bg-opacity,1))}.hover\:bg-red-100:hover{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.hover\:bg-red-50:hover{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.hover\:bg-red-500\/30:hover{background-color:rgba(239,68,68,.3)}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.hover\:bg-white:hover{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.hover\:bg-white\/10:hover{background-color:hsla(0,0%,100%,.1)}.hover\:bg-white\/20:hover{background-color:hsla(0,0%,100%,.2)}.hover\:bg-white\/90:hover{background-color:hsla(0,0%,100%,.9)}.hover\:from-blue-600:hover{--tw-gradient-from:#2563eb var(--tw-gradient-from-position);--tw-gradient-to:rgba(37,99,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:from-rose-600:hover{--tw-gradient-from:#e11d48 var(--tw-gradient-from-position);--tw-gradient-to:rgba(225,29,72,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:to-orange-600:hover{--tw-gradient-to:#ea580c var(--tw-gradient-to-position)}.hover\:to-purple-600:hover{--tw-gradient-to:#9333ea var(--tw-gradient-to-position)}.hover\:text-\[\#d62839\]:hover{--tw-text-opacity:1;color:rgb(214 40 57/var(--tw-text-opacity,1))}.hover\:text-\[var\(--text\)\]:hover{color:var(--text)}.hover\:text-black:hover{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.hover\:text-cyan-300:hover{--tw-text-opacity:1;color:rgb(103 232 249/var(--tw-text-opacity,1))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.hover\:text-gray-900:hover{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.hover\:text-pink-600:hover{--tw-text-opacity:1;color:rgb(219 39 119/var(--tw-text-opacity,1))}.hover\:text-purple-700:hover{--tw-text-opacity:1;color:rgb(126 34 206/var(--tw-text-opacity,1))}.hover\:text-red-600:hover{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.hover\:text-red-700:hover{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity,1))}.hover\:text-rose-700:hover{--tw-text-opacity:1;color:rgb(190 18 60/var(--tw-text-opacity,1))}.hover\:text-white:hover{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-90:hover{opacity:.9}.hover\:shadow:hover{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.hover\:shadow-2xl:hover,.hover\:shadow:hover{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-2xl:hover{--tw-shadow:0 25px 50px -12px rgba(0,0,0,.25);--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color)}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color)}.hover\:shadow-lg:hover,.hover\:shadow-md:hover{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color)}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.focus\:border-blue-500:focus{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.focus\:border-cyan-400:focus{--tw-border-opacity:1;border-color:rgb(34 211 238/var(--tw-border-opacity,1))}.focus\:border-red-500:focus{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.focus\:border-transparent:focus{border-color:transparent}.focus\:placeholder-gray-400:focus::-moz-placeholder{--tw-placeholder-opacity:1;color:rgb(156 163 175/var(--tw-placeholder-opacity,1))}.focus\:placeholder-gray-400:focus::placeholder{--tw-placeholder-opacity:1;color:rgb(156 163 175/var(--tw-placeholder-opacity,1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-\[\#e63946\]:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(230 57 70/var(--tw-ring-opacity,1))}.focus\:ring-\[\#e63946\]\/30:focus{--tw-ring-color:rgba(230,57,70,.3)}.focus\:ring-\[var\(--japan-red\)\]:focus{--tw-ring-color:var(--japan-red)}.focus\:ring-red-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(239 68 68/var(--tw-ring-opacity,1))}.focus\:ring-rose-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(244 63 94/var(--tw-ring-opacity,1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-600:disabled{--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity,1))}.disabled\:from-gray-600:disabled{--tw-gradient-from:#4b5563 var(--tw-gradient-from-position);--tw-gradient-to:rgba(75,85,99,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.disabled\:to-gray-700:disabled{--tw-gradient-to:#374151 var(--tw-gradient-to-position)}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}.disabled\:hover\:scale-100:hover:disabled{--tw-scale-x:1;--tw-scale-y:1}.disabled\:hover\:scale-100:hover:disabled,.group:hover .group-hover\:scale-110{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1}.group:hover .group-hover\:text-\[\#e63946\]{--tw-text-opacity:1;color:rgb(230 57 70/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-\[var\(--accent\)\]{color:var(--accent)}.group:hover .group-hover\:text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.group:hover .group-hover\:opacity-100{opacity:1}.group:hover .group-hover\:opacity-90{opacity:.9}.group:hover .group-hover\:ring-\[\#e63946\]\/40{--tw-ring-color:rgba(230,57,70,.4)}.dark\:border-blue-700:is(.dark *){--tw-border-opacity:1;border-color:rgb(29 78 216/var(--tw-border-opacity,1))}.dark\:border-blue-900\/50:is(.dark *){border-color:rgba(30,58,138,.5)}.dark\:border-gray-600:is(.dark *){--tw-border-opacity:1;border-color:rgb(75 85 99/var(--tw-border-opacity,1))}.dark\:border-gray-700:is(.dark *){--tw-border-opacity:1;border-color:rgb(55 65 81/var(--tw-border-opacity,1))}.dark\:border-gray-800:is(.dark *){--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity,1))}.dark\:border-red-900\/30:is(.dark *){border-color:rgba(127,29,29,.3)}.dark\:border-red-900\/50:is(.dark *){border-color:rgba(127,29,29,.5)}.dark\:bg-blue-900\/20:is(.dark *){background-color:rgba(30,58,138,.2)}.dark\:bg-gray-800:is(.dark *){--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.dark\:bg-gray-900:is(.dark *){--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity,1))}.dark\:bg-gray-900\/60:is(.dark *){background-color:rgba(17,24,39,.6)}.dark\:bg-red-900\/20:is(.dark *){background-color:rgba(127,29,29,.2)}.dark\:bg-red-900\/30:is(.dark *){background-color:rgba(127,29,29,.3)}.dark\:from-gray-900:is(.dark *){--tw-gradient-from:#111827 var(--tw-gradient-from-position);--tw-gradient-to:rgba(17,24,39,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.dark\:via-gray-900:is(.dark *){--tw-gradient-to:rgba(17,24,39,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#111827 var(--tw-gradient-via-position),var(--tw-gradient-to)}.dark\:to-gray-950:is(.dark *){--tw-gradient-to:#030712 var(--tw-gradient-to-position)}.dark\:text-blue-100:is(.dark *){--tw-text-opacity:1;color:rgb(219 234 254/var(--tw-text-opacity,1))}.dark\:text-blue-200:is(.dark *){--tw-text-opacity:1;color:rgb(191 219 254/var(--tw-text-opacity,1))}.dark\:text-blue-300:is(.dark *){--tw-text-opacity:1;color:rgb(147 197 253/var(--tw-text-opacity,1))}.dark\:text-blue-400:is(.dark *){--tw-text-opacity:1;color:rgb(96 165 250/var(--tw-text-opacity,1))}.dark\:text-gray-300:is(.dark *){--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity,1))}.dark\:text-gray-400:is(.dark *){--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.dark\:text-gray-500:is(.dark *){--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.dark\:text-green-400:is(.dark *){--tw-text-opacity:1;color:rgb(74 222 128/var(--tw-text-opacity,1))}.dark\:text-red-100:is(.dark *){--tw-text-opacity:1;color:rgb(254 226 226/var(--tw-text-opacity,1))}.dark\:text-red-200:is(.dark *){--tw-text-opacity:1;color:rgb(254 202 202/var(--tw-text-opacity,1))}.dark\:text-red-300:is(.dark *){--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.dark\:text-red-400:is(.dark *){--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity,1))}.dark\:text-white:is(.dark *){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.dark\:text-yellow-400:is(.dark *){--tw-text-opacity:1;color:rgb(250 204 21/var(--tw-text-opacity,1))}.dark\:hover\:bg-gray-700:hover:is(.dark *){--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity,1))}.dark\:hover\:bg-red-900\/20:hover:is(.dark *){background-color:rgba(127,29,29,.2)}.dark\:hover\:bg-red-900\/30:hover:is(.dark *){background-color:rgba(127,29,29,.3)}.dark\:hover\:text-red-300:hover:is(.dark *){--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.dark\:hover\:text-red-400:hover:is(.dark *){--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity,1))}.dark\:hover\:text-white:hover:is(.dark *){--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.group:hover .dark\:group-hover\:text-gray-400:is(.dark *){--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}@media (min-width:640px){.sm\:mt-0{margin-top:0}.sm\:block{display:block}.sm\:inline{display:inline}.sm\:h-\[250px\]{height:250px}.sm\:h-\[300px\]{height:300px}.sm\:h-\[350px\]{height:350px}.sm\:w-auto{width:auto}.sm\:max-w-xs{max-width:20rem}.sm\:flex-none{flex:none}.sm\:flex-row{flex-direction:row}.sm\:items-start{align-items:flex-start}.sm\:justify-start{justify-content:flex-start}.sm\:text-left{text-align:left}}@media (min-width:768px){.md\:mb-8{margin-bottom:2rem}.md\:h-12{height:3rem}.md\:h-16{height:4rem}.md\:h-\[300px\]{height:300px}.md\:h-\[400px\]{height:400px}.md\:h-\[450px\]{height:450px}.md\:w-12{width:3rem}.md\:w-16{width:4rem}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:gap-2{gap:.5rem}.md\:gap-3{gap:.75rem}.md\:gap-4{gap:1rem}.md\:p-4{padding:1rem}.md\:p-6{padding:1.5rem}.md\:px-4{padding-left:1rem;padding-right:1rem}.md\:px-6{padding-left:1.5rem;padding-right:1.5rem}.md\:py-3{padding-top:.75rem;padding-bottom:.75rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-4xl{font-size:2.25rem;line-height:2.5rem}.md\:text-base{font-size:1rem;line-height:1.5rem}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:text-xs{font-size:.75rem;line-height:1rem}}@media (min-width:1024px){.lg\:col-span-2{grid-column:span 2/span 2}.lg\:mx-12{margin-left:3rem;margin-right:3rem}.lg\:-mt-32{margin-top:-8rem}.lg\:block{display:block}.lg\:hidden{display:none}.lg\:h-56{height:14rem}.lg\:h-\[500px\]{height:500px}.lg\:h-\[70vh\]{height:70vh}.lg\:max-h-\[85vh\]{max-height:85vh}.lg\:min-h-\[500px\]{min-height:500px}.lg\:flex-none{flex:none}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.lg\:grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}.lg\:flex-row{flex-direction:row}.lg\:items-center{align-items:center}.lg\:rounded-3xl{border-radius:1.5rem}.lg\:p-10{padding:2.5rem}.lg\:p-12{padding:3rem}.lg\:p-4{padding:1rem}.lg\:p-8{padding:2rem}.lg\:px-12{padding-left:3rem;padding-right:3rem}.lg\:py-12{padding-top:3rem;padding-bottom:3rem}.lg\:text-2xl{font-size:1.5rem;line-height:2rem}.lg\:text-4xl{font-size:2.25rem;line-height:2.5rem}.lg\:text-5xl{font-size:3rem;line-height:1}.lg\:text-6xl{font-size:3.75rem;line-height:1}.lg\:text-xl{font-size:1.25rem;line-height:1.75rem}}