/* =============================================================================
 * FourcardsAI — precompiled Tailwind (v3 semantics), self-contained, no CDN/build.
 * Contains: (1) Tailwind Preflight base reset, (2) ONLY the utility classes that
 * index.html actually uses (incl. sm/lg/xl responsive + arbitrary values).
 * If you add new Tailwind classes to the HTML later, add the matching rule here
 * (or switch to a real Tailwind build).  MIT-licensed reset, same as the CDN had.
 * ========================================================================== */

/* ---------- Preflight (Tailwind base reset) ---------- */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:currentColor}
::before,::after{--tw-content:''}
html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";-webkit-tap-highlight-color:transparent}
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,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em}
small{font-size:80%}
sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}
sub{bottom:-0.25em}
sup{top:-0.5em}
table{text-indent:0;border-color:inherit;border-collapse:collapse}
button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}
button,select{text-transform:none}
button,input:where([type='button']),input:where([type='reset']),input:where([type='submit']){-webkit-appearance:button;background-color:transparent;background-image:none}
:-moz-focusring{outline:auto}
:-moz-ui-invalid{box-shadow:none}
progress{vertical-align:baseline}
::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}
[type='search']{-webkit-appearance:textfield;outline-offset:-2px}
::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
summary{display:list-item}
blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}
fieldset{margin:0;padding:0}
legend{padding:0}
ol,ul,menu{list-style:none;margin:0;padding:0}
dialog{padding:0}
textarea{resize:vertical}
input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}
button,[role="button"]{cursor:pointer}
:disabled{cursor:default}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}
[hidden]{display:none}

/* ---------- Display / box ---------- */
.block{display:block}
.flex{display:flex}
.inline-flex{display:inline-flex}
.hidden{display:none}
.flex-1{flex:1 1 0%}
.flex-col{flex-direction:column}
.shrink-0{flex-shrink:0}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.items-end{align-items:flex-end}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}
.justify-end{justify-content:flex-end}
.justify-start{justify-content:flex-start}
.overflow-hidden{overflow:hidden}
.object-cover{object-fit:cover}
.pointer-events-none{pointer-events:none}

/* ---------- Position ---------- */
.relative{position:relative}
.absolute{position:absolute}
.fixed{position:fixed}
.sticky{position:sticky}
.inset-0{inset:0}
.top-0{top:0}
.bottom-0{bottom:0}
.left-0{left:0}
.right-0{right:0}
.right-3{right:0.75rem}
.top-2\.5{top:0.625rem}
.z-50{z-index:50}
.z-\[100\]{z-index:100}
.z-\[110\]{z-index:110}

/* ---------- Width / height ---------- */
.w-full{width:100%}
.w-8{width:2rem}
.w-9{width:2.25rem}
.w-14{width:3.5rem}
.w-40{width:10rem}
.w-1\.5{width:0.375rem}
.h-8{height:2rem}
.h-9{height:2.25rem}
.h-14{height:3.5rem}
.h-1\.5{height:0.375rem}
.h-\[82vh\]{height:82vh}
.max-w-sm{max-width:24rem}
.max-w-lg{max-width:32rem}
.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-full{max-width:100%}
.max-w-\[86\%\]{max-width:86%}
.max-w-\[90\%\]{max-width:90%}
.min-w-0{min-width:0px}

/* ---------- Margin ---------- */
.mx-auto{margin-left:auto;margin-right:auto}
.-mt-1{margin-top:-0.25rem}
.mt-2{margin-top:0.5rem}
.mt-8{margin-top:2rem}
.mb-1{margin-bottom:0.25rem}
.mb-2{margin-bottom:0.5rem}
.mb-3{margin-bottom:0.75rem}
.mb-4{margin-bottom:1rem}
.mb-6{margin-bottom:1.5rem}
.mb-7{margin-bottom:1.75rem}
.mb-10{margin-bottom:2.5rem}
.ml-1{margin-left:0.25rem}

/* ---------- Padding ---------- */
.p-3{padding:0.75rem}
.p-8{padding:2rem}
.px-3{padding-left:0.75rem;padding-right:0.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-10{padding-left:2.5rem;padding-right:2.5rem}
.py-1\.5{padding-top:0.375rem;padding-bottom:0.375rem}
.py-2{padding-top:0.5rem;padding-bottom:0.5rem}
.py-3{padding-top:0.75rem;padding-bottom:0.75rem}
.py-3\.5{padding-top:0.875rem;padding-bottom:0.875rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.pt-8{padding-top:2rem}
.pt-12{padding-top:3rem}
.pt-24{padding-top:6rem}
.pb-2{padding-bottom:0.5rem}
.pb-3{padding-bottom:0.75rem}
.pb-28{padding-bottom:7rem}
.pb-44{padding-bottom:11rem}
.pl-4{padding-left:1rem}
.pr-9{padding-right:2.25rem}

/* ---------- Gap (column) ---------- */
.gap-x-1{column-gap:0.25rem}
.gap-x-1\.5{column-gap:0.375rem}
.gap-x-2{column-gap:0.5rem}
.gap-x-2\.5{column-gap:0.625rem}
.gap-x-3{column-gap:0.75rem}
.gap-x-4{column-gap:1rem}

/* ---------- Border / radius ---------- */
.border{border-width:1px}
.border-b{border-bottom-width:1px}
.border-t{border-top-width:1px}
.border-white\/10{border-color:rgba(255,255,255,0.1)}
.border-white\/5{border-color:rgba(255,255,255,0.05)}
.rounded-lg{border-radius:0.5rem}
.rounded-xl{border-radius:0.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-3xl{border-radius:1.5rem}
.rounded-full{border-radius:9999px}

/* ---------- Background ---------- */
.bg-white{background-color:#fff}
.bg-zinc-400{background-color:#a1a1aa}
.bg-black\/70{background-color:rgba(0,0,0,0.7)}
.bg-black\/80{background-color:rgba(0,0,0,0.8)}
.backdrop-blur-sm{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}

/* ---------- Typography ---------- */
.text-xs{font-size:0.75rem;line-height:1rem}
.text-sm{font-size:0.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-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-6xl{font-size:3.75rem;line-height:1}
.text-\[10px\]{font-size:10px}
.text-\[11px\]{font-size:11px}
.text-center{text-align:center}
.font-medium{font-weight:500}
.font-semibold{font-weight:600}
.font-bold{font-weight:700}
.tracking-tight{letter-spacing:-0.025em}
.tracking-tighter{letter-spacing:-0.05em}
.tracking-wide{letter-spacing:0.025em}
.leading-snug{line-height:1.375}
.leading-\[0\.88\]{line-height:0.88}
.text-white{color:#fff}
.text-red-400{color:#f87171}
.text-amber-500{color:#f59e0b}
.text-zinc-200{color:#e4e4e7}
.text-zinc-300{color:#d4d4d8}
.text-zinc-400{color:#a1a1aa}
.text-zinc-500{color:#71717a}
.text-zinc-950{color:#09090b}
.placeholder-zinc-500::placeholder{color:#71717a}

/* ---------- Transition ---------- */
.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}

/* ---------- Hover ---------- */
.hover\:text-white:hover{color:#fff}

/* ---------- Responsive: sm (≥640px) ---------- */
@media (min-width:640px){
  .sm\:block{display:block}
  .sm\:inline{display:inline}
  .sm\:p-6{padding:1.5rem}
  .sm\:px-5{padding-left:1.25rem;padding-right:1.25rem}
  .sm\:w-60{width:15rem}
  .sm\:text-2xl{font-size:1.5rem;line-height:2rem}
  .sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}
  .sm\:text-7xl{font-size:4.5rem;line-height:1}
  .sm\:max-w-\[72\%\]{max-width:72%}
  .sm\:max-w-\[82\%\]{max-width:82%}
}

/* ---------- Responsive: lg (≥1024px) ---------- */
@media (min-width:1024px){
  .lg\:text-8xl{font-size:6rem;line-height:1}
}

/* ---------- Responsive: xl (≥1280px) ---------- */
@media (min-width:1280px){
  .xl\:max-w-4xl{max-width:56rem}
}
