/* =====================================================================
   CAMPOSPORT — streaming-UI i TV2 Play-stil
   Dyb marineblå · rød accent · kort med titel UNDER billedet
   Schibsted Grotesk (display) + Hanken Grotesk (body)
   ===================================================================== */
:root{
  --bg:#0A1430;              /* dyb marineblå */
  --bg-2:#0C1838;
  --panel:#13234C;          /* kort/flade (lysere navy) */
  --panel-2:#172B58;
  --line:#22335F;
  --line-2:#2E4173;
  --text:#FFFFFF;
  --muted:#9DA9C7;          /* lys blaa-graa */
  --muted-2:#6C7A9C;
  --accent:#EE1B43;         /* TV2-agtig rød */
  --accent-strong:#CE1438;
  --accent-ink:#FFFFFF;
  --accent-dim:rgba(238,27,67,.16);
  --live:#EE1B43;
  --cream:#ECE6D5;          /* lyst badge (som TV2 "Ny episode") */
  --radius:14px;
  --radius-sm:9px;
  --shadow:0 22px 50px -28px rgba(0,0,0,.7);
  --shadow-sm:0 8px 22px -12px rgba(0,0,0,.55);
  --font-display:"Schibsted Grotesk",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --maxw:1320px;
}

*,*::before,*::after{box-sizing:border-box}
html{ -webkit-text-size-adjust:100% }
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--font-body); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.muted{color:var(--muted)}
.accent{color:var(--accent)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}

h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.06;margin:0;letter-spacing:-.015em}
::selection{background:var(--accent);color:#fff}

/* ---------- knapper ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-display);font-weight:600;font-size:15.5px;letter-spacing:0;
  padding:13px 24px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;
  transition:transform .12s ease, background .2s, border-color .2s, color .2s;
}
.btn:active{transform:translateY(1px)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-strong)}
.btn-accent .dot{width:9px;height:9px;border-radius:50%;background:#fff}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:var(--line-2)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.14)}
.btn-icon{width:48px;height:48px;border-radius:50%;border:1px solid var(--line-2);background:rgba(255,255,255,.08);
  color:#fff;cursor:pointer;font-size:17px;display:grid;place-items:center;transition:.2s}
.btn-icon:hover{border-color:#fff;background:rgba(255,255,255,.16)}

/* ---------- header / brand ---------- */
.site-header{position:sticky;top:0;z-index:40;background:rgba(10,20,48,.86);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.06)}
.nav{display:flex;align-items:center;gap:36px;height:72px}
.brand{display:inline-flex;align-items:center;gap:10px}
.brand-mark{width:32px;height:32px;border-radius:9px}
.brand-word{font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:.01em;color:#fff}
.brand-accent{color:var(--accent)}
.brand.small .brand-word{font-size:18px}
.brand.small .brand-mark{width:27px;height:27px}
.nav-links{display:flex;align-items:center;gap:30px;font-family:var(--font-display);font-weight:500;font-size:16px}
.nav-links a{color:var(--muted);transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-live{display:inline-flex;align-items:center;gap:7px;color:#fff!important}
.nav-live .dot,.live-badge .dot,.bb-live .dot,.tile-badge.live .dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.5)}70%{box-shadow:0 0 0 6px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.tag-op{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:#fff;background:var(--accent);padding:5px 11px;border-radius:7px}
.nav-right{display:flex;align-items:center;gap:16px;margin-left:auto}
.nav-search{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--line-2);
  color:var(--muted);background:transparent;cursor:pointer;font-size:17px;transition:.2s}
.nav-search:hover{border-color:#fff;color:#fff}
.nav-avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:var(--accent);color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;cursor:pointer}

/* ---------- billboard (TV2-agtig hero) ---------- */
.billboard{position:relative;min-height:clamp(460px,68vh,640px);display:flex;align-items:center;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.05)}
.bb-art{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center 30%;background-color:#0c1838}
.bb-scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg, var(--bg) 2%, rgba(10,20,48,.84) 30%, rgba(10,20,48,.2) 62%, rgba(10,20,48,.55) 100%),
    linear-gradient(180deg, rgba(10,20,48,.4), transparent 24%, transparent 52%, var(--bg) 100%)}
.bb-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 32px}
.bb-copy{max-width:560px}
.bb-badges{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.bb-chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:600;font-size:13.5px;
  color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);padding:5px 11px;border-radius:7px}
.bb-chip .brand-accent{color:var(--accent)}
.bb-live{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;font-size:12.5px;color:#fff;background:var(--accent);padding:6px 11px;border-radius:6px}
.bb-div{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;font-size:12.5px;color:#cdd6ea}
.bb-title{font-family:var(--font-display);font-weight:800;font-size:clamp(40px,5.6vw,72px);line-height:1.0;letter-spacing:-.03em;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.5)}
.bb-sub{color:#d4dbed;font-size:17px;margin:16px 0 0;max-width:44ch}
.bb-actions{display:flex;align-items:center;gap:13px;margin-top:28px}
.bb-dots{position:absolute;left:0;right:0;bottom:20px;z-index:3;display:flex;gap:7px;justify-content:center}
.bb-dots i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.32);transition:.2s}
.bb-dots i.on{background:#fff;width:22px;border-radius:4px}

/* ---------- rails ---------- */
.rails{padding:34px 0 50px}
.rail{margin:38px 0}
.rail-head{display:flex;align-items:baseline;justify-content:space-between;max-width:var(--maxw);margin:0 auto 14px;padding:0 32px}
.rail-head h2{font-size:25px;font-weight:700;letter-spacing:-.02em}
.rail-more{font-family:var(--font-display);font-weight:500;font-size:14.5px;color:var(--muted);transition:.2s}
.rail-more:hover{color:#fff}
.rail-wrap{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 32px}
.rail-track{display:flex;gap:18px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;
  padding:4px 2px 10px;-ms-overflow-style:none;scrollbar-width:none}
.rail-track::-webkit-scrollbar{display:none}
.rail-arrow{position:absolute;top:4px;width:54px;z-index:6;border:none;cursor:pointer;color:#fff;font-size:26px;
  font-family:var(--font-display);display:none;align-items:center}
.rail-arrow.left{left:32px;bottom:60px;justify-content:flex-start;padding-left:8px;background:linear-gradient(90deg,var(--bg),rgba(10,20,48,0))}
.rail-arrow.right{right:32px;bottom:60px;justify-content:flex-end;padding-right:8px;background:linear-gradient(270deg,var(--bg),rgba(10,20,48,0))}
.rail-wrap:hover .rail-arrow{display:flex}
.rail-arrow:hover{color:var(--accent)}

/* ---------- tiles (TV2-stil: titel UNDER billedet) ---------- */
.tile{flex:0 0 auto;width:320px;scroll-snap-align:start;display:block;transition:transform .18s ease}
.tile:hover{transform:translateY(-4px)}
.tile-art{position:relative;aspect-ratio:16/9;border-radius:9px;overflow:hidden;background-color:#0e1c40;
  background-size:cover;background-position:center 42%;box-shadow:var(--shadow-sm);transition:box-shadow .2s}
.tile:hover .tile-art{box-shadow:0 18px 40px -18px rgba(0,0,0,.7)}
.tile-art::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,20,48,.18),transparent 34%,transparent 72%,rgba(10,20,48,.32))}
.tile-badge{position:absolute;left:10px;bottom:10px;z-index:2;display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-weight:600;font-size:12px;letter-spacing:.01em;
  color:#1a2240;background:var(--cream);padding:4px 9px;border-radius:6px;box-shadow:0 4px 12px -4px rgba(0,0,0,.5)}
.tile-badge.live{text-transform:uppercase;letter-spacing:.06em;color:#fff;background:var(--accent)}
.tile-logo{position:absolute;left:10px;top:10px;z-index:2;width:24px;height:24px;border-radius:6px;display:grid;place-items:center;background:rgba(10,20,48,.55);backdrop-filter:blur(2px)}
.tile-logo svg{width:16px;height:16px}
.tile-sport{position:absolute;left:10px;top:10px;z-index:2;font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:11px;color:#fff;background:rgba(10,20,48,.62);padding:4px 8px;border-radius:6px;backdrop-filter:blur(2px)}
.tile-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.82);z-index:3;width:52px;height:52px;
  border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.95);color:var(--accent);font-size:16px;
  opacity:0;transition:.2s;box-shadow:0 8px 22px -6px rgba(0,0,0,.5)}
.tile:hover .tile-play{opacity:1;transform:translate(-50%,-50%) scale(1)}
.tile-meta{padding:12px 2px 0}
.tile-title{font-family:var(--font-display);font-weight:600;font-size:17px;line-height:1.2;color:#fff;letter-spacing:-.01em}
.tile-sub{color:var(--muted);font-size:13.5px;margin-top:4px}
.tile-sub .live-txt{color:var(--accent);font-weight:600}

/* ---------- kategori-tiles ---------- */
.tile-cat{flex:0 0 auto;width:250px;scroll-snap-align:start;aspect-ratio:16/9;border-radius:9px;border:1px solid var(--line);
  display:flex;flex-direction:column;justify-content:flex-end;padding:16px;position:relative;overflow:hidden;
  background:linear-gradient(150deg,var(--panel-2),var(--panel));transition:transform .18s,border-color .2s}
.tile-cat::before{content:"";position:absolute;left:0;top:0;width:100%;height:5px;background:var(--accent)}
.tile-cat:nth-child(2)::before{background:#2E93DE}
.tile-cat:nth-child(3)::before{background:#27B07B}
.tile-cat:nth-child(4)::before{background:#E8A13C}
.tile-cat:hover{transform:translateY(-4px);border-color:var(--line-2)}
.tile-cat b{font-family:var(--font-display);font-weight:700;font-size:23px;line-height:1.05;letter-spacing:-.01em;color:#fff}
.tile-cat span{color:var(--muted);font-size:13px;margin-top:5px}

.player-rail{border-top:1px solid rgba(255,255,255,.06);margin-top:10px;padding-top:24px}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid rgba(255,255,255,.06);background:var(--bg-2);padding:48px 0;margin-top:16px}
.footer-inner{display:flex;flex-direction:column;gap:11px;align-items:flex-start}
.footer-text{color:var(--muted);max-width:62ch;margin:8px 0 0;font-size:15px}
.footer-spon{color:var(--muted-2);font-size:14px;margin:0}
.footer-spon span{color:var(--accent)}

/* =====================================================================
   PLAYER-SIDE
   ===================================================================== */
.player-page{display:grid;grid-template-columns:minmax(0,1fr);gap:28px;max-width:1040px;margin:0 auto;padding:30px 32px 56px}
.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-weight:500;font-size:14.5px}
.back-link:hover{color:#fff}
.player-shell{display:flex;flex-direction:column;gap:16px}
.video-wrap{position:relative;aspect-ratio:16/9;background:#05091c;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.video-wrap video{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#05091c}
#adVideo{z-index:2;display:none}
.video-wrap.ad-active #adVideo{display:block}
.overlay-top{position:absolute;top:0;left:0;right:0;z-index:5;display:flex;align-items:flex-start;justify-content:space-between;padding:16px;background:linear-gradient(180deg,rgba(0,0,0,.5),transparent);pointer-events:none}
.badge-live{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:12.5px;color:#fff;background:var(--accent);padding:6px 12px;border-radius:8px}
.badge-live::before{content:"";width:8px;height:8px;border-radius:50%;background:#fff;animation:pulse 1.8s infinite}
.ov-meta{text-align:right;text-shadow:0 2px 12px rgba(0,0,0,.7);color:#fff}
.ov-title{font-family:var(--font-display);font-weight:700;font-size:20px;line-height:1.1;letter-spacing:-.015em}
.ov-div{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;color:#ffb8c4;font-size:12px}
.ad-overlay{position:absolute;inset:0;z-index:8;display:flex;flex-direction:column;justify-content:space-between;padding:16px;background:linear-gradient(180deg,rgba(0,0,0,.32),transparent 30%,transparent 70%,rgba(0,0,0,.5))}
.ad-overlay[hidden]{display:none}
.ad-tag{align-self:flex-start;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:#fff;background:var(--accent);padding:5px 11px;border-radius:6px}
.ad-kicker{align-self:flex-start;margin-top:9px;font-family:var(--font-display);letter-spacing:.02em;font-size:14px;color:#fff;background:rgba(0,0,0,.42);padding:5px 11px;border-radius:6px}
.ad-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px}
.ad-sponsor{font-family:var(--font-display);color:#e6eaf4;font-size:14px;text-shadow:0 2px 8px #000}
.ad-controls{display:flex;align-items:center;gap:10px}
.ad-timer{font-family:var(--font-display);font-weight:600;color:#fff;font-size:15px;min-width:34px;text-align:center}
.ad-btn{font-family:var(--font-display);font-weight:600;font-size:13.5px;padding:9px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.32);background:rgba(0,0,0,.42);color:#fff;cursor:pointer;transition:.18s}
.ad-btn:hover:not(:disabled){border-color:var(--accent);color:#fff;background:rgba(238,27,67,.25)}
.ad-btn:disabled{opacity:.5;cursor:not-allowed}
.ad-skip{background:var(--accent);color:#fff;border-color:var(--accent)}
.ad-skip:disabled{background:rgba(0,0,0,.42);color:#fff}
.start-overlay{position:absolute;inset:0;z-index:9;display:grid;place-items:center;background:rgba(5,9,28,.66);backdrop-filter:blur(3px)}
.start-overlay[hidden]{display:none}
.start-btn{font-family:var(--font-display);font-weight:700;font-size:18px;padding:17px 32px;border-radius:13px;border:none;background:var(--accent);color:#fff;cursor:pointer;box-shadow:0 16px 38px -14px rgba(238,27,67,.7)}
.under-player{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--muted);font-size:14.5px}
.up-presented b{color:var(--accent);font-weight:600}
.up-status{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--accent)}
.scoreboard{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;margin-top:18px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.sb-team{font-family:var(--font-display);font-weight:700;font-size:clamp(20px,3vw,28px);line-height:1.05;letter-spacing:-.02em;color:#fff}
.sb-team.away{text-align:right}
.sb-mid{display:flex;flex-direction:column;align-items:center;gap:6px}
.sb-vs{font-family:var(--font-display);font-weight:600;color:var(--muted-2);font-size:14px;text-transform:uppercase;letter-spacing:.1em}
.sb-div{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-size:12px}
.sb-venue{color:var(--muted);font-size:13px}
.exposure{align-self:start;position:sticky;top:92px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.exp-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:6px}
.exp-head h3{font-size:21px;font-weight:700;letter-spacing:-.015em}
.exp-tag{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--accent)}
.exp-sub-note{color:var(--muted);font-size:13.5px;margin:0 0 20px}
.exp-num{font-family:var(--font-display);font-weight:800;font-size:50px;line-height:1;color:#fff;letter-spacing:-.025em}
.exp-label{color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:.1em;margin-top:6px;font-family:var(--font-display)}
.exp-stats{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin:20px 0}
.exp-stat{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px}
.exp-stat b{font-family:var(--font-display);font-size:25px;font-weight:700;display:block;line-height:1;color:#fff}
.exp-stat span{color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.08em}
.exp-list{list-style:none;margin:8px 0 0;padding:0;max-height:172px;overflow:auto;display:flex;flex-direction:column;gap:8px}
.exp-list li{display:flex;align-items:center;justify-content:space-between;font-size:13.5px;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:9px 12px}
.exp-list li span:last-child{color:var(--accent);font-family:var(--font-display);font-weight:700}
.exp-list:empty::after{content:"Ingen leverede slots endnu";color:var(--muted-2);font-size:13px}
.exp-spon{margin-top:18px;border-top:1px solid var(--line);padding-top:14px;color:var(--muted);font-size:13.5px}
.exp-spon b{color:var(--accent);font-weight:600}

/* =====================================================================
   OPERATOER-SIDE
   ===================================================================== */
.op-page{max-width:560px;margin:0 auto;padding:54px 32px 80px;display:flex;flex-direction:column;gap:20px}
.op-page .exposure{position:static;top:auto;align-self:stretch}
.op-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
.op-card h2{font-size:26px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}
.op-gate p,.op-panel .op-hint{color:var(--muted);font-size:14.5px}
.op-field{margin:20px 0}
.op-field label{display:block;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;font-size:11.5px;color:var(--muted);margin-bottom:8px}
.op-input,.op-select{width:100%;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-sm);color:#fff;font-family:inherit;font-size:16px;padding:13px 14px}
.op-input:focus,.op-select:focus{outline:none;border-color:var(--accent)}
.gate-msg{color:var(--live);font-size:13.5px;min-height:18px;margin:6px 0 0}
.op-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.op-state{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;font-size:13px}
.op-dot{width:11px;height:11px;border-radius:50%;background:var(--muted-2)}
.op-dot.is-live{background:#3DDC84}
.op-dot.is-break{background:var(--live);animation:pulse 1.6s infinite}
.op-buttons{display:flex;flex-direction:column;gap:12px;margin:22px 0 8px}
.op-btn{font-family:var(--font-display);font-weight:600;font-size:16.5px;padding:16px;border-radius:12px;border:1px solid var(--line-2);background:var(--panel-2);color:#fff;cursor:pointer;transition:transform .12s,border-color .2s,background .2s}
.op-btn:hover:not(:disabled){transform:translateY(-2px)}
.op-btn:disabled{opacity:.55;cursor:not-allowed}
.op-btn.is-half:hover:not(:disabled){background:var(--accent-dim);border-color:var(--accent)}
.op-btn.is-nat:hover:not(:disabled){background:var(--accent-dim);border-color:rgba(238,27,67,.5)}
.op-btn.is-end{background:var(--accent);color:#fff;border-color:var(--accent)}
.op-btn.is-end:hover:not(:disabled){background:var(--accent-strong)}
.op-feedback{min-height:20px;font-size:14px;margin:6px 0 0;font-weight:600}
.op-feedback.ok{color:#3DDC84}
.op-feedback.err{color:var(--live)}
.op-hint{margin-top:14px;border-top:1px solid var(--line);padding-top:14px}
.unlock-btn{margin-top:6px;width:100%}

/* ---------- responsivt ---------- */
@media (max-width:920px){
  .player-page{grid-template-columns:1fr}
  .exposure{position:static;top:auto}
}
@media (max-width:760px){ .nav-links{display:none} }
@media (max-width:560px){
  .wrap,.bb-inner,.rail-head,.rail-wrap{padding-left:18px;padding-right:18px}
  .tile{width:264px} .tile-cat{width:200px}
  .billboard{min-height:clamp(420px,62vh,540px)}
  .bb-copy{max-width:none}
  .scoreboard{padding:16px}
}
