/* =================================================================
   WinBet NL — base styles
   Performance-first. No gradients. No webfonts. Common classes.
   ================================================================= */

:root{
  --bg:        #222222;
  --bg-alt:    #1a1a1a;
  --bg-card:   #2c2c2c;
  --bg-card-2: #333333;
  --brand:     #E42313;
  --brand-dk:  #b81b0e;
  --cta:       #19B14E;
  --reviews:  #FFD24A;
  --cta-dk:    #149643;
  --cta-text:  #ffffff;
  --text:      #ffffff;
  --text-mut:  #c8c8c8;
  --text-dim:  #8a8a8a;
  --line:      #3a3a3a;
  --line-2:    #444444;
  --good:      #4ac26b;
  --warn:      #ff6b6b;
  --radius:    8px;
  --radius-sm: 4px;
  --maxw:      1200px;
}

*{box-sizing:border-box}
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth }
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font:16px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeSpeed;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--cta);text-decoration:none}
a:hover{text-decoration:underline}
.sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 16px }

/* ============ Buttons ============ */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 18px; border-radius:var(--radius-sm);
  font-weight:700; font-size:14px;
  letter-spacing:.02em; text-transform:uppercase;
  border:2px solid transparent;
  cursor:pointer; transition:transform .12s ease, background .12s ease, color .12s ease, border-color .12s ease;
  text-decoration:none !important; white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{ background:var(--cta); color:var(--cta-text) }
.btn--primary:hover{ background:var(--cta-dk); color:var(--cta-text) }
.btn--ghost{ background:transparent; color:#fff; border-color:#fff }
.btn--ghost:hover{ background:#fff; color:var(--brand) }
.btn--lg{ padding:14px 26px; font-size:15px }

/* ============ Header ============ */
.hdr{
  position:sticky; top:0; z-index:50;
  background:var(--brand);
  border-bottom:2px solid var(--brand-dk);
}
.hdr__row{
  display:flex; align-items:center; gap:16px;
  padding:10px 16px; min-height:56px;
}
.hdr__logo{ display:inline-flex; align-items:center; gap:6px; color:#fff; font-weight:900; font-size:20px; letter-spacing:.04em; flex:0 0 auto }
.hdr__logo img{ height:32px; width:auto }
.hdr__logo:hover{text-decoration:none}
.hdr__logo-fb{ display:inline-block }
.hdr__logo img[src=""],.hdr__logo img:not([src]){ display:none }

.hdr__nav{ display:flex; gap:18px; margin-left:18px; flex:1 1 auto }
.hdr__nav a{ color:#fff; font-weight:600; font-size:14px; padding:6px 2px }
.hdr__nav a:hover{ color:var(--cta); text-decoration:none }

.hdr__cta{ display:flex; gap:8px; flex:0 0 auto; align-items:center }
.hdr__cta .btn{ padding:8px 14px; font-size:13px }

/* gift icon CTA */
.hdr__gift{
  position:relative;
  width:38px; height:38px;
  display:inline-flex; align-items:center; justify-content:center;
  background:#fff; color:var(--brand);
  border-radius:50%;
  flex:0 0 38px;
  transition:transform .15s ease, background .15s ease, color .15s ease;
  text-decoration:none !important;
}
.hdr__gift:hover{
  background:var(--cta); color:#fff; transform:scale(1.06);
}
.hdr__gift svg{
  width:20px; height:20px;
  stroke:currentColor; fill:none;
  stroke-width:2; stroke-linecap:round; stroke-linejoin:round;
}
.hdr__gift-dot{
  position:absolute; top:-2px; right:-2px;
  width:11px; height:11px;
  background:var(--cta);
  border:2px solid var(--brand);
  border-radius:50%;
  animation:gift-pulse 1.8s ease-in-out infinite;
}
@keyframes gift-pulse{
  0%,100%{ transform:scale(1); opacity:1 }
  50%    { transform:scale(1.35); opacity:.75 }
}

@media (max-width:760px){
  .hdr__nav{ display:none }
  .hdr__row{ justify-content:space-between }
  .hdr__cta .btn{ padding:8px 12px }
}

/* ============ Hero ============ */
.hero{
  padding:36px 0 28px;
  background-color:var(--bg);
  background-image:url('/assets/winbet-background.webp');         /* user inserts hero bg image here */
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  border-bottom:1px solid var(--line);
  position:relative;
  overflow:hidden;
}
.hero::before{
  /* solid dark overlay for text legibility — no gradient */
  content:""; position:absolute; inset:0;
  background:rgba(0,0,0,.82);
  pointer-events:none;
  z-index:0;
}
.hero .wrap{ position:relative; z-index:1 }
.hero__grid{
  display:grid;
  grid-template-columns: minmax(0,1.35fr) minmax(0,1fr);
  gap:32px;
  align-items:start;
}
.hero__eyebrow{
  color:var(--cta); font-weight:700; font-size:12px;
  letter-spacing:.12em; text-transform:uppercase; margin:0 0 10px;
}
.hero h1{
  margin:0 0 16px; font-size:34px; line-height:1.15; font-weight:800;
  letter-spacing:-.01em;
}
.hero__lede{ font-size:17px; line-height:1.55; margin:0 0 12px; color:#eaeaea }
.hero__lede strong{ color:#fff }
.hero__lede em{ color:var(--reviews); font-style:normal; font-weight:600 }
.hero__sub{ font-size:15px; line-height:1.55; color:var(--text-mut); margin:0 0 22px }
.hero__cta-row{ display:flex; gap:12px; flex-wrap:wrap; margin:0 0 14px }
.hero__legal{ font-size:12px; color:var(--text-dim); margin:0 }

/* score panel */
.hero__panel{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-left:4px solid var(--brand);
  border-radius:var(--radius);
  padding:20px;
}
.hero__panel-head{
  display:flex; align-items:baseline; gap:10px;
  padding-bottom:14px; margin-bottom:14px;
  border-bottom:1px dashed var(--line-2);
}
.hero__score{ font-size:38px; font-weight:900; color:var(--reviews); line-height:1 }
.hero__score-out{ font-size:18px; color:var(--reviews); font-weight:600 }
.hero__score-label{ font-size:13px; color:var(--reviews); margin-left:auto }

.ratebars{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px }
.ratebars li{
  display:grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  column-gap:10px;
}
.ratebars__label{ font-size:13px; color:#eaeaea; grid-column:1; grid-row:1 }
.ratebars__val{ font-size:13px; color:var(--reviews); font-weight:700; grid-column:2; grid-row:1 }
.ratebars__bar{
  grid-column:1 / -1; grid-row:2;
  display:block; height:6px; background:var(--bg--2);
  border-radius:3px; overflow:hidden;
}
.ratebars__bar > span{
  display:block; height:100%; background:var(--reviews);
}

.hero__facts{ display:flex; flex-wrap:wrap; gap:6px; margin-top:16px }
.chip{
  display:inline-block; padding:4px 10px; border-radius:99px;
  background:var(--bg-card-2); color:#fff; font-size:12px; font-weight:600;
  border:1px solid var(--line-2);
}

@media (max-width:900px){
  .hero__grid{ grid-template-columns: 1fr; gap:20px }
  .hero h1{ font-size:26px }
  .hero__lede{ font-size:15px }
}

/* ============ Section base ============ */
.sec{ padding:44px 0; border-bottom:1px solid var(--line) }
.sec--alt{ background:var(--bg-alt) }
.sec__head{ margin:0 0 22px }
.sec__head h2{
  margin:0 0 8px; font-size:26px; font-weight:800; letter-spacing:-.01em;
}
.sec__lead{ margin:0; color:var(--text-mut); font-size:15px; max-width:780px }
.sec__sub{
  margin:24px 0 14px; font-size:18px; font-weight:700;
  color:#fff; padding-left:10px;
  border-left:3px solid var(--brand);
}
.lead{ font-size:16px; line-height:1.6; color:#eaeaea; margin:0 0 12px }

@media (max-width:600px){
  .sec{ padding:32px 0 }
  .sec__head h2{ font-size:22px }
}

/* ============ Game tiles ============ */
.tiles{
  display:grid;
  grid-template-columns: repeat(6, minmax(0,1fr));
  gap:10px;
  margin:0 0 6px;
}
@media (max-width:1100px){ .tiles{ grid-template-columns: repeat(5, minmax(0,1fr)) } }
@media (max-width:900px) { .tiles{ grid-template-columns: repeat(4, minmax(0,1fr)) } }
@media (max-width:680px) { .tiles{ grid-template-columns: repeat(3, minmax(0,1fr)); gap:8px } }
@media (max-width:460px) { .tiles{ grid-template-columns: repeat(2, minmax(0,1fr)) } }

.tile{
  position:relative;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition: transform .15s ease, border-color .15s ease;
}
.tile:hover{ transform:translateY(-2px); border-color:var(--cta) }
.tile__fav{
  position:absolute; top:6px; left:6px; z-index:2;
  width:22px; height:22px; border-radius:50%;
  background:rgba(0,0,0,.55); color:var(--cta);
  display:flex; align-items:center; justify-content:center; font-size:12px;
}
.tile__badge{
  position:absolute; top:8px; right:8px; z-index:2;
  background:var(--brand); color:#fff;
  padding:2px 8px; font-size:10px; font-weight:700;
  border-radius:3px; text-transform:uppercase; letter-spacing:.03em;
}
.tile__img{
  display:block; aspect-ratio: 1 / 1; width:100%;
  background:var(--bg-card-2);
  position:relative; overflow:hidden;
}
.tile__img img{ width:100%; height:100%; object-fit:cover }
.tile__img img[src=""],
.tile__img img:not([src]){ display:none }
.tile__img::after{
  /* simple flat placeholder badge for missing logo (no gradient) */
  content:"WinBet"; position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.08); font-size:14px; font-weight:900;
  letter-spacing:.08em; text-transform:uppercase;
  pointer-events:none;
}
.tile__img img[src]:not([src=""]) ~ * { } /* no-op, keeps cascade clean */

.tile__name{
  margin:0; padding:8px 8px 4px;
  font-size:12px; font-weight:600; line-height:1.3;
  color:#fff; text-align:center;
  min-height:34px;
}
.tile__cta{
  display:block; margin:0 0 0; padding:7px 8px;
  background:var(--cta); color:var(--cta-text);
  font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.04em;
  text-align:center; text-decoration:none !important;
  transition:background .12s ease;
}
.tile__cta:hover{ background:var(--cta-dk); color:var(--cta-text) }

/* "see all" tile */
.tile--all{
  background:var(--bg-card); border:2px dashed var(--cta);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:18px 10px;
  text-decoration:none !important;
}
.tile--all:hover{ background:var(--bg-card-2); transform:translateY(-2px) }
.tile--all__icon{
  font-size:42px; font-weight:300; color:var(--cta); line-height:1; margin-bottom:8px;
}
.tile--all__txt{ color:#fff; font-size:13px; font-weight:600 }
.tile--all__txt strong{ display:block; color:var(--cta); font-size:18px; margin-top:2px }

/* Sport tiles — wider, with event count below name */
.tiles--sport{
  grid-template-columns: repeat(5, minmax(0,1fr));
}
@media (max-width:1100px){ .tiles--sport{ grid-template-columns: repeat(4, minmax(0,1fr)) } }
@media (max-width:900px) { .tiles--sport{ grid-template-columns: repeat(3, minmax(0,1fr)) } }
@media (max-width:680px) { .tiles--sport{ grid-template-columns: repeat(2, minmax(0,1fr)) } }
@media (max-width:420px) { .tiles--sport{ grid-template-columns: 1fr 1fr } }

.tile--sport .tile__img{ aspect-ratio: 16 / 10 }
.tile--sport .tile__img::after{ content:"⚽"; font-size:32px; color:rgba(255,255,255,.1) }
.tile__meta{
  display:flex; flex-direction:column; align-items:center;
  padding:10px 8px 12px; gap:4px;
}
.tile--sport .tile__name{
  margin:0; padding:0;
  font-size:13px; font-weight:700; color:#fff;
  text-align:center; min-height:auto;
}
.tile__evt{
  font-size:12px; font-weight:600; color:var(--cta);
}

/* ============ Verdict block ============ */
.verdict{
  background:var(--bg-card); border-radius:var(--radius);
  border:1px solid var(--line); border-top:3px solid var(--brand);
  padding:22px 24px;
}
.verdict p{ margin:0 0 12px; line-height:1.65; color:#eaeaea }
.verdict p:last-child{ margin:0 }

/* ============ Tables ============ */
.tbl-scroll{
  width:100%; overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:var(--bg-card);
}
.tbl{
  width:100%; min-width:560px;
  border-collapse:collapse; font-size:14px;
}
.tbl caption{ display:none }
.tbl thead th{
  background:var(--bg-card-2); color:#fff;
  text-align:left; padding:12px 14px;
  font-weight:700; font-size:13px;
  text-transform:uppercase; letter-spacing:.03em;
  border-bottom:1px solid var(--line);
  white-space:nowrap;
}
.tbl tbody td, .tbl tbody th{
  padding:11px 14px; border-bottom:1px solid var(--line);
  color:#eaeaea; vertical-align:top;
}
.tbl tbody th{
  text-align:left; font-weight:600; color:#fff;
  background:rgba(255,255,255,.02);
  width:40%;
}
.tbl tbody tr:last-child td, .tbl tbody tr:last-child th{ border-bottom:0 }
.tbl tbody tr:hover{ background:rgba(255,255,255,.03) }

.tbl--facts{ min-width:480px }

@media (max-width:600px){
  .tbl{ font-size:13px; min-width:520px }
  .tbl thead th, .tbl tbody td, .tbl tbody th{ padding:10px 12px }
}

/* ============ Wagering calculator ============ */
.calc{
  margin-top:22px;
  background:var(--bg-card); border:1px solid var(--line);
  border-left:4px solid var(--cta);
  border-radius:var(--radius);
  padding:20px;
}
.calc__head{ margin-bottom:16px }
.calc__head h3{ margin:0 0 4px; font-size:18px; color:#fff }
.calc__head p{ margin:0; font-size:13px; color:var(--text-mut) }
.calc__form{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:10px; align-items:end;
}
.calc__field{ display:flex; flex-direction:column; gap:4px }
.calc__field span{ font-size:12px; color:var(--text-mut); font-weight:600 }
.calc__field input{
  background:var(--bg); color:#fff;
  border:1px solid var(--line-2); border-radius:var(--radius-sm);
  padding:10px 12px; font-size:15px; font-weight:600;
  font-family:inherit;
}
.calc__field input:focus{ outline:none; border-color:var(--cta) }
.calc__btn{ height:42px }

.calc__result{
  display:block; margin-top:14px; padding:14px 16px;
  background:var(--bg); border:1px dashed var(--line-2);
  border-radius:var(--radius-sm);
}
.calc__row{
  display:flex; justify-content:space-between; align-items:baseline;
  padding:4px 0;
  font-size:14px; color:var(--text-mut);
}
.calc__row strong{ color:var(--cta); font-size:18px; font-weight:800 }
.calc__hint{
  display:block; margin-top:6px; padding-top:8px;
  border-top:1px dashed var(--line-2);
  font-size:12px; color:var(--text-dim);
}

/* === PATCH: wagering calculator mobile layout === */

/* Tablet / wide phone: 2 cols, 3rd field & button span full width */
@media (max-width:680px){
  .calc__form{ grid-template-columns:1fr 1fr }
  .calc__field:nth-child(3){ grid-column:1 / -1 }
  .calc__btn{ grid-column:1 / -1 }
}

/* Narrow phone: stack everything */
@media (max-width:460px){
  .calc__form{ grid-template-columns:1fr; gap:8px }
  .calc__field:nth-child(3){ grid-column:auto }
  .calc{ padding:16px }
  .calc__head h3{ font-size:16px }
}

/* Result rows shouldn't overflow on tiny screens */
@media (max-width:380px){
  .calc__row{ flex-wrap:wrap; gap:2px }
  .calc__row strong{ font-size:16px }
}
/* ============ Checklist ============ */
.checklist{ margin-top:22px; padding:18px 20px; background:var(--bg-card); border:1px solid var(--line); border-radius:var(--radius) }
.checklist h3{ margin:0 0 10px; font-size:16px; color:#fff }
.checklist ul{ margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:8px }
.checklist li{
  position:relative; padding-left:24px;
  font-size:14px; line-height:1.55; color:#eaeaea;
}
.checklist li::before{
  content:"✓"; position:absolute; left:0; top:0;
  color:var(--cta); font-weight:900;
}
.checklist li strong{ color:#fff }

/* ============ Cards ============ */
.cards-2, .cards-3, .cards-4{
  display:grid; gap:14px;
}
.cards-2{ grid-template-columns: 1fr 1fr }
.cards-3{ grid-template-columns: repeat(3, minmax(0,1fr)) }
.cards-4{ grid-template-columns: repeat(4, minmax(0,1fr)) }

@media (max-width:880px){
  .cards-2, .cards-3, .cards-4{ grid-template-columns: 1fr 1fr }
}
@media (max-width:520px){
  .cards-2, .cards-3, .cards-4{ grid-template-columns: 1fr }
}

.card{
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:var(--radius); padding:18px 20px;
}
.card__title{ margin:0 0 10px; font-size:17px; color:#fff }
.card p{ margin:0 0 10px; color:#eaeaea; font-size:14px; line-height:1.55 }
.card .btn{ margin-top:6px }

/* steps in registratie/login */
.steps{ list-style:none; padding:0; margin:0 0 14px; counter-reset:none }
.steps li{
  position:relative; padding:10px 12px 10px 42px;
  margin-bottom:6px; background:rgba(255,255,255,.03);
  border-radius:var(--radius-sm);
  font-size:14px; line-height:1.5; color:#eaeaea;
}
.steps__n{
  position:absolute; left:10px; top:50%; transform:translateY(-50%);
  width:24px; height:24px; border-radius:50%;
  background:var(--brand); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:800;
}
.steps li em{ color:var(--cta); font-style:normal; font-weight:600 }

.ul-inline{ list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:6px }
.ul-inline li{
  background:var(--bg-card-2); color:#fff;
  padding:4px 10px; border-radius:99px; font-size:12px; font-weight:600;
  border:1px solid var(--line-2);
}

/* ============ Provider logos ============ */
.prov-logos{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top:14px;
}
.prov-logos a{
  display:flex; align-items:center; justify-content:center;
  flex:1 1 140px; min-height:50px;
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:8px 12px;
  color:var(--text-dim); font-size:12px; font-weight:600;
}
.prov-logos a:hover{ border-color:var(--cta); text-decoration:none }
.prov-logos img[src=""],.prov-logos img:not([src]){ display:none }

/* ============ Note ============ */
.note{
  margin-top:14px; padding:12px 16px;
  background:var(--bg-card); border-left:3px solid var(--warn);
  border-radius:var(--radius-sm);
  font-size:13px; color:#eaeaea; line-height:1.55;
}

/* ============ Pros / cons ============ */
.proscons{
  display:grid; grid-template-columns: 1fr 1fr; gap:14px;
}
.proscons__col{
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:var(--radius); padding:18px 20px;
}
.proscons__col h3{ margin:0 0 12px; font-size:17px; color:#fff }
.proscons__col ul{ margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:8px }
.proscons__col li{
  position:relative; padding-left:24px;
  font-size:14px; line-height:1.55; color:#eaeaea;
}
.proscons__col--pro{ border-top:3px solid var(--good) }
.proscons__col--pro li::before{
  content:"+"; position:absolute; left:4px; top:-1px;
  color:var(--good); font-weight:900; font-size:18px;
}
.proscons__col--con{ border-top:3px solid var(--warn) }
.proscons__col--con li::before{
  content:"−"; position:absolute; left:4px; top:-1px;
  color:var(--warn); font-weight:900; font-size:18px;
}
@media (max-width:680px){
  .proscons{ grid-template-columns:1fr }
}

/* ============ FAQ ============ */
.faq{ display:flex; flex-direction:column; gap:8px }
.faq__item{
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:var(--radius); overflow:hidden;
}
.faq__item summary{
  list-style:none; cursor:pointer;
  padding:14px 44px 14px 18px;
  font-size:15px; font-weight:600; color:#fff;
  position:relative; line-height:1.4;
}
.faq__item summary::-webkit-details-marker{ display:none }
.faq__item summary::after{
  content:"+"; position:absolute; right:16px; top:50%;
  transform:translateY(-50%);
  width:24px; height:24px; line-height:22px; text-align:center;
  background:var(--brand); color:#fff;
  border-radius:50%; font-size:18px; font-weight:700;
  transition:transform .15s ease;
}
.faq__item[open] summary::after{ content:"−" }
.faq__item summary:hover{ color:var(--cta) }
.faq__a{ padding:0 18px 16px }
.faq__a p{ margin:0; color:#eaeaea; font-size:14px; line-height:1.6 }
.faq__a em{ color:var(--cta); font-style:normal }

/* ============ Footer ============ */
.ftr{ background:var(--bg-alt); padding:32px 0 22px; border-top:2px solid var(--brand) }
.ftr__banners{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr));
  gap:10px; margin-bottom:20px;
}
.ftr__banners a{
  display:flex; align-items:center; justify-content:center;
  min-height:70px;
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:var(--radius);
  padding:10px 14px;
  color:var(--text-dim); font-size:13px; font-weight:600;
}
.ftr__banners a:hover{ border-color:var(--cta); text-decoration:none }
.ftr__banners img[src=""],.ftr__banners img:not([src]){ display:none }

.ftr__warn{
  background:var(--bg-card); border:1px solid var(--line);
  border-left:4px solid var(--brand);
  border-radius:var(--radius);
  padding:16px 20px; margin-bottom:20px;
}
.ftr__warn p{ margin:0 0 8px; color:#eaeaea; font-size:13px; line-height:1.55 }
.ftr__warn p:last-child{ margin:0 }
.ftr__warn strong{ color:#fff }

.ftr__logos{
  display:flex; flex-wrap:wrap; gap:8px;
  padding-bottom:16px; border-bottom:1px solid var(--line);
  margin-bottom:14px;
}
.ftr__logos a{
  display:flex; align-items:center; justify-content:center;
  min-width:80px; min-height:38px;
  background:var(--bg-card); border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:4px 10px;
  color:var(--text-dim); font-size:11px; font-weight:600;
}
.ftr__logos a:hover{ border-color:var(--cta); text-decoration:none }
.ftr__logos img[src=""],.ftr__logos img:not([src]){ display:none }

.ftr__copy{ margin:0; color:var(--text-dim); font-size:12px; text-align:center }

@media (max-width:680px){
  .ftr__banners{ grid-template-columns:1fr; gap:8px }
}

/* ============ Reduced motion ============ */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important }
}
