*,::before,::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;color:#111827;background:#fff;padding-bottom:56px}
@media(min-width:768px){body{padding-bottom:0}}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.hidden{display:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.flex{display:flex}
.grid{display:grid}
.block{display:block}
.inline-block{display:inline-block}
.inline-flex{display:inline-flex}
.text-center{text-align:center}
.text-left{text-align:left}
.bg-white{background:#fff}
.bg-gray-50{background:#f9fafb}
.bg-gray-100{background:#f3f4f6}
.bg-red-600{background:#dc2626}
.bg-blue-900{background:#1e3a8a}
.bg-blue-800{background:#1e40af}
.bg-emerald-600{background:#059669}
.bg-emerald-800{background:#065f46}
.bg-green-500{background:#22c55e}
.bg-orange-500{background:#f97316}
.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}
.from-blue-900{--tw-gradient-from:#1e3a8a;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,transparent)}
.to-blue-800{--tw-gradient-to:#1e40af}
.from-emerald-800{--tw-gradient-from:#065f46;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,transparent)}
.to-emerald-700{--tw-gradient-to:#047857}
.text-white{color:#fff}
.text-gray-700{color:#374151}
.text-gray-900{color:#111827}
.text-gray-500{color:#6b7280}
.text-gray-400{color:#9ca3af}
.text-red-600{color:#dc2626}
.text-blue-900{color:#1e3a8a}
.text-emerald-600{color:#059669}
.text-green-400{color:#4ade80}
.text-blue-200{color:#bfdbfe}
.font-bold{font-weight:700}
.font-black{font-weight:900}
.font-medium{font-weight:500}
.uppercase{text-transform:uppercase}
.tracking-wider{letter-spacing:.05em}
.tracking-widest{letter-spacing:.1em}
.tracking-tighter{letter-spacing:-.05em}
.tracking-tight{letter-spacing:-.025em}
.leading-relaxed{line-height:1.625}
.leading-none{line-height:1}
.leading-tight{line-height:1.25}
.rounded{border-radius:.25rem}
.rounded-lg{border-radius:.5rem}
.rounded-xl{border-radius:.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-full{border-radius:9999px}
.rounded-\[2rem\]{border-radius:2rem}
.rounded-\[3rem\]{border-radius:3rem}
.border{border-width:1px}
.border-t{border-top-width:1px}
.border-b{border-bottom-width:2px}
.border-b-2{border-bottom-width:2px}
.border-gray-100{border-color:#f3f4f6}
.border-gray-200{border-color:#e5e7eb}
.border-red-600{border-color:#dc2626}
.border-emerald-600{border-color:#059669}
.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.shadow-xl{box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}
.shadow-sm{box-shadow:0 1px 2px 0 rgba(0,0,0,.05)}
.px-3{padding-left:.75rem;padding-right:.75rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-5{padding-left:1.25rem;padding-right:1.25rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.px-8{padding-left:2rem;padding-right:2rem}
.py-1{padding-top:.25rem;padding-bottom:.25rem}
.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}
.py-2{padding-top:.5rem;padding-bottom:.5rem}
.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}
.py-3{padding-top:.75rem;padding-bottom:.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-6{padding-top:1.5rem;padding-bottom:1.5rem}
.py-8{padding-top:2rem;padding-bottom:2rem}
.py-12{padding-top:3rem;padding-bottom:3rem}
.py-16{padding-top:4rem;padding-bottom:4rem}
.py-20{padding-top:5rem;padding-bottom:5rem}
.py-24{padding-top:6rem;padding-bottom:6rem}
.pt-4{padding-top:1rem}
.pb-8{padding-bottom:2rem}
.pb-\[56px\]{padding-bottom:56px}
.mt-1{margin-top:.25rem}
.mt-2{margin-top:.5rem}
.mt-3{margin-top:.75rem}
.mt-4{margin-top:1rem}
.mt-6{margin-top:1.5rem}
.mt-8{margin-top:2rem}
.mt-10{margin-top:2.5rem}
.mt-12{margin-top:3rem}
.mt-16{margin-top:4rem}
.mb-2{margin-bottom:.5rem}
.mb-3{margin-bottom:.75rem}
.mb-4{margin-bottom:1rem}
.mb-6{margin-bottom:1.5rem}
.mb-8{margin-bottom:2rem}
.mb-10{margin-bottom:2.5rem}
.mb-12{margin-bottom:3rem}
.mb-16{margin-bottom:4rem}
.mr-2{margin-right:.5rem}
.mr-3{margin-right:.75rem}
.mr-4{margin-right:1rem}
.ml-2{margin-left:.5rem}
.ml-4{margin-left:1rem}
.gap-1{gap:.25rem}
.gap-2{gap:.5rem}
.gap-3{gap:.75rem}
.gap-4{gap:1rem}
.gap-6{gap:1.5rem}
.gap-8{gap:2rem}
.space-y-2>*+*{margin-top:.5rem}
.space-y-3>*+*{margin-top:.75rem}
.space-y-4>*+*{margin-top:1rem}
.space-y-6>*+*{margin-top:1.5rem}
.space-y-8>*+*{margin-top:2rem}
.space-x-4>*+*{margin-left:1rem}
.text-\[10px\]{font-size:10px}
.text-xs{font-size:.75rem}
.text-sm{font-size:.875rem}
.text-base{font-size:1rem}
.text-lg{font-size:1.125rem}
.text-xl{font-size:1.25rem}
.text-2xl{font-size:1.5rem}
.text-3xl{font-size:1.875rem}
.text-4xl{font-size:2.25rem}
.text-5xl{font-size:3rem}
.text-6xl{font-size:3.75rem}
.text-7xl{font-size:4.5rem}
.w-4{width:1rem}
.w-5{width:1.25rem}
.w-10{width:2.5rem}
.w-12{width:3rem}
.w-14{width:3.5rem}
.h-4{height:1rem}
.h-5{height:1.25rem}
.h-10{height:2.5rem}
.h-12{height:3rem}
.h-14{height:3.5rem}
.w-full{width:100%}
.max-w-3xl{max-width:48rem}
.max-w-4xl{max-width:56rem}
.max-w-5xl{max-width:64rem}
.max-w-6xl{max-width:72rem}
.max-w-7xl{max-width:80rem}
.mx-auto{margin-left:auto;margin-right:auto}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}
.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}
.flex-1{flex:1 1 0%}
.flex-shrink-0{flex-shrink:0}
.relative{position:relative}
.absolute{position:absolute}
.fixed{position:fixed}
.sticky{position:sticky}
.top-0{top:0}
.bottom-0{bottom:0}
.left-0{left:0}
.right-0{right:0}
.z-50{z-index:50}
.z-\[60\]{z-index:60}
.overflow-hidden{overflow:hidden}
.overflow-x-hidden{overflow-x:hidden}
.overflow-y-auto{overflow-y:auto}
.col-span-2{grid-column:span 2/span 2}
.col-span-3{grid-column:span 3/span 3}
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-duration:.15s}
.transition-all{transition-property:all;transition-duration:.15s}
.transition-transform{transition-property:transform;transition-duration:.15s}
.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s}
.duration-200{transition-duration:.2s}
.duration-300{transition-duration:.3s}
.duration-500{transition-duration:.5s}
.hover\:bg-gray-50:hover{background:#f9fafb}
.hover\:bg-gray-200:hover{background:#e5e7eb}
.hover\:bg-white:hover{background:#fff}
.hover\:bg-red-50:hover{background:#fef2f2}
.hover\:bg-red-600:hover{background:#dc2626}
.hover\:bg-red-700:hover{background:#b91c1c}
.hover\:bg-emerald-50:hover{background:#ecfdf5}
.hover\:bg-emerald-600:hover{background:#059669}
.hover\:bg-blue-50:hover{background:#eff6ff}
.hover\:text-white:hover{color:#fff}
.hover\:text-red-600:hover{color:#dc2626}
.hover\:text-red-300:hover{color:#fca5a5}
.hover\:text-emerald-600:hover{color:#059669}
.hover\:text-orange-300:hover{color:#fdba74}
.hover\:text-green-300:hover{color:#86efac}
.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.hover\:shadow-2xl:hover{box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}
.hover\:shadow-xl:hover{box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1)}
.hover\:scale-105:hover{transform:scale(1.05)}
.hover\:scale-110:hover{transform:scale(1.1)}
.hover\:-translate-y-2:hover{transform:translateY(-.5rem)}
.hover\:-translate-y-4:hover{transform:translateY(-1rem)}
.hover\:translate-x-2:hover{transform:translateX(.5rem)}
.active\:scale-95:active{transform:scale(.95)}
.active\:scale-\[0\.97\]:active{transform:scale(.97)}
.active\:scale-\[0\.98\]:active{transform:scale(.98)}
.group:hover .group-hover\:scale-110{transform:scale(1.1)}
.group:hover .group-hover\:rotate-12{transform:rotate(12deg)}
.group:hover .group-hover\:bg-red-600{background:#dc2626}
.group:hover .group-hover\:bg-blue-800{background:#1e40af}
.group:hover .group-hover\:bg-emerald-600{background:#059669}
.group:hover .group-hover\:text-white{color:#fff}
.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.opacity-30{opacity:.3}
.opacity-50{opacity:.5}
.opacity-80{opacity:.8}
.italic{font-style:italic}
.underline{text-decoration-line:underline}
.no-underline{text-decoration-line:none}
.list-none{list-style-type:none}
.select-none{user-select:none}
.pointer-events-none{pointer-events:none}
.whitespace-nowrap{white-space:nowrap}
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.backdrop-blur{backdrop-filter:blur(8px)}
.backdrop-blur-lg{backdrop-filter:blur(16px)}
.backdrop-blur-sm{backdrop-filter:blur(4px)}
@media(min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}}
@media(min-width:768px){
  .md\:flex{display:flex}
  .md\:hidden{display:none}
  .md\:block{display:block}
  .md\:grid{display:grid}
  .md\:text-2xl{font-size:1.5rem}
  .md\:text-3xl{font-size:1.875rem}
  .md\:text-4xl{font-size:2.25rem}
  .md\:text-5xl{font-size:3rem}
  .md\:text-6xl{font-size:3.75rem}
  .md\:text-7xl{font-size:4.5rem}
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .md\:col-span-2{grid-column:span 2/span 2}
  .md\:col-span-3{grid-column:span 3/span 3}
  .md\:col-span-4{grid-column:span 4/span 4}
  .md\:col-span-5{grid-column:span 5/span 5}
  .md\:py-20{padding-top:5rem;padding-bottom:5rem}
  .md\:py-24{padding-top:6rem;padding-bottom:6rem}
  .md\:py-28{padding-top:7rem;padding-bottom:7rem}
  .md\:py-32{padding-top:8rem;padding-bottom:8rem}
  .md\:px-12{padding-left:3rem;padding-right:3rem}
  .md\:px-20{padding-left:5rem;padding-right:5rem}
  .md\:p-10{padding:2.5rem}
  .md\:p-12{padding:3rem}
  .md\:p-16{padding:4rem}
  .md\:p-20{padding:5rem}
  .md\:text-left{text-align:left}
  .md\:pb-12{padding-bottom:3rem}
  .md\:pb-0{padding-bottom:0}
  .md\:bottom-0{bottom:0}
  .md\:right-8{right:2rem}
  .md\:bottom-8{bottom:2rem}
  .md\:w-1\/2{width:50%}
  .md\:flex-row{flex-direction:row}
  .md\:items-center{align-items:center}
  .md\:space-x-4>*+*{margin-left:1rem}
}
@media(min-width:1024px){
  .lg\:grid{display:grid}
  .lg\:flex{display:flex}
  .lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}
  .lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}
  .lg\:col-span-1{grid-column:span 1/span 1}
  .lg\:col-span-2{grid-column:span 2/span 2}
  .lg\:sticky{position:sticky}
  .lg\:top-24{top:6rem}
  .lg\:w-1\/2{width:50%}
  .lg\:gap-12{gap:3rem}
  .lg\:mt-0{margin-top:0}
  .lg\:flex-row{flex-direction:row}
}
@media(min-width:1280px){.xl\:inline{display:inline}}.scroll-fade{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}.scroll-fade-left{opacity:0;transform:translateX(-30px);transition:opacity .7s ease,transform .7s ease}.scroll-fade-right{opacity:0;transform:translateX(30px);transition:opacity .7s ease,transform .7s ease}.scroll-fade.visible,.scroll-fade-left.visible,.scroll-fade-right.visible{opacity:1;transform:translate(0)}
/* Tailwind opacity modifier fallbacks */
.bg-blue-50\/50{background-color:rgb(239 246 255 / .5)}
.bg-gray-50\/50{background-color:rgb(249 250 251 / .5)}
.bg-white\/90{background-color:rgb(255 255 255 / .9)}
.bg-white\/80{background-color:rgb(255 255 255 / .8)}
.text-white\/70{color:rgb(255 255 255 / .7)}
.text-white\/90{color:rgb(255 255 255 / .9)}
.text-white\/10{color:rgb(255 255 255 / .1)}
.text-white\/40{color:rgb(255 255 255 / .4)}
.shadow-gray-200\/50{--tw-shadow-color:rgb(229 231 235 / .5);--tw-shadow:var(--tw-shadow-colored)}
.bg-red-600\/20{background-color:rgb(220 38 38 / .2)}
.bg-emerald-600\/20{background-color:rgb(5 150 105 / .2)}
.hover\:-translate-y-2:hover{--tw-translate-y:-0.5rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}
