/* ===========================================================
   OOF GAME — microsite
   Barvy/typografie/rozestupy dle handoff README (závazné).
   =========================================================== */

:root{
  --red:    #E4151E;
  --yellow: #FFD400;
  --white:  #ffffff;
  --ink:    #111111;
  --blue:   #1BA6E0; /* suit */
  --pink:   #FB3199; /* suit */
  --green:  #1F8A5B; /* kostka DROP */
  --purple: #7A3FF2; /* kostka LAG */
  --vignette: rgba(120,0,0,.5);

  --anton:  'Anton', sans-serif;
  --baloo:  'Baloo 2', sans-serif;
  --hanken: 'Hanken Grotesk', sans-serif;

  --pad-y: clamp(80px, 12vw, 160px);
  --pad-x: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--red);
  font-family:var(--hanken), sans-serif;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
}
/* overflow-x:clip ořeže vodorovný přesah dekorací, ale (na rozdíl od hidden)
   nevytváří scroll-container — position:sticky v sekci CHAOS tak funguje.
   hidden je fallback pro prohlížeče bez podpory clip. */
#oof{ position:relative; overflow-x:hidden; overflow-x:clip; }
img{ max-width:100%; }
a{ color:inherit; }

/* ---------- Keyframes ---------- */
@keyframes spin{ to{ transform:rotate(360deg); } }
@keyframes floatB{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(11px); } }
@keyframes dropIn{
  0%{   opacity:0; transform:translateY(-120px) scale(.55); }
  68%{  opacity:1; transform:translateY(14px) scale(1.04); }
  100%{ opacity:1; transform:translateY(0) scale(1); }
}
@keyframes riseIn{
  0%{   opacity:0; transform:translateY(46px); }
  100%{ opacity:1; transform:translateY(0); }
}

/* ---------- Entrance animation utilities (hero) ---------- */
.anim-rise{ display:block; }
.anim-rise--1{ animation:riseIn .7s .05s both; }
.anim-rise--2{ animation:riseIn .7s .18s both; }
.anim-rise--3{ animation:riseIn .7s .55s both; }
.anim-drop--box{ animation:dropIn .8s .4s both; }
.anim-drop--cta{ animation:dropIn .8s .7s both; }
.anim-drop--1{ animation:dropIn .9s .15s both; }
.anim-drop--2{ animation:dropIn .9s .35s both; }
.anim-drop--3{ animation:dropIn .9s .5s both; }

/* Scroll reveal (toggled by JS; hidden state only added when motion allowed) */
.reveal{
  opacity:0; transform:translateY(42px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
}
.reveal.is-in{ opacity:1; transform:none; }

/* ===========================================================
   Reusable style components
   =========================================================== */

/* Halftone (Ben-day) texture */
.halftone{ position:absolute; inset:0; pointer-events:none; }
.halftone--red{
  background-image:radial-gradient(circle, rgba(0,0,0,.15) 1.7px, transparent 2px);
  background-size:16px 16px;
}
.halftone--yellow{
  background-image:radial-gradient(circle, rgba(17,17,17,.1) 1.7px, transparent 2px);
  background-size:17px 17px;
}
.halftone--white{
  background-image:radial-gradient(circle, rgba(228,21,30,.08) 1.7px, transparent 2px);
  background-size:18px 18px;
}

/* Danger tape */
.danger-tape{
  position:absolute; left:0; right:0; bottom:0; height:30px; z-index:25;
  background:repeating-linear-gradient(45deg, var(--ink) 0 26px, var(--yellow) 26px 52px);
}

/* Sunburst */
.sunburst{
  background:repeating-conic-gradient(from 0deg, rgba(255,212,0,.85) 0 7deg, rgba(255,212,0,0) 7deg 16deg);
  border-radius:50%;
  pointer-events:none;
  animation:spin 60s linear infinite;
}

/* Logo OOF GAME */
.logo{
  display:inline-flex; align-items:flex-end; gap:8px;
  text-decoration:none; line-height:1;
}
.logo-oof{
  font-family:var(--baloo); font-weight:800; font-size:30px; line-height:.78;
  color:var(--white); -webkit-text-stroke:4px var(--ink); paint-order:stroke;
  letter-spacing:-2px; text-shadow:0 3px 0 var(--ink);
}
.logo-game{
  font-family:var(--baloo); font-weight:800; font-size:11px; color:var(--ink);
  background:var(--yellow); border:2px solid var(--ink); border-radius:5px;
  padding:1px 6px; letter-spacing:1px; margin-bottom:6px;
}
.logo--footer .logo-oof{ font-size:34px; -webkit-text-stroke-width:4px; }
.logo--footer .logo-game{ font-size:12px; padding:1px 7px; margin-bottom:7px; }

/* Buttons / CTA */
.btn{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--anton); text-transform:uppercase; text-decoration:none;
  cursor:pointer; background:var(--yellow); color:var(--ink);
  border:4px solid var(--ink); border-radius:16px;
}
.btn--cta{
  margin-top:28px; font-size:clamp(20px,2.6vw,28px); letter-spacing:.5px;
  padding:17px 34px; box-shadow:0 7px 0 var(--ink);
  transform:rotate(-1.5deg) translate(var(--mx,0px),var(--my,0px)); will-change:transform;
}
.hero-cta-wrap{ display:inline-block; }
.btn--cta-lg{
  margin-top:18px; font-size:clamp(22px,3vw,32px);
  padding:19px 40px; border-radius:18px; box-shadow:0 8px 0 var(--ink);
}
.btn--dice{
  margin-top:26px; font-size:24px; letter-spacing:.5px;
  padding:15px 32px; border-radius:14px; box-shadow:0 6px 0 var(--ink);
  transition:transform .1s;
}

/* Secondary pill links */
.pill{
  display:inline-flex; align-items:center; gap:10px; margin-top:24px;
  font-family:var(--anton); text-transform:uppercase; font-size:19px;
  color:var(--ink); background:var(--white);
  border:3px solid var(--ink); border-radius:30px;
  padding:11px 22px; text-decoration:none; box-shadow:0 5px 0 var(--ink);
}
.pill--yellow{ background:var(--yellow); padding:11px 24px; }

/* ===========================================================
   Layout helpers
   =========================================================== */
/* Vnitřní wrapper: jen šířka + centrování. Horizontální padding dává .section
   (u hero, kde sekce padding nemá, ho dodává .hero-inner). */
.container{ position:relative; max-width:1240px; margin:0 auto; width:100%; }
.container--narrow{ max-width:1180px; }

.section{ position:relative; padding:var(--pad-y) var(--pad-x); overflow:hidden; }
.section--white{ background:var(--white); }
.section--yellow{ background:var(--yellow); }
.section--red{ background:var(--red); }

/* Section typography */
.kicker{
  margin:0; font-family:var(--anton); text-transform:uppercase;
  letter-spacing:3px; color:var(--red); font-size:clamp(15px,2vw,19px);
}
.kicker--yellow{ color:var(--yellow); }
.h2{
  margin:14px 0 0; font-family:var(--anton); text-transform:uppercase;
  color:var(--ink); font-size:clamp(40px,7vw,90px);
  line-height:.95; letter-spacing:-1px; max-width:15ch;
}
.h2--stroke{
  color:var(--white); -webkit-text-stroke:2px var(--ink); paint-order:stroke;
}
.t-red{ color:var(--red); }
.lead{
  margin:18px 0 0; font-weight:600; font-size:clamp(17px,2vw,21px);
  max-width:560px; color:#222; line-height:1.45;
}
.lead--white{ color:var(--white); max-width:460px; }

/* ===========================================================
   TOPBAR
   =========================================================== */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:90;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px clamp(16px,4vw,40px);
  background:rgba(228,21,30,.94); border-bottom:3px solid var(--ink);
  transform:translateY(-110%);
  transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.topbar-buy{
  font-family:var(--anton); font-size:16px; letter-spacing:.5px; color:var(--ink);
  background:var(--yellow); border:3px solid var(--ink); border-radius:30px;
  padding:9px 20px; text-transform:uppercase; text-decoration:none;
  box-shadow:0 4px 0 var(--ink);
}

/* ===========================================================
   1) HERO
   =========================================================== */
.hero{
  position:relative; min-height:100vh; overflow:hidden;
  display:flex; align-items:center;
}
.hero-vignette{
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 90% at 30% 35%, transparent 52%, var(--vignette) 100%);
}
.hero-sunburst{
  position:absolute; right:-12vw; top:6vh; width:min(820px,90vw); aspect-ratio:1;
  opacity:.5; z-index:1;
}

.hero-mascot-wrap{
  position:absolute; right:clamp(10px,4vw,70px); top:50%; z-index:6;
}
.hero-mascot{
  display:block; height:min(640px,76vh); transform:translateY(-50%);
  filter:drop-shadow(0 22px 26px rgba(0,0,0,.4));
}

.hero-deco{ position:absolute; }
.hero-deco--1{ left:54%; top:5%;    z-index:5; }
.hero-deco--2{ left:45%; bottom:1%; z-index:7; }
.hero-deco--3{ left:1%;  top:30%;   z-index:5; }
.hero-deco-img{ display:block; }
.hero-deco--1 .hero-deco-img{ height:158px; filter:drop-shadow(0 12px 16px rgba(0,0,0,.4)); }
.hero-deco--2 .hero-deco-img{ height:150px; filter:drop-shadow(0 14px 18px rgba(0,0,0,.42)); }
.hero-deco--3 .hero-deco-img{ height:128px; filter:drop-shadow(0 12px 16px rgba(0,0,0,.4)); }
.r13{ transform:rotate(13deg); }
.r-7{ transform:rotate(-7deg); }
.r-15{ transform:rotate(-15deg); }

.hero-inner{ z-index:20; padding:0 var(--pad-x); }
.hero-text{ max-width:680px; }
.hero-headline{
  margin:0; font-family:var(--anton); text-transform:uppercase; color:var(--white);
  font-size:clamp(50px,8.5vw,104px); line-height:.9; letter-spacing:-1px;
  -webkit-text-stroke:2.5px var(--ink); paint-order:stroke;
  text-shadow:0 7px 0 rgba(0,0,0,.22);
}
.hero-sticker-wrap{ display:inline-block; margin-top:12px; }
.hero-sticker{
  display:inline-block; background:var(--yellow);
  border:4px solid var(--ink); border-radius:9px;
  padding:2px clamp(12px,2vw,20px); transform:rotate(-2deg);
  box-shadow:0 6px 0 var(--ink);
}
.hero-sticker span{
  font-family:var(--anton); text-transform:uppercase; color:var(--ink);
  font-size:clamp(42px,7.4vw,86px); line-height:1.02; letter-spacing:-1px;
}
.hero-sub{
  margin:26px 0 0; font-weight:600; color:var(--white);
  font-size:clamp(17px,2.1vw,22px); line-height:1.45; max-width:520px;
}

.scroll-cue{
  position:absolute; left:50%; bottom:54px; transform:translateX(-50%); z-index:20;
  color:var(--white); font-family:var(--anton); letter-spacing:2px; font-size:14px;
  text-transform:uppercase; opacity:.85; animation:floatB 2.4s ease-in-out infinite;
}

/* ===========================================================
   2) O CO JDE — 3 columns
   =========================================================== */
.cols-3{
  display:flex; gap:clamp(20px,3vw,40px);
  margin-top:clamp(48px,7vw,84px); flex-wrap:wrap;
}
.col{ flex:1; min-width:240px; border-top:5px solid var(--ink); padding-top:20px; }
.col--accent{ border-top-color:var(--yellow); }
.col-num{ font-family:var(--anton); font-size:clamp(34px,4.5vw,56px); color:var(--red); line-height:1; }
.col-label{ font-family:var(--anton); text-transform:uppercase; font-size:20px; margin-top:4px; }
.col-text{ margin:12px 0 0; font-weight:600; font-size:17px; line-height:1.5; color:#333; }
.oof-badge{
  display:inline-block; font-family:var(--baloo); font-weight:800;
  font-size:clamp(34px,4.5vw,52px); color:var(--ink); background:var(--yellow);
  border:3px solid var(--ink); border-radius:10px; padding:0 14px;
  transform:rotate(-2deg); line-height:1.15;
}
.col--accent .col-label{ margin-top:10px; }

/* ===========================================================
   3) SPECIÁLNÍ KARTY — grid (cells built in JS)
   =========================================================== */
.specials{ padding-bottom:clamp(70px,9vw,120px); }
.cards-grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:clamp(18px,2.4vw,30px); margin-top:clamp(44px,6vw,72px);
}
.card{
  background:var(--white); border:4px solid var(--ink); border-radius:18px;
  padding:16px 16px 18px; box-shadow:0 8px 0 var(--ink);
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s;
  transform-style:preserve-3d; will-change:transform;
}
.card-panel{
  border:3px solid var(--ink); border-radius:12px; overflow:hidden;
  display:flex; align-items:flex-end; justify-content:center; height:215px;
}
.card-panel img{
  height:200px; filter:drop-shadow(0 8px 10px rgba(0,0,0,.35)); pointer-events:none;
}
.card-name{
  font-family:var(--anton); text-transform:uppercase; font-size:24px;
  margin-top:14px; color:var(--ink); line-height:1;
}
.card-effect{ font-weight:600; font-size:14.5px; line-height:1.4; color:#444; margin-top:5px; }

/* ===========================================================
   4) CHAOS TORNÁDO
   =========================================================== */
.chaos{ position:relative; height:200vh; background:var(--red); }
.chaos-sticky{
  position:sticky; top:0; height:100vh; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.vortex-title{
  position:absolute; z-index:30; text-align:center; opacity:0; pointer-events:none;
}
.vortex-title-main{
  font-family:var(--anton); text-transform:uppercase; color:var(--white);
  font-size:clamp(60px,14vw,200px); line-height:.85; letter-spacing:-2px;
  -webkit-text-stroke:3px var(--ink); paint-order:stroke;
  text-shadow:0 10px 0 rgba(0,0,0,.3);
}
.vortex-title-pill{
  display:inline-block; margin-top:8px; font-family:var(--anton); text-transform:uppercase;
  color:var(--ink); background:var(--yellow); padding:6px 20px;
  border:3px solid var(--ink); border-radius:40px; font-size:clamp(15px,2vw,22px);
}
.vortex-art{
  position:absolute; left:50%; top:50%; height:min(620px,74vh);
  transform:translate(-50%,-50%) scale(.42); opacity:.16; z-index:20;
  filter:drop-shadow(0 20px 30px rgba(0,0,0,.45));
}
.vortex{ position:absolute; left:50%; top:50%; }
.vortex img{ display:block; filter:drop-shadow(0 10px 14px rgba(0,0,0,.4)); }

/* ===========================================================
   5) EXTRA KOSTKA
   =========================================================== */
.dice-wrap{ display:flex; gap:clamp(30px,5vw,70px); align-items:center; }
.dice-text{ flex:1; min-width:280px; }
.dice-text .lead{ max-width:430px; color:#333; }
.die-out{ margin-top:24px; min-height:74px; border-left:5px solid var(--yellow); padding-left:18px; }
.die-name{ font-family:var(--anton); text-transform:uppercase; font-size:26px; color:var(--red); transition:opacity .2s; }
.die-desc{ font-weight:600; font-size:16px; line-height:1.45; color:#333; margin-top:4px; max-width:420px; }

.die-stage{
  flex:0 0 auto; display:flex; align-items:center; justify-content:center;
  perspective:1100px; min-height:340px; width:300px; margin:0 auto;
}
.die-cube{
  position:relative; width:200px; height:200px; transform-style:preserve-3d;
  transform:rotateX(-18deg) rotateY(-22deg);
  transition:transform 1.15s cubic-bezier(.2,.85,.25,1);
  cursor:pointer;
}
.die-face{
  position:absolute; inset:0; border:5px solid var(--ink); border-radius:20px;
  background:var(--white); display:flex;
  align-items:center; justify-content:center; backface-visibility:hidden; overflow:hidden;
}
.die-face-img{ width:88%; height:88%; object-fit:contain; pointer-events:none; user-select:none; }

/* ===========================================================
   6 + 7) SPLIT sekce (text + media)
   =========================================================== */
.split{ display:flex; gap:clamp(30px,5vw,64px); align-items:center; }
.split-text{ flex:1; min-width:280px; }
.split-media{ flex:1; min-width:280px; position:relative; }
.photo{
  width:100%; display:block; border:5px solid var(--ink); border-radius:18px;
  box-shadow:0 16px 0 rgba(0,0,0,.18);
}
.section--red .photo{ box-shadow:0 16px 0 rgba(0,0,0,.25); }
.split-deco{ position:absolute; }
.split-deco--quality{
  right:-34px; bottom:-40px; height:230px; transform:rotate(8deg);
  filter:drop-shadow(0 14px 18px rgba(0,0,0,.4));
}
.split-deco--house{
  left:-40px; bottom:-36px; height:220px; transform:rotate(-7deg);
  filter:drop-shadow(0 14px 18px rgba(0,0,0,.45));
}

/* ===========================================================
   8) SOUTĚŽ O ROBUXY
   =========================================================== */
.contest{ text-align:center; }
.contest .kicker{ margin:0 auto; }
.contest-vyhraj{
  margin:12px auto 0; font-family:var(--anton); text-transform:uppercase;
  color:var(--ink); font-size:clamp(30px,4.6vw,56px); line-height:.95; letter-spacing:-1px;
}
.contest-num{
  font-family:var(--anton); color:var(--red); font-size:clamp(64px,15vw,200px);
  line-height:.85; letter-spacing:-3px; -webkit-text-stroke:3px var(--ink); paint-order:stroke;
  text-shadow:0 9px 0 rgba(0,0,0,.18); margin-top:6px;
}
.contest-unit{
  font-family:var(--anton); text-transform:uppercase; color:var(--ink);
  font-size:clamp(26px,4.4vw,52px); letter-spacing:1px; margin-top:-4px;
}
.steps{
  display:flex; gap:clamp(16px,2.4vw,28px); margin-top:clamp(44px,6vw,72px);
  flex-wrap:wrap; justify-content:center;
}
.step{
  flex:1; min-width:230px; max-width:330px; background:var(--white);
  border:4px solid var(--ink); border-radius:18px; padding:24px;
  box-shadow:0 8px 0 var(--ink); text-align:left;
}
.step-num{ font-family:var(--anton); font-size:42px; color:var(--red); line-height:1; }
.step-text{ font-weight:700; font-size:18px; margin-top:6px; }

/* ===========================================================
   9) OOF! FINÁLE + footer
   =========================================================== */
.finale{ padding:clamp(90px,13vw,170px) var(--pad-x) clamp(60px,8vw,90px); text-align:center; }
.finale-sunburst{
  position:absolute; left:50%; top:38%; transform:translate(-50%,-50%);
  width:min(760px,120vw); aspect-ratio:1; opacity:.4; z-index:0;
  background:repeating-conic-gradient(from 8deg, rgba(255,212,0,.85) 0 7deg, rgba(255,212,0,0) 7deg 16deg);
  animation:spin 70s linear infinite;
}
.finale-inner{ max-width:1100px; z-index:1; }
.finale-pre{
  font-family:var(--anton); text-transform:uppercase; color:var(--white);
  font-size:clamp(22px,3.6vw,40px); letter-spacing:2px;
  -webkit-text-stroke:1.5px var(--ink); paint-order:stroke;
}
.oof-burst{
  margin:6px auto 0; font-family:var(--baloo); font-weight:800; color:var(--white);
  font-size:clamp(110px,28vw,300px); line-height:.8;
  -webkit-text-stroke:clamp(7px,1.6vw,14px) var(--ink); paint-order:stroke;
  text-shadow:0 clamp(8px,1.6vw,16px) 0 var(--ink); letter-spacing:-8px;
}

.footer{
  position:relative; max-width:1200px; margin:clamp(60px,9vw,110px) auto 0;
  border-top:3px solid var(--ink); padding-top:28px;
  display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:space-between;
}
.footer-links{ display:flex; gap:22px; flex-wrap:wrap; font-family:var(--anton); text-transform:uppercase; font-size:15px; letter-spacing:1px; }
.footer-links a{ color:var(--ink); text-decoration:none; }
.footer-rating{ display:inline-flex; align-items:center; gap:7px; flex-wrap:wrap; color:#fff; text-decoration:none; }
.footer-rating-star{ color:var(--yellow); font-size:19px; line-height:1; }
.footer-rating-num{ font-family:var(--anton); font-size:19px; line-height:1; }
.footer-rating-max{ font-weight:700; opacity:.7; margin-left:-3px; }
.footer-rating-text{ font-weight:600; font-size:13px; opacity:.9; margin-left:4px; }
.footer-rating:hover .footer-rating-text{ text-decoration:underline; }
.footer-copy{ font-weight:600; font-size:13px; color:rgba(255,255,255,.85); width:100%; }

/* ===========================================================
   RESPONSIVE — jediné media queries (zbytek je clamp + flex/grid)
   =========================================================== */
@media (max-width:880px){
  [data-deco]{ display:none !important; }
  .hero-mascot-wrap{ right:-90px !important; }
  .hero-mascot{ opacity:.16 !important; height:560px !important; }
  .hero-headline{ font-size:clamp(46px,13vw,82px) !important; }
  [data-stack]{ flex-direction:column !important; }
  /* media-blok první u sekcí, kde je vlevo (House) — drž text nad fotkou? Ne: pořadí dle DOM. */
}
@media (max-width:560px){
  .hero-mascot-wrap{ display:none !important; }
}

/* ===========================================================
   prefers-reduced-motion: reduce — klidná varianta
   =========================================================== */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
}
