@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";/*! tailwindcss v4.1.13 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-duration:initial;--tw-ease:initial;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-50:oklch(97.1% .013 17.38);--color-red-100:oklch(93.6% .032 17.717);--color-red-200:oklch(88.5% .062 18.334);--color-red-300:oklch(80.8% .114 19.571);--color-red-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-green-50:oklch(98.2% .018 155.826);--color-green-100:oklch(96.2% .044 156.743);--color-green-200:oklch(92.5% .084 155.995);--color-green-300:oklch(87.1% .15 154.449);--color-green-400:oklch(79.2% .209 151.711);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-blue-200:oklch(88.2% .059 254.128);--color-blue-600:oklch(54.6% .245 262.881);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-4xl:56rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--text-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--leading-relaxed:1.625;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--ease-in-out:cubic-bezier(.4,0,.2,1);--animate-spin:spin 1s linear infinite;--animate-bounce:bounce 1s infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing)*0)}.top-0{top:calc(var(--spacing)*0)}.right-0{right:calc(var(--spacing)*0)}.left-0{left:calc(var(--spacing)*0)}.z-50{z-index:50}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-4{margin-inline:calc(var(--spacing)*4)}.mx-auto{margin-inline:auto}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-8{margin-top:calc(var(--spacing)*8)}.mr-2{margin-right:calc(var(--spacing)*2)}.mr-4{margin-right:calc(var(--spacing)*4)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.mb-8{margin-bottom:calc(var(--spacing)*8)}.ml-4{margin-left:calc(var(--spacing)*4)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.h-2{height:calc(var(--spacing)*2)}.h-3{height:calc(var(--spacing)*3)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-8{height:calc(var(--spacing)*8)}.h-10{height:calc(var(--spacing)*10)}.h-12{height:calc(var(--spacing)*12)}.h-16{height:calc(var(--spacing)*16)}.h-24{height:calc(var(--spacing)*24)}.h-full{height:100%}.min-h-\[60vh\]{min-height:60vh}.min-h-screen{min-height:100vh}.w-2{width:calc(var(--spacing)*2)}.w-3{width:calc(var(--spacing)*3)}.w-4{width:calc(var(--spacing)*4)}.w-5{width:calc(var(--spacing)*5)}.w-6{width:calc(var(--spacing)*6)}.w-8{width:calc(var(--spacing)*8)}.w-10{width:calc(var(--spacing)*10)}.w-12{width:calc(var(--spacing)*12)}.w-16{width:calc(var(--spacing)*16)}.w-24{width:calc(var(--spacing)*24)}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.max-w-4xl{max-width:var(--container-4xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-full{max-width:100%}.max-w-md{max-width:var(--container-md)}.min-w-0{min-width:calc(var(--spacing)*0)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.animate-bounce{animation:var(--animate-bounce)}.animate-spin{animation:var(--animate-spin)}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-1>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*1)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*1)*calc(1 - var(--tw-space-x-reverse)))}:where(.space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*2)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-x-reverse)))}:where(.space-x-3>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*3)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-x-reverse)))}:where(.space-x-4>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*4)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-x-reverse)))}.overflow-hidden{overflow:hidden}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-4{border-style:var(--tw-border-style);border-width:4px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-blue-200{border-color:var(--color-blue-200)}.border-gray-100{border-color:var(--color-gray-100)}.border-gray-200{border-color:var(--color-gray-200)}.border-gray-300{border-color:var(--color-gray-300)}.border-green-200{border-color:var(--color-green-200)}.border-green-300{border-color:var(--color-green-300)}.border-red-200{border-color:var(--color-red-200)}.border-red-300{border-color:var(--color-red-300)}.border-t-blue-600{border-top-color:var(--color-blue-600)}.border-t-green-400{border-top-color:var(--color-green-400)}.border-t-green-600{border-top-color:var(--color-green-600)}.border-t-red-500{border-top-color:var(--color-red-500)}.bg-black{background-color:var(--color-black)}.bg-blue-600{background-color:var(--color-blue-600)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-green-100{background-color:var(--color-green-100)}.bg-green-500{background-color:var(--color-green-500)}.bg-green-600{background-color:var(--color-green-600)}.bg-red-50{background-color:var(--color-red-50)}.bg-red-100{background-color:var(--color-red-100)}.bg-red-200{background-color:var(--color-red-200)}.bg-red-500{background-color:var(--color-red-500)}.bg-red-600{background-color:var(--color-red-600)}.bg-white{background-color:var(--color-white)}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-gray-50{--tw-gradient-from:var(--color-gray-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-green-50{--tw-gradient-from:var(--color-green-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.from-green-100{--tw-gradient-from:var(--color-green-100);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-gray-100{--tw-gradient-to:var(--color-gray-100);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-green-100{--tw-gradient-to:var(--color-green-100);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.to-green-200{--tw-gradient-to:var(--color-green-200);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position),var(--tw-gradient-from)var(--tw-gradient-from-position),var(--tw-gradient-to)var(--tw-gradient-to-position))}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.p-8{padding:calc(var(--spacing)*8)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-8{padding-inline:calc(var(--spacing)*8)}.py-1{padding-block:calc(var(--spacing)*1)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-2\.5{padding-block:calc(var(--spacing)*2.5)}.py-3{padding-block:calc(var(--spacing)*3)}.py-4{padding-block:calc(var(--spacing)*4)}.py-6{padding-block:calc(var(--spacing)*6)}.py-8{padding-block:calc(var(--spacing)*8)}.py-12{padding-block:calc(var(--spacing)*12)}.py-16{padding-block:calc(var(--spacing)*16)}.pt-4{padding-top:calc(var(--spacing)*4)}.pt-20{padding-top:calc(var(--spacing)*20)}.pb-8{padding-bottom:calc(var(--spacing)*8)}.text-center{text-align:center}.text-left{text-align:left}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-gray-300{color:var(--color-gray-300)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-800{color:var(--color-gray-800)}.text-green-400{color:var(--color-green-400)}.text-green-500{color:var(--color-green-500)}.text-green-600{color:var(--color-green-600)}.text-green-700{color:var(--color-green-700)}.text-red-400{color:var(--color-red-400)}.text-red-500{color:var(--color-red-500)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-white{color:var(--color-white)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a),0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-800{--tw-duration:.8s;transition-duration:.8s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media (hover:hover){.group-hover\:translate-x-1:is(:where(.group):hover *){--tw-translate-x:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-hover\/delete\:scale-110:is(:where(.group\/delete):hover *){--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:border-green-200:hover{border-color:var(--color-green-200)}.hover\:bg-gray-50:hover{background-color:var(--color-gray-50)}.hover\:bg-gray-200:hover{background-color:var(--color-gray-200)}.hover\:bg-green-50:hover{background-color:var(--color-green-50)}.hover\:bg-green-200:hover{background-color:var(--color-green-200)}.hover\:bg-green-600:hover{background-color:var(--color-green-600)}.hover\:bg-green-700:hover{background-color:var(--color-green-700)}.hover\:bg-red-50:hover{background-color:var(--color-red-50)}.hover\:bg-red-200:hover{background-color:var(--color-red-200)}.hover\:bg-red-300:hover{background-color:var(--color-red-300)}.hover\:bg-red-600:hover{background-color:var(--color-red-600)}.hover\:bg-red-700:hover{background-color:var(--color-red-700)}.hover\:text-gray-600:hover{color:var(--color-gray-600)}.hover\:text-gray-800:hover{color:var(--color-gray-800)}.hover\:text-green-600:hover{color:var(--color-green-600)}.hover\:text-green-700:hover{color:var(--color-green-700)}.hover\:text-red-600:hover{color:var(--color-red-600)}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:40rem){.sm\:h-12{height:calc(var(--spacing)*12)}.sm\:px-6{padding-inline:calc(var(--spacing)*6)}.sm\:py-4{padding-block:calc(var(--spacing)*4)}.sm\:py-8{padding-block:calc(var(--spacing)*8)}}@media (min-width:48rem){.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:64rem){.lg\:h-14{height:calc(var(--spacing)*14)}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:px-8{padding-inline:calc(var(--spacing)*8)}.lg\:py-6{padding-block:calc(var(--spacing)*6)}.lg\:py-12{padding-block:calc(var(--spacing)*12)}}.line-clamp-1{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.line-clamp-3{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.gradient-primary{background:linear-gradient(135deg,var(--color-main-green)0%,var(--color-deep-green)100%)}.gradient-secondary{background:linear-gradient(135deg,var(--color-light-green)0%,var(--color-main-green)100%)}.gradient-marine{background:linear-gradient(135deg,var(--color-marine-blue)0%,var(--color-rich-blue)100%)}.gradient-soft{background:linear-gradient(135deg,var(--color-lighter-green)0%,var(--color-light-white)100%)}.shadow-soft{box-shadow:0 2px 15px -3px #00000012,0 10px 20px -2px #0000000a}.shadow-medium{box-shadow:0 4px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.shadow-strong{box-shadow:0 10px 40px -10px #00000026,0 2px 10px -2px #0000000d}.animate-fade-in{animation:.5s ease-in-out fadeIn}.animate-slide-up{animation:.5s ease-out slideUp}.animate-bounce-in{animation:.6s ease-out bounceIn}.hover-lift{transition:transform .2s ease-in-out}.hover-lift:hover{transform:translateY(-2px)}.scrollbar-thin{scrollbar-width:thin;scrollbar-color:#cbd5e0 #f7fafc}.scrollbar-thin::-webkit-scrollbar{width:6px}.scrollbar-thin::-webkit-scrollbar-track{background:#f7fafc}.scrollbar-thin::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.scrollbar-thin::-webkit-scrollbar-thumb:hover{background:#a0aec0}}:root{--color-main-green:#64ab85;--color-deep-green:#3c7157;--color-light-green:#d4eee2;--color-lighter-green:#edf7f2;--color-light-white:#f9fafb;--color-light-gray:#9ca3af;--color-error-red:#ef4444;--color-success-green:#10b881;--color-marine-blue:#2b5288;--color-light-taube:#e5e0d9;--color-rich-blue:#191265;--color-pale-gray:#ebebdf;--color-musted-blush:#d1adb6;--color-light-periwinkle:#c5d1e8}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width:640px){.mobile-padding{padding-left:1rem;padding-right:1rem}.mobile-text-sm{font-size:.875rem}.mobile-text-base{font-size:1rem}.mobile-hidden{display:none}}@media (min-width:641px) and (max-width:1024px){.tablet-padding{padding-left:2rem;padding-right:2rem}.tablet-text-lg{font-size:1.125rem}.tablet-text-xl{font-size:1.25rem}}@media (min-width:1025px){.desktop-padding{padding-left:3rem;padding-right:3rem}.desktop-text-2xl{font-size:1.5rem}.desktop-text-3xl{font-size:1.875rem}}@media (hover:none) and (pointer:coarse){.btn-primary,.btn-secondary,.btn-outline,.btn-marine{min-height:3rem;padding:1rem 1.5rem}.navbar-nav-item{min-height:3rem;padding:.75rem 1rem}}.container-responsive{width:100%;max-width:80rem;margin:0 auto;padding:0 1rem}@media (min-width:640px){.container-responsive{padding:0 1.5rem}}@media (min-width:1024px){.container-responsive{padding:0 2rem}}.text-responsive-xs{font-size:.75rem}@media (min-width:640px){.text-responsive-xs{font-size:.875rem}}.text-responsive-sm{font-size:.875rem}@media (min-width:640px){.text-responsive-sm{font-size:1rem}}.text-responsive-base{font-size:1rem}@media (min-width:640px){.text-responsive-base{font-size:1.125rem}}.text-responsive-lg{font-size:1.125rem}@media (min-width:640px){.text-responsive-lg{font-size:1.25rem}}@media (min-width:1024px){.text-responsive-lg{font-size:1.5rem}}.text-responsive-xl{font-size:1.25rem}@media (min-width:640px){.text-responsive-xl{font-size:1.5rem}}@media (min-width:1024px){.text-responsive-xl{font-size:1.875rem}}.text-responsive-2xl{font-size:1.5rem}@media (min-width:640px){.text-responsive-2xl{font-size:1.875rem}}@media (min-width:1024px){.text-responsive-2xl{font-size:2.25rem}}.text-responsive-3xl{font-size:1.875rem}@media (min-width:640px){.text-responsive-3xl{font-size:2.25rem}}@media (min-width:1024px){.text-responsive-3xl{font-size:3rem}}.spacing-responsive-sm{padding:.5rem}@media (min-width:640px){.spacing-responsive-sm{padding:.75rem}}@media (min-width:1024px){.spacing-responsive-sm{padding:1rem}}.spacing-responsive-md{padding:1rem}@media (min-width:640px){.spacing-responsive-md{padding:1.5rem}}@media (min-width:1024px){.spacing-responsive-md{padding:2rem}}.spacing-responsive-lg{padding:1.5rem}@media (min-width:640px){.spacing-responsive-lg{padding:2rem}}@media (min-width:1024px){.spacing-responsive-lg{padding:3rem}}@media (prefers-color-scheme:dark){.dark-mode{color:#e2e8f0;background-color:#1a202c}}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.focus-visible:focus{outline-offset:2px;outline:2px solid #3b82f6}.btn-secondary{color:#3c7157;cursor:pointer;background-color:#d4eee2;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:500;transition:all .2s ease-in-out}.btn-secondary:hover,.btn-outline:hover{color:#fff;background-color:#64ab85;transform:translateY(-1px)}@media (min-width:1024px){.btn-outline{min-height:3.25rem;padding:1rem 2rem;font-size:1rem}}.btn-marine{color:#fff;cursor:pointer;background-color:#2b5288;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:500;transition:all .2s ease-in-out}.navbar{z-index:50;-webkit-backdrop-filter:blur();backdrop-filter:blur();background-color:#fff;border:1px solid #0000;width:100%;padding:.5rem 1.25rem .5rem .5rem;transition:all .3s;position:fixed;top:0;left:0;right:0}.navbar-container{width:100%;margin:0 auto;padding:1px .25rem}@media (min-width:640px){.navbar-container{padding:1px .25rem}}@media (min-width:1024px){.navbar-container{padding:1px 0}}.navbar-logo{flex:1;justify-content:flex-start;align-items:center;gap:.5rem;display:flex}.navbar-logo-icon{justify-content:center;align-items:center;width:4rem;height:4rem;display:flex}@media (min-width:640px){.navbar-logo-icon{width:4rem;height:4rem}}@media (min-width:1024px){.navbar-logo-icon{width:3rem;height:3rem}}.navbar-logo-text{color:#3c7157;font-size:1.25rem;font-weight:700;line-height:1.2}@media (min-width:640px){.navbar-logo-text{font-size:1.25rem}}@media (min-width:1024px){.navbar-logo-text{font-size:1.5rem}}.navbar-nav{align-items:center;gap:.75rem;margin-left:auto;display:none}.navbar-nav-center{flex:1;justify-content:center;align-items:center;gap:.75rem;display:none}@media (min-width:768px){.navbar-nav-center{display:flex}}.navbar-auth{flex:1;justify-content:flex-end;align-items:center;gap:.5rem;display:none}@media (min-width:768px){.navbar-auth{display:flex}}.navbar-auth-btn{cursor:pointer;color:#1f2937;background-color:#0000;border:none;border-radius:2.5rem;align-items:center;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s ease-in-out;display:flex}.navbar-login-btn{color:#1f2937}.navbar-login-btn:hover{color:#374151;background-color:#0000;font-weight:600}.navbar-signup-btn{color:#1f2937;background-color:#0000}.navbar-signup-btn:hover{color:#374151;background-color:#0000;font-weight:600}@media (min-width:1024px){.navbar-nav-center,.navbar-auth{display:flex}}.navbar-nav-item{color:#6b7280;background-color:#0000;border:none;border-radius:.75rem;align-items:center;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s ease-in-out;display:flex}.navbar-nav-item:hover,.navbar-nav-item.active{color:#1f2937;background-color:#0000;font-weight:600}@media (min-width:640px){.navbar-nav-item{font-size:.875rem}}@media (min-width:1024px){.navbar-nav-item{font-size:1rem}}.navbar-mobile-menu{z-index:40;background-color:#f9fafb;border-bottom:1px solid #edf7f2;position:absolute;top:100%;left:0;right:0;box-shadow:0 4px 6px -1px #0000001a}@media (min-width:1024px){.navbar-mobile-menu{display:none}}.btn-primary{color:#fff;cursor:pointer;background-color:#64ab85;border:none;border-radius:.5rem;min-height:2.75rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s ease-in-out}.btn-primary:hover{background-color:#3c7157;transform:translateY(-1px);box-shadow:0 4px 12px #64ab854d}.search-input-container{margin-bottom:2rem}.search-input-wrapper{max-width:600px;margin:0 auto;position:relative}.search-input-icon{color:#9ca3af;pointer-events:none;width:1.25rem;height:1.25rem;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.search-input{background-color:#fff;border:2px solid #e5e7eb;border-radius:.75rem;width:100%;padding:1rem 3rem;font-size:1rem;transition:all .2s ease-in-out;box-shadow:0 1px 3px #0000001a}.search-input:focus{border-color:#64ab85;outline:none;box-shadow:0 0 0 3px #64ab851a}.search-clear-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.25rem;transition:all .2s ease-in-out;display:flex;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.search-clear-btn:hover{color:#6b7280;background-color:#f3f4f6}.search-loading{position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.search-loading-content{text-align:center;color:#6b7280;padding:4rem 1rem}.search-loading-spinner{border:3px solid #e5e7eb;border-top-color:#64ab85;border-radius:50%;width:3rem;height:3rem;margin:0 auto 1rem;animation:1s linear infinite spin}.search-loading-text{color:#6b7280;margin:0;font-size:1rem}.search-spinner{border:2px solid #e5e7eb;border-top-color:#64ab85;border-radius:50%;width:1.25rem;height:1.25rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.search-content{min-height:400px;padding-bottom:5rem}.search-result-card-link{color:inherit;text-decoration:none;display:block}.search-result-card{cursor:pointer;background:#fff;border-radius:.75rem;flex-direction:column;height:100%;transition:all .2s ease-in-out;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000001a}.search-result-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.search-result-image{width:100%;height:200px;position:relative;overflow:hidden}.search-result-placeholder{background-color:#f3f4f6;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.search-result-content{flex-direction:column;flex:1;padding:1.25rem;display:flex}.search-result-title{color:#1f2937;margin-bottom:.5rem;font-size:1.125rem;font-weight:600;line-height:1.4}.search-result-address{color:#6b7280;margin-bottom:.75rem;font-size:.875rem}.search-result-description{color:#4b5563;flex:1;margin-bottom:1rem;font-size:.875rem;line-height:1.5}.search-result-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.search-result-tag{color:#3c7157;background-color:#edf7f2;border-radius:1rem;padding:.25rem .75rem;font-size:.75rem;font-weight:500}.search-result-actions{justify-content:flex-end;padding:0 1.25rem 1.25rem;display:flex}.search-results-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));justify-content:center;gap:1.5rem;width:100%;max-width:1200px;margin-top:1.5rem;margin-left:auto;margin-right:auto;display:grid}.search-results-header{text-align:center;margin-bottom:1rem}.search-results-title{color:#1f2937;font-size:1.25rem;font-weight:600}.recent-search-list{background:#fff;border-radius:.75rem;max-width:600px;margin:0 auto;overflow:hidden;box-shadow:0 1px 3px #0000001a}.recent-search-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:.75rem;display:flex}.recent-search-title{color:#1f2937;font-size:1.125rem;font-weight:600}.recent-search-clear-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s ease-in-out}.recent-search-clear-btn:hover{color:#ef4444;background-color:#fef2f2}.recent-search-items{display:block}.recent-search-item{border-bottom:1px solid #f3f4f6;align-items:center;padding:1rem 1.25rem;transition:background-color .2s ease-in-out;display:flex}.recent-search-item:last-child{border-bottom:none}.recent-search-item:hover{background-color:#f9fafb}.recent-search-image{border-radius:.5rem;flex-shrink:0;width:3rem;height:2rem;margin-right:1rem;overflow:hidden}.recent-search-placeholder{background-color:#f3f4f6;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.recent-search-content-link{color:inherit;flex:1;text-decoration:none;display:block}.recent-search-content{cursor:pointer;flex:1}.recent-search-item-title{color:#1f2937;margin:0;font-size:.875rem;font-weight:500}.recent-search-delete-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:.5rem;flex-shrink:0;padding:.5rem;transition:all .2s ease-in-out}.recent-search-delete-btn:hover{color:#ef4444;background-color:#fef2f2}.recent-search-empty{text-align:center;color:#6b7280;max-width:600px;margin:0 auto;padding:3rem 1rem}.recent-search-empty-icon{margin-bottom:1rem}.recent-search-empty-text{margin:0;font-size:1rem}.search-no-results{text-align:center;color:#6b7280;max-width:600px;margin:0 auto;padding:3rem 1rem}.search-no-results-icon{margin-bottom:1rem}.search-no-results-text{margin-bottom:.5rem;font-size:1.125rem;font-weight:500}.search-no-results-subtext{margin:0;font-size:.875rem}.search-error{text-align:center;color:#ef4444;max-width:600px;margin:0 auto;padding:3rem 1rem}.search-error-icon{margin-bottom:1rem}.search-error-text{margin:0;font-size:1rem}@media (max-width:640px){.search-results-grid{grid-template-columns:1fr;gap:1rem}.search-result-image{height:150px}.recent-search-items{display:block}.recent-search-item{padding:.75rem 1rem}.recent-search-image{width:2.5rem;height:2.5rem;margin-right:.75rem}}.error-boundary{background-color:#f5f5f5;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.error-content{text-align:center;background:#fff;border-radius:1rem;width:100%;max-width:400px;padding:3rem 2rem;box-shadow:0 4px 20px #0000001a}.error-content h2{color:#dc2626;margin-bottom:1rem;font-size:1.5rem;font-weight:700}.error-content p{color:#6b7280;margin-bottom:2rem;font-size:1rem;line-height:1.6}@media (min-width:640px){.btn-primary{min-height:3rem;padding:.875rem 1.75rem;font-size:1rem}}@media (min-width:1024px){.btn-primary{min-height:3.25rem;padding:1rem 2rem;font-size:1rem}}.btn-secondary{color:#3c7157;cursor:pointer;background-color:#d4eee2;border:none;border-radius:.5rem;min-height:2.75rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s ease-in-out}.btn-secondary:hover{color:#fff;background-color:#64ab85;transform:translateY(-1px);box-shadow:0 4px 12px #64ab854d}@media (min-width:640px){.btn-secondary{min-height:3rem;padding:.875rem 1.75rem;font-size:1rem}}@media (min-width:1024px){.btn-secondary{min-height:3.25rem;padding:1rem;font-size:1rem}}.btn-outline{color:#3c7157;cursor:pointer;background-color:#0000;border:2px solid #64ab85;border-radius:.5rem;min-height:2.75rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s ease-in-out}.btn-outline:hover{color:#fff;background-color:#64ab85;transform:translateY(-1px);box-shadow:0 4px 12px #64ab854d}@media (min-width:640px){.btn-outline{min-height:3rem;padding:.875rem 1.75rem;font-size:1rem}}@media (min-width:1024px){.btn-outline{min-height:3.25rem;padding:1rem;font-size:1rem}}.btn-marine{color:#fff;cursor:pointer;background-color:#2b5288;border:none;border-radius:.5rem;min-height:2.75rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s ease-in-out}.btn-marine:hover{background-color:#191265;transform:translateY(-1px);box-shadow:0 4px 12px #2b52884d}@media (min-width:640px){.btn-marine{min-height:3rem;padding:.875rem 1.75rem;font-size:1rem}}@media (min-width:1024px){.btn-marine{min-height:3.25rem;padding:1rem 2rem;font-size:1rem}}@media (hover:none) and (pointer:coarse){.btn-primary,.btn-secondary,.btn-outline,.btn-marine{min-height:3rem;padding:1rem 1.5rem}}.btn-primary:focus,.btn-secondary:focus,.btn-outline:focus,.btn-marine:focus{outline-offset:2px;outline:2px solid #64ab85}.btn-primary:disabled,.btn-secondary:disabled,.btn-outline:disabled,.btn-marine:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary:disabled:hover,.btn-secondary:disabled:hover,.btn-outline:disabled:hover,.btn-marine:disabled:hover{box-shadow:none;transform:none}.location-card{cursor:pointer;background-color:#fff;border-radius:1rem;transition:all .3s;overflow:hidden;box-shadow:0 2px 8px #0000001a}.location-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026}.location-image-container{width:100%;height:200px;position:relative;overflow:hidden}.location-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;transition:transform .3s}.location-card:hover .location-image{transform:scale(1.05)}.location-favorite-btn{cursor:pointer;color:#6b7280;background-color:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;transition:all .2s;display:flex;position:absolute;top:.75rem;right:.75rem}.location-favorite-btn:hover{color:#ef4444;background-color:#fff;transform:scale(1.1)}.location-info{padding:1.25rem}.location-name{color:#1f2937;margin-bottom:.5rem;font-size:1.125rem;font-weight:600;line-height:1.4}.location-address{color:#6b7280;margin-bottom:.75rem;font-size:.875rem;line-height:1.4}.location-rating{align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.rating-stars{gap:.125rem;display:flex}.star{color:#d1d5db;font-size:.875rem}.star.filled{color:#fbbf24}.rating-text{color:#6b7280;font-size:.875rem;font-weight:500}.location-tags{flex-wrap:wrap;gap:.5rem;display:flex}.location-tag{color:#3c7157;background-color:#edf7f2;border-radius:1rem;padding:.25rem .75rem;font-size:.75rem;font-weight:500}.random-locations{max-width:1200px;margin-bottom:0;margin-left:auto;margin-right:auto}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.section-title{color:#1f2937;font-size:1.5rem;font-weight:700}.refresh-btn{color:#6b7280;cursor:pointer;background-color:#0000;border:1px solid #d1d5db;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.refresh-btn:hover{color:#374151;background-color:#f9fafb;border-color:#9ca3af}.locations-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}@media (min-width:640px){.locations-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}}@media (min-width:1024px){.locations-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}}.loading-container,.error-container,.empty-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:3rem 1rem;display:flex}.loading-container{gap:1rem}.loading-spinner{border:3px solid #e5e7eb;border-top-color:#3c7157;border-radius:50%;width:2rem;height:2rem;margin-bottom:1rem;animation:1s linear infinite spin}.loading-spinner-text{color:#6b7280;margin:0;font-size:1rem;animation:none}.loading-text,.error-text,.empty-text{color:#6b7280;margin-bottom:1rem;font-size:1rem}.error-text{color:#ef4444}.location-slider{width:100vw;height:80vh;min-height:600px;box-shadow:none;border-radius:0;margin-bottom:0;margin-left:calc(50% - 50vw);overflow:hidden}.slider-container{width:100%;height:100%;transition:all .3s;display:flex}.slider-container.transitioning{opacity:.9;transform:scale(.98)}.slider-text-section{flex-direction:column;flex:1;justify-content:space-between;padding:3rem 3rem 3rem 4rem;transition:background-color .5s;display:flex}.slider-text-content{flex-direction:column;flex:1;justify-content:center;display:flex}.slider-category{margin-bottom:1.5rem}.category-label{color:#fff;letter-spacing:.05em;background-color:#000c;border-radius:1rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600}.slider-main-title{color:#374151;margin-bottom:1rem;font-size:2.5rem;font-weight:800;line-height:1.1}.slider-subtitle{color:#6b7280;margin-bottom:2rem;font-size:1.5rem;line-height:1.4}.slider-link{color:#4b5563;cursor:pointer;align-items:center;gap:.5rem;font-weight:600;text-decoration:none;transition:all .3s;display:flex}.slider-link:hover{color:#3c7157;transform:translate(.25rem)}.link-arrow{width:1rem;height:1rem;transition:transform .3s}.slider-link:hover .link-arrow{transform:translate(.25rem)}.slider-bottom-nav{align-items:center;gap:1.5rem;display:flex}.slider-progress{background-color:#0000001a;border-radius:2px;flex:1;height:4px;overflow:hidden}.slider-counter{color:#6b7280;text-align:center;min-width:4rem;font-size:.875rem;font-weight:600}.slider-controls{gap:.5rem;display:flex}.nav-btn{cursor:pointer;color:#6b7280;background-color:#fff;border:1px solid #d1d5db;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;transition:all .3s;display:flex}.nav-btn:hover{color:#fff;background-color:#3c7157;border-color:#3c7157;transform:scale(1.05)}.slider-image-section{flex:1;position:relative;overflow:hidden}.slider-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;transition:all .8s ease-in-out}.slider-image-section:hover .slider-image{transform:scale(1.05)}.slider-container.transitioning .slider-image{opacity:.8;transform:scale(1.1)}.image-overlay{z-index:2;position:absolute;top:2rem;right:2rem}.overlay-text{color:#fffc;text-shadow:1px 1px 2px #00000080;writing-mode:vertical-rl;text-orientation:mixed;font-size:1rem;font-weight:500}.slider-loading,.slider-error{background-color:#f5f5f5;border-radius:1.5rem;flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex}.live-recommendations-sidebar{max-width:280px;position:sticky;top:.5rem}.live-recommendations-card{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:1px solid #e2e8f0;border-radius:.75rem;max-height:70vh;padding:1rem;overflow-y:auto;box-shadow:0 2px 4px #00000014}.live-recommendations-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.live-recommendations-title{color:#1e293b;align-items:center;gap:.5rem;margin:0;font-size:1.125rem;font-weight:600;display:flex}.live-icon{font-size:1.25rem;animation:2s infinite pulse}@keyframes pulse{50%{opacity:.5}}.live-loading{align-items:center;gap:.5rem;display:flex}.loading-spinner{border:2px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:16px;height:16px;animation:1s linear infinite spin}.live-recommendations-list{flex-direction:column;gap:1rem;display:flex}.live-recommendation-item-detailed{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;gap:.5rem;padding:.75rem;transition:all .2s;display:flex;position:relative}.live-recommendation-item-detailed:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.live-recommendation-content{flex:1}.live-recommendation-title{color:#1e293b;margin:0 0 .25rem;font-size:.8rem;font-weight:600;line-height:1.2}.live-recommendation-city{color:#64748b;margin:0;font-size:.7rem}.live-recommendation-rank{color:#fff;z-index:1;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;font-weight:600;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 4px #0003}.live-recommendation-image{background:#f1f5f9;border-radius:.375rem;flex-shrink:0;width:60px;height:60px;position:relative;overflow:hidden}.live-recommendation-image img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.image-placeholder{color:#64748b;background:#f1f5f9;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.5rem;display:flex}.image-loading{background:#f1f5f9;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.live-recommendation-overview{color:#64748b;margin:.25rem 0 0;font-size:.7rem;line-height:1.3}.live-error{text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;padding:1rem}.live-error p{color:#dc2626;margin:0;font-size:.875rem}.live-no-results{text-align:center;color:#64748b;padding:1.5rem}.live-no-results p{margin:0;font-size:.875rem}@media (max-width:1024px){.recommendation-main-web{grid-template-columns:1fr;gap:1rem}.live-recommendations-sidebar{order:-1;max-width:none;position:static}.live-recommendations-card{max-height:400px}}@media (max-width:768px){.live-recommendations-card{padding:1rem}.live-recommendations-title{font-size:1rem}.live-recommendation-item-detailed{gap:.5rem;padding:.75rem}.live-recommendation-image{width:60px;height:60px}.live-recommendation-title{font-size:.8rem}.live-recommendation-city,.live-recommendation-overview{font-size:.7rem}.live-recommendation-rank{width:24px;height:24px;font-size:.7rem}}@media (max-width:1024px){.slider-text-section{padding:2rem 2rem 2rem 3rem}.slider-main-title{font-size:2.5rem}.slider-subtitle{font-size:1.25rem}}@media (max-width:768px){.location-slider{height:70vh;min-height:500px}.slider-container{flex-direction:column}.slider-text-section{flex:0 0 50%;padding:1.5rem 1.5rem 1.5rem 2rem}.slider-image-section{flex:0 0 50%}.slider-main-title{font-size:2rem}.slider-subtitle{font-size:1rem}.slider-bottom-nav{gap:1rem}.nav-btn{width:2rem;height:2rem}.image-overlay{top:1rem;right:1rem}.overlay-text{font-size:.875rem}}@media (max-width:480px){.location-slider{height:60vh;min-height:400px}.slider-text-section{padding:1rem 1rem 1rem 1.5rem}.slider-main-title{font-size:1.5rem}.slider-subtitle{font-size:.875rem}.slider-bottom-nav{flex-direction:column;align-items:flex-start;gap:.75rem}.slider-progress{order:1;width:100%}.slider-counter{order:2;min-width:auto}.slider-controls{order:3}}.auth-container{background:#f8f8f8;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.auth-card{background:#fff;border:1px solid #edf7f2;border-radius:16px;width:100%;max-width:500px;padding:2.5rem 2rem;box-shadow:0 4px 12px #0000000d}.auth-header{text-align:center;margin-bottom:2rem}.auth-title{color:#333;margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.auth-subtitle{color:#9ca3af;margin-bottom:0;font-size:.875rem}.auth-form-group{margin-bottom:1.25rem}.auth-label{color:#333;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.auth-input{background:#fff;border:1px solid #e0e0e0;border-radius:8px;width:100%;padding:.75rem 1rem;font-size:.875rem;transition:all .2s}.auth-input:focus{border-color:#66bb6a;outline:none;box-shadow:0 0 0 2px #66bb6a1a}.auth-input.error{background:#fef2f2;border-color:#ef4444}.auth-input.error:focus{box-shadow:0 0 0 2px #ef44441a}.auth-input-group{position:relative}.auth-password-toggle{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem;transition:color .2s;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.auth-password-toggle:hover{color:#64ab85}.auth-error-message{color:#ef4444;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.auth-button{color:#fff;cursor:pointer;background:#66bb6a;border:none;border-radius:8px;width:100%;padding:.875rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s}.auth-button:hover:not(:disabled){background:#4caf50}.auth-button:active:not(:disabled){transform:translateY(1px)}.auth-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-button-loading{justify-content:center;align-items:center;display:flex}.auth-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:1rem;height:1rem;margin-right:.5rem;animation:1s linear infinite spin}.auth-link{color:#66bb6a;font-weight:500;text-decoration:none;transition:color .2s}.auth-link:hover{color:#4caf50;text-decoration:underline}.auth-footer{text-align:center;border-top:1px solid #edf7f2;margin-top:1.5rem;padding-top:1rem}.auth-footer-link{color:#999;font-size:.875rem;text-decoration:none;transition:color .2s}.auth-footer-link:hover{color:#66bb6a}@media (max-width:640px){.auth-container{padding:1rem}.auth-card{border-radius:12px;padding:2rem 1.5rem}.auth-title{font-size:1.375rem}}.like-button{color:#6b7280;cursor:pointer;background-color:#0000;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex;position:relative}.like-button:hover,.like-button.liked{color:#ef4444;background-color:#fef2f2}.like-button.liked:hover{color:#dc2626;background-color:#fee2e2}.like-button-disabled{opacity:.5;cursor:not-allowed}.like-button-disabled:hover{color:#6b7280;background-color:#0000}.like-button.toggling{opacity:.7;cursor:not-allowed}.like-icon{width:1.25rem;height:1.25rem;transition:transform .2s}.like-button:hover .like-icon{transform:scale(1.1)}.like-button.liked .like-icon{animation:.6s ease-in-out heartBeat}.like-count{text-align:center;min-width:1rem;font-size:.75rem;font-weight:600}.like-loading{font-size:.75rem;animation:1s infinite pulse;position:absolute;right:.5rem}.like-button-small{padding:.25rem .5rem;font-size:.75rem}.like-button-small .like-icon{width:1rem;height:1rem}.like-button-large{padding:.75rem 1.5rem;font-size:1rem}.like-button-large .like-icon{width:1.5rem;height:1.5rem}@keyframes heartBeat{0%{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(1)}75%{transform:scale(1.1)}to{transform:scale(1)}}.favorite-card{cursor:pointer;background:#fff;border-radius:.75rem;flex-direction:column;height:100%;transition:all .2s ease-in-out;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000001a}.favorite-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.favorite-card-image{width:100%;height:200px;position:relative;overflow:hidden}.favorite-card-img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;transition:transform .3s}.favorite-card:hover .favorite-card-img{transform:scale(1.05)}.favorite-card-placeholder{background-color:#f3f4f6;justify-content:center;align-items:center;width:100%;height:100%;font-size:3rem;display:flex}.favorite-card-content{flex-direction:column;flex:1;padding:1.25rem;display:flex}.favorite-card-title{color:#1f2937;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.5rem;font-size:1.125rem;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.favorite-card-title:hover{color:#3c7157}.favorite-card-address{color:#6b7280;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;margin-bottom:.75rem;font-size:.875rem;display:-webkit-box;overflow:hidden}.favorite-card-actions{justify-content:flex-end;align-items:center;padding:0 1.25rem 1.25rem;display:flex}@media (max-width:640px){.favorite-card-image{height:150px}.favorite-card-content{padding:1rem}.favorite-card-title{font-size:1rem}}.login-popup-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.login-popup{background:#fff;border-radius:1rem;width:100%;max-width:400px;max-height:90vh;animation:.3s ease-out popupSlideIn;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}@keyframes popupSlideIn{0%{opacity:0;transform:scale(.9)translateY(-20px)}to{opacity:1;transform:scale(1)translateY(0)}}.login-popup-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:1.5rem 1.5rem 0;display:flex}.login-popup-title{color:#1f2937;margin:0;font-size:1.25rem;font-weight:600}.login-popup-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.login-popup-close:hover{color:#374151;background-color:#f3f4f6}.login-popup-content{text-align:center;padding:0 1.5rem 1.5rem}.login-popup-message{color:#6b7280;margin:0;font-size:1rem;line-height:1.5}.login-popup-actions{gap:.75rem;padding:0 1.5rem 1.5rem;display:flex}.login-popup-cancel{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:.5rem;flex:1;padding:.75rem 1rem;font-weight:500;transition:all .2s}.login-popup-cancel:hover{background-color:#f9fafb;border-color:#9ca3af}.login-popup-login{color:#fff;text-align:center;cursor:pointer;background-color:#64ab85;border:none;border-radius:.5rem;flex:1;justify-content:center;align-items:center;padding:.75rem 1rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.login-popup-login:hover{background-color:#3c7157;transform:translateY(-1px);box-shadow:0 4px 12px #64ab854d}@media (max-width:640px){.login-popup{max-width:none;margin:1rem}.login-popup-header{padding:1rem 1rem 0}.login-popup-content{padding:0 1rem 1rem}.login-popup-actions{flex-direction:column;padding:0 1rem 1rem}.login-popup-cancel,.login-popup-login{flex:none}}.location-detail-container{flex-direction:column;align-items:center;max-width:100%;margin:0 auto;display:flex}.location-detail-loading{text-align:center;color:#6b7280;width:100%;padding:4rem 1rem}.location-detail-spinner{border:3px solid #e5e7eb;border-top-color:#64ab85;border-radius:50%;width:3rem;height:3rem;margin:0 auto 1rem;animation:1s linear infinite spin}.location-detail-error{text-align:center;color:#ef4444;width:100%;padding:4rem 1rem}.location-detail-error-icon{margin-bottom:1rem}.location-detail-error-title{color:#1f2937;margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.location-detail-error-text{color:#6b7280;margin-bottom:2rem;font-size:1rem}.location-detail-back-btn{color:#fff;cursor:pointer;background-color:#64ab85;border:none;border-radius:.5rem;align-self:flex-start;align-items:center;padding:.75rem 1.5rem;font-weight:500;transition:all .2s ease-in-out;display:inline-flex}.location-detail-back-btn:hover{background-color:#3c7157;transform:translateY(-1px)}.location-detail-header{box-shadow:none;background:0 0;border-radius:0;width:100%;margin-bottom:2rem;padding:2rem;overflow:visible}.location-detail-image{border-radius:0;width:60%;height:60%;margin:1rem auto 0;position:relative;overflow:hidden}.location-detail-placeholder{background-color:#f3f4f6;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.location-detail-info{padding:0}.location-detail-title-section{width:60%!important;margin-bottom:1rem!important;margin-left:auto!important;margin-right:auto!important;padding:0 1rem!important}.location-detail-title{color:#1f2937;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.5rem;font-weight:700;line-height:1.3;overflow:hidden}.location-detail-title-actions{align-items:center;gap:.75rem;display:flex}.location-detail-share-btn-small{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:.5rem;justify-content:center;align-items:center;min-width:2.5rem;height:2.5rem;padding:.5rem;transition:all .2s ease-in-out;display:flex}.location-detail-share-btn-small:hover{color:#64ab85;background-color:#edf7f2}.location-detail-address{color:#6b7280;justify-content:center;align-items:center;margin-bottom:1rem;font-size:1rem;display:flex}.location-detail-address svg{flex-shrink:0;margin-right:.5rem}.location-detail-tags{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:2rem;display:flex}.location-detail-tag{color:#3c7157;background-color:#edf7f2;border-radius:1.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500}.location-detail-actions{justify-content:center;gap:1rem;display:flex}.location-detail-action-btn{color:#374151;cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;align-items:center;padding:.75rem 1.5rem;font-weight:500;transition:all .2s ease-in-out;display:flex}.location-detail-action-btn svg{margin-right:.5rem}.location-detail-favorite-btn:hover{color:#ef4444;background-color:#fef2f2;border-color:#ef4444}.location-detail-share-btn:hover{color:#64ab85;background-color:#edf7f2;border-color:#64ab85}.location-detail-tabs{background:#fff;border-radius:.75rem;justify-content:center;width:60%;margin:0 auto 2rem;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000001a}.location-detail-tab{color:#6b7280;cursor:pointer;background:#fff;border:none;border-bottom:3px solid #0000;flex:1;padding:1rem 1.5rem;font-weight:500;transition:all .2s ease-in-out}.location-detail-tab:hover{color:#374151;background-color:#f9fafb}.location-detail-tab.active{color:#64ab85;background-color:#f9fafb;border-bottom-color:#64ab85}.location-detail-content{background:#fff;border-radius:.75rem;width:60%;margin:0 auto;padding:2rem;box-shadow:0 1px 3px #0000001a}.location-detail-content-title{color:#1f2937;margin-bottom:1.5rem;font-size:1.5rem;font-weight:600}.location-detail-overview-text{color:#4b5563;font-size:1rem;line-height:1.7}.location-detail-no-content{text-align:center;color:#9ca3af;padding:3rem 1rem;font-style:italic}.location-detail-info-grid{gap:1.5rem;display:grid}.location-detail-info-item{flex-direction:column;gap:.5rem;display:flex}.location-detail-info-label{color:#374151;text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:600}.location-detail-info-value{color:#4b5563;font-size:1rem}.location-detail-info-link{color:#64ab85;word-break:break-all;background:#f0f9f4;border:1px solid #64ab85;border-radius:.5rem;max-width:100%;padding:.5rem 1rem;font-size:.9rem;text-decoration:none;transition:all .2s;display:inline-block}.location-detail-info-link:hover{color:#fff;background:#64ab85;text-decoration:none;transform:translateY(-1px);box-shadow:0 2px 8px #64ab854d}.location-detail-analysis-tab{padding:1.5rem}.location-detail-analysis-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1rem;display:grid}.location-detail-analysis-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.25rem;transition:all .2s}.location-detail-analysis-item:hover{border-color:#64ab85;box-shadow:0 4px 12px #64ab851a}.location-detail-analysis-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.location-detail-analysis-title{color:#1f2937;font-size:1.125rem;font-weight:600}.location-detail-analysis-content{flex-direction:column;gap:.75rem;display:flex}.location-detail-analysis-stats{flex-direction:column;gap:.5rem;display:flex}.location-detail-analysis-stat{color:#6b7280;align-items:center;font-size:.875rem;display:flex}.location-detail-analysis-bar{background-color:#e5e7eb;border-radius:.25rem;width:100%;height:.5rem;overflow:hidden}.location-detail-analysis-progress{background:linear-gradient(90deg,#64ab85,#3c7157);border-radius:.25rem;height:100%;transition:width .3s}.location-detail-keywords-container{flex-direction:column;gap:1.5rem;margin-top:1rem;display:flex}.location-detail-no-keywords{text-align:center;color:#9ca3af;padding:3rem 1rem}.location-detail-keyword-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1.25rem;transition:all .2s}.location-detail-keyword-item:hover{border-color:#64ab85;box-shadow:0 4px 12px #64ab851a}.location-detail-keyword-header{margin-bottom:1rem}.location-detail-keyword-name{color:#1f2937;text-align:center;margin:0;font-size:1.125rem;font-weight:600}.location-detail-keyword-analysis{flex-direction:column;gap:.75rem;display:flex}.location-detail-keyword-percentages{justify-content:space-between;align-items:center;font-size:.75rem;font-weight:500;display:flex}.location-detail-keyword-percentage{align-items:center;gap:.25rem;display:flex}.location-detail-keyword-percentage.negative{color:#ef4444}.location-detail-keyword-percentage.neutral{color:#6b7280}.location-detail-keyword-percentage.positive{color:#10b981}.location-detail-keyword-bar{background:#f3f4f6;border-radius:.5rem;height:1rem;display:flex;overflow:hidden}.location-detail-keyword-segment{height:100%;transition:width .3s}.location-detail-keyword-segment.negative{background:#ef4444}.location-detail-keyword-segment.neutral{background:#6b7280}.location-detail-keyword-segment.positive{background:#10b981}.llm-overview-section{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:1px solid #cbd5e1;border-radius:1rem;margin-bottom:2rem;padding:2rem;position:relative;overflow:hidden}.llm-overview-section:before{content:"";background:linear-gradient(90deg,#64ab85,#3c7157,#64ab85) 0 0/200% 100%;height:4px;animation:3s ease-in-out infinite shimmer;position:absolute;top:0;left:0;right:0}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.llm-overview-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.llm-overview-header .location-detail-content-title{color:#1e293b;align-items:center;gap:.75rem;margin:0;font-size:1.5rem;font-weight:700;display:flex}.llm-icon{filter:drop-shadow(0 2px 4px #0000001a);font-size:1.75rem}.llm-badge{color:#fff;letter-spacing:.05em;background:linear-gradient(135deg,#64ab85,#3c7157);border-radius:2rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;box-shadow:0 2px 8px #64ab854d}.llm-overview-content{position:relative}.llm-overview-text{color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;margin:0;padding:1.5rem;font-size:1.125rem;line-height:1.7;position:relative;box-shadow:0 2px 8px #0000000d}.llm-overview-text:before{content:'"';color:#64ab85;opacity:.3;font-family:serif;font-size:3rem;line-height:1;position:absolute;top:-.5rem;left:1rem}.llm-overview-text:after{content:'"';color:#64ab85;opacity:.3;font-family:serif;font-size:3rem;line-height:1;position:absolute;bottom:-1.5rem;right:1rem}.original-overview-section{margin-top:1rem}.original-overview-section .location-detail-content-title{color:#6b7280;margin-bottom:1rem;font-size:1.25rem;font-weight:600}.location-description-section{margin-bottom:2rem}.location-description-content{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;margin-top:1rem;padding:1.5rem}.location-description-text{color:#374151;white-space:pre-wrap;margin:0;font-size:1rem;line-height:1.7}.location-basic-info-section{margin-top:2rem}.location-basic-info-section .location-detail-content-title{color:#6b7280;margin-bottom:1rem;font-size:1.25rem;font-weight:600}@media (max-width:768px){.location-detail-title{font-size:1.125rem}.location-detail-title-actions{gap:.5rem}.location-detail-title-section{width:80%}.location-detail-title-section .flex{gap:.5rem}.location-detail-analysis-grid{grid-template-columns:1fr;gap:1rem}.location-detail-analysis-item{padding:1rem}.location-detail-keywords-container{gap:1rem}.location-detail-keyword-item{padding:1rem}.location-detail-keyword-percentages{flex-direction:column;align-items:flex-start;gap:.25rem}.location-detail-keyword-percentage{font-size:.75rem}.location-detail-image{width:80%;height:150px;margin:1rem auto 0}.location-detail-info{padding:1.5rem}.location-detail-tabs{flex-direction:column;justify-content:center;width:80%;margin:0 auto 1.5rem}.location-detail-tab{border-bottom:none;border-right:3px solid #0000}.location-detail-tab.active{border-bottom-color:#0000;border-right-color:#64ab85}.location-detail-content{width:80%;margin:0 auto;padding:1.5rem}.llm-overview-section{margin-bottom:1.5rem;padding:1.5rem}.llm-overview-header{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:1rem}.llm-overview-header .location-detail-content-title{font-size:1.25rem}.llm-icon{font-size:1.5rem}.llm-badge{align-self:flex-end;padding:.375rem .75rem;font-size:.75rem}.llm-overview-text{padding:1rem;font-size:1rem;line-height:1.6}.llm-overview-text:before,.llm-overview-text:after{font-size:2rem}.llm-overview-text:before{top:-.25rem;left:.75rem}.llm-overview-text:after{bottom:-1rem;right:.75rem}.location-description-section{margin-bottom:1.5rem}.location-description-content{padding:1rem}.location-description-text{font-size:.9rem;line-height:1.6}.location-basic-info-section{margin-top:1.5rem}.location-basic-info-section .location-detail-content-title{font-size:1.125rem}.location-detail-info-link{word-break:break-all;padding:.375rem .75rem;font-size:.8rem}}.review-section{padding:0}.review-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.review-title{color:#1f2937;margin:0;font-size:1.5rem;font-weight:600}.review-write-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#64ab85,#3c7157);border:none;border-radius:.75rem;align-items:center;gap:.5rem;padding:.875rem 2rem;font-size:.95rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 2px 8px #64ab854d}.review-write-btn:hover{background:linear-gradient(135deg,#3c7157,#2d5a47);transform:translateY(-2px);box-shadow:0 4px 12px #64ab8566}.review-write-btn:active{transform:translateY(0);box-shadow:0 2px 6px #64ab854d}.review-form{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;margin-bottom:2rem;padding:1.5rem}.review-textarea{resize:vertical;border:1px solid #d1d5db;border-radius:.5rem;width:100%;min-height:120px;margin-bottom:1rem;padding:1rem;font-family:inherit;font-size:1rem;line-height:1.5}.review-textarea:focus{border-color:#64ab85;outline:none;box-shadow:0 0 0 3px #64ab851a}.review-form-actions{justify-content:flex-end;gap:.75rem;display:flex}.review-cancel-btn{color:#fff;cursor:pointer;background-color:#6b7280;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:500;transition:all .2s}.review-cancel-btn:hover{background-color:#4b5563}.review-submit-btn{color:#fff;cursor:pointer;background-color:#64ab85;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:500;transition:all .2s}.review-submit-btn:hover:not(:disabled){background-color:#3c7157}.review-submit-btn:disabled{cursor:not-allowed;background-color:#9ca3af}.review-delete-btn{color:#fff;cursor:pointer;background-color:#ef4444;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:500;transition:all .2s}.review-delete-btn:hover:not(:disabled){background-color:#dc2626}.review-delete-btn:disabled{cursor:not-allowed;background-color:#9ca3af}.review-login-prompt{text-align:center;background-color:#fef3c7;border:1px solid #f59e0b;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.review-login-prompt p{color:#92400e;margin:0;font-weight:500}.review-list{flex-direction:column;gap:1rem;display:flex}.review-item{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.review-item-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.review-item-actions{align-items:center;gap:1rem;display:flex}.review-edit-actions{gap:.5rem;display:flex}.review-edit-btn{color:#fff;cursor:pointer;background-color:#64ab85;border:none;border-radius:.25rem;padding:.25rem .75rem;font-size:.875rem;font-weight:500;transition:all .2s}.review-edit-btn:hover{background-color:#3c7157}.review-delete-btn-small{color:#fff;cursor:pointer;background-color:#ef4444;border:none;border-radius:.25rem;padding:.25rem .75rem;font-size:.875rem;font-weight:500;transition:all .2s}.review-delete-btn-small:hover{background-color:#dc2626}.review-date{color:#6b7280;font-size:.875rem}.review-content{color:#374151;white-space:pre-wrap;line-height:1.6}.review-empty{text-align:center;color:#6b7280;padding:3rem 1rem}.review-empty p{margin:.5rem 0}.review-loading{text-align:center;color:#6b7280;padding:2rem}.my-review-section{background-color:#f9fafb;border-radius:.75rem;margin-bottom:1.5rem;padding:1.5rem}.my-review-header{margin-bottom:.5rem}.my-review-title{color:#1f2937;margin:0;font-size:1.125rem;font-weight:600}.my-review-content{flex-direction:column;gap:1rem;display:flex}.my-review-text{color:#1f2937;background-color:#e5e7eb;border-radius:.5rem;padding:.75rem;font-size:.875rem;line-height:1.5}.my-review-edit-btn{color:#fff;cursor:pointer;background-color:#64ab85;border:none;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.my-review-edit-btn:hover{background-color:#4a8b6b}.my-review-analyze-btn{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.my-review-analyze-btn:hover:not(:disabled){background-color:#2563eb}.my-review-analyze-btn:disabled{cursor:not-allowed;background-color:#9ca3af}.my-review-actions{gap:.75rem;margin-top:.75rem;display:flex}.my-review-delete-btn{color:#fff;cursor:pointer;background-color:#dc2626;border:none;border-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.my-review-delete-btn:hover{background-color:#b91c1c}.sentiment-result{background-color:#fff;border:1px solid #d1d5db;border-radius:.75rem;margin-top:.75rem;padding:1rem}.sentiment-title{color:#1f2937;margin:0 0 .5rem;font-size:.9375rem;font-weight:600}.sentiment-tag{color:#1f2937;border-radius:.5rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500}.sentiment-tag.sentiment-pos{color:#166534;background-color:#dcfce7}.sentiment-tag.sentiment-neg{color:#991b1b;background-color:#fee2e2}.sentiment-tag.sentiment-none{color:#6b7280;background-color:#f3f4f6}.sentiment-loading{text-align:center;color:#6b7280;padding:1rem;font-size:.875rem}.recommendation-page{background-color:#f5f5f5;min-height:100vh;padding:1rem}.recommendation-container{max-width:600px;margin:0 auto;padding:2rem 1rem}.recommendation-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.recommendation-header h1{color:#64ab85;margin:0;font-size:1.5rem;font-weight:700}.back-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:1rem}.back-btn:hover{color:#64ab85}.recommendation-content{background:#fff;border-radius:1rem;max-width:800px;margin:2rem auto;padding:3rem 2rem;box-shadow:0 4px 6px -1px #0000001a}.recommendation-content h2{text-align:center;color:#1f2937;margin-bottom:3rem;font-size:1.5rem;font-weight:700}.previous-selections{margin-bottom:2rem}.selection-item{background-color:#f9fafb;border:1px solid #64ab85;border-radius:.5rem;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:1rem;display:flex}.selection-tag{color:#fff;cursor:pointer;background-color:#64ab85;border:none;border-radius:1rem;padding:.5rem 1rem;font-size:.875rem}.keyword-selection{margin-bottom:2rem}.keyword-grid{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;display:flex}.keyword-btn{color:#64ab85;cursor:pointer;white-space:nowrap;background-color:#e5f3e5;border:none;border-radius:.75rem;min-width:140px;height:60px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s}.keyword-btn:hover{background-color:#d1e7dd}.keyword-btn.selected{color:#fff;background-color:#64ab85}.keyword-btn.none-option{color:#374151;background-color:#e5e7eb;min-width:140px;height:60px}.keyword-btn.none-option.selected{color:#fff;background-color:#64ab85}.features-header{text-align:center;margin-bottom:2rem}.features-header h2{color:#1f2937;text-align:center;margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.features-header p{color:#6b7280;text-align:center;margin:0;font-size:.9rem}.features-grid{grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(2,1fr);gap:.75rem;max-width:400px;margin-bottom:2rem;margin-left:auto;margin-right:auto;display:grid}.feature-btn{color:#374151;cursor:pointer;background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;justify-content:center;align-items:center;height:60px;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.feature-btn:hover{background-color:#64ab850d;border-color:#64ab85}.feature-btn.selected{color:#64ab85;background-color:#64ab8526;border-color:#64ab85;font-weight:600}.features-actions{text-align:center}.features-submit-btn{color:#fff;cursor:pointer;background-color:#3b82f6;border:2px solid #64ab85;border-radius:.75rem;width:100%;max-width:400px;margin:0 auto;padding:1rem;font-size:1rem;font-weight:700;transition:all .2s;display:block}.features-submit-btn:hover{background-color:#2563eb}.city-selection{margin-bottom:1.5rem}.city-grid{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;grid-template-columns:repeat(3,1fr);gap:.5rem;max-height:none;padding:.75rem;display:grid;overflow-y:visible}.city-card{cursor:pointer;text-align:center;background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;flex-direction:column;justify-content:center;align-items:center;min-height:60px;padding:1.25rem 1rem;transition:all .2s;display:flex;position:relative}.city-card:hover{background-color:#f9fafb;border-color:#64ab85;transform:translateY(-2px);box-shadow:0 4px 12px #64ab8526}.city-card.selected{background-color:#edf7f2;border-color:#64ab85;transform:translateY(-2px);box-shadow:0 4px 12px #64ab8533}.city-card .city-info{flex:1;justify-content:center;align-items:center;display:flex}.city-card .city-name{color:#1f2937;margin:0;font-size:.9rem;font-weight:600;line-height:1.2}.selected-indicator{color:#fff;background-color:#64ab85;border-radius:50%;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:.875rem;font-weight:700;display:flex;position:absolute;top:.5rem;right:.5rem}.city-actions{text-align:center;margin-top:2rem}.city-actions .btn-primary{min-width:200px}.city-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.error-container{justify-content:center;align-items:center;min-height:400px;display:flex}.error-message{text-align:center;background:#fff;border-radius:1rem;max-width:400px;padding:2rem;box-shadow:0 4px 6px -1px #0000001a}.natural-language-section{background:#fff;border-radius:.75rem;margin-bottom:1.5rem;padding:1rem;box-shadow:0 2px 4px #0000000d}.natural-language-section h3{color:#1f2937;margin-bottom:.5rem;font-weight:700}.input-group{gap:.5rem;display:flex}.natural-language-input{border:1px solid #d1d5db;border-radius:.375rem;flex:1;padding:.5rem;font-size:.875rem}.analyze-btn{color:#fff;cursor:pointer;background-color:#64ab85;border:none;border-radius:.375rem;padding:.5rem 1rem;transition:all .2s}.analyze-btn:hover:not(:disabled){background-color:#4a8b6b}.analyze-btn:disabled{opacity:.6;cursor:not-allowed}.recommendations-section{text-align:center}.no-recommendations{color:#6b7280;padding:3rem;font-size:1rem}.page-indicators{justify-content:center;gap:.5rem;margin-bottom:1rem;display:flex}.indicator{background-color:#9ca3af4d;border-radius:50%;width:.5rem;height:.5rem;transition:all .2s}.indicator.active{background-color:#64ab85}.recommendation-card{cursor:pointer;background:linear-gradient(135deg,#64ab851a,#64ab850d);border-radius:1.25rem;flex-direction:column;height:500px;margin-bottom:1.5rem;transition:transform .2s;display:flex;overflow:hidden;box-shadow:0 8px 25px #0000001a}.recommendation-card:hover{transform:translateY(-2px)}.card-image{background-color:#e5e7eb;border-radius:1.25rem 1.25rem 0 0;flex:3;position:relative;overflow:hidden}.card-image img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.image-placeholder{color:#9ca3af;justify-content:center;align-items:center;width:100%;height:100%;font-size:3rem;display:flex}.card-content{padding:1.25rem}.card-content h3{color:#64ab85;margin:0 0 .75rem;font-size:1.375rem;font-weight:700;line-height:1.3}.card-scores{gap:.5rem;margin-bottom:1rem;display:flex}.similarity-score,.final-score{color:#64ab85;border-radius:.9375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:600}.similarity-score{background-color:#64ab851a}.final-score{background-color:#64ab854d}.neg-penalty{color:#ef4444;background-color:#ef44441a;border-radius:.9375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:600}.card-footer{justify-content:flex-end;align-items:center;gap:.25rem;display:flex}.tap-hint{color:#6b7280;font-size:.75rem;font-style:italic}.navigation-buttons{justify-content:center;gap:1rem;margin-bottom:1rem;display:flex}.nav-btn{color:#fff;cursor:pointer;background-color:#64ab85;border:none;border-radius:.5rem;padding:.5rem 1rem;transition:all .2s}.nav-btn:hover{background-color:#4a8b6b}.detail-btn{color:#fff;cursor:pointer;background-color:#64ab85;border:none;border-radius:.75rem;width:100%;padding:1rem;font-size:1rem;font-weight:700;transition:all .2s}.detail-btn:hover{background-color:#4a8b6b}.loading-container{justify-content:center;align-items:center;min-height:50vh;display:flex}.loading-spinner{color:#6b7280;font-size:1rem}.login-prompt-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-prompt{text-align:center;background:#fff;border-radius:1rem;max-width:400px;padding:2rem;box-shadow:0 20px 25px -5px #0000001a}.login-prompt h3{color:#1f2937;margin-bottom:1rem;font-size:1.25rem;font-weight:700}.login-prompt p{color:#6b7280;margin-bottom:2rem}.login-prompt-actions{justify-content:center;gap:1rem;display:flex}.login-prompt-cancel,.login-prompt-login{cursor:pointer;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .2s}.login-prompt-cancel{color:#374151;background-color:#f3f4f6}.login-prompt-cancel:hover{background-color:#e5e7eb}.login-prompt-login{color:#fff;background-color:#64ab85}.login-prompt-login:hover{background-color:#4a8b6b}.location-detail-fields-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1rem;display:grid}.location-detail-field-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;transition:all .2s;box-shadow:0 1px 3px #0000001a}.location-detail-field-card:hover{transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.location-detail-field-header{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.location-detail-field-title{color:#1f2937;margin:0;font-size:1.125rem;font-weight:600}.location-detail-field-stats{flex-direction:column;gap:1rem;display:flex}.location-detail-field-stat{flex-direction:column;gap:.5rem;display:flex}.location-detail-field-stat-header{justify-content:space-between;align-items:center;display:flex}.location-detail-field-stat-label{border-radius:.375rem;padding:.25rem .5rem;font-size:.875rem;font-weight:500}.location-detail-field-stat-label.positive{color:#166534;background:#dcfce7}.location-detail-field-stat-label.neutral{color:#374151;background:#f3f4f6}.location-detail-field-stat-label.negative{color:#991b1b;background:#fee2e2}.location-detail-field-stat-count{color:#6b7280;font-size:.875rem;font-weight:500}.location-detail-field-progress{background:#f3f4f6;border-radius:.25rem;width:100%;height:.5rem;overflow:hidden}.location-detail-field-progress-bar{border-radius:.25rem;height:100%;transition:width .3s}.location-detail-field-progress-bar.positive{background:#10b981}.location-detail-field-progress-bar.neutral{background:#6b7280}.location-detail-field-progress-bar.negative{background:#ef4444}@media (max-width:768px){.location-detail-fields-grid{grid-template-columns:1fr;gap:1rem}.location-detail-field-card{padding:1rem}.location-detail-field-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.line-clamp-3{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.sentiment-result{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:12px;margin-top:1rem;padding:1rem}.progress-bar{background-color:#e5e7eb;border-radius:4px;width:100%;height:8px;margin-bottom:.5rem;overflow:hidden}.progress-fill{background-color:#64ab85;border-radius:4px;height:100%;transition:width .3s}.progress-text{text-align:center;color:#6b7280;margin:0 0 1.5rem;font-size:.875rem;font-weight:500}.option-selection{margin-bottom:1.5rem}.option-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;max-width:500px;margin:0 auto;display:grid}.option-card{cursor:pointer;text-align:center;background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;flex-direction:column;justify-content:center;align-items:center;min-height:60px;padding:1rem;transition:all .2s;display:flex;position:relative}.option-card:hover{background-color:#f9fafb;border-color:#64ab85;transform:translateY(-2px);box-shadow:0 4px 12px #64ab8526}.option-card.selected{background-color:#edf7f2;border-color:#64ab85;transform:translateY(-2px);box-shadow:0 4px 12px #64ab8533}.option-card span{color:#1f2937;font-size:.9rem;font-weight:600;line-height:1.2}.option-card.selected span{color:#3c7157}@media (max-width:640px){.option-grid{grid-template-columns:1fr;gap:.5rem}.option-card{min-height:50px;padding:.75rem}.option-card span{font-size:.875rem}}.recommendation-page-web{background:linear-gradient(135deg,#f8fafc,#e2e8f0);min-height:100vh;padding:0}.recommendation-container-web{max-width:1200px;margin:0 auto;padding:.75rem}.recommendation-header-web{align-items:center;gap:2rem;margin-bottom:3rem;padding:2rem 0;display:flex}.back-btn-web{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:500;transition:all .2s;display:flex;box-shadow:0 1px 3px #0000001a}.back-btn-web:hover{color:#64ab85;background:#f8fafc;border-color:#64ab85;transform:translateY(-1px);box-shadow:0 4px 12px #64ab8526}.header-content{flex:1}.page-title{color:#1e293b;-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#64ab85,#3c7157);-webkit-background-clip:text;background-clip:text;margin:0 0 .25rem;font-size:1.5rem;font-weight:800}.page-subtitle{color:#64748b;margin:0;font-size:.875rem;font-weight:400}.recommendation-main-web{grid-template-columns:240px 1fr 300px;align-items:start;gap:1rem;max-width:1000px;margin:0 auto;display:grid}.progress-sidebar{max-width:220px;position:sticky;top:.5rem}.progress-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;padding:.75rem;box-shadow:0 4px 8px #00000014}.progress-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.progress-header h3{color:#1e293b;margin:0;font-size:.875rem;font-weight:700}.step-counter{color:#fff;background:linear-gradient(135deg,#64ab85,#3c7157);border-radius:1rem;padding:.25rem .5rem;font-size:.7rem;font-weight:600}.progress-bar-web{background:#e2e8f0;border-radius:4px;width:100%;height:8px;margin-bottom:2rem;overflow:hidden}.progress-fill-web{background:linear-gradient(90deg,#64ab85,#3c7157);border-radius:4px;height:100%;transition:width .5s}.step-list{flex-direction:column;gap:.75rem;display:flex}.step-item{border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem;transition:all .2s;display:flex;position:relative}.step-item.completed{background:linear-gradient(135deg,#64ab851a,#3c71571a);border:1px solid #64ab8533}.step-item.current{background:linear-gradient(135deg,#64ab8526,#3c715726);border:1px solid #64ab85;box-shadow:0 4px 12px #64ab8533}.step-icon{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:1rem;display:flex;box-shadow:0 1px 4px #0000001a}.step-title{color:#1e293b;flex:1;font-size:.75rem;font-weight:600}.step-item.completed .step-title{color:#64ab85}.step-item.current .step-title{color:#3c7157;font-weight:700}.check-icon{color:#64ab85;font-size:1.25rem;font-weight:700}.selection-main{min-height:400px}.selection-card{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;flex-direction:column;height:100%;padding:1rem;display:flex;box-shadow:0 4px 8px #00000014}.selection-header{text-align:center;margin-bottom:1.5rem}.selection-title{color:#1e293b;margin:0 0 .5rem;font-size:1.25rem;font-weight:700;line-height:1.3}.selection-description{color:#64748b;margin:0;font-size:.875rem;font-weight:400}.selection-content{flex:1;justify-content:center;align-items:center;min-height:400px;display:flex}.selection-actions{text-align:center;margin-top:2rem}.options-grid-web{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;width:100%;max-width:600px;margin:0 auto;display:grid}.option-card-web{cursor:pointer;text-align:center;background:#fff;border:2px solid #e2e8f0;border-radius:.75rem;flex-direction:column;justify-content:center;align-items:center;min-height:80px;padding:1rem .75rem;transition:all .3s;display:flex;position:relative;box-shadow:0 2px 8px #0000000d}.option-card-web:hover{background:linear-gradient(135deg,#64ab850d,#3c71570d);border-color:#64ab85;transform:translateY(-4px);box-shadow:0 8px 25px #64ab8526}.option-card-web.selected{background:linear-gradient(135deg,#64ab851a,#3c71571a);border-color:#64ab85;transform:translateY(-4px);box-shadow:0 8px 25px #64ab8533}.option-content{flex-direction:column;align-items:center;gap:.75rem;display:flex}.option-icon{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.5rem;display:flex;box-shadow:0 2px 8px #0000001a}.option-text{color:#1e293b;font-size:.875rem;font-weight:600;line-height:1.3}.option-card-web.selected .option-text{color:#3c7157;font-weight:700}.selected-indicator-web{color:#fff;background:linear-gradient(135deg,#64ab85,#3c7157);border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;display:flex;position:absolute;top:1rem;right:1rem;box-shadow:0 2px 8px #64ab854d}.btn-primary-web{color:#fff;cursor:pointer;background:linear-gradient(135deg,#64ab85,#3c7157);border:none;border-radius:1rem;align-items:center;gap:.75rem;min-width:200px;padding:1rem 2.5rem;font-size:1.125rem;font-weight:600;transition:all .3s;display:inline-flex;box-shadow:0 4px 15px #64ab854d}.btn-primary-web:hover:not(:disabled){background:linear-gradient(135deg,#3c7157,#2d5a47);transform:translateY(-2px);box-shadow:0 8px 25px #64ab8566}.btn-primary-web:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:0 4px 15px #64ab8533}.btn-primary-web:disabled:hover{transform:none;box-shadow:0 4px 15px #64ab8533}@media (max-width:1024px){.recommendation-container-web{padding:1.5rem}.recommendation-main-web{grid-template-columns:280px 1fr;gap:2rem;max-width:900px}.page-title{font-size:1.75rem}.selection-title{font-size:1.5rem}.options-grid-web{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem}.option-card-web{min-height:100px;padding:1.5rem 1rem}.option-icon{width:2.5rem;height:2.5rem;font-size:1.75rem}.option-text{font-size:1rem}}@media (max-width:768px){.recommendation-container-web{padding:1rem}.recommendation-header-web{flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:2rem;padding:1rem 0}.back-btn-web{align-self:flex-start}.page-title{font-size:1.5rem}.page-subtitle{font-size:.875rem}.recommendation-main-web{grid-template-columns:1fr;gap:2rem;max-width:100%}.progress-sidebar{order:2;position:static}.progress-card{padding:1.5rem}.step-list{gap:.5rem}.step-item{padding:.75rem}.step-icon{width:2rem;height:2rem;font-size:1.25rem}.step-title{font-size:.875rem}.selection-main{order:1}.selection-card{padding:2rem 1.5rem}.selection-title{font-size:1.5rem}.selection-description{font-size:1rem}.options-grid-web{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.option-card-web{min-height:80px;padding:1rem .75rem}.option-icon{width:2rem;height:2rem;font-size:1.5rem}.option-text{font-size:.875rem}.selected-indicator-web{width:1.5rem;height:1.5rem;top:.5rem;right:.5rem}.btn-primary-web{min-width:180px;padding:.875rem 2rem;font-size:1rem}}@media (max-width:480px){.recommendation-container-web{padding:.75rem}.page-title{font-size:1.25rem}.page-subtitle{font-size:.75rem}.progress-card{padding:1rem}.selection-card{padding:1.5rem 1rem}.selection-title{font-size:1.25rem}.selection-description{font-size:.875rem}.options-grid-web{grid-template-columns:1fr;gap:.75rem}.option-card-web{min-height:70px;padding:.875rem .5rem}.option-content{gap:.5rem}.option-icon{width:1.75rem;height:1.75rem;font-size:1.25rem}.option-text{font-size:.8rem}.btn-primary-web{min-width:160px;padding:.75rem 1.5rem;font-size:.875rem}}.sentiment-title{color:#374151;align-items:center;margin-bottom:.75rem;font-size:1rem;font-weight:600;display:flex}.sentiment-title:before{content:"📊";margin-right:.5rem}.sentiment-tags{flex-wrap:wrap;gap:.5rem;display:flex}.sentiment-tag{border:1px solid;border-radius:20px;padding:.375rem .75rem;font-size:.875rem;font-weight:500}.sentiment-pos{color:#166534;background-color:#dcfce7;border-color:#bbf7d0}.sentiment-neg{color:#dc2626;background-color:#fef2f2;border-color:#fecaca}.sentiment-none{color:#6b7280;background-color:#f3f4f6;border-color:#d1d5db}.sentiment-aspects{flex-direction:column;gap:.75rem;display:flex}.sentiment-aspect{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem;box-shadow:0 1px 3px #0000001a}.aspect-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.aspect-name{color:#374151;font-size:.875rem;font-weight:600}.sentiment-scores{gap:.5rem;display:flex}.sentiment-score{border:1px solid;border-radius:12px;padding:.25rem .5rem;font-size:.75rem;font-weight:500}.sentiment-loading{text-align:center;color:#6b7280;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-top:1rem;padding:1rem;font-style:italic}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1f2937;background-color:#f9fafb;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}a{color:#3b82f6;text-decoration:none;transition:color .2s ease-in-out}a:hover{color:#2563eb}button{cursor:pointer;border:none;outline:none;font-family:inherit;transition:all .2s ease-in-out}button:focus-visible{outline-offset:2px;outline:2px solid #3b82f6}input,textarea,select{outline:none;font-family:inherit;transition:all .2s ease-in-out}input:focus,textarea:focus,select:focus{outline-offset:2px;outline:2px solid #3b82f6}img{max-width:100%;height:auto;display:block}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}::-moz-selection{color:#fff;background-color:#3b82f6}::selection{color:#fff;background-color:#3b82f6}@media (prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (prefers-contrast:high){.destination-card,.btn-primary{border:2px solid #000}}@media print{.no-print{display:none!important}body{color:#000!important;background:#fff!important}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}#root{width:100%;margin:0;padding:0;min-height:100vh;background-color:#fff}body{background-color:#fff;margin:0 auto;padding:0}html{background-color:#fff}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
