/* Domino's CM2026 — Tippspiel local mockup */
:root{
  --blue:#006491;
  --blue-d:#00557c;
  --blue-l:#2D8CBE;
  --blue-pale:#E3EDF2;
  --red:#E31837;
  --red-d:#c5142f;
  --gold:#E0A100;
  --silver:#8a96a3;
  --bronze:#B5703A;
  --white:#fff;
  --ink:#1a1f24;
  --grey:#6b7280;
  --row:#f4f7f9;
  --radius:22px;
  --shadow:0 18px 40px rgba(0,0,0,.18);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,Arial,sans-serif;
  color:var(--white);
  background:var(--blue);
  -webkit-font-smoothing:antialiased;
  /* sticky footer: page fills viewport, footer pinned to bottom on short pages */
  display:flex;
  flex-direction:column;
  min-height:100vh;
}
/* football pitch as a fixed backdrop (cadru) */
body::before{
  content:'';
  position:fixed;
  inset:0;
  z-index:-1;
  background:var(--blue) url('pitch.svg') center center / cover no-repeat;
  pointer-events:none;
}
h1,h2,h3{font-family:'Montserrat',sans-serif;font-weight:800;line-height:1.05;margin:0}
a{color:inherit;text-decoration:none}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.section{padding:72px 0}
.center{text-align:center}

/* ---------- header ---------- */
.nav{position:sticky;top:0;z-index:40;background:rgba(0,100,145,.92);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.08)}
.nav .container{display:flex;align-items:center;gap:28px;height:74px}
.logo{display:flex;align-items:center;gap:12px;font-family:'Montserrat',sans-serif;font-weight:800;font-size:26px;color:#fff}
.logo svg{width:42px;height:42px;display:block}
.nav-links{display:flex;gap:26px;margin-left:8px;font-weight:500;font-size:16px;opacity:.92}
.nav-links a:hover{opacity:.7}
.nav-spacer{flex:1}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:'Montserrat',sans-serif;font-weight:800;letter-spacing:.04em;text-transform:uppercase;border:none;cursor:pointer;border-radius:999px;padding:14px 30px;font-size:15px;transition:transform .12s ease,background .2s}
.btn:hover{transform:translateY(-1px)}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-d)}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.btn-blue{background:var(--blue-l);color:#fff}
.btn-sm{padding:11px 22px;font-size:13px}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:90px 0 80px}
.hero .container{display:grid;grid-template-columns:1.3fr .7fr;align-items:center;gap:30px}
.hero h1{font-size:clamp(40px,7vw,72px);letter-spacing:-.02em}
.page-title{font-size:clamp(30px,6vw,52px)}
.page-title-xl{font-size:clamp(46px,10vw,88px)}
.hero p{font-size:19px;line-height:1.55;opacity:.95;max-width:560px;margin:24px 0 32px}
.ball{width:230px;height:230px;justify-self:center;filter:drop-shadow(0 16px 24px rgba(0,0,0,.25))}
.eyebrow{display:inline-block;background:rgba(255,255,255,.14);padding:7px 16px;border-radius:999px;font-weight:600;font-size:14px;letter-spacing:.04em;margin-bottom:22px}

/* ---------- generic section heading ---------- */
.h-sec{font-size:clamp(28px,4.5vw,42px);margin-bottom:36px}
.sub{opacity:.85;font-size:18px}

/* ---------- stages ---------- */
.stages{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.stg{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:22px 16px;text-align:center}
.stg b{display:block;font-family:'Montserrat';font-size:18px;margin-bottom:4px}
.stg span{opacity:.82;font-size:14px}

/* ---------- prizes ---------- */
.prize-hero{max-width:780px;margin:0 auto 38px;border-radius:22px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.12)}
.prize-hero img{display:block;width:100%;height:auto}
.prizes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prize{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:26px;text-align:center}
.prize .ph{height:150px;border-radius:14px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;color:var(--blue);font-weight:700;margin-bottom:18px}
.prize .tag{font-weight:800;font-family:'Montserrat';text-transform:uppercase;font-size:13px;letter-spacing:.06em;color:#ffd244}
.prize h3{font-size:20px;margin:8px 0 0}

/* ---------- rules ---------- */
.rules{background:#fff;color:var(--ink);border-radius:26px;box-shadow:var(--shadow);padding:46px;transform:rotate(-.4deg)}
.rules h2{color:var(--blue);font-size:34px;margin-bottom:26px}
.rule{display:flex;gap:18px;align-items:flex-start;padding:16px 0;border-top:1px dashed #d8e0e6}
.rule:first-of-type{border-top:none}
.rule .ic{flex:0 0 54px;height:54px;border-radius:14px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;font-size:26px}
.rule p{margin:0;line-height:1.5;color:#39434b}
.rule b{color:var(--blue)}

/* ---------- product lineup ---------- */
.line{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:#fff;border-radius:18px;overflow:hidden;color:var(--ink);box-shadow:var(--shadow)}
.card .ph{height:200px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;color:var(--blue);font-weight:600}
.card .pizpic{display:block;width:100%;height:200px;object-fit:cover;transition:transform .3s ease}
a.card{transition:transform .15s ease,box-shadow .15s ease}
a.card:hover{transform:translateY(-5px);box-shadow:0 26px 50px rgba(0,0,0,.28)}
a.card:hover .pizpic{transform:scale(1.05)}
a.card:hover .br{color:var(--red)}
.card .meta{padding:16px 18px}
.card .meta .nm{font-weight:700}
.card .meta .br{color:var(--blue);font-weight:800;font-family:'Montserrat';font-size:14px;margin-top:2px}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid rgba(255,255,255,.16);padding:18px 4px}
.faq summary{cursor:pointer;font-weight:600;font-size:18px;list-style:none;display:flex;justify-content:space-between}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:24px;opacity:.7}
.faq details[open] summary::after{content:'–'}
.faq p{opacity:.85;margin:14px 0 2px;line-height:1.55}

/* ---------- footer ---------- */
footer{background:var(--blue-d);padding:40px 0;margin-top:auto}
footer .container{display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center;font-size:14px;opacity:.85}
.fl{display:flex;gap:22px;flex-wrap:wrap}

/* ---------- board (joc) ---------- */
.board-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.qcard{background:#fff;color:var(--ink);border-radius:22px;box-shadow:var(--shadow);padding:28px;display:flex;flex-direction:column;gap:14px}
.qcard .round{color:var(--blue);font-size:30px}
.qcard .q{font-weight:600;min-height:74px;color:#39434b}
.qcard input,.qcard select{width:100%;border:none;background:var(--blue-pale);border-radius:12px;padding:15px 16px;font-size:16px;color:var(--ink);font-family:inherit}
.qcard .hint{font-size:13px;color:var(--grey)}
.timer{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--grey);margin-top:4px}
.timer b{font-variant-numeric:tabular-nums;background:var(--blue);color:#fff;padding:4px 10px;border-radius:8px;font-family:'Inter'}
.note{max-width:760px;margin:36px auto 0;text-align:center;opacity:.9;line-height:1.55}

/* ---------- match cards (per-meci) ---------- */
.stage-bar{display:flex;align-items:center;gap:14px;justify-content:center;margin:30px 0 6px}
.stage-bar .chip{background:rgba(255,255,255,.14);padding:8px 18px;border-radius:999px;font-weight:600;font-size:15px}
.mcard{position:relative;background:#fff;color:var(--ink);border-radius:22px;box-shadow:var(--shadow);padding:26px 24px 24px;display:flex;flex-direction:column;gap:16px}
.saved-tag{position:absolute;top:14px;right:14px;background:#1c8a4a;color:#fff;font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px;letter-spacing:.02em}
.timer.locked b{background:var(--grey)}
.mcard .teams{display:flex;align-items:center;justify-content:center;gap:8px;font-family:'Montserrat';font-weight:800;font-size:18px;min-height:48px;flex-wrap:wrap;text-align:center}
.mcard .timer{margin-top:auto}
.mcard .teams .fl{font-size:22px}
.mcard .teams .vs{color:var(--grey);font-weight:600}
.scorebox{display:flex;align-items:center;justify-content:center;gap:14px}
.scorebox input{width:84px;height:74px;text-align:center;font-size:34px;font-family:'Montserrat';font-weight:800;color:var(--blue);border:2px solid var(--blue-pale);background:#fafcfd;border-radius:14px}
.scorebox input:focus{outline:none;border-color:var(--blue-l)}
.scorebox input.err-empty{border-color:var(--red);background:#fff4f5}
.scorebox .dash{font-family:'Montserrat';font-weight:800;font-size:26px;color:var(--grey)}
.qual .qlabel{font-size:14px;color:var(--grey);margin-bottom:8px;text-align:center}
.qbtns{display:flex;gap:10px}
.qbtn{flex:1;border:2px solid var(--blue-pale);background:#fff;color:var(--ink);font-family:'Inter';font-weight:600;font-size:15px;padding:13px 8px;border-radius:12px;cursor:pointer;transition:.15s}
.qbtn:hover{border-color:var(--blue-l)}
.qbtn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.pts-hint{display:flex;gap:6px;flex-wrap:nowrap;justify-content:center;font-size:11px;color:var(--grey)}
.pts-hint span{background:var(--blue-pale);color:var(--blue);padding:4px 8px;border-radius:8px;font-weight:600;white-space:nowrap}
.pts-hint .pts-max{background:transparent;color:var(--grey)}

/* ---------- countdown ---------- */
.cd-mount{margin:0 auto}
.cdown{max-width:560px;margin:0 auto;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:22px 18px;text-align:center}
.cdown-title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:15px;letter-spacing:.04em;text-transform:uppercase;opacity:.92;margin-bottom:14px}
.cdown-grid{display:flex;justify-content:center;gap:10px}
.cdseg{background:var(--blue-d);border-radius:14px;padding:14px 10px;min-width:74px}
.cdseg b{display:block;font-family:'Montserrat',sans-serif;font-weight:800;font-size:34px;line-height:1;color:#fff;font-variant-numeric:tabular-nums}
.cdseg span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;opacity:.7;margin-top:6px}
@media(max-width:600px){.cdseg{min-width:58px;padding:12px 6px}.cdseg b{font-size:26px}}

/* ---------- coming-soon: blanked cards + big countdown overlay ---------- */
.board-grid{position:relative}
.mcard.ghost .teams{color:var(--grey)}
.mcard.ghost input:disabled,.mcard.ghost .qbtn:disabled{opacity:.6;cursor:default}
.ghost .qm{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--blue-pale);color:var(--blue);font-weight:800;font-family:'Montserrat',sans-serif}
.board-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;border-radius:24px;background:rgba(2,52,78,.6);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);z-index:5}
.board-overlay .cdown{background:transparent;border:none;max-width:none}
.board-overlay .cdown-title{font-size:18px}
.board-overlay .cdseg{min-width:90px}
.board-overlay .cdseg b{font-size:46px}
@media(max-width:600px){.board-overlay .cdseg{min-width:62px;padding:10px 6px}.board-overlay .cdseg b{font-size:30px}}

/* ---------- leaderboard ---------- */
.lbcard{background:#fff;color:var(--ink);border-radius:26px;box-shadow:var(--shadow);padding:18px 30px;max-width:1000px;margin:0 auto}
table.lb{width:100%;border-collapse:collapse}
table.lb th{font-family:'Inter';font-weight:600;color:var(--grey);font-size:14px;text-transform:uppercase;letter-spacing:.04em;text-align:left;padding:18px 10px}
table.lb td{padding:16px 10px;border-top:1px solid #eef2f5;font-size:18px}
table.lb td.rank{font-family:'Montserrat';font-weight:800;color:var(--blue);width:80px}
table.lb td.name{font-weight:600}
table.lb td.ex{color:var(--grey);text-align:center;width:140px}
table.lb td.pts{font-family:'Montserrat';font-weight:800;color:var(--blue);text-align:right;width:120px}
table.lb tr.alt td{background:var(--row)}
table.lb tr.you td{background:var(--blue-pale)}
table.lb tr.you td{color:var(--red)}
.rank.g{color:var(--gold)} .rank.s{color:var(--silver)} .rank.b{color:var(--bronze)}
.legend{text-align:center;margin-top:30px;opacity:.9;font-weight:500}
.legend b{color:#ffd244}

/* ---------- legal doc ---------- */
.doc{background:#fff;color:var(--ink);border-radius:22px;box-shadow:var(--shadow);padding:46px;max-width:900px;margin:0 auto;line-height:1.62}
.doc h1{color:var(--blue);font-size:clamp(26px,4vw,34px);margin-bottom:6px}
.doc h2{color:var(--blue);font-size:20px;margin:30px 0 10px}
.doc p{margin:8px 0;color:#39434b}
.doc ul{margin:8px 0;padding-left:22px;color:#39434b}
.doc li{margin:5px 0}
.doc .meta{color:var(--grey);font-size:14px;margin-bottom:18px}
.doc .box{background:var(--blue-pale);color:var(--blue);padding:14px 18px;border-radius:14px;font-size:15px;margin:14px 0}
.doc a{color:var(--blue);text-decoration:underline}
@media(max-width:600px){.doc{padding:26px 20px}}

/* ---------- modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(0,30,45,.7);display:none;align-items:center;justify-content:center;z-index:80;padding:20px}
.modal-bg.open{display:flex}
.modal{background:#fff;color:var(--ink);border-radius:24px;max-width:440px;width:100%;padding:38px 34px;text-align:center;box-shadow:var(--shadow)}
.modal .chk{width:72px;height:72px;border-radius:50%;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:34px}
.modal h3{color:var(--blue);font-size:26px;margin-bottom:10px}
.modal p{color:#39434b;line-height:1.55;margin:0 0 24px}
.modal .btn{width:100%}
.modal .x{margin-top:14px;display:inline-block;color:var(--grey);font-size:14px;cursor:pointer}
.modal{position:relative;max-height:92vh;overflow-y:auto}
.modal-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:28px;line-height:1;color:var(--grey);cursor:pointer;padding:4px}
.modal-close:hover{color:var(--ink)}
.dommodal{max-width:560px}
.dom-routes{display:flex;gap:14px;text-align:left;margin:10px 0 4px}
.dom-route{flex:1;background:var(--blue-pale);border-radius:16px;padding:18px 16px;display:flex;flex-direction:column;gap:8px}
.dom-route .dom-ic{font-size:30px}
.dom-route b{color:var(--blue);font-family:'Montserrat',sans-serif}
.dom-route span{font-size:13px;color:#39434b;line-height:1.45;flex:1}
.dom-route .btn{width:100%;margin-top:6px}
.dom-tip{font-size:13px;color:var(--grey)!important;margin:14px 0 6px!important}
.dom-cta{display:inline-block;margin-top:16px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;padding:10px 18px;border-radius:999px;font-weight:600;font-size:14px;cursor:pointer}
.dom-cta:hover{background:rgba(255,255,255,.2)}
@media(max-width:560px){.dom-routes{flex-direction:column}}

/* auth form */
.authform{text-align:left;margin-top:8px}
.authform label{display:block;font-size:13px;font-weight:600;color:#39434b;margin:13px 0 0}
.authform input[type=text],.authform input[type=email],.authform input[type=tel]{width:100%;margin-top:6px;padding:12px 14px;border:1.5px solid var(--blue-pale);border-radius:12px;font-size:15px;font-family:inherit;color:var(--ink);background:#fafcfd}
.authform input:focus{outline:none;border-color:var(--blue-l)}
.authform small{display:block;color:var(--grey);font-weight:500;font-size:12px;margin-top:5px}
.authform .row2{display:flex;gap:12px}
.authform .row2 label{flex:1}
.authform .chkrow{display:flex;align-items:flex-start;gap:9px;font-weight:500;font-size:13.5px;margin-top:14px;color:#39434b;cursor:pointer}
.authform .chkrow input{margin-top:3px;flex:0 0 auto;width:16px;height:16px;accent-color:var(--blue)}
.authform .chkrow a{color:var(--blue);text-decoration:underline}
.authform .err{color:var(--red);font-size:13px;margin-top:10px;font-weight:600}
.authform .reg-note{font-size:12px;color:#39434b;line-height:1.45;margin:14px 0 2px;background:var(--blue-pale);padding:10px 12px;border-radius:10px}
.authform .btn{width:100%;margin-top:18px}
.authswitch{display:block;margin-top:16px;font-size:14px;color:var(--grey)}
.authswitch a{color:var(--blue);text-decoration:underline;cursor:pointer}
.devnote{font-size:12px;color:var(--grey);margin:12px 0 0;line-height:1.45}
.metag{display:inline-block;background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:999px;margin-left:6px;vertical-align:middle}

/* ---------- account indicator + toast ---------- */
.acct-slot{display:flex;align-items:center;gap:14px}
.acct{font-weight:600;font-size:15px;color:#fff;white-space:nowrap}
a.acct{text-decoration:none;cursor:pointer}
a.acct:hover{opacity:.8}
.acct-out{font-size:14px;color:rgba(255,255,255,.7);cursor:pointer;text-decoration:underline;white-space:nowrap}
.acct-out:hover{color:#fff}
.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,20px);background:#0b3a52;color:#fff;padding:14px 24px;border-radius:14px;font-weight:600;box-shadow:var(--shadow);z-index:120;opacity:0;transition:.3s;max-width:90%;text-align:center}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* ---------- cookie banner ---------- */
.cookiebar{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);z-index:150;max-width:700px;width:calc(100% - 32px);background:#0b3a52;color:#fff;border:1px solid rgba(255,255,255,.14);border-radius:16px;box-shadow:var(--shadow);padding:16px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;transition:opacity .3s,transform .3s}
.cookiebar.hide{opacity:0;transform:translateX(-50%) translateY(16px)}
.cookiebar p{margin:0;font-size:13.5px;line-height:1.5;flex:1;min-width:230px;opacity:.95}
.cookiebar a{color:#fff;text-decoration:underline}
.cookiebar .btn{padding:11px 24px;font-size:13px;white-space:nowrap}
@media(max-width:600px){.cookiebar{bottom:0;left:0;transform:none;width:100%;border-radius:16px 16px 0 0;justify-content:center;text-align:center}.cookiebar.hide{transform:translateY(16px)}}
@media(max-width:600px){ .acct{font-size:13px} .acct-out{display:none} }

/* ---------- age gate ---------- */
.agegate{position:fixed;inset:0;z-index:200;background:rgba(0,40,60,.93);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px}
.agegate .card{background:#fff;color:var(--ink);border-radius:24px;max-width:460px;width:100%;padding:40px 34px;text-align:center;box-shadow:var(--shadow)}
.agegate .badge18{width:74px;height:74px;border-radius:50%;background:var(--blue);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:25px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.agegate h3{color:var(--blue);font-size:27px;margin-bottom:10px;font-family:'Montserrat',sans-serif}
.agegate p{color:#39434b;line-height:1.55;margin:0 0 24px}
.agegate .btns{display:flex;flex-direction:column;gap:10px}
.agegate .btns .btn{width:100%}
.agegate .deny{color:var(--grey);font-size:14px;cursor:pointer;background:none;border:none;padding:10px;font-family:inherit}
.agegate .deny:hover{color:var(--ink)}
.agegate .reg{display:block;margin-top:16px;font-size:13px;color:var(--grey);text-decoration:underline}

@media(max-width:980px){
  .hero .container{grid-template-columns:1fr}.ball{display:none}
  .prizes,.line,.board-grid{grid-template-columns:1fr}
  .stages{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .section{padding:50px 0}
  .rules{padding:30px;transform:none}
}
@media(max-width:600px){
  .container{padding:0 16px}
  /* header on 2 rows: logo + account on top, nav links centered below, CTA button hidden */
  .nav .container{height:auto;flex-wrap:wrap;gap:8px 14px;padding-top:9px;padding-bottom:9px}
  .nav-spacer{display:none}
  .nav .container > a.btn{display:none}
  .acct-slot{order:2;margin-left:auto}
  .acct{font-size:13px}
  .acct-out{display:inline}
  .nav-links{display:flex;order:3;flex-basis:100%;justify-content:center;gap:18px;font-size:14px;margin:0;opacity:.95}
  .logo{font-size:21px}.logo svg{width:34px;height:34px}
  .board-overlay{align-items:flex-start;padding-top:36px}
  .btn{padding:12px 22px;font-size:14px}
  .hero{padding:46px 0 36px}
  .board-grid{margin-top:22px;gap:18px}
  .mcard{padding:22px 18px}
  .scorebox input{width:74px;height:64px;font-size:28px}
  .prize .ph{height:120px}
  .lbcard{padding:6px 12px}
  table.lb th,table.lb td{padding:13px 6px;font-size:15px}
  table.lb td.rank,table.lb td.pts{font-size:17px}
  table.lb td.ex,table.lb th.ex-h{display:none}
  .legend{font-size:13px;line-height:1.9}
  .stage-bar{margin:22px 0 4px}.stage-bar .chip{font-size:13px;text-align:center;line-height:1.4}
  .note{font-size:15px}
  footer .container{flex-direction:column;align-items:flex-start;gap:12px}
}
