/* 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-onyx);font-family:var(--font-body);-webkit-font-smoothing:antialiased}
/* subtle ketchup-red wash so the mustard has warmth + depth */
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse at 50% 0%, rgba(211,47,47,.14) 0%, transparent 55%),radial-gradient(ellipse at 50% 100%, rgba(13,13,13,.08) 0%, transparent 55%);}
#root{position:relative;z-index:1}

/* ---------- 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:visible;border-radius:var(--radius-lg);border:1px solid var(--border-hair-hi);background:var(--grub-ink);padding:44px 24px 24px}
@media(min-width:768px){.bento{padding:52px 32px 32px}}
.bento > *{position:relative}
.bento-accent-red{box-shadow:var(--shadow-bento-red)}
.bento-accent-yellow{box-shadow:var(--shadow-bento-yellow)}
.tape{position:absolute;top:-14px;left:24px;display:inline-flex;align-items:center;line-height:1;padding:7px 16px 6px;font-family:var(--font-mono);font-weight:800;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:#FFFFFF;background:#D32F2F;transform:rotate(-2deg);box-shadow:0 6px 20px -10px rgba(211,47,47,.7);z-index:2;border-radius:2px}
.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}

/* ---------- SandwichVerdict (Is a hot dog a sandwich?) ---------- */
.sv-bento{background:#0D0D0D;color:#F5E6C4;border:1px solid rgba(0,0,0,.1);padding-top:24px}
.sv-head .eyebrow{color:#FFC107}
.sv-h2{font-family:var(--font-display);font-weight:800;text-transform:uppercase;line-height:.88;letter-spacing:.01em;color:#F5E6C4;margin:8px 0 0;font-size:clamp(2.5rem,5vw,4.5rem)}
.sv-verdict{display:inline-flex;align-items:baseline;gap:18px;font-family:var(--font-display);font-weight:900;text-transform:uppercase;line-height:1;color:#fff;background:var(--grub-ketchup);padding:10px 22px 12px;border-radius:6px;transform:rotate(-2deg);box-shadow:0 14px 40px -14px rgba(211,47,47,.7)}
.sv-verdict .big{font-size:clamp(3.5rem,8vw,6.5rem);letter-spacing:-.02em}
.sv-verdict .small{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.28em;font-weight:700;color:rgba(255,255,255,.9);transform:translateY(-.5em)}
.sv-quote{font-family:var(--font-display);font-weight:700;line-height:1.05;color:#F5E6C4;font-size:clamp(1.25rem,1.9vw,1.75rem);letter-spacing:.005em;margin:0;text-wrap:balance}
.sv-quote .attr{display:block;margin-top:14px;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.26em;text-transform:uppercase;color:#FFC107;font-weight:400}
.sv-reasons{list-style:none;margin:0;padding:0;display:grid;gap:12px;justify-items:start}
.sv-reason{display:inline-grid;grid-template-columns:28px auto;gap:14px;padding:12px 14px;border:1px solid rgba(255,193,7,.14);border-radius:12px;background:rgba(255,193,7,.03)}
.sv-reason .num{font-family:var(--font-mono);font-size:.7rem;font-weight:700;letter-spacing:.2em;color:var(--grub-ketchup)}
.sv-reason h4{font-family:var(--font-mono);font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#FFC107;margin:0 0 3px}
.sv-reason p{margin:0;font-size:.88rem;line-height:1.5;color:rgba(245,230,196,.82);max-width:42ch;text-wrap:balance}
.sv-thumb-wrap{position:relative;aspect-ratio:9/16;border-radius:18px;overflow:hidden;border:2px solid var(--grub-ketchup);background:#1B1B1B;box-shadow:0 30px 60px -24px rgba(211,47,47,.55);cursor:pointer;display:block;text-decoration:none;color:inherit;transition:transform 200ms var(--ease-grub)}
.sv-thumb-wrap:hover{transform:translateY(-4px)}
.sv-thumb-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 40%}
.sv-thumb-grad{position:absolute;inset:0;background:linear-gradient(0deg,rgba(13,13,13,.92) 0%,rgba(13,13,13,.25) 40%,rgba(13,13,13,.05) 70%,rgba(13,13,13,.5) 100%)}
.sv-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);height:80px;width:80px;border-radius:9999px;background:rgba(13,13,13,.82);border:2px solid #fff;display:grid;place-items:center;backdrop-filter:blur(6px);transition:all 200ms var(--ease-grub)}
.sv-thumb-wrap:hover .sv-play{background:var(--grub-ketchup);transform:translate(-50%,-50%) scale(1.08)}
.sv-play svg{fill:#fff;height:32px;width:32px;margin-left:4px}
.sv-thumb-top{position:absolute;top:14px;left:14px;right:14px;display:flex;justify-content:space-between;align-items:flex-start;gap:8px;z-index:2}
.sv-yt-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(13,13,13,.78);color:#fff;font-family:var(--font-mono);font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;padding:5px 9px;border-radius:9999px;backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.15)}
.sv-yt-badge .dot{height:6px;width:6px;border-radius:50%;background:#FF0000}
.sv-duration{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.14em;color:#fff;background:rgba(13,13,13,.78);padding:3px 7px;border-radius:4px;font-weight:700}
.sv-thumb-bottom{position:absolute;left:16px;right:16px;bottom:16px;z-index:2}
.sv-thumb-title{font-family:var(--font-display);font-weight:800;font-size:1.3rem;text-transform:uppercase;color:#fff;line-height:1;letter-spacing:.01em;margin:0 0 6px}
.sv-thumb-meta{font-family:var(--font-mono);font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7);margin:0}
.sv-debate{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);text-transform:uppercase;color:rgba(245,230,196,.75);border-radius:9999px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);margin-bottom:18px;white-space:nowrap}
.sv-debate .vs{font-family:var(--font-display);font-weight:900;color:var(--grub-ketchup);letter-spacing:0}
.sv-watch{display:inline-flex;align-items:center;gap:10px;background:var(--grub-ketchup);color:#fff;padding:11px 20px;border-radius:9999px;font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:1rem;text-decoration:none;box-shadow:0 10px 30px -14px rgba(211,47,47,.8);transition:transform 200ms var(--ease-grub)}
.sv-watch:hover{transform:scale(1.04)}
.sv-grid-a{display:grid;gap:36px;align-items:start}
.sv-thumb-card{display:grid;gap:14px;justify-self:start;width:100%}
/* Mobile stack */
@media (max-width:720px){.sv-grid-a{grid-template-columns:1fr !important}.sv-thumb-card{max-width:360px}}
