/* ============================================================
   Live Lokal — Landing page styles
   Editorial, calm SaaS · Linear meets Eliteserien
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* ── Brand ── */
  --brand:      #1B388E;
  --brand-2:    #14296a;
  --brand-3:    #2952cc;
  --brand-bar:  #1939a8;
  --brand-soft: #e8edf8;

  --red:        #c5292f;
  --red-2:      #a61f24;
  --red-soft:   #f5e3df;

  --green:      #2e7d4f;
  --green-soft: #e1ede5;

  /* ── Surfaces ── */
  --bg:         #f4f3ee;
  --canvas:     #ffffff;
  --canvas-2:   #faf9f6;
  --panel:      #f7f6f2;

  /* ── Lines / ink ── */
  --line:       #e3e2dc;
  --line-2:     #ebeae4;
  --line-3:     #d8d6cf;
  --ink:        #1c1c1a;
  --ink-2:      #4a4a47;
  --ink-3:      #76756f;
  --ink-4:      #a3a29a;
  --ink-5:      #c8c6bd;

  /* ── Type ── */
  --font-sans:  'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-disp:  'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-mono:  'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --shadow-sm:  0 1px 0 rgba(28,28,26,0.04);
  --shadow:     0 1px 2px rgba(28,28,26,0.05), 0 0 0 0.5px rgba(28,28,26,0.06);
  --shadow-pop: 0 18px 40px -16px rgba(28,28,26,0.22), 0 0 0 0.5px rgba(28,28,26,0.08);
  --shadow-phone: 0 28px 60px -20px rgba(20,30,80,0.35), 0 0 0 1px rgba(28,28,26,0.08);
}

html, body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.container {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 32px;
}

/* ─── Reveal animation ── */
.rev { opacity: 0; transform: translateY(14px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.rev.in { opacity: 1; transform: none; }

/* ─── Type helpers ── */
.kicker {
  display: inline-block;
  font: 600 11px/1.2 var(--font-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 16px;
}
.kicker-light { color: rgba(255,255,255,0.78); }
.kicker-tiny { font-size: 9.5px; letter-spacing: 0.18em; margin-bottom: 6px; color: var(--ink-3); }

.mono, .t-mono { font-family: var(--font-mono); font-feature-settings: 'tnum'; }
.t-mono { color: var(--ink-3); font-size: 12px; }
.t-dim { color: var(--ink-3); }

.h2 {
  font-family: var(--font-disp);
  font-weight: 700;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.08;
  letter-spacing: -0.022em;
  color: var(--ink);
  text-wrap: balance;
}
.h2-light { color: #fff; }

.h3 {
  font: 600 17px/1.3 var(--font-sans);
  letter-spacing: -0.01em;
  margin-bottom: 8px;
}
.h3-light { color: #fff; font: 600 17px/1.3 var(--font-sans); letter-spacing: -0.01em; margin-bottom: 8px; }

.display {
  font-family: var(--font-disp);
  font-weight: 800;
  font-size: clamp(38px, 5.6vw, 72px);
  line-height: 1.02;
  letter-spacing: -0.032em;
  color: #fff;
  text-wrap: balance;
}
.display-dim {
  display: block;
  font-weight: 500;
  color: rgba(255,255,255,0.66);
  margin-top: 12px;
  font-size: 0.62em;
  line-height: 1.18;
  letter-spacing: -0.02em;
}

.lede {
  font-size: 18px;
  line-height: 1.5;
  color: rgba(255,255,255,0.82);
  max-width: 520px;
  margin-top: 24px;
}

.section-lede {
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 640px;
  margin-top: 14px;
}
.section-lede-dark { color: rgba(255,255,255,0.74); }

/* ─── Buttons ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 11px 20px;
  border-radius: 8px;
  font: 600 14px/1 var(--font-sans);
  letter-spacing: -0.005em;
  border: 1px solid transparent;
  transition: background .15s, border-color .15s, color .15s, transform .15s;
  white-space: nowrap;
  cursor: pointer;
}
.btn-lg { padding: 14px 24px; font-size: 15px; border-radius: 10px; }
.btn-block { width: 100%; padding: 14px; font-size: 15px; }

.btn-primary { background: var(--red); color: #fff; }
.btn-primary:hover { background: var(--red-2); }

.btn-ghost {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.28);
  color: #fff;
}
.btn-ghost:hover { background: rgba(255,255,255,0.16); }

.btn-ghost-dark {
  background: transparent;
  border-color: var(--line-3);
  color: var(--ink-2);
}
.btn-ghost-dark:hover { background: var(--canvas-2); border-color: var(--ink-3); color: var(--ink); }

/* ─── Nav ─────────────────────────────── */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(244,243,238,0.86);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--line);
}
.nav-inner {
  max-width: 1240px; margin: 0 auto;
  height: 64px;
  padding: 0 32px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
}
.logo img { height: 26px; width: auto; }
.nav-links {
  display: flex; gap: 28px;
  font: 500 14px/1 var(--font-sans);
  color: var(--ink-2);
}
.nav-links a:hover { color: var(--ink); }
.nav-cta { display: flex; gap: 10px; align-items: center; }

/* ─── Hero ────────────────────────────── */
.hero {
  position: relative;
  background: linear-gradient(180deg, #14296a 0%, #1B388E 55%, #1f3fa3 100%);
  color: #fff;
  padding: 96px 0 120px;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(900px 500px at 80% 20%, rgba(41,82,204,0.55), transparent 60%),
    radial-gradient(600px 400px at 10% 80%, rgba(20,41,106,0.7), transparent 60%);
  pointer-events: none;
}
.hero-grid {
  position: relative;
  max-width: 1240px; margin: 0 auto;
  padding: 0 32px;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 64px;
  align-items: center;
}
.hero-copy { max-width: 620px; }
.hero-actions {
  display: flex; gap: 12px; flex-wrap: wrap;
  margin-top: 36px;
}
.hero-marks {
  display: flex; flex-wrap: wrap; gap: 18px 32px;
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.16);
  list-style: none;
}
.hero-marks li {
  font-size: 13px;
  color: rgba(255,255,255,0.7);
  flex: 1 1 200px;
}
.hero-marks strong { color: #fff; font-weight: 600; display: block; margin-bottom: 2px; }

/* Hero proof — pitch + phone */
.hero-proof {
  position: relative;
  height: 600px;
}
.pitch-card {
  position: absolute;
  top: 0; left: 0;
  width: 62%;
  background: var(--canvas);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--shadow-pop);
  transform: rotate(-1.5deg);
}
.pitch-art { height: 320px; background: #b8c6d6; position: relative; }
.pitch-art svg { width: 100%; height: 100%; display: block; }

/* FIKS phone (hand holding phone) */
.fiks-art {
  height: 380px;
  background: linear-gradient(160deg, #d8d2c2 0%, #b8a98a 100%);
  position: relative;
  overflow: hidden;
}
.fiks-hand {
  position: absolute;
  bottom: -40px; left: 50%; transform: translateX(-50%);
  width: 240px;
}
.fiks-hand::before {
  /* hand silhouette */
  content: "";
  position: absolute;
  bottom: -60px; left: -30px; right: -30px;
  height: 200px;
  background: #c9a280;
  border-radius: 90px 90px 60px 60px;
  z-index: 0;
  box-shadow: inset 0 8px 20px rgba(0,0,0,0.08);
}
.fiks-thumb {
  position: absolute;
  right: -28px; bottom: 60px;
  width: 56px; height: 90px;
  background: #c9a280;
  border-radius: 30px 30px 22px 22px;
  transform: rotate(-18deg);
  z-index: 2;
  box-shadow: inset -4px 0 8px rgba(0,0,0,0.1);
}
.fiks-phone {
  position: relative;
  z-index: 1;
  width: 200px;
  margin: 0 auto;
  background: #0c0c0c;
  border-radius: 28px;
  padding: 6px;
  box-shadow: 0 10px 22px rgba(0,0,0,0.25);
}
.fiks-screen {
  background: #f7f6f2;
  border-radius: 22px;
  padding: 10px 10px 12px;
  display: flex; flex-direction: column;
  gap: 6px;
}
.fiks-status {
  display: flex; justify-content: space-between;
  font: 600 9px/1 var(--font-mono);
  color: var(--ink-3);
  padding: 2px 4px;
}
.fiks-app-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 8px;
  background: var(--brand);
  border-radius: 6px;
  color: #fff;
}
.fiks-logo { font: 800 11px/1 var(--font-disp); letter-spacing: 0.04em; }
.fiks-meta { font-size: 9px; color: rgba(255,255,255,0.85); }
.fiks-section {
  font: 700 8.5px/1 var(--font-sans);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 4px;
}
.fiks-section-pad { margin-top: 6px; }
.fiks-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  font: 600 11px/1 var(--font-sans);
  color: var(--ink);
}
.fiks-btn-active {
  background: var(--brand-soft);
  border-color: var(--brand);
  color: var(--brand);
  box-shadow: 0 0 0 2px rgba(41,82,204,0.15);
}
.fiks-btn-ic {
  width: 20px; height: 20px;
  border-radius: 4px;
  background: var(--brand);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px;
}
.fiks-btn-active .fiks-btn-ic { background: var(--brand); }
.fiks-num-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 3px;
}
.fiks-num {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 6px 0;
  text-align: center;
  font: 700 11px/1 var(--font-mono);
  color: var(--ink-2);
}
.fiks-num-on {
  background: var(--brand);
  border-color: var(--brand);
  color: #fff;
  box-shadow: 0 0 0 2px rgba(41,82,204,0.18);
}
.pitch-cap {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px;
  font: 500 13px/1 var(--font-sans);
  color: var(--ink-2);
  background: var(--canvas);
  border-top: 1px solid var(--line);
}
.pitch-cap-dark { background: var(--canvas); }
.pitch-cap .mono { color: var(--ink); font-weight: 600; }

.pulse-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--red);
  animation: pulse 1.6s ease-in-out infinite;
  box-shadow: 0 0 0 3px rgba(197,41,47,0.18);
}
.pulse-dot-green { background: var(--green); box-shadow: 0 0 0 3px rgba(46,125,79,0.2); }
.pulse-dot-red { background: var(--red); }
@keyframes pulse { 0%,100% { opacity: 1 } 50% { opacity: 0.4 } }

.phone-card {
  position: absolute;
  right: 0; bottom: 0;
  z-index: 2;
}
.phone-card .pitch-cap {
  margin-top: 12px;
  border-radius: 10px;
  border: 1px solid var(--line);
}

/* ─── Phone (generic) ─────────────────── */
.phone {
  width: 240px;
  height: 480px;
  background: #0c0c0c;
  border-radius: 36px;
  padding: 8px;
  box-shadow: var(--shadow-phone);
  position: relative;
}
.phone-notch {
  position: absolute;
  top: 14px; left: 50%; transform: translateX(-50%);
  width: 76px; height: 18px;
  background: #000;
  border-radius: 12px;
  z-index: 5;
}
.phone-screen {
  width: 100%; height: 100%;
  background: #fff;
  border-radius: 28px;
  overflow: hidden;
  position: relative;
  display: flex; flex-direction: column;
}

.proof-arrow {
  position: absolute;
  left: 56%;
  top: 290px;
  display: flex; align-items: center; gap: 8px;
  color: rgba(255,255,255,0.85);
  font: 500 12px/1 var(--font-sans);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  z-index: 1;
}
.proof-arrow svg { width: 60px; height: 30px; }

/* ─── Instagram-bar (top of phone) ── */
.ig-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 32px 12px 6px;
  font-size: 12px;
}
.ig-back { color: #fff; font-size: 18px; opacity: 0; }
.ig-avatar {
  width: 24px; height: 24px; border-radius: 50%;
  background: linear-gradient(135deg, var(--brand), var(--red));
  border: 1.5px solid #fff;
}
.ig-handle { font-weight: 600; line-height: 1.1; }
.ig-time { font-size: 10px; color: var(--ink-3); font-weight: 400; }
.ig-more { margin-left: auto; color: var(--ink-2); }
.ig-progress {
  height: 2px; background: rgba(0,0,0,0.08);
  margin: 4px 12px 0;
  position: relative;
}
.ig-progress span {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 38%;
  background: var(--ink);
  border-radius: 2px;
}

/* ─── Story creative ── */
.story {
  flex: 1;
  background: linear-gradient(180deg, #cfd9ec 0%, #93a8c9 50%, #5b7aa3 100%);
  margin: 8px 12px 12px;
  border-radius: 12px;
  padding: 14px 12px;
  position: relative;
  overflow: hidden;
  display: flex; flex-direction: column;
  align-items: center;
  text-align: center;
  color: var(--brand);
}
.story::before {
  content: "MÅL";
  position: absolute;
  top: 38px; left: 50%; transform: translateX(-50%);
  font: 900 86px/1 var(--font-disp);
  color: var(--brand);
  opacity: 0.55;
  letter-spacing: -0.04em;
  pointer-events: none;
  z-index: 0;
}
.story > * { position: relative; z-index: 1; }
.story-tag {
  font: 700 9px/1 var(--font-sans);
  letter-spacing: 0.12em;
  color: var(--brand);
  margin-bottom: 6px;
}
.story-mal { display: none; } /* visible only via ::before to avoid double */
.story-portrait {
  width: 80px; height: 80px;
  border-radius: 50%;
  overflow: hidden;
  margin-top: 4px;
  background: #dfe7f3;
  box-shadow: 0 6px 16px rgba(20,30,80,0.18);
  border: 2px solid #fff;
}
.story-portrait svg { width: 100%; height: 100%; }
.story-min {
  display: flex; align-items: center; gap: 5px;
  margin-top: 8px;
  font: 700 11px/1 var(--font-mono);
  color: var(--green);
}
.story-min .dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--green);
}
.story-score {
  display: flex; align-items: center; gap: 8px;
  margin-top: 4px;
}
.score-num {
  font: 800 28px/1 var(--font-disp);
  color: var(--brand);
  letter-spacing: -0.03em;
}
.score-logo {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--brand);
  position: relative;
}
.score-logo::after {
  content: "IF";
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font: 700 8px/1 var(--font-sans);
  color: var(--brand);
}
.score-logo-r::after { content: "ØB"; color: #b03a3a; }
.score-logo-r { border-color: #b03a3a; }
.story-name {
  font: 600 11px/1.1 var(--font-sans);
  color: var(--brand);
  margin-top: 4px;
}
.story-sponsor {
  margin-top: auto;
  padding-top: 10px;
  width: 100%;
}
.story-sponsor .kicker {
  font: 700 7.5px/1 var(--font-sans);
  letter-spacing: 0.18em;
  color: var(--brand);
  margin-bottom: 6px;
  display: block;
}
.sponsor-row {
  display: flex; gap: 6px; justify-content: center;
}
.sponsor-block {
  font: 800 11px/1 var(--font-disp);
  letter-spacing: -0.01em;
  padding: 6px 8px;
  border-radius: 4px;
  color: #fff;
}
.sb-1 { background: var(--brand); }
.sb-2 { background: #d4a017; color: #1c1c1a; }

/* ─── Sections ─── */
.section { padding: 96px 0; }
.section-light { background: var(--bg); border-top: 1px solid var(--line); }
.section-canvas { background: var(--canvas); border-top: 1px solid var(--line); }
.section-dark {
  background: linear-gradient(180deg, #14296a 0%, #0c1842 100%);
  color: #fff;
  border-top: none;
}
.section-pillar-2 { padding-top: 0; }

.section-head { max-width: 720px; margin-bottom: 56px; }
.section-head-dark .kicker { color: rgba(255,255,255,0.78); }

/* ─── Vignettes ─── */
.vignettes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 8px;
}
.vignette {
  background: var(--canvas);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 28px;
}
.vignette-num {
  font: 700 11px/1 var(--font-mono);
  color: var(--red);
  letter-spacing: 0.1em;
  margin-bottom: 14px;
}
.vignette p { color: var(--ink-2); font-size: 14.5px; line-height: 1.55; }

/* ─── Pillars ─── */
.pillar {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.pillar-2 { grid-template-columns: 1fr 1fr; }
.pillar-2 .pillar-copy { order: 2; }
.pillar-2 .pillar-visual { order: 1; }
.pillar-copy p {
  color: var(--ink-2);
  font-size: 15px; line-height: 1.6;
  margin-top: 16px;
  max-width: 540px;
}

.metric-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 36px;
  padding: 24px;
  background: var(--brand-soft);
  border: 1px solid var(--line);
  border-radius: 8px;
}
.metric-num {
  font: 800 36px/1 var(--font-disp);
  color: var(--brand);
  letter-spacing: -0.02em;
}
.metric-label {
  font-size: 12px; line-height: 1.4;
  color: var(--ink-2);
  margin-top: 6px;
}

.pillar-pull {
  font-size: 14px;
  color: var(--ink-2);
  border-left: 2px solid var(--red);
  padding: 4px 0 4px 16px;
  margin-top: 32px;
}
.pillar-pull em { font-style: italic; color: var(--ink); }

/* Before / after */
.ba-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items: stretch;
}
.ba-card {
  background: var(--canvas);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px;
  display: flex; flex-direction: column;
  min-height: 380px;
}
.ba-tag {
  font: 600 10px/1 var(--font-sans);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 10px;
}
.ba-tag-good { color: var(--green); }
.ba-art {
  flex: 1;
  background: var(--bg);
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
/* "Before" mess */
.ba-mess {
  width: 100%;
  background: #fff;
  border: 1px solid var(--line);
  padding: 18px 14px;
  font-family: var(--font-sans);
  text-align: center;
  position: relative;
  transform: rotate(-0.6deg);
}
.ba-text-1 {
  font: 800 22px/1.1 Georgia, serif;
  color: #2a2a2a;
  margin-bottom: 6px;
}
.ba-text-2 {
  font-size: 12px; color: #555;
  margin-bottom: 12px;
}
.ba-photo {
  height: 100px;
  background: linear-gradient(135deg, #b8c6d6, #6a8aaf);
  border-radius: 4px;
  margin-bottom: 12px;
}
.ba-tiny-logo {
  font-size: 9px;
  color: #999;
  text-align: right;
}
.phone-mini {
  width: 180px;
  background: #0c0c0c;
  border-radius: 24px;
  padding: 6px;
}
.phone-mini .story {
  margin: 0;
  border-radius: 18px;
  height: 320px;
}
.phone-mini .story::before { font-size: 64px; top: 30px; }
.phone-mini .story-portrait { width: 60px; height: 60px; }
.phone-mini .score-num { font-size: 22px; }
.story-mini { padding: 12px 10px; }

/* Grid 9 — én kamp, ni stories i kronologisk orden — editorial photo-feel */
.grid-9 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  background: var(--canvas);
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
}
.g-story {
  aspect-ratio: 9/16;
  position: relative;
  border-radius: 6px;
  overflow: hidden;
  background: #1a1f2e;
  color: #fff;
  display: flex; flex-direction: column;
}
.g-photo {
  position: absolute; inset: 0;
  overflow: hidden;
}
.g-photo-night { background: #0e1424; }
.g-sky {
  position: absolute; top: 0; left: 0; right: 0; height: 55%;
  background: linear-gradient(180deg, #b9cce4 0%, #8aa6c8 60%, #6e88ad 100%);
}
.g-sky-night {
  background: linear-gradient(180deg, #1e2746 0%, #2c3a5e 60%, #3a4a72 100%);
}
.g-sky-dusk {
  background: linear-gradient(180deg, #d99a6c 0%, #a07395 60%, #4a4670 100%);
}
.g-sky-warm {
  background: linear-gradient(180deg, #e8c896 0%, #c9956a 60%, #8a6a4a 100%);
}
.g-sky-mvp {
  background: linear-gradient(180deg, #1B388E 0%, #2952cc 100%);
}
.g-stand {
  position: absolute; top: 38%; left: 0; right: 0; height: 22%;
  background:
    repeating-linear-gradient(90deg,
      rgba(255,255,255,0.08) 0 2px,
      transparent 2px 4px),
    linear-gradient(180deg, #2a3445 0%, #1c2435 100%);
  border-bottom: 1px solid rgba(0,0,0,0.3);
}
.g-stand::before {
  content: ""; position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 50%, rgba(200,210,230,0.18) 1px, transparent 2px),
    radial-gradient(circle at 35% 60%, rgba(200,210,230,0.18) 1px, transparent 2px),
    radial-gradient(circle at 55% 45%, rgba(200,210,230,0.18) 1px, transparent 2px),
    radial-gradient(circle at 75% 55%, rgba(200,210,230,0.18) 1px, transparent 2px),
    radial-gradient(circle at 90% 50%, rgba(200,210,230,0.18) 1px, transparent 2px);
  background-size: 8% 50%;
  background-repeat: repeat;
  opacity: 0.7;
}
.g-stand-blur { filter: blur(0.5px); opacity: 0.85; }
.g-turf {
  position: absolute; bottom: 0; left: 0; right: 0; height: 45%;
  background:
    repeating-linear-gradient(95deg,
      rgba(0,0,0,0.08) 0 14px,
      transparent 14px 28px),
    linear-gradient(180deg, #4a8a3a 0%, #2e6a26 70%, #1f4a18 100%);
}
.g-turf-dark {
  background:
    repeating-linear-gradient(95deg,
      rgba(0,0,0,0.18) 0 12px,
      transparent 12px 24px),
    linear-gradient(180deg, #2a4a22 0%, #18301a 100%);
}
.g-light {
  position: absolute; top: 0;
  width: 30%; height: 60%;
  background: radial-gradient(ellipse at 50% 0%, rgba(255,240,200,0.4) 0%, transparent 60%);
  pointer-events: none;
}
.g-light-l { left: -5%; }
.g-light-r { right: -5%; }

/* Player portrait silhouette */
.g-portrait {
  position: absolute;
  bottom: 8%;
  left: 50%; transform: translateX(-50%);
  width: 62%;
  height: 72%;
  background:
    radial-gradient(ellipse 28% 18% at 50% 16%, #d8b89a 0%, #c89a78 70%, transparent 100%),
    linear-gradient(180deg, transparent 0%, transparent 22%, #fff 22%, #fff 38%, #1B388E 38%, #1B388E 100%);
  clip-path: polygon(38% 0%, 62% 0%, 70% 18%, 86% 28%, 100% 50%, 100% 100%, 0% 100%, 0% 50%, 14% 28%, 30% 18%);
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.3));
}
.g-portrait-2 {
  background:
    radial-gradient(ellipse 28% 18% at 50% 16%, #c8987a 0%, #a87a5a 70%, transparent 100%),
    linear-gradient(180deg, transparent 0%, transparent 22%, #f4f3ee 22%, #f4f3ee 38%, #1B388E 38%, #1B388E 100%);
}
.g-portrait-3 {
  background:
    radial-gradient(ellipse 28% 18% at 50% 16%, #d8b89a 0%, #b8927a 70%, transparent 100%),
    linear-gradient(180deg, transparent 0%, transparent 22%, #c5292f 22%, #c5292f 38%, #1B388E 38%, #1B388E 100%);
}
.g-portrait-mvp {
  background:
    radial-gradient(ellipse 28% 18% at 50% 16%, #e0c8a8 0%, #c89a78 70%, transparent 100%),
    linear-gradient(180deg, transparent 0%, transparent 22%, #f4f3ee 22%, #f4f3ee 38%, #1B388E 38%, #1B388E 100%);
}

/* Watermark MÅL behind portrait */
.g-watermark {
  position: absolute;
  top: 6%;
  left: 50%; transform: translateX(-50%);
  font: 900 clamp(48px, 11vw, 92px)/0.85 var(--font-disp);
  letter-spacing: -0.04em;
  color: rgba(255,255,255,0.95);
  -webkit-text-stroke: 0;
  text-shadow: 0 2px 8px rgba(0,0,0,0.3);
  z-index: 1;
  pointer-events: none;
}

/* Yellow card prop */
.g-yellowcard {
  position: absolute;
  top: 32%;
  left: 50%;
  transform: translate(-50%, 0) rotate(-8deg);
  width: 38%;
  aspect-ratio: 2/3;
  background: linear-gradient(135deg, #f0c419 0%, #d4a017 100%);
  border-radius: 3px;
  box-shadow:
    0 4px 12px rgba(0,0,0,0.25),
    inset -2px -2px 6px rgba(0,0,0,0.18);
}

/* Final score backdrop */
.g-final-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 30% 20%, rgba(41,82,204,0.4) 0%, transparent 50%),
    radial-gradient(circle at 70% 80%, rgba(197,41,47,0.2) 0%, transparent 50%),
    linear-gradient(180deg, #14296a 0%, #0a1840 100%);
}
.g-final-bg::after {
  content: ""; position: absolute; inset: 0;
  background:
    repeating-linear-gradient(90deg,
      rgba(255,255,255,0.04) 0 1px,
      transparent 1px 24px);
}

/* Overlays — typography on photo */
.g-overlay {
  position: relative;
  z-index: 2;
  padding: 10px 10px;
}
.g-overlay-bottom { margin-top: auto; padding-bottom: 32px; }
.g-overlay-top { padding-top: 12px; padding-bottom: 0; }
.g-overlay-center {
  margin: auto 0;
  text-align: center;
  padding: 12px;
}

.g-club {
  font: 800 8px/1 var(--font-disp);
  letter-spacing: 0.18em;
  color: rgba(255,255,255,0.85);
  margin-bottom: 6px;
}
.g-eyebrow {
  font: 700 8px/1 var(--font-mono);
  letter-spacing: 0.16em;
  color: rgba(255,255,255,0.85);
  margin-bottom: 6px;
}
.g-eyebrow-light { color: rgba(255,255,255,0.7); }
.g-headline {
  font: 900 18px/0.95 var(--font-disp);
  letter-spacing: -0.02em;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,0.35);
}
.g-headline-xl { font-size: 26px; }
.g-headline-light { color: #fff; }
.g-subline {
  font: 600 10px/1.2 var(--font-sans);
  color: rgba(255,255,255,0.85);
  margin-top: 4px;
}
.g-min-mark {
  display: inline-block;
  font: 800 11px/1 var(--font-mono);
  background: var(--green);
  color: #fff;
  padding: 4px 8px;
  border-radius: 3px;
  margin-bottom: 6px;
}
.g-score {
  font: 900 30px/0.9 var(--font-disp);
  letter-spacing: -0.03em;
  color: #fff;
  text-shadow: 0 2px 6px rgba(0,0,0,0.4);
  margin-bottom: 4px;
}
.g-player {
  font: 700 10px/1 var(--font-disp);
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.95);
}

/* Pause scoreboard */
.g-scoreboard {
  position: relative;
  z-index: 2;
  margin: auto 12px;
  background: rgba(20,30,60,0.92);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 4px;
  padding: 10px 12px;
  color: #fff;
  font-family: var(--font-mono);
}
.g-sb-label {
  font: 700 9px/1 var(--font-disp);
  letter-spacing: 0.16em;
  color: rgba(255,255,255,0.7);
  margin-bottom: 6px;
  text-align: center;
}
.g-sb-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 3px 0;
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 11px;
}
.g-sb-team { font-weight: 700; letter-spacing: 0.08em; }
.g-sb-num { font-weight: 800; font-size: 14px; }

/* Bytte */
.g-swap-row {
  display: flex; flex-direction: column; gap: 4px;
  margin-top: 8px;
  font: 700 10px/1 var(--font-mono);
}
.g-swap-out { color: #ffb4b4; letter-spacing: 0.06em; }
.g-swap-in { color: #b8e6c8; letter-spacing: 0.06em; }

/* Final */
.g-final-score {
  font: 900 56px/0.85 var(--font-disp);
  letter-spacing: -0.04em;
  color: #fff;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4);
  margin: 8px 0;
}
.g-final-teams {
  font: 700 9px/1 var(--font-disp);
  letter-spacing: 0.14em;
  color: rgba(255,255,255,0.85);
  display: flex; justify-content: center; gap: 8px;
}
.g-final-sep { color: rgba(255,255,255,0.35); }

/* MVP badge */
.g-mvp-badge {
  position: absolute;
  top: 10px; right: 10px;
  z-index: 3;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #f0c419, #d4a017);
  color: #14296a;
  display: flex; align-items: center; justify-content: center;
  font: 800 14px/1 var(--font-disp);
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
}

/* Sponsor bar at bottom of every story */
.g-spbar {
  position: absolute; bottom: 0; left: 0; right: 0;
  z-index: 3;
  background: rgba(255,255,255,0.92);
  padding: 4px 0;
  display: flex; justify-content: center;
  border-top: 1px solid rgba(0,0,0,0.06);
}
.g-spbar-yellow { background: #f0c419; }
.g-sp {
  font: 800 7.5px/1 var(--font-disp);
  letter-spacing: 0.18em;
  color: #1B388E;
}
.g-spbar-yellow .g-sp { color: #14296a; }

/* Kampuken */
.week {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.week-day {
  background: var(--canvas);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 22px;
  position: relative;
  display: flex; flex-direction: column;
  gap: 6px;
}
.week-day-human {
  background: var(--brand-soft);
  border-color: var(--brand);
}
.week-tag {
  font: 700 11px/1 var(--font-mono);
  letter-spacing: 0.12em;
  color: var(--ink-3);
  margin-bottom: 4px;
}
.week-auto {
  display: inline-block;
  align-self: flex-start;
  font: 600 9.5px/1 var(--font-sans);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 3px;
  background: var(--green-soft);
  color: var(--green);
  margin-bottom: 6px;
}
.week-auto-human {
  background: var(--brand);
  color: #fff;
}
.week-day h3 {
  font: 600 14.5px/1.3 var(--font-sans);
  letter-spacing: -0.005em;
  color: var(--ink);
  margin: 0;
}
.week-day p {
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink-2);
  margin: 0;
}

@media (max-width: 1100px) {
  .week { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .week { grid-template-columns: 1fr; }
}
.grid-9-cap {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 14px;
  padding: 0 4px;
}

/* ─── Flow (dark section) ─── */
.flow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  list-style: none;
  position: relative;
}
.flow::before {
  content: "";
  position: absolute;
  top: 22px; left: 5%; right: 5%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.18), transparent);
  z-index: 0;
}
.flow-step {
  position: relative;
  padding-top: 0;
}
.flow-num {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: #fff;
  color: var(--brand);
  font: 700 14px/1 var(--font-mono);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
  position: relative; z-index: 1;
  border: 1px solid rgba(255,255,255,0.2);
}
.flow-time {
  font: 600 11px/1 var(--font-mono);
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.5);
  margin-bottom: 12px;
  text-transform: uppercase;
}
.flow-step p {
  color: rgba(255,255,255,0.72);
  font-size: 13.5px;
  line-height: 1.55;
  margin-top: 6px;
}

/* ─── Features ─── */
.features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.feature {
  background: var(--canvas);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 28px;
  transition: border-color .2s, transform .2s;
}
.feature:hover { border-color: var(--ink-4); }
.feature-icon {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--brand-soft);
  color: var(--brand);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.feature-icon svg { width: 18px; height: 18px; }
.feature p { color: var(--ink-2); font-size: 14px; line-height: 1.55; }

/* ─── Phones row (3 phones) ─── */
.section-app { padding-top: 96px; }
.phones-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  align-items: start;
  justify-items: center;
  perspective: 1400px;
}
.phone-shell { display: flex; flex-direction: column; align-items: center; gap: 18px; }
.phone-shell-tilt .phone-frame { transform: translateY(-12px); }
.phone-frame {
  width: 280px;
  height: 580px;
  background: #0c0c0c;
  border-radius: 42px;
  padding: 8px;
  box-shadow: var(--shadow-phone);
  position: relative;
}
.phone-frame .phone-notch {
  position: absolute;
  top: 16px; left: 50%; transform: translateX(-50%);
  width: 86px; height: 22px;
  background: #000;
  border-radius: 12px;
  z-index: 5;
}
.phone-screen-app {
  width: 100%; height: 100%;
  background: var(--canvas);
  border-radius: 34px;
  overflow: hidden;
  display: flex; flex-direction: column;
  font-size: 12px;
}
.phone-cap {
  font: 500 13px/1.4 var(--font-sans);
  color: var(--ink-2);
  text-align: center;
  max-width: 240px;
}

/* App header inside phones */
.app-header {
  display: flex; align-items: center; gap: 8px;
  padding: 36px 14px 10px;
  border-bottom: 1px solid var(--line);
  font: 600 13px/1 var(--font-sans);
}
.app-back, .app-close, .app-add {
  width: 24px; text-align: center;
  color: var(--ink-3);
  font-size: 16px;
}
.app-title { flex: 1; }
.app-pulse {
  display: flex; align-items: center; gap: 6px;
  font: 700 9px/1 var(--font-sans);
  letter-spacing: 0.1em;
  color: var(--red);
  text-transform: uppercase;
}

.app-score {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 8px;
  padding: 14px;
  border-bottom: 1px solid var(--line);
}
.app-team { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.app-crest {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--brand);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font: 700 11px/1 var(--font-sans);
}
.crest-away { background: #b03a3a; }
.app-team-name { font: 500 10px/1 var(--font-sans); color: var(--ink-2); }
.app-score-num {
  font: 800 24px/1 var(--font-disp);
  letter-spacing: -0.02em;
  color: var(--ink);
}
.app-min {
  text-align: center;
  padding: 8px;
  font: 700 11px/1 var(--font-mono);
  color: var(--ink-3);
  background: var(--canvas-2);
  border-bottom: 1px solid var(--line);
}

.app-feed { list-style: none; padding: 0; flex: 1; overflow: hidden; }
.app-event {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  gap: 8px; align-items: center;
  padding: 10px 14px;
  border-bottom: 1px solid var(--line-2);
}
.app-event-icon {
  width: 24px; height: 24px;
  border-radius: 4px;
  background: var(--brand-soft);
  color: var(--brand);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px;
  font-weight: 700;
}
.ev-card { background: #f3e9cf; color: #8a6a26; }
.ev-sub { background: var(--accent-soft); color: #353e54; }
.app-event-title { font: 600 11px/1.2 var(--font-sans); }
.app-event-sub { font-size: 10px; color: var(--ink-3); margin-top: 2px; }
.app-event-status {
  font: 600 9px/1 var(--font-sans);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 4px 6px;
  border-radius: 4px;
}
.status-published { background: var(--green-soft); color: var(--green); }
.status-pending { background: #f3e9cf; color: #8a6a26; }

/* App preview phone */
.app-preview {
  padding: 12px;
  display: flex; justify-content: center;
}
.story-preview {
  margin: 0;
  width: 180px;
  height: 280px;
  border-radius: 10px;
}
.story-preview::before { font-size: 60px; top: 26px; }
.story-preview .story-portrait { width: 56px; height: 56px; }
.story-preview .score-num { font-size: 20px; }
.app-meta {
  padding: 0 14px 8px;
  font-size: 11px;
}
.meta-row {
  display: flex; justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px solid var(--line-2);
}
.meta-row:last-child { border-bottom: none; }
.meta-key { color: var(--ink-3); }
.meta-val { color: var(--ink); font-weight: 500; }
.pill {
  padding: 2px 8px; border-radius: 999px;
  font: 600 10px/1.4 var(--font-sans);
}
.pill-green { background: var(--green-soft); color: var(--green); }
.seg {
  display: inline-block;
  padding: 2px 6px; border-radius: 4px;
  font: 600 10px/1.4 var(--font-mono);
  border: 1px solid var(--line);
  margin-left: 4px;
  color: var(--ink-3);
}
.seg-on { background: var(--brand-soft); color: var(--brand); border-color: var(--brand); }

.app-actions {
  padding: 10px 14px 14px;
  display: flex; flex-direction: column; gap: 6px;
}
.btn-app-primary {
  background: var(--brand);
  color: #fff;
  padding: 10px;
  border-radius: 8px;
  font: 600 12px/1 var(--font-sans);
  border: 0;
}
.btn-app-secondary {
  background: var(--canvas);
  color: var(--ink-2);
  padding: 10px;
  border-radius: 8px;
  font: 600 12px/1 var(--font-sans);
  border: 1px solid var(--line);
}

/* App tabs */
.app-tabs {
  display: flex; gap: 4px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--line);
}
.tab {
  font: 500 11px/1 var(--font-sans);
  padding: 6px 10px;
  border-radius: 6px;
  color: var(--ink-3);
}
.tab-on { background: var(--brand-soft); color: var(--brand); font-weight: 600; }
.app-search {
  padding: 8px 14px;
  font-size: 10px;
  color: var(--ink-3);
  border-bottom: 1px solid var(--line);
}
.app-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  padding: 6px;
}
.img-tile {
  aspect-ratio: 1/1;
  position: relative;
  border-radius: 4px;
  overflow: hidden;
}
.img-photo {
  position: absolute; inset: 0;
}
.p-1 { background: linear-gradient(135deg, #1B388E, #4a72b8); }
.p-2 { background: linear-gradient(135deg, #c5292f, #e57175); }
.p-3 { background: linear-gradient(135deg, #2e7d4f, #6cb18a); }
.p-4 { background: linear-gradient(135deg, #1B388E, #b8c6d6); }
.p-5 { background: linear-gradient(135deg, #353e54, #93a8c9); }
.p-6 { background: linear-gradient(135deg, #8a6a26, #d4a017); }
.p-7 { background: linear-gradient(135deg, #14296a, #5b7aa3); }
.p-8 { background: linear-gradient(135deg, #b03a3a, #f1b3a0); }
.p-9 { background: linear-gradient(135deg, #2952cc, #cfd9ec); }
.img-num {
  position: absolute;
  bottom: 4px; left: 4px;
  font: 700 9px/1 var(--font-mono);
  background: rgba(0,0,0,0.6);
  color: #fff;
  padding: 2px 4px;
  border-radius: 3px;
}

/* ─── MacBook mockup ─────────────────── */
.section-mac { padding-bottom: 96px; }
.mac-wrap {
  position: relative;
  max-width: 1080px;
  margin: 0 auto;
}
.mac {
  background: #1c1c1c;
  border-radius: 14px 14px 4px 4px;
  padding: 14px 14px 0;
  box-shadow: var(--shadow-pop);
  position: relative;
}
.mac-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 0 6px 12px;
}
.mac-dot {
  width: 11px; height: 11px; border-radius: 50%;
  background: #444;
}
.mac-dot-r { background: #ff5f56; }
.mac-dot-y { background: #ffbd2e; }
.mac-dot-g { background: #27c93f; }
.mac-url {
  margin: 0 auto;
  background: #2a2a2a;
  color: rgba(255,255,255,0.7);
  font-size: 11px;
  padding: 4px 14px;
  border-radius: 5px;
}
.mac-screen {
  display: grid;
  grid-template-columns: 200px 1fr;
  background: var(--bg);
  border-radius: 4px 4px 0 0;
  overflow: hidden;
  height: 540px;
}
.mac-base {
  height: 14px;
  background: linear-gradient(180deg, #1c1c1c 0%, #2a2a2a 100%);
  border-radius: 0 0 6px 6px;
  margin: 0 -2px;
  position: relative;
}
.mac-base::after {
  content: ""; position: absolute;
  top: 0; left: 50%; transform: translateX(-50%);
  width: 80px; height: 6px;
  background: #0c0c0c;
  border-radius: 0 0 6px 6px;
}
.mac-foot {
  height: 6px;
  background: linear-gradient(180deg, #b8b8b8, #888);
  border-radius: 0 0 12px 12px;
  margin: 0 6%;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

.mac-side {
  background: var(--sidebar, #efeee9);
  border-right: 1px solid var(--line);
  padding: 14px 12px;
  display: flex; flex-direction: column;
  gap: 18px;
  font-size: 12px;
}
.mac-logo {
  font: 800 14px/1 var(--font-disp);
  letter-spacing: -0.01em;
  display: flex;
}
.ml-l { color: var(--brand); }
.ml-r { color: var(--red); }
.mac-club {
  display: flex; align-items: center; gap: 8px;
  padding: 8px;
  background: var(--canvas);
  border: 1px solid var(--line);
  border-radius: 6px;
}
.mac-crest {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--brand);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font: 700 10px/1 var(--font-sans);
}
.mac-club-name { font: 600 11px/1.2 var(--font-sans); color: var(--ink); }
.mac-club-sub { font-size: 9px; color: var(--ink-3); margin-top: 1px; }
.mac-nav-group { display: flex; flex-direction: column; gap: 2px; }
.mac-nav-kicker {
  font: 700 8.5px/1 var(--font-sans);
  letter-spacing: 0.14em;
  color: var(--ink-4);
  margin-bottom: 4px;
  padding: 0 6px;
}
.mac-nav {
  font: 500 11px/1 var(--font-sans);
  color: var(--ink-2);
  padding: 6px 8px;
  border-radius: 4px;
  cursor: default;
}
.mac-nav-on {
  background: var(--brand-soft);
  color: var(--brand);
  font-weight: 600;
}

.mac-main {
  padding: 16px 18px;
  overflow: hidden;
}
.mac-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: 14px;
}
.mac-h-kicker {
  font: 700 9px/1 var(--font-sans);
  letter-spacing: 0.14em;
  color: var(--ink-3);
  margin-bottom: 6px;
}
.mac-h-title { font: 600 16px/1.2 var(--font-sans); letter-spacing: -0.01em; color: var(--ink); }
.mac-actions { display: flex; gap: 6px; }
.mac-btn {
  font: 500 11px/1 var(--font-sans);
  padding: 7px 12px;
  border: 1px solid var(--line);
  background: var(--canvas);
  border-radius: 5px;
  color: var(--ink-2);
}
.mac-btn-pri { background: var(--brand); border-color: var(--brand); color: #fff; }

.mac-tabs {
  display: flex; gap: 4px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
}
.mac-tab {
  font: 600 9.5px/1 var(--font-sans);
  letter-spacing: 0.05em;
  padding: 6px 10px;
  border-radius: 4px;
  color: var(--ink-3);
  background: var(--canvas);
  border: 1px solid var(--line);
}
.mac-tab-on { background: var(--ink); color: #fff; border-color: var(--ink); }
.mac-tab-now { background: var(--brand-soft); color: var(--brand); border-color: var(--brand); }

.mac-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  background: var(--canvas);
  border: 1px solid var(--line);
  border-radius: 6px;
  margin-bottom: 6px;
  font-size: 11px;
}
.mac-row-head { background: transparent; border: none; padding: 4px 0; font-weight: 600; }
.mac-pill {
  font: 600 9px/1 var(--font-sans);
  padding: 3px 7px;
  background: var(--ink);
  color: #fff;
  border-radius: 3px;
}
.mac-pill-soft { background: var(--brand-soft); color: var(--brand); }

.mac-match { flex: 1; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.mac-time { font: 600 11px/1 var(--font-mono); color: var(--ink-2); }
.mac-teams { display: flex; align-items: center; gap: 8px; font: 600 12px/1 var(--font-sans); }
.mac-team-name { color: var(--ink); }
.mac-score {
  background: var(--brand-soft);
  color: var(--brand);
  padding: 3px 8px;
  border-radius: 4px;
  font: 700 11px/1 var(--font-mono);
}
.mac-meta { font-size: 10px; color: var(--ink-3); }
.mac-status {
  font: 600 9px/1 var(--font-sans);
  padding: 4px 8px;
  border-radius: 3px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--green-soft);
  color: var(--green);
}

.mac-event {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  background: var(--canvas);
  border: 1px solid var(--line-2);
  border-radius: 5px;
  margin-bottom: 4px;
  font-size: 11px;
  margin-left: 22px;
}
.mac-event-live { border-left: 2px solid var(--red); }
.mac-ev-date { color: var(--ink-3); width: 50px; }
.mac-ev-tag {
  background: var(--bg);
  color: var(--ink-2);
  padding: 3px 8px;
  border-radius: 3px;
  font: 600 10px/1 var(--font-sans);
}
.mac-ev-tag-goal { background: var(--brand-soft); color: var(--brand); }
.mac-ev-spacer { flex: 1; }
.mac-ev-pill {
  font: 600 9px/1 var(--font-sans);
  padding: 3px 7px;
  border-radius: 3px;
  letter-spacing: 0.04em;
}
.mac-ev-pub { background: var(--green-soft); color: var(--green); }
.mac-ev-new { background: var(--brand-soft); color: var(--brand); }
.mac-ev-eye { color: var(--ink-4); font-size: 12px; }

.mac-cap {
  text-align: center;
  margin-top: 24px;
  font-size: 12px;
  color: var(--ink-4);
}

@media (max-width: 900px) {
  .mac-screen { grid-template-columns: 160px 1fr; height: 460px; }
  .mac-side { padding: 10px 8px; }
}
@media (max-width: 720px) {
  .mac-screen { grid-template-columns: 1fr; height: auto; }
  .mac-side { display: none; }
}
.team {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}
.team-card {
  text-align: left;
}
.team-portrait {
  width: 140px; height: 140px;
  border-radius: 50%;
  background: var(--canvas);
  border: 1px solid var(--line);
  overflow: hidden;
  margin-bottom: 18px;
  box-shadow: var(--shadow);
}
.team-portrait svg { width: 100%; height: 100%; }
.team-name {
  font: 600 16px/1.2 var(--font-sans);
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 2px;
}
.team-role {
  font: 500 12px/1.2 var(--font-sans);
  color: var(--brand);
  margin-bottom: 10px;
}
.team-bio {
  font-size: 13.5px; line-height: 1.55;
  color: var(--ink-2);
}
.team-foot {
  margin-top: 32px;
  text-align: left;
  font-size: 12px;
  color: var(--ink-4);
}

/* ─── Hvem dette er for ─── */
.for-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 64px;
  align-items: start;
}
.for-list { display: flex; flex-direction: column; gap: 14px; }
.for-item {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 12px;
  padding: 14px 0;
  border-top: 1px solid var(--line);
  font-size: 14.5px;
  line-height: 1.5;
  color: var(--ink-2);
}
.for-item:last-child { border-bottom: 1px solid var(--line); }
.for-item strong { color: var(--ink); font-weight: 600; }
.for-mark {
  width: 22px; height: 22px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font: 700 12px/1 var(--font-sans);
}
.for-mark-good { background: var(--green-soft); color: var(--green); }
.for-mark-bad { background: var(--bg); color: var(--ink-4); border: 1px solid var(--line); }

/* ─── Trust ─── */
.trust-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-bottom: 56px;
}
.trust-stat {
  padding: 24px;
  background: var(--canvas);
  border: 1px solid var(--line);
  border-radius: 8px;
}
.trust-num {
  font: 800 36px/1 var(--font-disp);
  color: var(--brand);
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
.trust-label {
  font-size: 12.5px;
  color: var(--ink-2);
  line-height: 1.45;
}

.logo-strip {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0;
  padding: 32px 0;
  margin-bottom: 56px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  align-items: center;
}
.club-logo {
  text-align: center;
  font: 800 13px/1 var(--font-disp);
  letter-spacing: 0.08em;
  color: var(--ink-4);
  padding: 8px;
  border-right: 1px solid var(--line);
}
.club-logo:last-child { border-right: none; }

.quote {
  max-width: 780px;
  padding: 32px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-bottom: 32px;
}
.quote blockquote {
  font: 500 22px/1.4 var(--font-disp);
  letter-spacing: -0.012em;
  color: var(--ink);
  text-wrap: balance;
}
.quote figcaption {
  margin-top: 14px;
  font-size: 13px;
  color: var(--ink-3);
}

.tech-trust {
  display: flex; gap: 18px 32px; flex-wrap: wrap;
  list-style: none;
  font-size: 12.5px;
  color: var(--ink-3);
}
.tech-trust li::before {
  content: "•";
  margin-right: 8px;
  color: var(--brand);
}

/* ─── CTA section ─── */
.section-cta {
  background: linear-gradient(180deg, #14296a 0%, #1B388E 100%);
  color: #fff;
}
.cta-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.cta-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.cta-info {
  list-style: none;
  display: flex; gap: 32px;
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.16);
}
.cta-info li {
  font-size: 14px;
  color: rgba(255,255,255,0.85);
}
.cta-info li a { color: #fff; font-weight: 500; }
.cta-info .kicker { color: rgba(255,255,255,0.6); display: block; margin-bottom: 4px; }

.cta-form {
  background: var(--canvas);
  color: var(--ink);
  border-radius: 12px;
  padding: 32px;
  box-shadow: var(--shadow-pop);
}
.cta-form h3 {
  color: var(--ink) !important;
  margin-bottom: 20px;
}
.field { margin-bottom: 14px; display: flex; flex-direction: column; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.field label {
  font: 600 10px/1.2 var(--font-sans);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 6px;
}
.field input {
  font: 400 14px/1.4 var(--font-sans);
  color: var(--ink);
  background: var(--canvas-2);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 10px 12px;
  outline: none;
  transition: border-color .15s, background .15s;
}
.field input:focus { border-color: var(--brand); background: #fff; }
.form-success {
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--green-soft);
  color: var(--green);
  border-radius: 6px;
  font-size: 13px;
}

/* ─── Footer ─── */
.footer {
  background: var(--bg);
  border-top: 1px solid var(--line);
  padding: 56px 0 24px;
}
.footer-inner {
  display: grid;
  grid-template-columns: 1.2fr 2fr;
  gap: 56px;
  margin-bottom: 32px;
}
.footer-logo { height: 22px; margin-bottom: 14px; }
.footer-brand p { font-size: 13.5px; color: var(--ink-3); max-width: 320px; line-height: 1.5; }
.footer-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.footer-cols > div { display: flex; flex-direction: column; gap: 8px; }
.footer-cols .kicker { color: var(--ink-3); margin-bottom: 4px; }
.footer-cols a { font-size: 13.5px; color: var(--ink-2); }
.footer-cols a:hover { color: var(--ink); }

.footer-base {
  display: flex; justify-content: space-between;
  padding-top: 20px;
  border-top: 1px solid var(--line);
  color: var(--ink-3);
  font-size: 12px;
}

/* ─── Responsive ─── */
@media (max-width: 1100px) {
  .pillar, .pillar-2 { grid-template-columns: 1fr; gap: 40px; }
  .pillar-2 .pillar-copy, .pillar-2 .pillar-visual { order: 0; }
  .for-grid { grid-template-columns: 1fr; gap: 32px; }
  .cta-wrap { grid-template-columns: 1fr; }
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-proof { height: 540px; }
  .features { grid-template-columns: repeat(2, 1fr); }
  .team { grid-template-columns: repeat(2, 1fr); }
  .trust-stats { grid-template-columns: repeat(2, 1fr); }
  .phones-row { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; gap: 32px; }
}

@media (max-width: 720px) {
  .container { padding: 0 20px; }
  .nav-inner { padding: 0 20px; }
  .nav-links { display: none; }
  .nav-cta .btn-ghost-dark { display: none; }
  .section { padding: 64px 0; }
  .hero { padding: 64px 0 80px; }
  .hero-grid { padding: 0 20px; }
  .hero-proof { height: 520px; }
  .pitch-card { width: 70%; }
  .vignettes, .features, .flow, .trust-stats { grid-template-columns: 1fr; }
  .team { grid-template-columns: 1fr; }
  .logo-strip { grid-template-columns: repeat(3, 1fr); gap: 16px 0; }
  .ba-wrap { grid-template-columns: 1fr; }
  .footer-cols { grid-template-columns: 1fr 1fr; }
  .footer-base { flex-direction: column; gap: 8px; }
  .field-row { grid-template-columns: 1fr; }
  .display { font-size: 38px; }
  .h2 { font-size: 28px; }
  .grid-9 { grid-template-columns: repeat(3, 1fr); }
}
