@import url('https://fonts.googleapis.com/css2?family=Anton&family=Inter:wght@400;600;800;900&display=swap');

:root{
  --green:#003f21;
  --green2:#00612f;
  --gold:#f3b51b;
  --gold2:#c99008;
  --cream:#fffaf0;
  --ink:#111;
  --muted:#666;
  --line:#e8ddc5;
  --red:#e94b2d;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,sans-serif;
  color:var(--ink);
  background:#f7f3e9;
}
.page{
  max-width:1280px;
  margin:0 auto;
  background:#fffdf8;
  box-shadow:0 0 50px rgba(0,0,0,.2);
  overflow:hidden;
}

.hero{
  min-height:430px;
  color:#fff;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:30px;
  padding:30px 48px 34px;
  background:
    radial-gradient(circle at 85% 35%, rgba(247,181,27,.38), transparent 28%),
    radial-gradient(circle at 90% 80%, rgba(247,181,27,.22), transparent 24%),
    linear-gradient(110deg, #003317 0%, #004721 52%, #042713 100%);
  position:relative;
}
.hero:before{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(155deg, transparent 55%, rgba(243,181,27,.85) 55.3%, transparent 56%),
    linear-gradient(150deg, transparent 58%, rgba(243,181,27,.34) 58.3%, transparent 60%),
    radial-gradient(circle at 90% 55%, rgba(255,201,54,.65) 0 2px, transparent 3px);
  background-size:100% 100%,100% 100%,18px 18px;
  opacity:.55;
  pointer-events:none;
}
.hero__copy,.hero__bok{position:relative;z-index:1}
.logo{
  width:470px;
  max-width:100%;
  border-radius:14px;
  filter:drop-shadow(0 10px 10px rgba(0,0,0,.35));
}
.eyebrow{
  margin:22px 0 0;
  text-transform:uppercase;
  letter-spacing:3px;
  font-family:Anton,Impact,sans-serif;
  font-size:44px;
  line-height:1;
  text-shadow:0 3px 0 rgba(0,0,0,.22);
}
h1{
  margin:0;
  font-family:Anton,Impact,sans-serif;
  font-size:86px;
  letter-spacing:3px;
  line-height:1;
  color:var(--gold);
  text-transform:uppercase;
  text-shadow:0 5px 0 rgba(0,0,0,.28);
}
.tagline{
  display:inline-block;
  margin:22px 0 24px;
  padding:10px 26px;
  border-top:3px solid var(--gold);
  border-bottom:3px solid var(--gold);
  text-transform:uppercase;
  letter-spacing:2px;
  font-weight:900;
  font-size:22px;
}
.hero-points{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  max-width:700px;
}
.hero-points div{display:grid;grid-template-columns:58px 1fr;gap:10px}
.hero-points span{
  grid-row:span 2;
  width:52px;height:52px;border:3px solid var(--gold);border-radius:50%;
  display:grid;place-items:center;font-size:26px;color:var(--gold);
}
.hero-points b{color:var(--gold);text-transform:uppercase;font-size:15px}
.hero-points small{font-size:13px;line-height:1.45}
.hero__bok{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}
.hero__bok img{width:92%;max-width:450px;border-radius:22px;box-shadow:0 18px 36px rgba(0,0,0,.35);object-fit:cover}
.hero__bok strong{
  color:var(--gold);
  font-family:Georgia,serif;
  font-style:italic;
  font-size:38px;
  text-shadow:0 3px 0 #001d0f;
}

.prize{
  display:grid;
  grid-template-columns:1.1fr 1.3fr .18fr 1.1fr .18fr 1.1fr;
  gap:18px;
  align-items:center;
  padding:34px 52px;
  background:#fff;
}
.prize-title{
  border-right:2px solid var(--line);
  min-height:140px;
  display:flex;
  align-items:center;
}
.prize h2{
  color:var(--green);
  font-family:Anton,Impact,sans-serif;
  font-size:34px;
  letter-spacing:1px;
  text-transform:uppercase;
}
.prize-item{
  text-align:center;
  align-self:start;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.prize-item img{display:block;width:190px;height:125px;max-width:100%;object-fit:cover;border-radius:12px;border:4px solid #fff;box-shadow:0 8px 18px rgba(0,0,0,.22)}
.prize-item b{
  display:inline-block;
  min-width:170px;
  background:linear-gradient(#086131,#003d1f);
  color:#fff;
  padding:8px 16px;
  border-radius:6px;
  font-size:18px;
  text-transform:uppercase;
  box-shadow:0 4px 10px rgba(0,0,0,.16);
}
.prize-item small{display:block;margin-top:8px;line-height:1.35}
.plus{
  width:40px;height:40px;background:var(--green);border-radius:50%;
  color:#fff;font-size:30px;font-weight:900;display:grid;place-items:center;
}

.how{
  margin:0 32px 18px;
  padding:24px 34px 28px;
  border:1px solid var(--line);
  background:#fffefb;
  border-radius:4px;
}
.how h2,.form-panel h2,.rules h2{
  margin:0 0 22px;
  text-align:center;
  font-family:Anton,Impact,sans-serif;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:2px;
  font-size:31px;
}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.steps div{position:relative;padding-left:74px}
.steps div:before{
  content:"";
  position:absolute;left:0;top:0;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(145deg,#006433,#002c16);
  box-shadow:0 8px 12px rgba(0,0,0,.16);
}
.steps div:nth-child(1):before{content:"✎";color:#fff;display:grid;place-items:center;font-size:30px}
.steps div:nth-child(2):before{content:"📅";display:grid;place-items:center;font-size:28px}
.steps div:nth-child(3):before{content:"🛒";display:grid;place-items:center;font-size:30px}
.steps div:nth-child(4):before{content:"🎁";display:grid;place-items:center;font-size:30px}
.steps span{
  position:absolute;left:48px;top:6px;background:var(--gold);color:#003d1f;
  width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-weight:900;
}
.steps b{text-transform:uppercase;color:var(--green);display:block;margin:8px 0 6px}
.steps p{margin:0;font-size:14px;line-height:1.45}

.content-grid{
  display:grid;
  grid-template-columns:2.1fr 1fr;
  gap:22px;
  padding:0 32px 28px;
}
.panel{
  background:#fffdf8;
  border:1px solid var(--line);
  border-radius:8px;
  padding:24px;
  box-shadow:0 8px 18px rgba(56,35,0,.06);
}
.form-panel h2{
  display:flex;align-items:center;justify-content:center;gap:18px;
}
.form-panel h2 img{width:54px;height:54px;object-fit:cover;border-radius:10px}
label{display:block;font-weight:800;margin:12px 0 8px}
em{color:#d71e1e;font-style:normal}
input[type=email]{
  width:100%;height:48px;border:1px solid #bbb;border-radius:5px;
  padding:0 14px;font-size:16px;
}
.match{
  display:grid;
  grid-template-columns:120px 1fr 70px 20px 70px 1fr;
  gap:14px;
  align-items:center;
  margin:14px 0;
  padding:14px;
  background:#fbf8f1;
  border-radius:8px;
  border:1px solid #eee3d0;
}
.date{
  background:linear-gradient(#006433,#003c1e);
  color:#fff;
  font-weight:900;
  font-size:13px;
  text-transform:uppercase;
  padding:9px 10px;
  border-radius:5px;
  text-align:center;
}
.team{font-weight:900;text-transform:uppercase}
.opponent{text-align:right}
.match input{
  width:70px;height:54px;
  font-size:24px;text-align:center;
  border:1px solid #aaa;border-radius:6px;background:#fff;
}
.match span{text-align:center;font-weight:900}

.prediction-confirm{
  grid-column:2 / 7;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  margin:0;
  font-size:13px;
  font-weight:800;
  color:var(--green);
}
.prediction-confirm input{
  width:18px;
  height:18px;
  margin:0;
  accent-color:var(--green);
}
.prediction-confirm span{
  text-align:left;
  font-weight:800;
}
.match-status{
  grid-column:1 / 7;
  text-align:right;
  font-size:12px;
  color:var(--muted);
}
.match--closed .prediction-confirm{opacity:.55}

.check{
  display:flex;
  align-items:flex-start;
  gap:14px;
  margin-top:18px;
}
.check input{width:34px;height:34px;flex:0 0 auto}
.check a{color:var(--green);font-weight:700}
button{
  display:block;
  width:72%;
  margin:22px auto 10px;
  border:0;
  background:linear-gradient(90deg,#006431,#002d17);
  color:#fff;
  text-transform:uppercase;
  font-size:25px;
  letter-spacing:1px;
  font-weight:900;
  padding:18px 22px;
  border-radius:7px;
  cursor:pointer;
  box-shadow:0 8px 0 #001b0d, 0 14px 20px rgba(0,0,0,.18);
}
button:before{content:"🦌 ";font-size:22px}
button:hover{transform:translateY(1px);box-shadow:0 7px 0 #001b0d, 0 12px 18px rgba(0,0,0,.18)}
.safe{text-align:center;font-size:13px;margin:14px 0 0;color:#333}
.rules{
  background:linear-gradient(#fffdf6,#fff5df);
}
.rules h2{text-align:left;font-size:26px}
.rules ul{list-style:none;padding:0;margin:0}
.rules li{
  position:relative;
  padding-left:32px;
  margin:0 0 18px;
  line-height:1.35;
}
.rules li:before{
  content:"✓";
  position:absolute;left:0;top:0;
  width:18px;height:18px;border:2px solid var(--green);border-radius:50%;
  color:var(--green);font-size:12px;display:grid;place-items:center;font-weight:900;
}
footer{
  background:linear-gradient(90deg,#003617,#005529,#003617);
  border-top:4px solid var(--gold);
  color:#fff;
  display:grid;
  grid-template-columns:180px 1fr 140px;
  align-items:center;
  padding:18px 54px;
}
footer img{width:120px;height:120px;object-fit:cover;border-radius:16px}
footer p{text-align:center;margin:0;text-transform:uppercase;letter-spacing:1px}
footer p b{color:#fff}
footer p span{
  color:#fff;
  text-transform:none;
  font-family:Georgia,serif;
  font-style:italic;
  font-size:20px;
}
.footer-icons{text-align:right;font-size:22px;color:var(--gold)}

/* Responsive layout */
img{max-width:100%;height:auto}
input,button{font:inherit}

@media(max-width:1100px){
  .hero{grid-template-columns:1fr .72fr;padding:28px 30px}
  h1{font-size:clamp(58px,7vw,78px)}
  .eyebrow{font-size:clamp(30px,4vw,40px)}
  .hero-points{gap:14px}
  .prize{padding:30px 28px;gap:12px}
  .prize-item img{width:165px;height:112px}
  .prize-item b{min-width:150px;font-size:16px}
  .content-grid{grid-template-columns:minmax(0,2fr) minmax(260px,1fr);padding-inline:22px}
  .match{grid-template-columns:105px minmax(90px,1fr) 64px 18px 64px minmax(80px,1fr);gap:10px}
  .match input{width:64px}
}

@media(max-width:820px){
  body{background:#fffdf8}
  .page{width:100%;box-shadow:none}
  .hero{grid-template-columns:1fr;padding:24px 20px 28px;text-align:center}
  .logo{width:min(470px,100%)}
  h1{font-size:clamp(52px,12vw,72px);overflow-wrap:anywhere}
  .eyebrow{font-size:clamp(28px,7vw,38px)}
  .tagline{font-size:clamp(15px,3.8vw,20px);padding-inline:12px}
  .hero-points{grid-template-columns:repeat(3,minmax(0,1fr));max-width:none;text-align:left}
  .hero-points div{grid-template-columns:48px 1fr}
  .hero-points span{width:44px;height:44px;font-size:22px}
  .hero__bok img{width:min(430px,92%)}

  .prize{grid-template-columns:repeat(3,minmax(0,1fr));padding:28px 18px;gap:14px}
  .prize-title{grid-column:1/-1;border-right:0;border-bottom:2px solid var(--line);min-height:auto;justify-content:center}
  .prize h2{text-align:center;margin:0 0 18px;font-size:30px}
  .plus{display:none}
  .prize-item{align-self:stretch}
  .prize-item img{width:100%;height:130px}
  .prize-item b{min-width:0;width:100%;font-size:15px;padding-inline:8px}

  .how{margin:0 16px 18px;padding:22px 20px}
  .steps{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
  .content-grid{grid-template-columns:1fr;padding:0 16px 20px}
  .panel{padding:22px 18px}
  .match{grid-template-columns:105px minmax(80px,1fr) 64px 18px 64px minmax(80px,1fr)}
  button{width:100%;font-size:20px}
  footer{grid-template-columns:120px 1fr;padding:18px 24px;gap:18px}
  footer img{width:100px;height:100px}
  .footer-icons{display:none}
}

@media(max-width:600px){
  .hero{padding-inline:16px}
  .hero-points{grid-template-columns:1fr;gap:15px;text-align:left}
  .hero-points div{max-width:360px;margin-inline:auto;width:100%}
  .hero__bok img{width:100%;border-radius:14px}

  .prize{grid-template-columns:1fr;padding:24px 16px}
  .prize-item{width:min(330px,100%);margin-inline:auto}
  .prize-item img{height:190px}
  .prize-item b{font-size:17px}

  .steps{grid-template-columns:1fr}
  .steps div{min-height:62px}
  .how h2,.form-panel h2,.rules h2{font-size:26px}
  .form-panel h2{gap:9px;line-height:1.1}
  .form-panel h2 img{width:38px;height:38px;flex:0 0 auto}

  .match{
    grid-template-columns:minmax(0,1fr) 26px minmax(0,1fr);
    gap:9px 8px;
    padding:13px 10px;
  }
  .date{grid-column:1/-1;width:100%}
  .team{grid-column:1;text-align:center;font-size:13px;overflow-wrap:anywhere}
  .opponent{grid-column:3;text-align:center}
  .match input[type="number"]{width:min(78px,100%);height:52px;justify-self:center;font-size:22px}
  .match input[type="number"]:first-of-type{grid-column:1;grid-row:3}
  .match > span:not(.kickoff){grid-column:2;grid-row:3;align-self:center}
  .match input[type="number"]:nth-of-type(2){grid-column:3;grid-row:3}
  .prediction-confirm{grid-column:1/-1;justify-content:center;margin-top:4px}
  .match-status{grid-column:1/-1;text-align:center}

  .check input{width:26px;height:26px}
  button{padding:16px 12px;font-size:18px}
  footer{grid-template-columns:1fr;text-align:center;padding:20px 16px}
  footer img{margin:auto;width:92px;height:92px}
  footer p span{font-size:17px}
}

@media(max-width:380px){
  h1{font-size:46px;letter-spacing:1px}
  .eyebrow{font-size:26px;letter-spacing:2px}
  .tagline{font-size:14px;letter-spacing:1px}
  .panel{padding:18px 12px}
  .form-panel h2 img{display:none}
  .match{padding-inline:8px}
}

/* Match entry cut-off states */
.kickoff {
  display: block;
  margin-top: 2px;
  font-size: 0.72rem;
  font-weight: 600;
  opacity: 0.78;
}

.match-status {
  grid-column: 1 / -1;
  margin-top: 7px;
  font-size: 0.78rem;
  font-weight: 700;
  text-align: center;
  color: #37663f;
}

.match--closed {
  opacity: 0.72;
  background: #ececec;
}

.match--closed input[type="number"] {
  cursor: not-allowed;
  background: #d8d8d8;
  border-color: #b7b7b7;
}

.match--closed .match-status {
  color: #9e2f2f;
}

.form-panel button:disabled {
  cursor: not-allowed;
  opacity: 0.58;
}
