:root {
  --bg: #0b1220; /* deep blue */
  --panel: #0f1a2b; /* slightly lighter */
  --ink: #e6f4f1; /* soft cyan white */
  --muted: #96b0ad;
  --ring: #134e4a; /* teal ring */
  --brand: #0ea5a4; /* primary teal */
  --brand-2: #1d4ed8; /* blue */
  --brand-3: #0f766e; /* deep teal */
  --accent: #22c55e; /* green accents */
  --warn: #f59e0b;
  --gold: #d1fae5; /* used for stars tint over dark */
  --cta-bg: #16a34a;
  --cta-text: #04120f;
  --container: 1120px;
  --radius: 14px;
  --shadow: 0 6px 30px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.03);
}

* { box-sizing: border-box; }

html, body { height: 100%; }

body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Helvetica Neue", Arial, sans-serif;
  color: var(--ink);
  line-height: 2;
  background: radial-gradient(1200px 800px at 20% -10%, #10243e 0%, var(--bg) 60%), var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

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

/* Hero */
.hero {
  display: block;
  background: linear-gradient(180deg, rgba(13, 31, 39,.7), rgba(4, 18, 15,.9)), radial-gradient(800px 400px at 80% -20%, rgba(20,83,45,.35), transparent 70%);
  padding: 44px 0 36px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.hero__brand img { filter: drop-shadow(0 6px 20px rgba(0,0,0,.5)); }
.hero__title { font: 800 28px/1.2 Space Grotesk, Inter, system-ui; letter-spacing: .2px; margin: 10px 0 8px; }
.hero__subtitle { color: var(--muted); margin: 0 0 10px; font-weight: 500; }
.hero__usp { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; font-weight: 600; color: #cde9e4; }
.hero__usp i { color: var(--accent); margin-right: 6px; }
.hero__meta { color: #9fbdb8; font-size: 13px; }

/* Decorative grid dots */
.hero::after { content: ""; display: block; height: 6px; width: 100%; background: linear-gradient(90deg, transparent, rgba(34,197,94,.35), transparent); filter: blur(.4px); margin-top: 18px; }

/* Catalog */
.catalog { padding: 28px 0; }
.catalog__head { display: grid; grid-template-columns: 2fr 3fr 2fr  1.5fr; gap: 12px; align-items: center; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); color: #bfe1dd; border-radius: var(--radius); padding: 10px 16px; margin-bottom: 12px; }
.catalog__cell { text-align: center; font-weight: 700; }
.catalog__cell:first-child { text-align: left; }
.catalog__cell:last-child { text-align: right; }

.brand-card { position: relative; display: grid; grid-template-columns: 2fr 3fr 2fr 2fr 1.5fr; align-items: center; gap: 16px; background: var(--panel); border: 1px solid color-mix(in oklab, var(--ring), #000 35%); border-radius: var(--radius); padding: 16px; margin-bottom: 20px; box-shadow: var(--shadow); transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s; }
.brand-card::before { content: ""; position: absolute; inset: -1px; border-radius: inherit; padding: 1px; background: linear-gradient(135deg, color-mix(in oklab, var(--brand), #fff 8%), transparent 30%, color-mix(in oklab, var(--ring), #fff 6%)); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity: .7; pointer-events: none; }
.brand-card:hover { transform: translateY(-3px); box-shadow: 0 10px 40px rgba(0,0,0,.45); }
.brand-card:focus-within { outline: 2px solid var(--brand); outline-offset: 3px; }

.logo-box { background: transparent; border: 1px solid color-mix(in oklab, var(--brand), #000 40%); border-radius: 10px; padding: 16px 10px; display: inline-flex; align-items: center; justify-content: center; width: 100%; box-shadow: inset 0 0 0 1px rgba(255,255,255,.02); }
.logo { height: 56px; width: auto; display: block; filter: saturate(.9) contrast(1.05); }
.ct{
  display: flex;
  flex-wrap: wrap;
}
.card-opl{
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.card-opl p{
  text-align: center;
  text-transform:capitalize;
  color:#fff;
  font-size: 12px;
  width: 100%;
}
.offer-title { font: 800 20px/1.15 Space Grotesk, Inter, system-ui; letter-spacing: .2px; color: #e9fbf7;}
.offer-note { color: #a7d3cd; font-weight: 600; margin-top: 0px; font-size: 12px; margin-left: 5px; margin-right: 5px;}

.brand-card__score { text-align: center; }
.score-val { font: 800 40px/1 Inter, system-ui; color: #dcfff7; }
.score-stars { color: #8bf3d2; margin: 6px 0; text-shadow: 0 0 10px rgba(34,197,94,.15); }
.score-note { color: #8bb3ad; font-size: 13px; }

/* .brand-card__cta { text-align: right; } */

.btn { appearance: none; outline: none; border: none; cursor: pointer; font-weight: 700; border-radius: 999px; position: relative; isolation: isolate; }
.btn--accent { background: linear-gradient(180deg, color-mix(in oklab, var(--cta-bg), #fff 6%), var(--cta-bg)); color: var(--cta-text); padding: 12px 24px; text-decoration: none; display: inline-block; box-shadow: 0 6px 20px rgba(22,163,74,.35); }
.btn--accent::after { content: ""; position: absolute; inset: 0; border-radius: inherit; box-shadow: inset 0 1px 0 rgba(255,255,255,.35), inset 0 -8px 20px rgba(0,0,0,.25); pointer-events: none; }
.btn--accent:hover { filter: saturate(1.05) brightness(1.03); transform: translateY(-1px); }
.btn--xl { padding: 14px 28px; font-size: 16px; }

.badge { background: #083344; color: #cbeaed; font-size: 12px; font-weight: 800; padding: 4px 10px; border-radius: 999px; }

/* FAQ */
.faq { padding: 8px 0 40px; }
.faq__title { font: 800 22px/1.2 Space Grotesk, Inter, system-ui; margin: 8px 0 16px; }
.qa { background: var(--panel); border: 1px solid rgba(255,255,255,.06); border-radius: 10px; margin-bottom: 10px; overflow: clip; }
.qa__q { width: 100%; text-align: left; background: transparent; color: var(--ink); border: none; padding: 14px 16px; font-weight: 700; display: flex; justify-content: space-between; align-items: center; cursor: pointer; }
.qa__q[aria-expanded="true"] { background: rgba(255,255,255,.03); }
.qa__a { color: #ffffff; padding: 10px; }
.qa__q {
  font-size: 20px;
}
/* Footer */
.site-foot { background: #071018; color: var(--ink); padding: 28px 0 36px; border-top: 1px solid rgba(255,255,255,.06); }
.foot-cols { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.foot-title { margin: 0 0 6px; font-weight: 800; }
.foot-col p { margin: 0; color: #b4c9c6; }
.foot-logos { margin: 18px 0 10px; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 12px 16px; color: #a7bab7; }
.foot-copy { color: #89a3a0; font-size: 12px; text-align: center; }

/* Age gate */
.age-gate { position: fixed; inset: 0; background: rgba(2,6,23,0.78); display: none; align-items: center; justify-content: center; padding: 16px; z-index: 1000; }
.age-gate[aria-hidden="false"] { display: flex; }
.age-gate__dialog { background: var(--panel); color: var(--ink); width: min(520px, 100%); border-radius: 12px; padding: 20px; text-align: center; border: 1px solid rgba(255,255,255,.06); box-shadow: var(--shadow); }
.age-gate__actions { display: flex; gap: 12px; justify-content: center; margin-top: 12px; }
.btn--primary { background: var(--brand-2); color: #e6f0ff; padding: 10px 14px; border-radius: 10px; }
.btn--ghost { background: transparent; color: #c8dde0; border: 1px solid rgba(255,255,255,.12); padding: 10px 14px; border-radius: 10px; }

/* Helpers */
@media (max-width: 980px) {
  .catalog__head { grid-template-columns: 1.8fr 2.8fr 1.6fr 1.2fr; }
  .brand-card { grid-template-columns: 1.8fr 2.8fr 1.6fr 1.2fr; }
}
@media (max-width: 760px) {
  .hero__title { font-size: 24px; }
  .catalog__head { display: none; }
  .brand-card { grid-template-columns: 1fr; text-align: center; }
  .brand-card__cta { text-align: center; }
}
@media (max-width:1000px) {
    .brand-card { grid-template-columns: 1fr; text-align: center; }
  
}

/* ensure at least one card fully visible on mobile with spacing */
.brand-card { scroll-snap-align: start; }
.catalog { overflow: hidden; }
@media (max-width: 760px) {
  .catalog { overflow-x: auto; scroll-snap-type: x mandatory; padding-left: 16px; padding-right: 16px; }
  .brand-card { min-width: calc(100% - 32px); margin-right: 16px; }
}

/* Optional: prevent scroll when age gate is open */
body.age-gate-open { overflow: hidden; }

/* Utility */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

footer,header,main{
  padding-left: 10px;
  padding-right: 10px;
}
.hero__brand img{
  max-width: 120px;
  margin: auto;
  display: block;
}
.hero__title{
  text-align: center;
}
.hero__subtitle{
  text-align: center;
}
.foot-logos img{
  width: auto;
  height: 30px;
  padding-left: 5px;
  padding-right: 5px;
}
.card-opl img{
  width: auto;
  height: 10px;
}
.ln{
  width: 100%;
  height: 2px;
      background: linear-gradient(180deg,
 color-mix(in oklab, var(--cta-bg), #fff 6%), var(--cta-bg));
 border-radius: 12px;
 margin-top: 5px;
 margin-bottom: 5px;
}
.rrrt{
  max-width: 800px;
  margin: auto;
  padding-bottom: 40px;
}
footer .foot-col a{
  color: #bfe1dd;
  font-size: 16px;
  padding-left: 10px;
  padding-right: 10px;
}
.ll{
  display: flex;
  align-items: center;
  text-align: center;
  justify-content: center;
  flex-wrap: wrap;
}

@media screen and (max-width:700px) {
  footer .foot-cols{
  display: flex;
  flex-wrap: wrap;
}
  
}