/* home-refined.css — the front door as an editorial read, not a dashboard.
   Opens on a cinematic dark cover (the masthead promise + the next match as one
   above-the-fold moment), then breaks into the warm-paper body: schedule,
   the neutral's guide, a matchday-briefing sign-up, and what's changed.
   No models, no odds, no probability bars. No photography — atmosphere is built
   from type, the crest lockup and a restrained CSS pitch motif. Archivo +
   Source Serif only; warm-neutral literals shared with the other refined sheets. */

/* let the homepage go edge-to-edge (other pages keep the centered main) */
main.home-main{ max-width:none; margin:0; padding:0; }

/* ===================== the cover ===================== */
.hr-cover{ position:relative; overflow:hidden; background:#1b1a14; color:#f4f0e7;
  padding:clamp(38px,6vw,74px) 24px clamp(46px,6vw,68px); }
/* floodlight wash + a faint pitch centre-circle and halfway line on the right */
.hr-cover::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 95% at 78% -15%, rgba(40,140,80,.26), transparent 58%); }
.hr-cover-pitch{ position:absolute; top:0; bottom:0; right:6%; width:340px; pointer-events:none;
  background:
    radial-gradient(circle at 50% 50%, transparent 0 128px, rgba(244,240,231,.07) 128px 130px, transparent 131px),
    linear-gradient(90deg, transparent calc(50% - .5px), rgba(244,240,231,.055) 50%, transparent calc(50% + .5px)); }

.hr-cover-in{ position:relative; z-index:1; max-width:980px; margin:0 auto; }
.hr-cover-kicker{ font-family:var(--font-text); font-size:12px; font-weight:600; text-transform:uppercase;
  letter-spacing:.18em; color:#79c79a; margin:0 0 18px; }
.hr-cover-title{ font-family:var(--font-display); font-weight:800; font-size:clamp(38px,6.4vw,72px);
  letter-spacing:-.035em; line-height:.96; margin:0; color:#f7f3ea; }
.hr-cover-lede{ font-family:var(--font-serif); font-size:clamp(17px,1.9vw,20px); line-height:1.55;
  color:#c4bda9; margin:20px 0 0; max-width:60ch; }

/* the opener, set into the cover */
.hr-cover-opener{ display:block; text-decoration:none; color:inherit; margin:30px 0 0; max-width:680px;
  background:rgba(255,255,255,.035); border:1px solid rgba(244,240,231,.14); border-radius:14px;
  padding:20px 24px 22px; transition:background .14s ease, border-color .14s ease; }
.hr-cover-opener:hover{ background:rgba(255,255,255,.06); border-color:rgba(244,240,231,.26); }
.hr-cover-up{ display:flex; align-items:center; gap:9px; font-family:var(--font-text); font-size:11.5px;
  font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:#cfc8b4; }
.hr-live-dot{ width:7px; height:7px; border-radius:50%; background:#3ddc84;
  box-shadow:0 0 0 3px rgba(61,220,132,.22); flex:none; }
.hr-cover-count{ margin-left:auto; color:#3ddc84; letter-spacing:.05em; font-variant-numeric:tabular-nums;
  font-size:12.5px; }
.hr-cover-match{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin:15px 0 0; }
.hr-cover-team{ display:flex; align-items:center; gap:12px; font-family:var(--font-display); font-weight:800;
  font-size:clamp(25px,3.6vw,38px); letter-spacing:-.025em; line-height:1; color:#f7f3ea; }
.hr-cover-v{ font-family:var(--font-serif); font-style:italic; font-weight:400; font-size:21px; color:#8d8770; }
.hr-cover-flag{ width:50px; height:50px; border-radius:50%; background-size:cover; background-position:center;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.3), 0 0 0 1px rgba(244,240,231,.12); flex:none; }
.hr-cover-meta{ font-family:var(--font-text); font-size:12.5px; color:#a39c87; margin:16px 0 0;
  display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.hr-cover-hook{ font-family:var(--font-serif); font-style:italic; font-size:clamp(17px,2.1vw,21px);
  line-height:1.32; color:#e7e0cf; margin:12px 0 0; max-width:48ch; }
.hr-cover-cta{ display:inline-block; margin-top:16px; font-family:var(--font-text); font-weight:700;
  font-size:14px; color:#3ddc84; }

/* broadcaster pill — light body + dark-cover variants */
.tv-pill{ display:inline-block; font-family:var(--font-text); font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.04em; color:var(--accent2-strong);
  border:1px solid var(--accent2-strong); border-radius:5px; padding:2px 8px; white-space:nowrap; }
.tv-pill--dark{ color:#7fb8ec; border-color:rgba(127,184,236,.5); }

/* ===================== the body ===================== */
.hr-wrap{ max-width:1000px; margin:0 auto; padding:8px 28px 90px; }

.hr-sec{ margin:44px 0 0; }
.hr-sec-head{ display:flex; align-items:baseline; gap:14px; flex-wrap:wrap;
  border-bottom:2px solid var(--ink); padding-bottom:10px; margin-bottom:18px; }
.hr-sec-head h2{ font-family:var(--font-display); font-weight:800; font-size:clamp(22px,2.8vw,29px);
  letter-spacing:-.02em; color:var(--ink); margin:0; border:0; padding:0; }
.hr-sec-link{ margin-left:auto; font-family:var(--font-text); font-size:13px; font-weight:700;
  color:var(--accent-strong); text-decoration:none; }
.hr-sec-note{ font-family:var(--font-serif); font-style:italic; font-size:15px; color:#86826f;
  flex-basis:100%; line-height:1.5; }
.hr-sec-foot{ font-family:var(--font-text); font-size:13px; color:#86826f; margin:14px 0 0; }
.hr-sec-foot a{ color:var(--accent-strong); font-weight:700; text-decoration:none; }

/* schedule + collisions cards */
.hr-sched, .hr-collide{ display:grid; grid-template-columns:repeat(auto-fill, minmax(290px,1fr)); gap:14px; }
.hr-match{ display:block; text-decoration:none; color:inherit; background:var(--panel);
  border:1px solid #eee9df; border-radius:12px; padding:16px 18px 17px;
  transition:border-color .12s ease, box-shadow .12s ease; }
.hr-match:hover{ border-color:#ded7c6; box-shadow:0 8px 24px -18px rgba(40,36,25,.3); }
.hr-match--mark{ border-top:3px solid var(--accent-strong); }
.hr-match-top{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.hr-grp{ font-family:var(--font-text); font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; color:var(--accent-strong); }
.hr-date{ font-family:var(--font-text); font-size:12px; color:#a8a292; font-variant-numeric:tabular-nums; }
.hr-match-teams{ margin:12px 0 0; display:flex; flex-direction:column; gap:7px; }
.hr-mt{ display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:700;
  font-size:18px; letter-spacing:-.015em; color:var(--ink); }
.hr-mv{ font-family:var(--font-serif); font-style:italic; font-weight:400; font-size:13px; color:#bdb7a6;
  padding-left:2px; }
.hr-flag-sm{ width:26px; height:26px; border-radius:50%; background-size:cover; background-position:center;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.14); flex:none; }
.hr-match-foot{ margin:14px 0 0; padding-top:11px; border-top:1px solid #f1ede3; display:flex;
  align-items:center; gap:10px; flex-wrap:wrap; }
.hr-venue{ font-family:var(--font-text); font-size:12px; color:#86826f; }
.hr-collide-why{ font-family:var(--font-serif); font-size:15px; line-height:1.55; color:#3a382f;
  margin:14px 0 0; padding-top:12px; border-top:1px solid #f1ede3; }

/* newsletter */
.hr-news{ margin:48px 0 0; background:#26241d; border-radius:16px; padding:38px 28px; text-align:center; }
.hr-news-in{ max-width:520px; margin:0 auto; }
.hr-news h2{ font-family:var(--font-display); font-weight:800; font-size:clamp(23px,3vw,30px);
  letter-spacing:-.02em; color:#f6f2e9; margin:0 0 10px; border:0; padding:0; }
.hr-news p{ font-family:var(--font-serif); font-size:16px; line-height:1.55; color:#c5bfac; margin:0 0 22px; }
.hr-news-form{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }
.hr-news-input{ flex:1 1 280px; min-width:0; padding:12px 14px; font-family:var(--font-serif); font-size:15px;
  color:#f6f2e9; background:#1b1914; border:1px solid #45412f; border-radius:8px; }
.hr-news-input::placeholder{ color:#8d8770; }
.hr-news-input:focus{ outline:none; border-color:var(--accent-strong); }
.hr-news-btn{ padding:12px 22px; font-family:var(--font-text); font-weight:800; font-size:14px;
  color:#fff; background:var(--accent-strong); border:0; border-radius:8px; cursor:pointer;
  white-space:nowrap; transition:filter .12s ease; }
.hr-news-btn:hover{ filter:brightness(1.06); }
.hr-news-fine{ font-family:var(--font-text)!important; font-size:12px!important; color:#8d8770!important;
  margin:16px 0 0!important; }

/* digest */
.hr-digest{ display:grid; gap:10px; }
.hr-digest-row{ display:flex; gap:13px; align-items:flex-start; text-decoration:none; color:inherit;
  background:var(--panel); border:1px solid #eee9df; border-radius:10px; padding:14px 16px;
  transition:border-color .12s ease; }
.hr-digest-row:hover{ border-color:#ded7c6; }
.hr-digest-row .hr-flag-sm{ margin-top:2px; }
.hr-digest-text{ display:flex; flex-direction:column; gap:3px; }
.hr-digest-text strong{ font-family:var(--font-display); font-weight:700; font-size:15.5px;
  letter-spacing:-.01em; color:var(--ink); line-height:1.3; }
.hr-digest-text span{ font-family:var(--font-serif); font-size:14.5px; line-height:1.5; color:#3a382f; }

@media(max-width:760px){
  .hr-cover-pitch{ display:none; }
}
@media(max-width:640px){
  .hr-wrap{ padding:6px 18px 70px; }
  .hr-cover{ padding:32px 18px 40px; }
  .hr-cover-flag{ width:40px; height:40px; }
  .hr-sched, .hr-collide{ grid-template-columns:1fr; }
}
