
/* Local replacement for the Tailwind utility classes used by index.html.
   Keep this file beside index.html so the page does not rely on cdn.tailwindcss.com. */

*, *::before, *::after { box-sizing: border-box; border-width: 0; border-style: solid; border-color: #e5e7eb; }
html { line-height: 1.5; -webkit-text-size-adjust: 100%; tab-size: 4; font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
body { margin: 0; line-height: inherit; }
button { font: inherit; color: inherit; margin: 0; padding: 0; background-color: transparent; background-image: none; text-transform: none; cursor: pointer; }
img, svg { display: block; vertical-align: middle; max-width: 100%; height: auto; }
p, h3 { margin: 0; }

/* Layout */
.relative { position: relative; }
.absolute { position: absolute; }
.inset-0 { inset: 0; }
.inset-y-0 { top: 0; bottom: 0; }
.inset-y-3 { top: .75rem; bottom: .75rem; }
.top-0 { top: 0; }
.top-3 { top: .75rem; }
.top-1\/2 { top: 50%; }
.bottom-0 { bottom: 0; }
.bottom-3 { bottom: .75rem; }
.left-0 { left: 0; }
.left-1\/2 { left: 50%; }
.right-0 { right: 0; }
.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-nowrap { flex-wrap: nowrap; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.flex-none { flex: none; }
.shrink-0 { flex-shrink: 0; }
.overflow-hidden { overflow: hidden; }
.pointer-events-none { pointer-events: none; }
.select-none { user-select: none; }
.cursor-pointer { cursor: pointer; }

/* Sizing */
.min-h-screen { min-height: 100vh; }
.min-h-\[88px\] { min-height: 88px; }
.min-w-\[300px\] { min-width: 300px; }
.w-full { width: 100%; }
.w-auto { width: auto; }
.w-max { width: max-content; }
.w-16 { width: 4rem; }
.w-px { width: 1px; }
.w-\[calc\(34\%\+20px\)\] { width: calc(34% + 20px); }
.h-16 { height: 4rem; }
.h-24 { height: 6rem; }
.h-px { height: 1px; }
.max-w-2xl { max-width: 42rem; }
.max-w-3xl { max-width: 48rem; }
.max-w-md { max-width: 28rem; }

/* Spacing */
.mx-auto { margin-left: auto; margin-right: auto; }
.mt-4 { margin-top: 1rem; }
.mt-10 { margin-top: 2.5rem; }
.mt-\[2px\] { margin-top: 2px; }
.mb-1 { margin-bottom: .25rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-8 { margin-bottom: 2rem; }
.gap-6 { gap: 1.5rem; }
.gap-24 { gap: 6rem; }
.p-4 { padding: 1rem; }
.p-8 { padding: 2rem; }
.px-0 { padding-left: 0; padding-right: 0; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }

/* Transforms */
.-translate-x-1\/2 { transform: translateX(-50%); }
.-translate-y-1\/2 { transform: translateY(-50%); }

/* Typography */
.text-center { text-align: center; }
.leading-relaxed { line-height: 1.625; }
.font-semibold { font-weight: 600; }
.text-xs { font-size: .75rem; line-height: 1rem; }
.text-sm { font-size: .875rem; line-height: 1.25rem; }
.text-lg { font-size: 1.125rem; line-height: 1.75rem; }
.text-xl { font-size: 1.25rem; line-height: 1.75rem; }
.text-slate-200 { color: rgb(226 232 240); }
.text-gray-100 { color: rgb(243 244 246); }
.text-gray-200 { color: rgb(229 231 235); }
.text-gray-300 { color: rgb(209 213 219); }
.text-gray-400 { color: rgb(156 163 175); }
.text-gray-700 { color: rgb(55 65 81); }

/* Backgrounds, borders, effects */
.bg-\[\#1f1f1f\] { background-color: #1f1f1f; }
.bg-black { background-color: #000; }
.bg-gray-500\/60 { background-color: rgb(107 114 128 / .6); }
.bg-gradient-to-r { background-image: linear-gradient(to right, var(--tw-gradient-from, transparent), var(--tw-gradient-to, transparent)); }
.bg-gradient-to-l { background-image: linear-gradient(to left, var(--tw-gradient-from, transparent), var(--tw-gradient-to, transparent)); }
.from-black { --tw-gradient-from: #000; }
.to-transparent { --tw-gradient-to: transparent; }
.border { border-width: 1px; }
.border-gray-700 { border-color: rgb(55 65 81); }
.rounded-2xl { border-radius: 1rem; }
.rounded-3xl { border-radius: 1.5rem; }
.shadow-2xl { box-shadow: 0 25px 50px -12px rgb(0 0 0 / .25); }
.opacity-0 { opacity: 0; }
.opacity-80 { opacity: .8; }
.opacity-90 { opacity: .9; }

/* Transitions */
.transition-transform { transition-property: transform; transition-timing-function: cubic-bezier(.4,0,.2,1); transition-duration: 150ms; }
.transition-opacity { transition-property: opacity; transition-timing-function: cubic-bezier(.4,0,.2,1); transition-duration: 150ms; }
.duration-100 { transition-duration: 100ms; }
.duration-150 { transition-duration: 150ms; }
.duration-200 { transition-duration: 200ms; }
.hover\:opacity-100:hover { opacity: 1; }
.hover\:scale-105:hover { transform: scale(1.05); }
.will-change-transform { will-change: transform; }

@media (max-width: 640px) {
  .p-8 { padding: 1.25rem; }
  .gap-6 { gap: .75rem; }
  .gap-24 { gap: 3.5rem; }
  .h-16 { height: 3rem; }
  .w-16 { width: 3rem; }
  .min-w-\[300px\] { min-width: min(300px, 100%); }
}
