/*! tailwindcss v3.3.0 | MIT License | https://tailwindcss.com */
*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::after,::before{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace, SFMono-Regular, "Consolas", "Liberation Mono", "Menlo", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}

/* Dark mode support */
@media (prefers-color-scheme: dark) {
  .dark\:bg-gray-900 { background-color: rgb(17 24 39); }
  .dark\:bg-gray-800 { background-color: rgb(31 41 55); }
  .dark\:bg-gray-700 { background-color: rgb(55 65 81); }
  .dark\:text-gray-100 { color: rgb(243 244 246); }
  .dark\:text-white { color: rgb(255 255 255); }
}

.dark .dark\:bg-gray-900 { background-color: rgb(17 24 39); }
.dark .dark\:bg-gray-800 { background-color: rgb(31 41 55); }
.dark .dark\:bg-gray-700 { background-color: rgb(55 65 81); }
.dark .dark\:text-gray-100 { color: rgb(243 244 246); }
.dark .dark\:text-white { color: rgb(255 255 255); }
.dark .dark\:hover\:text-purple-400:hover { color: rgb(196 181 253); }

/* Essential Tailwind utilities */
.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}
.mx-auto{margin-left:auto;margin-right:auto}
.flex{display:flex}
.grid{display:grid}
.hidden{display:none}
.block{display:block}
.inline-block{display:inline-block}
.inline-flex{display:inline-flex}
.fixed{position:fixed}
.relative{position:relative}
.absolute{position:absolute}
.top-0{top:0px}
.z-50{z-index:50}
.z-10{z-index:10}
.w-full{width:100%}
.min-h-screen{min-height:100vh}
.items-center{align-items:center}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}
.space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(2rem * var(--tw-space-x-reverse));margin-left:calc(2rem * calc(1 - var(--tw-space-x-reverse)))}
.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1.5rem * var(--tw-space-x-reverse));margin-left:calc(1.5rem * calc(1 - var(--tw-space-x-reverse)))}
.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}
.overflow-hidden{overflow:hidden}
.rounded-full{border-radius:9999px}
.rounded-xl{border-radius:0.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-lg{border-radius:0.5rem}
.bg-white{background-color:rgb(255 255 255)}
.bg-gray-50{background-color:rgb(249 250 251)}
.bg-gray-800{background-color:rgb(31 41 55)}
.bg-opacity-20{--tw-bg-opacity:0.2}
.bg-opacity-30{--tw-bg-opacity:0.3}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-20{padding-top:5rem;padding-bottom:5rem}
.py-8{padding-top:2rem;padding-bottom:2rem}
.py-3{padding-top:0.75rem;padding-bottom:0.75rem}
.py-2{padding-top:0.5rem;padding-bottom:0.5rem}
.px-8{padding-left:2rem;padding-right:2rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-3{padding-left:0.75rem;padding-right:0.75rem}
.py-1{padding-top:0.25rem;padding-bottom:0.25rem}
.p-2{padding:0.5rem}
.p-6{padding:1.5rem}
.p-8{padding:2rem}
.p-4{padding:1rem}
.pt-20{padding-top:5rem}
.pt-4{padding-top:1rem}
.pb-4{padding-bottom:1rem}
.mb-8{margin-bottom:2rem}
.mb-6{margin-bottom:1.5rem}
.mb-4{margin-bottom:1rem}
.mb-3{margin-bottom:0.75rem}
.mb-2{margin-bottom:0.5rem}
.mt-4{margin-top:1rem}
.mt-2{margin-top:0.5rem}
.mr-3{margin-right:0.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.text-5xl{font-size:3rem;line-height:1}
.text-6xl{font-size:3.75rem;line-height:1}
.text-7xl{font-size:4.5rem;line-height:1}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-sm{font-size:0.875rem;line-height:1.25rem}
.font-bold{font-weight:700}
.font-semibold{font-weight:600}
.text-white{color:rgb(255 255 255)}
.text-gray-800{color:rgb(253, 254, 255)}
.text-gray-600{color:rgb(75 85 99)}
.text-gray-700{color:rgb(55 65 81)}
.text-gray-500{color:rgb(107 114 128)}
.text-gray-400{color:rgb(156 163 175)}
.text-purple-600{color:rgb(147 51 234)}
.text-purple-500{color:rgb(168 85 247)}
.text-blue-500{color:rgb(59 130 246)}
.text-green-500{color:rgb(34 197 94)}
.hover\:text-purple-300:hover{color:rgb(196 181 253)}
.hover\:text-purple-400:hover{color:rgb(196 181 253)}
.hover\:text-purple-700:hover{color:rgb(126 34 206)}
.hover\:text-blue-700:hover{color:rgb(29 78 216)}
.hover\:bg-gray-100:hover{background-color:rgb(243 244 246)}
.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(0.4,0,0.2,1);transition-duration:150ms}
.transition-all{transition-property:all;transition-timing-function:cubic-bezier(0.4,0,0.2,1);transition-duration:150ms}
.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(0.4,0,0.2,1);transition-duration:150ms}
.duration-300{transition-duration:300ms}
.shadow-lg{box-shadow:0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)}
.shadow-xl{box-shadow:0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1)}
.hover\:shadow-xl:hover{box-shadow:0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1)}

/* Responsive utilities */
@media (min-width: 768px) {
  .md\:hidden{display:none}
  .md\:flex{display:flex}
  .md\:grid-cols-2{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .md\:text-6xl{font-size:3.75rem;line-height:1}
  .md\:text-xl{font-size:1.25rem;line-height:1.75rem}
}

@media (min-width: 1024px) {
  .lg\:grid-cols-3{grid-template-columns:repeat(3, minmax(0, 1fr))}
  .lg\:text-7xl{font-size:4.5rem;line-height:1}
  .lg\:text-2xl{font-size:1.5rem;line-height:2rem}
}

/* Grid utilities */
.grid-cols-2{grid-template-columns:repeat(2, minmax(0, 1fr))}
.gap-8{gap:2rem}
.gap-12{gap:3rem}
.gap-4{gap:1rem}
.gap-2{gap:0.5rem}
.gap-6{gap:1.5rem}
.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}
.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}
.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}

/* Background utilities */
.bg-gradient-to-r{background-image:linear-gradient(to right, var(--tw-gradient-stops))}
.bg-gradient-to-br{background-image:linear-gradient(to bottom right, var(--tw-gradient-stops))}
.from-purple-500{--tw-gradient-from:#a855f7 var(--tw-gradient-from-position);--tw-gradient-to:rgb(168 85 247 / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}
.to-blue-500{--tw-gradient-to:#3b82f6 var(--tw-gradient-to-position)}
.from-purple-400{--tw-gradient-from:#c084fc var(--tw-gradient-from-position);--tw-gradient-to:rgb(192 132 252 / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}
.from-purple-100{--tw-gradient-from:#f3e8ff var(--tw-gradient-from-position);--tw-gradient-to:rgb(243 232 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}
.to-blue-100{--tw-gradient-to:#dbeafe var(--tw-gradient-to-position)}

/* Color utilities */
.bg-purple-100{background-color:rgb(243 232 255)}
.bg-blue-100{background-color:rgb(219 234 254)}
.bg-green-100{background-color:rgb(220 252 231)}
.bg-yellow-100{background-color:rgb(254 249 195)}
.bg-orange-100{background-color:rgb(255 237 213)}
.bg-red-100{background-color:rgb(254 226 226)}
.bg-indigo-100{background-color:rgb(224 231 255)}
.bg-pink-100{background-color:rgb(252 231 243)}
.bg-gray-100{background-color:rgb(243 244 246)}
.bg-gray-200{background-color:rgb(229 231 235)}

.text-purple-600{color:rgb(147 51 234)}
.text-blue-600{color:rgb(37 99 235)}
.text-green-600{color:rgb(22 163 74)}
.text-yellow-600{color:rgb(202 138 4)}
.text-orange-600{color:rgb(234 88 12)}
.text-red-600{color:rgb(220 38 38)}
.text-indigo-600{color:rgb(79 70 229)}
.text-pink-600{color:rgb(219 39 119)}
.text-gray-600{color:rgb(75 85 99)}

/* Sizing utilities */
.w-24{width:6rem}
.h-1{height:0.25rem}
.h-2{height:0.5rem}
.h-48{width:12rem}
.w-48{width:12rem}
.h-12{height:3rem}
.w-12{width:3rem}
.max-w-3xl{max-width:48rem}
.max-w-4xl{max-width:56rem}
.max-w-6xl{max-width:72rem}

/* Text utilities */
.text-center{text-align:center}
.leading-relaxed{line-height:1.625}
.opacity-90{opacity:0.9}
.opacity-10{opacity:0.1}

/* Border utilities */
.border{border-width:1px}
.border-t{border-top-width:1px}
.border-white{border-color:rgb(255 255 255)}
.border-gray-300{border-color:rgb(209 213 219)}
.border-opacity-20{--tw-border-opacity:0.2}

/* Focus utilities */
.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}
.focus\:border-purple-500:focus{border-color:rgb(168 85 247)}

/* Flex utilities */
.flex-wrap{flex-wrap:wrap}
.items-start{align-items:flex-start}