/* Website UI kit — ports all the @layer components from src/index.css,
   plus Tailwind-like utilities we actually use. */
@import url('colors_and_type.css');

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--grub-black);color:var(--grub-bun);font-family:var(--font-body);-webkit-font-smoothing:antialiased}

/* ---------- layout primitives ---------- */
.container{max-width:1280px;margin:0 auto;padding-left:16px;padding-right:16px}
@media(min-width:640px){.container{padding-left:24px;padding-right:24px}}
@media(min-width:1024px){.container{padding-left:32px;padding-right:32px}}
.grid{display:grid}
.flex{display:flex}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.items-end{align-items:flex-end}
.items-baseline{align-items:baseline}
.justify-between{justify-content:space-between}
.justify-center{justify-content:center}
.justify-end{justify-content:flex-end}
.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}
.flex-1{flex:1 1 0%}
.flex-none{flex:none}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-5{gap:20px}.gap-6{gap:24px}.gap-8{gap:32px}.gap-10{gap:40px}

/* ---------- display type ---------- */
.display{font-family:var(--font-display);font-weight:800;letter-spacing:.01em;line-height:.88;text-transform:uppercase;margin:0}
.eyebrow{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--grub-mustard);margin:0}
.meta{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,230,196,.5);margin:0}
.text-stroke{-webkit-text-stroke:1.5px var(--grub-mustard);color:transparent}
.ketchup{color:var(--grub-ketchup)}
.mustard{color:var(--grub-mustard)}
.relish{color:var(--grub-relish)}

/* ---------- buttons ---------- */
.btn-primary{display:inline-flex;align-items:center;gap:12px;border-radius:9999px;background:var(--grub-ketchup);padding:14px 32px;font-family:var(--font-display);font-size:1.5rem;text-transform:uppercase;letter-spacing:.04em;color:#fff;box-shadow:var(--shadow-ketchup-glow);transition:all var(--dur-med) var(--ease-grub);border:0;cursor:pointer;text-decoration:none;font-weight:800}
.btn-primary:hover{transform:scale(1.05);background:#e53935}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;border-radius:9999px;border:1px solid var(--grub-ash);padding:10px 24px;font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.22em;color:var(--grub-bun);transition:all var(--dur-med) var(--ease-grub);background:transparent;cursor:pointer;text-decoration:none}
.btn-ghost:hover{transform:scale(1.05);border-color:var(--grub-mustard);color:var(--grub-mustard)}
.btn-mustard{display:inline-flex;align-items:center;gap:12px;border-radius:9999px;background:var(--grub-mustard);padding:14px 28px;font-family:var(--font-display);font-weight:800;font-size:1.25rem;text-transform:uppercase;letter-spacing:.04em;color:var(--grub-black);transition:all var(--dur-med) var(--ease-grub);border:0;cursor:pointer;text-decoration:none}
.btn-mustard:hover{transform:scale(1.05)}
.btn-mustard[disabled]{opacity:.9;cursor:not-allowed}

/* ---------- bento ---------- */
.bento{position:relative;overflow:hidden;border-radius:var(--radius-lg);border:1px solid var(--border-hair);background:var(--grub-ink);padding:24px}
@media(min-width:768px){.bento{padding:32px}}
.bento-accent-red{box-shadow:var(--shadow-bento-red)}
.bento-accent-yellow{box-shadow:var(--shadow-bento-yellow)}
.tape{position:absolute;top:-10px;left:24px;padding:4px 16px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--grub-black);background:var(--grub-mustard);transform:rotate(-2deg);box-shadow:0 6px 20px -10px rgba(255,193,7,.8);z-index:1}
.grain::after{content:'';position:absolute;inset:0;pointer-events:none;opacity:.06;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.9'/></svg>")}

/* ---------- reveal animation (Framer replacement via CSS) ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .7s var(--ease-grub),transform .7s var(--ease-grub)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ---------- marquee ---------- */
.marquee-track{animation:mar 28s linear infinite;width:max-content}
@keyframes mar{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- misc ---------- */
.hide-scrollbar::-webkit-scrollbar{display:none}
.hide-scrollbar{scrollbar-width:none}
.flame-pulse{animation:flame 2.4s ease-in-out infinite}
@keyframes flame{0%,100%{opacity:.75;transform:translateY(0) scale(1)}50%{opacity:1;transform:translateY(-2px) scale(1.04)}}
.ping{animation:ping 1.4s cubic-bezier(0,0,.2,1) infinite}
@keyframes ping{75%,100%{transform:scale(2);opacity:0}}
.grid-bg{background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:32px 32px}

.img-placeholder{background:linear-gradient(135deg,#2A2A2A,#141414);position:absolute;inset:0;display:grid;place-items:center;color:rgba(245,230,196,.3);font-family:var(--font-mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase}
