:root{
  --bg:#f7f9fb;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --border:#e5e7eb;
  --accent:#2563eb;
  --accent-2:#a855f7;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,Segoe UI,Arial,sans-serif}

/* Header / layout */
.wrap{max-width:1400px;margin:40px auto;padding:0 24px}
header{display:block;margin-bottom:18px}
h1{margin:0;font-size:28px;line-height:1.2}
.sub{margin:6px 0 0;color:var(--muted);font-size:15px}

/* Tabs — centered, inline, text-style (no pills) */
.tabs{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:0;
  margin:12px 0 22px 0;
}
.tab{
  appearance:none;
  background:transparent;
  border:0;
  padding:0 16px;
  height:auto;
  color:var(--muted);
  font-size:14px;
  font-weight:600;
  letter-spacing:.02em;
  cursor:pointer;
  position:relative;
  transition:color .15s ease;
}
.tab:hover{ color:var(--text); }
.tab + .tab::before{
  content:"•";
  position:absolute;
  left:-8px;
  top:0; bottom:0;
  display:flex; align-items:center;
  color:#c7cbd3;
  font-weight:400;
}
.tab.is-active{ color:var(--accent); }
.tab.is-active::after{
  content:"";
  position:absolute; left:10px; right:10px; bottom:-6px;
  height:2px; border-radius:2px; background:var(--accent);
}
.tab-note{ margin-left:14px; color:var(--muted); font-size:12px }

/* Section title */
h2.sub{color:var(--text);font-size:17px;font-weight:600;margin:0 0 14px}

/* Card shell */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:0 10px 30px rgba(15,23,42,.06);
  padding:12px;
  justify-content: center;
  align-items: center;
  justify-items: center;
}

/* Grid */
.grid{
  display:grid;
  gap:20px; /* add spacing between icons */
  justify-content:center; /* center tiles */
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); /* slightly larger tiles */
  list-style:none;
}

/* Tiles */
.tile{
  position:relative;
  border:0;
  border-radius:12px;   /* remove rounding here */
  place-items: center;
  display:grid;
  overflow:visible;  /* allow the image to keep its radius */
  background:transparent;
  transition:transform .16s ease, box-shadow .16s ease;
}

.tile:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(15,23,42,.14)}
.tile a{display:block;height:100%;text-decoration:none;color:inherit;outline:0}
.tile:focus-within{box-shadow:0 0 0 3px rgba(37,99,235,.25)}

.tile img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  background:transparent;       
  border-radius:10px;
  padding:0;                 /* adds breathing space, removes boxy look */
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  display:block;
}

.tile:hover img{filter:brightness(60%) blur(1px);transform:scale(1.03)}

/* Hover caption block */
.hovermeta{
  position:absolute;left:16px;right:16px;bottom:16px;color:#fff;
  opacity:0;transform:translateY(10px);
  transition:opacity .25s ease, transform .25s ease;
  pointer-events:none;text-shadow:0 2px 16px rgba(0,0,0,.6);
}
.tile:hover .hovermeta,
.tile:focus-within .hovermeta{opacity:1;transform:translateY(0)}
.hovercat{display:block;font-size:10px;letter-spacing:4px;font-weight:300;opacity:.9;text-transform:uppercase}
.hovertitle{display:block;margin-top:4px;font-size:17px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}

/* Fallback for old markup */
.hovername{
  position:absolute;left:16px;right:16px;bottom:16px;color:#fff;
  font-size:17px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  text-shadow:0 2px 16px rgba(0,0,0,.6);
  opacity:0;transform:translateY(10px);
  transition:opacity .25s ease, transform .25s ease;pointer-events:none;
}
.tile:hover .hovername,.tile:focus-within .hovername{opacity:1;transform:translateY(0)}
.label{display:none}

/* Footer */
footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;color:var(--muted);font-size:13px}
.badge{color:var(--accent);background:rgba(37,99,235,.10);padding:6px 10px;border-radius:10px}

/* Utility */
[hidden]{display:none !important}

/* centered provider title with logo */
.section-title{
  display:flex; align-items:center; justify-content:center;
  gap:10px; margin:0 0 14px;
}
.section-title .provider-logo{
  width:28px; height:28px; object-fit:contain; flex:0 0 auto;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,.08));
}
.section-title span{
  color:var(--text); font-size:17px; font-weight:600; letter-spacing:.2px;
}
@media (min-width:768px){
  .section-title .provider-logo{ width:32px; height:32px; }
}

/* Centered provider headline */
.provider-headline{
  display:flex; justify-content:center; align-items:center;
  gap:10px; margin: 0 auto 18px auto; text-align:center;
  letter-spacing:.3px; font-size:18px; font-weight:600; color:var(--text);
}
.provider-headline-logo{
  width:26px; height:26px; object-fit:contain;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,.10));
}
@media(min-width:768px){
  .provider-headline-logo{ width:32px; height:32px; }
}

/* --- in-page find bar --- */
.findbar{position:sticky; top:8px; z-index:50; display:none; justify-content:center; margin:8px 0 6px}
.findbar.open{display:flex}
.findbar .box{
  display:flex; align-items:center; gap:10px;
  background:#fff; border:1px solid var(--border); border-radius:999px;
  padding:8px 12px; box-shadow:0 10px 24px rgba(15,23,42,.10)
}
.findbar input{border:0; outline:0; width:280px; font-size:14px; color:var(--text)}
.findbar .count{font-size:12px; color:var(--muted)}
.findbar button{border:0; background:transparent; cursor:pointer; font-size:16px; color:var(--muted)}

/* make matches “look hovered” + outline */
.tile.match{
  box-shadow:0 0 0 3px rgba(37,99,235,.35), 0 12px 24px rgba(15,23,42,.14);
  transform:translateY(-2px);
}
.tile.match .hovermeta,
.tile.match .hovername{opacity:1; transform:translateY(0)}
