/* ============================================================
   ARDROSSAN WINTON ROVERS F.C. — Site stylesheet
   Black & white hoops · red trim · founded 1900
   Design tokens map directly onto Elementor Global Colours/Fonts.
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Barlow:ital,wght@0,400;0,500;0,600;0,700;1,500&display=swap');

/* ---- Design tokens ---- */
:root{
  /* Brand */
  --black:#141414;
  --ink:#0d0d0d;          /* deepest black */
  --panel:#1c1c1c;        /* card surface on dark */
  --panel-2:#232323;      /* raised surface */
  --line:#2e2e2e;         /* hairline borders on dark */
  --red:#C62828;
  --red-bright:#E03131;
  --white:#ffffff;
  --off-white:#E8E8E8;
  --muted:#9a9a9a;        /* muted text on dark */
  --muted-2:#6f6f6f;

  /* Light surfaces */
  --paper:#f4f4f3;
  --paper-line:#e3e3e1;
  --paper-ink:#1a1a1a;
  --paper-muted:#5e5e5e;

  /* Type */
  --display:'Oswald',sans-serif;
  --body:'Barlow',sans-serif;

  /* Metrics */
  --wrap:1200px;
  --wrap-wide:1320px;
  --radius:14px;
  --radius-sm:9px;
  --gap:24px;
  --header-h:74px;
  --shadow:0 18px 44px rgba(0,0,0,.34);
  --shadow-sm:0 6px 18px rgba(0,0,0,.22);
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  font-size:17px;
  line-height:1.65;
  color:var(--off-white);
  background:var(--black);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.04;margin:0;letter-spacing:.01em}
h1{font-size:clamp(2.6rem,6vw,5rem);text-transform:uppercase}
h2{font-size:clamp(2rem,3.6vw,3.1rem);text-transform:uppercase}
h3{font-size:1.5rem}
p{margin:0 0 1.1em}
p:last-child{margin-bottom:0}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:24px}
.wrap-wide{max-width:var(--wrap-wide);margin-inline:auto;padding-inline:24px}
.section{padding:84px 0}
.section--tight{padding:56px 0}
.section--light{background:var(--paper);color:var(--paper-ink)}
.section--ink{background:var(--ink)}
.center{text-align:center}
.stack-lg{display:flex;flex-direction:column;gap:48px}

/* ---- Hoops motif: thin black/white band with red edge ---- */
.hoops{
  height:14px;
  background:repeating-linear-gradient(90deg,#161616 0 26px,#fff 26px 52px);
  border-top:3px solid var(--red);
  border-bottom:3px solid var(--red);
}
.hoops--thin{height:10px;background:repeating-linear-gradient(90deg,#161616 0 18px,#f0f0f0 18px 36px)}

/* ---- Eyebrow / section heading ---- */
.eyebrow{
  font-family:var(--display);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.82rem;
  font-weight:600;
  color:var(--red-bright);
  display:inline-flex;align-items:center;gap:10px;
  margin:0 0 14px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red)}
.section--light .eyebrow{color:var(--red)}
.sec-head{margin-bottom:38px}
.sec-head .lead{color:var(--muted);max-width:54ch;margin-top:10px}
.section--light .sec-head .lead{color:var(--paper-muted)}
.sec-head--row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}

/* ---- Buttons ---- */
.btn{
  --bg:var(--red);--fg:#fff;
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--display);font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;font-size:.95rem;
  padding:14px 26px;border-radius:8px;border:2px solid transparent;
  background:var(--bg);color:var(--fg);cursor:pointer;
  transition:transform .15s ease,background .15s ease,border-color .15s ease,color .15s ease;
  line-height:1;
}
.btn:hover{transform:translateY(-2px);background:var(--red-bright)}
.btn .arr{transition:transform .15s ease}
.btn:hover .arr{transform:translateX(3px)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.32)}
.btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn--dark{background:var(--ink);color:#fff}
.btn--dark:hover{background:#000}
.section--light .btn--ghost{color:var(--paper-ink);border-color:rgba(0,0,0,.22)}
.section--light .btn--ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn--sm{padding:10px 18px;font-size:.82rem}

.textlink{
  font-family:var(--display);font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;font-size:.9rem;color:#fff;
  display:inline-flex;align-items:center;gap:8px;
}
.textlink .arr{color:var(--red-bright);transition:transform .15s}
.textlink:hover .arr{transform:translateX(4px)}
.section--light .textlink{color:var(--paper-ink)}

/* ============================================================
   HEADER
   ============================================================ */
.topbar{background:var(--ink);color:var(--muted);font-size:.8rem;border-bottom:1px solid var(--line)}
.topbar .wrap-wide{display:flex;align-items:center;justify-content:space-between;height:38px;gap:18px}
.topbar a{color:var(--muted);transition:color .15s}
.topbar a:hover{color:#fff}
.topbar__meta{display:flex;align-items:center;gap:18px;font-family:var(--display);letter-spacing:.04em;text-transform:uppercase;font-size:.76rem;white-space:nowrap}
.topbar__meta .dot{color:var(--red-bright)}
.topbar__social{display:flex;align-items:center;gap:14px}
.topbar__social svg{width:16px;height:16px;fill:currentColor;display:block}

.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(16,16,16,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:20px}
.brand{display:flex;align-items:center;gap:13px;flex-shrink:0}
.brand img{height:50px;width:auto}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:1.04rem;letter-spacing:.02em;color:#fff}
.brand__sub{font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--red-bright);font-weight:600;font-family:var(--display);margin-top:3px}

.mainnav{display:flex;align-items:center;gap:4px}
.mainnav a{
  font-family:var(--display);font-weight:500;text-transform:uppercase;
  letter-spacing:.05em;font-size:.92rem;color:#d6d6d6;
  padding:10px 13px;border-radius:7px;position:relative;transition:color .15s,background .15s;
}
.mainnav a:hover{color:#fff;background:rgba(255,255,255,.06)}
.mainnav a.is-active{color:#fff}
.mainnav a.is-active::after{content:"";position:absolute;left:13px;right:13px;bottom:3px;height:2px;background:var(--red)}
.header-cta{display:flex;align-items:center;gap:12px}

.navtoggle{display:none;background:none;border:0;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.navtoggle span{width:26px;height:2px;background:#fff;display:block;transition:.2s}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:min(86vh,760px);display:flex;align-items:flex-end;overflow:hidden;background:#000}
.hero__bg{position:absolute;inset:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;opacity:.62}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(10,10,10,.5) 0%,rgba(10,10,10,.12) 32%,rgba(10,10,10,.78) 82%,rgba(10,10,10,.97) 100%),
    linear-gradient(90deg,rgba(10,10,10,.7),rgba(10,10,10,0) 60%);
}
.hero__inner{position:relative;z-index:2;width:100%;padding-bottom:64px;padding-top:90px}
.hero__crest{width:84px;height:84px;margin-bottom:22px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.5))}
.hero h1{color:#fff;max-width:16ch;text-shadow:0 4px 30px rgba(0,0,0,.5)}
.hero h1 .hl{color:var(--red-bright)}
.hero__sub{font-size:1.2rem;color:#e7e7e7;max-width:46ch;margin-top:18px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero__est{
  position:absolute;right:28px;top:120px;z-index:2;
  writing-mode:vertical-rl;font-family:var(--display);font-weight:600;
  letter-spacing:.4em;text-transform:uppercase;font-size:.8rem;color:rgba(255,255,255,.5);
}

/* ============================================================
   NEXT MATCH / MATCH STRIP
   ============================================================ */
.matchstrip{background:var(--red);color:#fff}
.matchstrip .wrap-wide{display:flex;align-items:center;gap:30px;flex-wrap:wrap;padding-block:18px;justify-content:space-between}
.matchstrip__tag{font-family:var(--display);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:600;opacity:.85}
.matchstrip__teams{display:flex;align-items:center;gap:16px;font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:1.15rem}
.matchstrip__teams .vs{opacity:.7;font-size:.85rem}
.matchstrip__meta{display:flex;align-items:center;gap:22px;font-size:.9rem;font-weight:500}
.matchstrip__meta .i{display:flex;align-items:center;gap:7px}
.matchstrip__meta svg{width:15px;height:15px;fill:currentColor;opacity:.85}

/* ============================================================
   CARDS — News
   ============================================================ */
.grid{display:grid;gap:var(--gap)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

.ncard{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .18s ease,border-color .18s ease;
}
.ncard:hover{transform:translateY(-4px);border-color:#3d3d3d}
.ncard__media{aspect-ratio:16/10;overflow:hidden;position:relative}
.ncard__media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.ncard:hover .ncard__media img{transform:scale(1.05)}
.ncard__tag{
  position:absolute;left:14px;top:14px;background:var(--red);color:#fff;
  font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;
  font-size:.7rem;font-weight:600;padding:5px 11px;border-radius:5px;
}
.ncard__body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.ncard__date{font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:var(--muted)}
.ncard__title{font-family:var(--display);font-weight:600;font-size:1.3rem;line-height:1.12;color:#fff}
.ncard:hover .ncard__title{color:var(--off-white)}
.ncard__excerpt{color:var(--muted);font-size:.96rem}
.ncard__more{margin-top:auto;padding-top:8px;font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:.8rem;letter-spacing:.06em;color:var(--red-bright);display:inline-flex;gap:7px;align-items:center}
.section--light .ncard{background:#fff;border-color:var(--paper-line);box-shadow:var(--shadow-sm)}
.section--light .ncard__title{color:var(--paper-ink)}
.section--light .ncard__excerpt,.section--light .ncard__date{color:var(--paper-muted)}

/* Featured news (large + list) */
.news-feature{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--gap);align-items:stretch}
.news-feature .ncard--big .ncard__media{aspect-ratio:16/9}
.news-feature .ncard--big .ncard__title{font-size:2rem}
.news-list{display:flex;flex-direction:column;gap:14px}
.news-row{display:grid;grid-template-columns:104px 1fr;gap:15px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .15s,transform .15s}
.news-row:hover{border-color:#3d3d3d;transform:translateX(3px)}
.news-row__media{overflow:hidden}
.news-row__media img{width:100%;height:100%;object-fit:cover}
.news-row__body{padding:12px 14px 12px 0;display:flex;flex-direction:column;justify-content:center;gap:5px}
.news-row__date{font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;color:var(--muted)}
.news-row__title{font-family:var(--display);font-weight:600;font-size:1.05rem;line-height:1.14;color:#fff}

/* ============================================================
   TABLE + FIXTURES grid (home)
   ============================================================ */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);align-items:start}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.panel__head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line);background:var(--panel-2)}
.panel__head h3{font-family:var(--display);text-transform:uppercase;font-size:1.15rem;letter-spacing:.04em;color:#fff;display:flex;align-items:center;gap:10px}
.panel__head h3 .pip{width:8px;height:18px;background:var(--red);border-radius:2px;display:inline-block}
.panel__body{padding:8px 0}
.panel__foot{padding:16px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end}

/* Static styled league table */
.ltable{width:100%;border-collapse:collapse;font-size:.95rem}
.ltable th{
  font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;
  font-size:.72rem;color:var(--muted);font-weight:600;text-align:center;
  padding:8px 6px;border-bottom:1px solid var(--line);
}
.ltable th.team-col,.ltable td.team-col{text-align:left;padding-left:22px}
.ltable td{padding:11px 6px;text-align:center;border-bottom:1px solid rgba(255,255,255,.05);color:#d8d8d8}
.ltable td.pos{color:var(--muted);font-family:var(--display)}
.ltable td.team-col{font-weight:600;color:#fff}
.ltable td.pts{font-family:var(--display);font-weight:700;color:#fff;font-size:1.05rem}
.ltable tr:last-child td{border-bottom:0}
.ltable tr.is-us{background:rgba(198,40,40,.16)}
.ltable tr.is-us td.pos{color:var(--red-bright)}
.ltable tr.is-us td.team-col{position:relative}
.ltable tr.is-us td.team-col::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:4px;background:var(--red);border-radius:0 3px 3px 0}
.ltable .promo{box-shadow:inset 3px 0 0 #2e7d32}

/* Fixture / result rows */
.fix{display:flex;align-items:center;gap:14px;padding:13px 22px;border-bottom:1px solid rgba(255,255,255,.05)}
.fix:last-child{border-bottom:0}
.fix__date{width:48px;flex-shrink:0;text-align:center;font-family:var(--display);line-height:1}
.fix__date .d{font-size:1.35rem;font-weight:700;color:#fff}
.fix__date .m{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.fix__main{flex:1;min-width:0}
.fix__teams{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:1rem;color:#fff;letter-spacing:.01em}
.fix__teams .opp{color:#d0d0d0}
.fix__sub{font-size:.78rem;color:var(--muted);margin-top:2px;display:flex;gap:10px;flex-wrap:wrap}
.fix__comp{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.fix__score{
  font-family:var(--display);font-weight:700;font-size:1.05rem;flex-shrink:0;
  background:var(--ink);border:1px solid var(--line);border-radius:7px;padding:6px 12px;min-width:54px;text-align:center;color:#fff;
}
.fix__score.win{border-color:#2e7d32;color:#7bd982}
.fix__score.loss{border-color:#7d2e2e;color:#e08585}
.fix__score.draw{color:var(--muted)}
.fix__tag{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;font-family:var(--display);font-weight:600;color:#fff;background:var(--red);padding:4px 9px;border-radius:5px;flex-shrink:0}
.fix--home .fix__ha{color:var(--red-bright)}

/* LeagueRepublic embed shell — light card keeps the widget's
   default dark-on-light output perfectly legible. */
.lr-card{background:#fff;border-radius:var(--radius);padding:22px 24px;color:#1a1a1a;box-shadow:var(--shadow);min-height:120px;overflow-x:auto}
.lr-card [id^="lrep"]{color:#555;font-size:.95rem;min-height:40px;font-family:var(--body)}
.lr-card table{width:100%}
.lr-note{
  display:flex;gap:12px;align-items:flex-start;margin-top:18px;padding:14px 16px;
  background:rgba(198,40,40,.10);border:1px solid rgba(198,40,40,.3);border-radius:10px;
  font-size:.86rem;color:var(--off-white);
}
.lr-note svg{width:18px;height:18px;fill:var(--red-bright);flex-shrink:0;margin-top:2px}
.lr-note b{color:#fff}
.livebadge{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;font-weight:600;color:#fff;background:var(--red);padding:5px 11px;border-radius:20px}
.livebadge .pulse{width:8px;height:8px;border-radius:50%;background:#fff;animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ============================================================
   SPLIT / ABOUT
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split__media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.split__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.split__media .badge-est{
  position:absolute;left:18px;bottom:18px;background:var(--ink);border:1px solid var(--line);
  padding:10px 16px;border-radius:9px;font-family:var(--display);text-transform:uppercase;
  letter-spacing:.1em;font-size:.82rem;color:#fff;display:flex;gap:9px;align-items:center;
}
.split__media .badge-est b{color:var(--red-bright)}

.statrow{display:flex;gap:34px;flex-wrap:wrap;margin-top:28px}
.stat{display:flex;flex-direction:column}
.stat__n{font-family:var(--display);font-weight:700;font-size:2.6rem;color:#fff;line-height:1}
.section--light .stat__n{color:var(--paper-ink)}
.stat__l{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-top:6px;font-family:var(--display)}
.section--light .stat__l{color:var(--paper-muted)}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery a{position:relative;overflow:hidden;border-radius:10px;display:block;background:#000}
.gallery img{width:100%;height:100%;object-fit:cover;aspect-ratio:1;transition:transform .4s ease,opacity .2s}
.gallery a:hover img{transform:scale(1.07);opacity:.85}
.gallery .tall{grid-row:span 2;aspect-ratio:auto}
.gallery .tall img{aspect-ratio:1/2}
.gallery .wide{grid-column:span 2}
.gallery .wide img{aspect-ratio:2/1}

/* ============================================================
   SQUAD
   ============================================================ */
.pos-group{margin-bottom:54px}
.pos-group__title{font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-size:1.5rem;color:#fff;display:flex;align-items:center;gap:12px;margin-bottom:22px}
.pos-group__title .pip{width:10px;height:24px;background:var(--red);border-radius:2px}
.players{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .18s,border-color .18s}
.pcard:hover{transform:translateY(-4px);border-color:#3d3d3d}
.pcard__media{aspect-ratio:3/4;position:relative;overflow:hidden;background:linear-gradient(160deg,#262626,#161616)}
.pcard__media img{width:100%;height:100%;object-fit:cover;object-position:top center}
.pcard__no{position:absolute;right:12px;top:8px;font-family:var(--display);font-weight:700;font-size:2.6rem;color:rgba(255,255,255,.16);line-height:1}
.pcard__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(13,13,13,.92))}
.pcard__name{position:absolute;left:14px;bottom:12px;z-index:2}
.pcard__name .n{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:1.12rem;color:#fff;line-height:1}
.pcard__name .p{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--red-bright);margin-top:4px;font-family:var(--display)}
.pcard--empty .pcard__media{display:flex;align-items:center;justify-content:center}
.pcard--empty .silhouette{width:60%;opacity:.12}

/* ============================================================
   SPONSORS
   ============================================================ */
.sponsor-tier{margin-bottom:46px}
.sponsor-tier__label{text-align:center;font-family:var(--display);text-transform:uppercase;letter-spacing:.2em;font-size:.82rem;color:var(--muted);margin-bottom:22px}
.sponsors{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.sponsor{
  background:#fff;border-radius:12px;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;
  padding:24px;text-align:center;transition:transform .18s;
}
.sponsor:hover{transform:translateY(-4px)}
.sponsor__name{font-family:var(--display);font-weight:700;text-transform:uppercase;color:#1a1a1a;font-size:1.25rem;letter-spacing:.02em;line-height:1.1}
.sponsor__name span{display:block;font-size:.66rem;letter-spacing:.14em;color:#888;margin-top:6px;font-weight:500}
.sponsors--lead{grid-template-columns:repeat(2,1fr)}
.sponsors--lead .sponsor{aspect-ratio:21/9}
.sponsors--lead .sponsor__name{font-size:1.8rem}

/* ============================================================
   PAGE HEADER (inner pages)
   ============================================================ */
.pagehead{position:relative;background:var(--ink);overflow:hidden;border-bottom:1px solid var(--line)}
.pagehead__bg{position:absolute;inset:0}
.pagehead__bg img{width:100%;height:100%;object-fit:cover;opacity:.28}
.pagehead__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,13,13,.55),rgba(13,13,13,.92))}
.pagehead__inner{position:relative;z-index:2;padding:64px 0 50px}
.pagehead h1{color:#fff;font-size:clamp(2.4rem,5vw,3.8rem)}
.crumbs{font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--muted);margin-bottom:16px;display:flex;gap:9px;align-items:center}
.crumbs a:hover{color:#fff}
.crumbs .sep{color:var(--red-bright)}

/* ============================================================
   SHOP
   ============================================================ */
.products{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.product{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .18s,border-color .18s}
.product:hover{transform:translateY(-4px);border-color:#3d3d3d}
.product__media{aspect-ratio:1;position:relative;overflow:hidden;background:linear-gradient(160deg,#242424,#141414);display:flex;align-items:center;justify-content:center}
.product__media img{width:100%;height:100%;object-fit:cover}
.product__flag{position:absolute;left:12px;top:12px;background:var(--red);color:#fff;font-family:var(--display);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;padding:5px 10px;border-radius:5px}
.product__body{padding:18px 20px;display:flex;flex-direction:column;gap:8px}
.product__name{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:1.15rem;color:#fff}
.product__price{font-family:var(--display);font-weight:700;font-size:1.3rem;color:var(--red-bright)}
.product__body .btn{margin-top:6px;justify-content:center}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.infocard{display:flex;gap:16px;padding:22px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:16px}
.infocard__ico{width:46px;height:46px;border-radius:10px;background:rgba(198,40,40,.14);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.infocard__ico svg{width:22px;height:22px;fill:var(--red-bright)}
.infocard h4{font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;color:#fff;font-size:1.05rem;margin-bottom:4px}
.infocard p{color:var(--muted);font-size:.95rem;margin:0}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;color:var(--muted);margin-bottom:7px}
.field input,.field textarea{
  width:100%;background:var(--ink);border:1px solid var(--line);border-radius:9px;
  padding:13px 15px;color:#fff;font-family:var(--body);font-size:1rem;transition:border-color .15s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--red)}
.field textarea{min-height:140px;resize:vertical}

.mapwrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/10;margin-top:24px}
.mapwrap iframe{width:100%;height:100%;border:0;filter:grayscale(.3) invert(.9) hue-rotate(180deg) contrast(.9)}

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{position:relative;overflow:hidden;background:var(--ink)}
.cta-band__bg{position:absolute;inset:0}
.cta-band__bg img{width:100%;height:100%;object-fit:cover;opacity:.22}
.cta-band__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(13,13,13,.96),rgba(13,13,13,.6))}
.cta-band__inner{position:relative;z-index:2;padding:72px 0;max-width:60ch}
.cta-band h2{color:#fff}
.cta-band p{color:var(--off-white);font-size:1.15rem;margin-top:12px}
.cta-band .hero__cta{margin-top:26px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);border-top:3px solid var(--red);color:var(--muted);font-size:.92rem}
.footer-top{padding:56px 0 40px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
.footer-brand{display:flex;flex-direction:column;gap:16px;max-width:34ch}
.footer-brand .brand img{height:64px}
.footer-brand p{color:var(--muted);font-size:.92rem}
.fcol h5{font-family:var(--display);text-transform:uppercase;letter-spacing:.08em;font-size:.92rem;color:#fff;margin:0 0 16px}
.fcol ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.fcol a{color:var(--muted);transition:color .15s}
.fcol a:hover{color:#fff}
.fcol .fmeta{display:flex;gap:10px;align-items:flex-start;color:var(--muted)}
.fcol .fmeta svg{width:16px;height:16px;fill:var(--red-bright);flex-shrink:0;margin-top:3px}
.footer-social{display:flex;gap:12px;margin-top:6px}
.footer-social a{width:40px;height:40px;border-radius:9px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;transition:.15s}
.footer-social a:hover{background:var(--red);border-color:var(--red);color:#fff}
.footer-social svg{width:18px;height:18px;fill:currentColor}
.footer-bottom{border-top:1px solid var(--line);padding:20px 0;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.82rem}
.footer-bottom a:hover{color:#fff}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:960px){
  .grid-3,.grid-4,.players,.gallery,.sponsors,.products{grid-template-columns:repeat(2,1fr)}
  .duo,.split,.news-feature,.contact-grid{grid-template-columns:1fr}
  .split{gap:32px}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:1/-1}
  .sponsors--lead{grid-template-columns:1fr}
  .hero__est{display:none}
}
@media (max-width:1024px){
  body{font-size:16px}
  .section{padding:60px 0}
  .mainnav,.header-cta .btn{display:none}
  .navtoggle{display:flex}
  .site-header.nav-open .mainnav{
    display:flex;position:absolute;top:var(--header-h);left:0;right:0;
    flex-direction:column;background:var(--ink);border-bottom:1px solid var(--line);
    padding:14px;gap:4px;align-items:stretch;
  }
  .site-header.nav-open .mainnav a{padding:13px 14px}
  .topbar__meta .hide-sm{display:none}
  .matchstrip .wrap-wide{justify-content:flex-start;gap:16px}
  .sec-head--row{align-items:flex-start}
}
@media (max-width:520px){
  .grid-3,.grid-4,.players,.sponsors,.products{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .news-row{grid-template-columns:84px 1fr}
  .statrow{gap:22px}
}


/* ===== MOBILE FIXES ===== */
@media (max-width: 768px) {
  .hero { min-height: 70vh; }
  .hero__bg img { min-height: 70vh; }
  .hero h1 { font-size: clamp(1.6rem, 6vw, 2.8rem); }
  .hero__sub { font-size: 0.85rem; letter-spacing: 0.08em; }
  .hero__crest { width: 70px; }
  .hero__cta { flex-direction: column; gap: 10px; }
  .hero__cta .btn { width: 100%; text-align: center; }
  
  .brand__name { font-size: 1rem !important; }
  .brand__sub { font-size: 0.65rem !important; }
  .brand img { width: 40px !important; height: 40px !important; }
  
  .site-header__inner { padding: 10px 16px; }
  .mainnav { display: none; }
  .nav-open .mainnav { 
    display: flex; flex-direction: column; 
    position: absolute; top: 100%; left: 0; right: 0; 
    background: #0d0d0d; padding: 10px 0; z-index: 100;
    border-top: 2px solid #C62828;
  }
  .nav-open .mainnav a { padding: 12px 20px; border-bottom: 1px solid #1c1c1c; }
  .header-cta { display: none; }
  .navtoggle { display: flex !important; }
  
  .topbar { font-size: 0.7rem; padding: 6px 10px; }
  .topbar__meta .hide-sm { display: none; }
  
  .matchstrip__teams { font-size: 1.1rem; flex-wrap: wrap; justify-content: center; }
  .matchstrip__meta { flex-wrap: wrap; justify-content: center; gap: 10px; }
  
  .duo { grid-template-columns: 1fr !important; }
  .panel__body { max-height: 350px; }
  
  .news-feature { grid-template-columns: 1fr !important; }
  .ncard--big { grid-column: auto; }
  .news-list { grid-template-columns: 1fr; }
  .news-row__media { width: 80px; min-height: 60px; }
  
  .split { grid-template-columns: 1fr !important; }
  .gallery { grid-template-columns: repeat(2, 1fr) !important; }
  .gallery .wide { grid-column: auto; }
  
  .footer-top { grid-template-columns: 1fr !important; gap: 30px; }
  .footer-bottom { flex-direction: column; text-align: center; gap: 8px; }
  
  .cta-band__inner { padding: 30px 20px; }
  .cta-band h2 { font-size: 1.5rem; }
  
  .sponsors--lead, .sponsors { flex-direction: column; align-items: center; gap: 20px; }
  .sponsor { width: 100%; max-width: 300px; }
  
  .sec-head--row { flex-direction: column; gap: 15px; text-align: center; }
  .sec-head--row .btn { align-self: center; }
  
  .wrap-wide { padding-left: 16px; padding-right: 16px; }
  
  .statrow { flex-wrap: wrap; }
  .stat { min-width: 80px; }
  
  /* Squad cards */
  .squad-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 480px) {
  .hero h1 { font-size: 1.4rem; }
  .hero__crest { width: 60px; }
  .hero__est { font-size: 0.6rem; padding: 4px 10px; }
  .gallery { grid-template-columns: 1fr 1fr !important; }
  .squad-grid { grid-template-columns: 1fr !important; }
  .matchstrip__teams { font-size: 0.95rem; }
}


/* ===== BADGE/CREST FIX ===== */
.hero__crest {
  width: 90px !important;
  height: 90px !important;
  object-fit: contain !important;
  aspect-ratio: 1 / 1;
}
.brand img {
  width: 44px !important;
  height: 44px !important;
  object-fit: contain !important;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
}
.footer-brand .brand img {
  width: 56px !important;
  height: 56px !important;
  object-fit: contain !important;
}
@media (max-width: 768px) {
  .hero__crest {
    width: 70px !important;
    height: 70px !important;
  }
  .brand img {
    width: 36px !important;
    height: 36px !important;
  }
}


/* ===== DROPDOWN NAV ===== */
.has-dropdown { position: relative; }
.dd-trigger { display: flex; align-items: center; gap: 4px; }
.dd-arrow { width: 16px; height: 16px; fill: currentColor; transition: transform .2s; flex-shrink: 0; }
.dropdown {
  display: none;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: #0d0d0d;
  border: 1px solid #222;
  border-top: 2px solid #C62828;
  min-width: 200px;
  z-index: 200;
  box-shadow: 0 8px 24px rgba(0,0,0,.5);
  border-radius: 0 0 6px 6px;
}
.dropdown a {
  display: block;
  padding: 12px 18px;
  font-size: 0.85rem;
  color: #ccc;
  text-decoration: none;
  white-space: nowrap;
  transition: background .15s, color .15s;
  border-bottom: 1px solid #1a1a1a;
}
.dropdown a:last-child { border-bottom: none; }
.dropdown a:hover { background: #1a1a1a; color: #fff; }
.has-dropdown:hover .dropdown { display: block; }
.has-dropdown:hover .dd-arrow { transform: rotate(180deg); }

/* Mobile dropdown */
@media (max-width: 768px) {
  .has-dropdown { width: 100%; }
  .dd-trigger { padding: 12px 20px; border-bottom: 1px solid #1c1c1c; justify-content: space-between; width: 100%; box-sizing: border-box; }
  .has-dropdown:hover .dropdown { display: none; }
  .has-dropdown.dd-open .dropdown { display: block; }
  .has-dropdown.dd-open .dd-arrow { transform: rotate(180deg); }
  .dropdown {
    position: static;
    transform: none;
    border: none;
    border-top: none;
    box-shadow: none;
    background: #111;
    min-width: auto;
    border-radius: 0;
  }
  .dropdown a { padding: 10px 20px 10px 36px; font-size: 0.82rem; border-bottom: 1px solid #1a1a1a; }
}
