/*
Theme Name: Klubbnet Theme
Theme URI: https://klubbnet.se
Author: Kodio
Author URI: https://kodio.se
Description: Modernt WordPress-tema för Klubbnet – föreningar, lag, spelare, matcher, sponsorer och biljetter.
Version: 0.1.6
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: klubbnet-theme
License: GPLv2 or later
*/

:root {
  --kn-navy: #102033;
  --kn-navy-2: #172c45;
  --kn-mint: #4bd9c1;
  --kn-bg: #f4f8f7;
  --kn-card: #ffffff;
  --kn-text: #122033;
  --kn-muted: #647084;
  --kn-border: rgba(16,32,51,.12);
  --kn-radius: 26px;
  --kn-shadow: 0 20px 55px rgba(16,32,51,.10);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--kn-bg);
  color: var(--kn-text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.65;
}
img { max-width: 100%; height: auto; }
a { color: var(--kn-navy); }
a:hover { color: #0b756a; }
.kn-container { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }

.kn-site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: rgba(244,248,247,.92);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(16,32,51,.08);
}
.admin-bar .kn-site-header { top: 32px; }
.kn-topbar { background: var(--kn-navy); color: rgba(255,255,255,.82); font-size: 13px; }
.kn-topbar-inner { min-height: 34px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.kn-topbar-links { display: flex; gap: 14px; flex-wrap: wrap; justify-content: flex-end; }
.kn-topbar a { color: rgba(255,255,255,.84); text-decoration: none; font-weight: 750; }
.kn-topbar a:hover { color: var(--kn-mint); }
.kn-header-inner { min-height: 86px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.kn-logo { display: inline-flex; align-items: center; text-decoration: none; }
.kn-logo img { display: block; width: 230px; max-width: 56vw; background: transparent; }
.custom-logo-link img { max-height: 70px; width: auto; }
.kn-nav { display: flex; align-items: center; gap: 14px; }
.kn-nav ul { list-style: none; margin: 0; padding: 0; display: flex; gap: 4px; flex-wrap: wrap; justify-content: flex-end; }
.kn-nav li { position: relative; }
.kn-nav a { display: inline-flex; padding: 10px 11px; border-radius: 999px; text-decoration: none; color: var(--kn-text); font-weight: 850; font-size: 14px; }
.kn-nav a:hover { background: #fff; color: var(--kn-navy); box-shadow: 0 8px 24px rgba(16,32,51,.08); }
.kn-ticket-link { display: inline-flex; align-items: center; gap: 8px; border-radius: 999px; padding: 12px 16px; background: var(--kn-navy); color: #fff !important; text-decoration: none; font-weight: 900; white-space: nowrap; box-shadow: 0 12px 28px rgba(16,32,51,.18); }
.kn-ticket-link:after { content: '→'; color: var(--kn-mint); }

.kn-club-hero {
  min-height: 620px;
  display: flex;
  align-items: center;
  background: linear-gradient(90deg, rgba(7,16,29,.86), rgba(7,16,29,.48)), radial-gradient(circle at 80% 30%, rgba(75,217,193,.28), transparent 30%), linear-gradient(135deg, #122033, #233a56);
  background-position: center;
  background-size: cover;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.kn-club-hero:after { content: ''; position: absolute; inset: auto 0 0; height: 180px; background: linear-gradient(transparent, rgba(244,248,247,.96)); pointer-events: none; }
.kn-club-hero-inner { position: relative; z-index: 2; display: grid; grid-template-columns: minmax(0,1.25fr) minmax(280px,.55fr); gap: 34px; align-items: center; padding: 72px 0 86px; }
.kn-eyebrow, .kn-section-kicker, .kn-card-label { display: inline-flex; align-items: center; border-radius: 999px; padding: 8px 12px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.18); color: var(--kn-mint); font-weight: 950; font-size: 12px; letter-spacing: .04em; text-transform: uppercase; }
.kn-club-hero h1 { color: #fff; font-size: clamp(46px, 8vw, 92px); line-height: .93; letter-spacing: -.07em; margin: 18px 0; max-width: 900px; }
.kn-club-hero p { color: rgba(255,255,255,.82); font-size: clamp(18px, 2vw, 22px); max-width: 680px; margin: 0; }
.kn-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 30px; }
.kn-button { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border-radius: 999px; padding: 14px 20px; background: var(--kn-navy); color: #fff; text-decoration: none; font-weight: 900; border: 0; box-shadow: 0 14px 30px rgba(16,32,51,.20); }
.kn-button:hover { color: #fff; transform: translateY(-1px); }
.kn-button-mint { background: var(--kn-mint); color: #06201d !important; }
.kn-button-ghost { background: rgba(255,255,255,.13); border: 1px solid rgba(255,255,255,.18); color: #fff !important; box-shadow: none; }
.kn-button-ghost-dark { background: rgba(16,32,51,.08); border: 1px solid rgba(16,32,51,.12); color: var(--kn-navy) !important; box-shadow: none; }
.kn-club-hero-card { align-self: end; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.18); backdrop-filter: blur(18px); border-radius: 32px; padding: 26px; box-shadow: 0 34px 90px rgba(0,0,0,.25); }
.kn-club-hero-card h2 { color: #fff; margin: 12px 0 8px; font-size: 34px; line-height: 1; letter-spacing: -.04em; }
.kn-club-hero-card p { font-size: 15px; color: rgba(255,255,255,.72); }
.kn-hero-mini-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 12px; padding: 13px 0; border-top: 1px solid rgba(255,255,255,.16); color: rgba(255,255,255,.82); }
.kn-hero-mini-row strong { color: var(--kn-mint); font-size: 24px; }

.kn-match-strip { margin-top: -50px; position: relative; z-index: 5; }
.kn-next-match-card { background: #fff; border-radius: 30px; border: 1px solid var(--kn-border); box-shadow: 0 24px 70px rgba(16,32,51,.18); padding: 24px; display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 22px; align-items: center; }
.kn-next-match-card .kn-card-label { background: #e9fffb; border-color: #cafff4; color: #08796a; }
.kn-next-match-card h2 { margin: 10px 0 4px; font-size: clamp(26px,4vw,46px); line-height: 1.05; color: var(--kn-navy); letter-spacing: -.05em; }
.kn-next-match-card h2 span { color: var(--kn-mint); font-size: .7em; letter-spacing: 0; padding: 0 10px; }
.kn-next-match-card p { margin: 0; color: var(--kn-muted); font-weight: 700; }
.kn-next-match-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }

.kn-section { padding: 66px 0; }
.kn-section-title { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 26px; }
.kn-section-title h2 { font-size: clamp(32px, 5vw, 56px); line-height: .98; letter-spacing: -.06em; margin: 8px 0 0; color: var(--kn-navy); }
.kn-section-title p { color: var(--kn-muted); max-width: 520px; margin: 0; }
.kn-section-kicker { background: #e9fffb; color: #08796a; border-color: #cafff4; }
.kn-text-link { color: var(--kn-navy); font-weight: 950; text-decoration: none; }
.kn-club-feature-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 16px; }
.kn-club-feature { background: #fff; border: 1px solid var(--kn-border); border-radius: 28px; padding: 24px; text-decoration: none; color: var(--kn-text); box-shadow: var(--kn-shadow); min-height: 190px; }
.kn-club-feature:hover { color: var(--kn-text); transform: translateY(-2px); }
.kn-club-feature span { width: 48px; height: 48px; display: inline-flex; align-items: center; justify-content: center; border-radius: 16px; background: var(--kn-mint); color: var(--kn-navy); font-weight: 950; margin-bottom: 18px; }
.kn-club-feature h3 { margin: 0 0 8px; color: var(--kn-navy); font-size: 24px; }
.kn-club-feature p { margin: 0; color: var(--kn-muted); }

.kn-dark-section { background: linear-gradient(135deg, #07111f, var(--kn-navy)); color: #fff; position: relative; overflow: hidden; }
.kn-dark-section:before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 20% 20%, rgba(75,217,193,.22), transparent 28%); pointer-events: none; }
.kn-dark-section .kn-container { position: relative; z-index: 2; }
.kn-section-title-dark h2 { color: #fff; }
.kn-section-title-dark .kn-text-link { color: var(--kn-mint); }
.kn-player-strip, .kn-demo-player-strip { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 16px; }
.kn-player-tile { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: 26px; overflow: hidden; box-shadow: 0 24px 60px rgba(0,0,0,.18); }
.kn-player-tile a { text-decoration: none; color: #fff; }
.kn-player-tile img { width: 100%; height: 250px; object-fit: cover; display: block; }
.kn-player-tile > div { padding: 18px; }
.kn-player-tile strong { color: var(--kn-mint); font-size: 32px; line-height: 1; }
.kn-player-tile h3 { color: #fff; margin: 8px 0 2px; font-size: 21px; }
.kn-player-tile p { color: rgba(255,255,255,.72); margin: 0; }
.kn-player-tile-placeholder, .kn-demo-photo { height: 250px; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, rgba(75,217,193,.35), rgba(255,255,255,.08)); color: #fff; font-size: 64px; font-weight: 950; }

.kn-news-layout { display: grid; grid-template-columns: minmax(0,1fr) 350px; gap: 22px; align-items: start; }
.kn-section-title-small { display: block; }
.kn-news-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 18px; }
.kn-news-card { background: #fff; border: 1px solid var(--kn-border); border-radius: 28px; overflow: hidden; box-shadow: var(--kn-shadow); }
.kn-news-image { display: block; min-height: 185px; background: linear-gradient(135deg, #dffff9, #fff); }
.kn-news-image img { width: 100%; height: 205px; object-fit: cover; display: block; }
.kn-news-image span { display: block; height: 205px; }
.kn-news-card > div { padding: 20px; }
.kn-news-card time { color: #0b8b7b; font-size: 12px; font-weight: 950; text-transform: uppercase; }
.kn-news-card h3 { margin: 8px 0; font-size: 22px; line-height: 1.15; }
.kn-news-card h3 a { text-decoration: none; color: var(--kn-navy); }
.kn-news-card p { margin: 0; color: var(--kn-muted); }
.kn-side-stack { display: grid; gap: 18px; }
.kn-table-card, .kn-ticket-card { background: #fff; border: 1px solid var(--kn-border); border-radius: 28px; padding: 24px; box-shadow: var(--kn-shadow); }
.kn-table-card h3, .kn-ticket-card h3 { margin: 10px 0; color: var(--kn-navy); font-size: 28px; line-height: 1; letter-spacing: -.04em; }
.kn-table-card p, .kn-ticket-card p { color: var(--kn-muted); }
.kn-table-demo { display: grid; gap: 8px; margin: 18px 0; }
.kn-table-demo div { display: grid; grid-template-columns: 28px 1fr auto; gap: 10px; align-items: center; padding: 10px; border-radius: 14px; background: #f5f8f7; }
.kn-table-demo strong { color: var(--kn-mint); }
.kn-table-demo em { font-style: normal; font-weight: 950; color: var(--kn-navy); }

.kn-fixtures-section { padding-top: 26px; }
.kn-fixture-list { display: grid; gap: 12px; }
.kn-fixture-row { background: #fff; border: 1px solid var(--kn-border); border-radius: 22px; padding: 18px 20px; display: grid; grid-template-columns: minmax(0,1.1fr) minmax(240px,.7fr) auto; gap: 16px; align-items: center; box-shadow: 0 12px 34px rgba(16,32,51,.06); }
.kn-fixture-row div { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.kn-fixture-row strong { color: var(--kn-navy); }
.kn-fixture-row span { color: var(--kn-mint); font-weight: 950; }
.kn-fixture-row p { margin: 0; color: var(--kn-muted); font-weight: 700; }
.kn-fixture-row a { font-weight: 950; text-decoration: none; }

.kn-sponsor-band { background: #fff; border-top: 1px solid var(--kn-border); padding: 58px 0; }
.kn-sponsor-band h2 { margin: 12px 0 24px; color: var(--kn-navy); font-size: clamp(30px,4vw,48px); letter-spacing: -.05em; line-height: 1; }
.kn-sponsor-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
.kn-sponsor-grid div { min-height: 96px; display: flex; align-items: center; justify-content: center; border-radius: 22px; background: #f4f8f7; border: 1px solid var(--kn-border); color: var(--kn-muted); font-weight: 950; }

.kn-main { padding: 44px 0 72px; }
.kn-content-card { background: #fff; border-radius: var(--kn-radius); border: 1px solid var(--kn-border); padding: clamp(24px, 4vw, 48px); box-shadow: var(--kn-shadow); }
.kn-content-card h1 { color: var(--kn-navy); font-size: clamp(34px, 5vw, 58px); line-height: 1.02; letter-spacing: -0.05em; margin-top: 0; }
.kn-content-card p, .kn-content-card li { color: #334155; }
.kn-empty-note { background: #fff; border: 1px dashed var(--kn-border); border-radius: 22px; padding: 24px; color: var(--kn-muted); }

.kn-archive-hero, .kn-team-hero, .kn-player-hero {
  background: linear-gradient(135deg, var(--kn-navy), #173952 68%, #0e6d65);
  color: #fff;
  border-radius: 38px;
  padding: clamp(28px, 5vw, 56px);
  margin-bottom: 24px;
  box-shadow: 0 30px 80px rgba(16,32,51,.22);
}
.kn-archive-hero h1, .kn-team-hero h1, .kn-player-hero h1 { color: #fff; font-size: clamp(40px, 6vw, 78px); line-height: .98; letter-spacing: -0.06em; margin: 0 0 14px; }
.kn-archive-hero p, .kn-team-hero p, .kn-player-hero p { max-width: 720px; color: rgba(255,255,255,.78); font-size: 18px; margin: 0; }
.kn-archive-hero .kn-kicker, .kn-team-hero .kn-kicker, .kn-player-hero .kn-kicker { background: rgba(255,255,255,.12); color: var(--kn-mint); border-color: rgba(255,255,255,.18); }
.kn-team-grid, .kn-player-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.kn-team-card, .kn-player-card { overflow: hidden; background: #fff; border: 1px solid var(--kn-border); border-radius: var(--kn-radius); box-shadow: var(--kn-shadow); }
.kn-team-card > a, .kn-player-card > a { display: block; min-height: 210px; background: linear-gradient(135deg, var(--kn-navy), #155f59); text-decoration: none; }
.kn-team-card img, .kn-player-card img { width: 100%; height: 230px; object-fit: cover; display: block; }
.kn-team-card-placeholder, .kn-player-card-placeholder { height: 230px; display: flex; align-items: center; justify-content: center; color: var(--kn-navy); background: linear-gradient(135deg, #d9fff8, #fff); font-size: 56px; font-weight: 950; }
.kn-team-card-body, .kn-player-card-body { padding: 22px; }
.kn-team-card h2, .kn-player-card h2, .kn-team-card h3, .kn-player-card h3 { margin: 0 0 8px; color: var(--kn-navy); font-size: 24px; line-height: 1.12; }
.kn-team-card h2 a, .kn-player-card h2 a, .kn-team-card h3 a, .kn-player-card h3 a { color: var(--kn-navy); text-decoration: none; }
.kn-team-card p, .kn-player-card p { color: var(--kn-muted); margin: 0; }
.kn-kicker { display: inline-flex; align-items: center; gap: 6px; border-radius: 999px; padding: 7px 10px; margin: 0 0 12px; background: #d9fff8; color: #08796a !important; font-size: 12px; font-weight: 900; letter-spacing: .02em; }
.kn-team-layout { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(280px, .7fr); gap: 22px; align-items: start; }
.kn-team-media { overflow: hidden; border-radius: 34px; background: linear-gradient(135deg, var(--kn-navy), #155f59); box-shadow: var(--kn-shadow); margin-bottom: 22px; }
.kn-team-media img { width: 100%; height: min(520px, 56vw); object-fit: cover; display: block; }
.kn-team-panel { background: #fff; border: 1px solid var(--kn-border); border-radius: 28px; padding: 24px; box-shadow: var(--kn-shadow); margin-bottom: 18px; }
.kn-team-panel h2, .kn-team-panel h3 { color: var(--kn-navy); margin-top: 0; }
.kn-meta-list { display: grid; gap: 12px; }
.kn-meta-row { border-top: 1px solid var(--kn-border); padding-top: 12px; }
.kn-meta-row:first-child { border-top: 0; padding-top: 0; }
.kn-meta-row strong { display: block; color: var(--kn-navy); margin-bottom: 3px; }
.kn-meta-row span, .kn-meta-row a { color: var(--kn-muted); }
.kn-roster-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; }
.kn-player-mini { background: #f8fbfa; border: 1px solid var(--kn-border); border-radius: 22px; overflow: hidden; }
.kn-player-mini img { width: 100%; height: 190px; object-fit: cover; display: block; }
.kn-player-mini-placeholder { height: 190px; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #d9fff8, #fff); color: var(--kn-navy); font-size: 46px; font-weight: 950; }
.kn-player-mini-body { padding: 16px; }
.kn-player-mini h3 { margin: 6px 0 2px; font-size: 18px; }
.kn-player-mini h3 a { color: var(--kn-navy); text-decoration: none; }
.kn-player-mini p { margin: 0; color: var(--kn-muted); }
.kn-player-number { color: var(--kn-mint); font-size: 26px; line-height: 1; font-weight: 950; }
.kn-player-single-grid { display: grid; grid-template-columns: 360px minmax(0,1fr); gap: 22px; align-items: start; }
.kn-player-photo { overflow: hidden; border-radius: 30px; background: #fff; box-shadow: var(--kn-shadow); }
.kn-player-photo img { width: 100%; display: block; }

.kn-site-footer { background: #07111f; color: rgba(255,255,255,.76); padding: 52px 0; }
.kn-footer-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 34px; align-items: start; }
.kn-footer-brand .kn-logo img { width: 230px; margin-bottom: 12px; }
.kn-site-footer h2, .kn-site-footer h3 { color: #fff; margin-top: 0; }
.kn-site-footer a { color: rgba(255,255,255,.82); text-decoration: none; }
.kn-site-footer a:hover { color: var(--kn-mint); }
.kn-footer-muted { color: var(--kn-mint); font-weight: 900; }
.kn-footer-info { text-align: right; }
.kn-footer-links ul { list-style: none; margin: 18px 0 0; padding: 0; display: flex; justify-content: flex-end; gap: 12px; flex-wrap: wrap; }

@media (max-width: 1020px) {
  .kn-club-feature-grid, .kn-player-strip, .kn-demo-player-strip, .kn-sponsor-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .kn-news-layout, .kn-club-hero-inner, .kn-team-layout { grid-template-columns: 1fr; }
  .kn-next-match-card, .kn-fixture-row { grid-template-columns: 1fr; }
  .kn-next-match-actions { justify-content: flex-start; }
}
@media (max-width: 900px) {
  .admin-bar .kn-site-header { top: 46px; }
  .kn-topbar-inner { flex-direction: column; align-items: flex-start; padding: 8px 0; }
  .kn-header-inner { align-items: flex-start; flex-direction: column; padding: 14px 0; }
  .kn-nav { width: 100%; justify-content: space-between; flex-wrap: wrap; }
  .kn-nav ul { justify-content: flex-start; }
  .kn-section-title { display: block; }
  .kn-team-grid, .kn-player-grid, .kn-roster-grid, .kn-news-grid, .kn-footer-grid, .kn-player-single-grid { grid-template-columns: 1fr; }
  .kn-footer-info { text-align: left; }
  .kn-footer-links ul { justify-content: flex-start; }
}
@media (max-width: 620px) {
  .kn-container { width: min(100% - 24px, 1180px); }
  .kn-club-hero { min-height: 560px; }
  .kn-club-feature-grid, .kn-player-strip, .kn-demo-player-strip, .kn-sponsor-grid { grid-template-columns: 1fr; }
  .kn-club-hero h1 { font-size: 44px; }
  .kn-next-match-card h2 { font-size: 28px; }
}

/* Klubbnet v0.1.6 – club-site demo polish */
.kn-club-logo-mark { display: inline-flex; align-items: center; gap: 12px; color: var(--kn-navy); text-decoration: none; }
.kn-club-crest { width: 46px; height: 46px; border-radius: 14px; display: inline-flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--kn-navy), #07111f); color: #fff; font-weight: 950; letter-spacing: -.06em; box-shadow: 0 12px 30px rgba(7,17,31,.18); }
.kn-club-logo-text { display: grid; gap: 2px; line-height: 1; }
.kn-club-logo-text strong { font-size: 19px; letter-spacing: -.04em; }
.kn-club-logo-text em { font-style: normal; font-size: 10px; text-transform: uppercase; letter-spacing: .10em; color: var(--kn-muted); font-weight: 900; }
.kn-site-footer .kn-club-logo-mark { color: #fff; }
.kn-site-footer .kn-club-logo-text em { color: rgba(255,255,255,.55); }
.kn-powered-logo img { width: 150px; display: inline-block; margin-top: 12px; opacity: .9; }

.kn-club-home-v16 { background: #f3f6f5; }
.kn-sports-hero { min-height: 640px; padding: 112px 0 100px; background-position: center; background-size: cover; position: relative; overflow: hidden; }
.kn-sports-hero:before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 68% 26%, rgba(75,217,193,.20), transparent 28%), linear-gradient(180deg, rgba(7,17,31,.12), rgba(7,17,31,.76)); pointer-events: none; }
.kn-sports-hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.15fr) 410px; gap: 48px; align-items: center; }
.kn-sports-hero-copy { color: #fff; max-width: 720px; }
.kn-sports-hero-copy .kn-eyebrow { background: rgba(255,255,255,.13); color: #fff; border: 1px solid rgba(255,255,255,.18); backdrop-filter: blur(8px); }
.kn-sports-hero-copy h1 { margin: 18px 0 18px; max-width: 800px; color: #fff; font-size: clamp(54px, 7vw, 98px); line-height: .86; letter-spacing: -.08em; text-transform: none; }
.kn-sports-hero-copy p { max-width: 620px; margin: 0 0 28px; color: rgba(255,255,255,.82); font-size: 20px; line-height: 1.7; }
.kn-hero-scoreboard { padding: 26px; border-radius: 28px; background: rgba(8,18,32,.74); border: 1px solid rgba(255,255,255,.14); color: #fff; box-shadow: 0 40px 90px rgba(0,0,0,.36); backdrop-filter: blur(15px); }
.kn-hero-scoreboard h2 { margin: 10px 0 16px; color: #fff; font-size: 34px; letter-spacing: -.05em; }
.kn-hero-scoreboard p { color: rgba(255,255,255,.70); margin-bottom: 0; }
.kn-scoreboard-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin: 22px 0; }
.kn-scoreboard-stats div { border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.07); border-radius: 18px; padding: 15px; }
.kn-scoreboard-stats strong { display: block; color: var(--kn-mint); font-size: 24px; line-height: 1; }
.kn-scoreboard-stats span { display: block; margin-top: 6px; color: rgba(255,255,255,.66); font-size: 12px; font-weight: 800; }

.kn-matchday-strip { margin: -48px 0 36px; position: relative; z-index: 3; }
.kn-matchday-card { display: grid; grid-template-columns: 1fr minmax(270px, .8fr) 1fr auto; gap: 20px; align-items: center; padding: 24px; background: #fff; border: 1px solid rgba(16,32,51,.10); border-radius: 30px; box-shadow: 0 28px 80px rgba(16,32,51,.17); }
.kn-team-badge { display: flex; align-items: center; gap: 14px; min-width: 0; }
.kn-team-badge span { width: 54px; height: 54px; border-radius: 17px; display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; background: var(--kn-navy); color: #fff; font-size: 18px; font-weight: 950; letter-spacing: -.07em; text-transform: uppercase; }
.kn-team-badge-away span { background: #e7eeec; color: var(--kn-navy); }
.kn-team-badge strong { font-size: 24px; color: var(--kn-navy); line-height: 1.06; }
.kn-matchday-center { text-align: center; }
.kn-matchday-center small { display: block; color: var(--kn-mint); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; font-weight: 950; }
.kn-matchday-center b { display: block; margin: 4px 0 3px; font-size: 32px; color: var(--kn-navy); letter-spacing: -.06em; }
.kn-matchday-center p { margin: 0; color: var(--kn-muted); font-weight: 750; }
.kn-matchday-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }

.kn-news-match-grid { display: grid; grid-template-columns: minmax(0, 1.45fr) 360px; gap: 34px; align-items: start; }
.kn-tight-title { margin-bottom: 20px; }
.kn-modern-news-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 18px; }
.kn-modern-news-card { overflow: hidden; border-radius: 26px; background: #fff; border: 1px solid rgba(16,32,51,.10); box-shadow: 0 18px 48px rgba(16,32,51,.09); }
.kn-news-image { display: block; min-height: 172px; background: #dce9e7; overflow: hidden; }
.kn-news-image img { width: 100%; height: 190px; object-fit: cover; display: block; transition: transform .24s ease; }
.kn-modern-news-card:hover .kn-news-image img { transform: scale(1.04); }
.kn-modern-news-card div { padding: 18px; }
.kn-modern-news-card time { display: block; margin-bottom: 10px; color: #118575; font-size: 11px; font-weight: 950; text-transform: uppercase; letter-spacing: .06em; }
.kn-modern-news-card h3 { margin: 0 0 9px; color: var(--kn-navy); font-size: 21px; line-height: 1.08; letter-spacing: -.04em; }
.kn-modern-news-card h3 a { color: inherit; text-decoration: none; }
.kn-modern-news-card p { margin: 0; color: var(--kn-muted); line-height: 1.55; }
.kn-club-sidebar { display: grid; gap: 18px; }
.kn-standing-card, .kn-banner-card { min-height: 260px; }
.kn-banner-card { color: #fff; background-size: cover; background-position: center; }
.kn-banner-card h3 { color: #fff; }
.kn-banner-card p { color: rgba(255,255,255,.78); }
.kn-table-modern div { display: grid; grid-template-columns: 28px 1fr auto; gap: 8px; align-items: center; }

.kn-team-showcase-section { padding-top: 34px; }
.kn-team-showcase-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 20px; }
.kn-team-showcase-card { overflow: hidden; position: relative; min-height: 320px; border-radius: 30px; background: var(--kn-navy); box-shadow: 0 26px 65px rgba(16,32,51,.12); }
.kn-team-showcase-img { position: absolute; inset: 0; display: block; }
.kn-team-showcase-img:after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(7,17,31,.05), rgba(7,17,31,.82)); }
.kn-team-showcase-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.kn-team-showcase-card > div { position: absolute; left: 24px; right: 24px; bottom: 22px; color: #fff; }
.kn-team-showcase-card span { display: inline-flex; margin-bottom: 8px; padding: 6px 9px; border-radius: 999px; background: rgba(75,217,193,.16); color: var(--kn-mint); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; font-weight: 950; }
.kn-team-showcase-card h3 { margin: 0; color: #fff; font-size: 32px; letter-spacing: -.06em; }
.kn-team-showcase-card h3 a { color: #fff; text-decoration: none; }

.kn-player-feature-section { background-image: radial-gradient(circle at 80% 0, rgba(75,217,193,.16), transparent 25%), linear-gradient(180deg, #07111f, #0d2034); }
.kn-player-strip-real { grid-template-columns: repeat(4, minmax(0,1fr)); }
.kn-player-strip-real .kn-player-tile { overflow: hidden; padding: 0; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); }
.kn-player-strip-real .kn-player-tile > a, .kn-player-strip-real .kn-player-tile > img { display: block; height: 300px; width: 100%; background: #13253a; }
.kn-player-strip-real .kn-player-tile img { width: 100%; height: 300px; object-fit: cover; display: block; }
.kn-player-strip-real .kn-player-tile div { padding: 18px; background: rgba(7,17,31,.58); }
.kn-player-strip-real .kn-player-tile strong { display: block; color: var(--kn-mint); font-size: 38px; line-height: .92; }
.kn-player-strip-real .kn-player-tile h3 { margin: 6px 0 3px; color: #fff; font-size: 20px; }
.kn-player-strip-real .kn-player-tile h3 a { color: #fff; text-decoration: none; }
.kn-player-strip-real .kn-player-tile p { margin: 0; color: rgba(255,255,255,.64); }

.kn-fixture-list-modern { display: grid; gap: 12px; }
.kn-fixture-list-modern .kn-fixture-row { border-radius: 22px; box-shadow: none; border: 1px solid rgba(16,32,51,.10); }
.kn-sponsor-band-modern { background: #fff; }
.kn-sponsor-band-modern .kn-sponsor-grid div { background: #f5f8f7; border: 1px solid rgba(16,32,51,.12); color: rgba(16,32,51,.64); font-size: 13px; letter-spacing: .12em; font-weight: 950; }
.kn-demo-content { outline: 0; }

@media (max-width: 1080px) {
  .kn-sports-hero-grid, .kn-news-match-grid { grid-template-columns: 1fr; }
  .kn-matchday-card { grid-template-columns: 1fr; text-align: left; }
  .kn-matchday-center { text-align: left; }
  .kn-matchday-actions { justify-content: flex-start; }
  .kn-modern-news-grid, .kn-team-showcase-grid, .kn-player-strip-real { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 680px) {
  .kn-sports-hero { min-height: 620px; padding-top: 84px; }
  .kn-sports-hero-copy h1 { font-size: 50px; }
  .kn-modern-news-grid, .kn-team-showcase-grid, .kn-player-strip-real, .kn-scoreboard-stats { grid-template-columns: 1fr; }
  .kn-team-badge strong { font-size: 20px; }
}
