/* ============================================================
   1xBet India — Design System  ·  premium minimal, electric blue
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@500;600;700;800&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#060c18; --bg-2:#08111f;
  --surface:#0c1626; --surface-2:#111e34; --surface-3:#16243d;
  --line:#1b2c48; --line-soft:#16243c;
  --ink:#dce8fb; --ink-strong:#fff; --muted:#8198be; --muted-2:#5d769e; --faint:#46597d;
  --accent:#2f7dff; --accent-hi:#5b9bff; --accent-lo:#1f5fd8;
  --accent-glow:rgba(47,125,255,.30); --accent-tint:rgba(47,125,255,.10);
  --gold:#e0b252; --gold-hi:#f2cd7e;
  --good:#3fb56b; --bad:#e2574c;
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:22px;
  --font-display:'Outfit',system-ui,sans-serif; --font-body:'Inter',system-ui,sans-serif;
  --shadow-1:0 1px 0 rgba(255,255,255,.03),0 8px 24px rgba(0,0,0,.28);
  --shadow-2:0 18px 60px rgba(0,0,0,.45); --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{background:var(--bg);color:var(--ink);-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);font-size:15px;line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit}
img,svg{display:block;max-width:100%}
img{height:auto}
main,section,article,aside,div{min-width:0}
:focus-visible{outline:2px solid var(--accent-hi);outline-offset:2px;border-radius:4px}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
.ic{width:20px;height:20px;flex-shrink:0;stroke:currentColor;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ic-lg{width:26px;height:26px}.ic-sm{width:16px;height:16px}

/* ---------- HEADER ---------- */
#hdr{background:rgba(8,17,31,.82);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:200;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.hdr-inner{max-width:var(--maxw);margin:0 auto;min-height:62px;display:flex;align-items:center;padding:0 24px;gap:18px;position:relative}
.logo-link{display:flex;align-items:center;flex-shrink:0}
.logo-img{height:30px;width:auto}
.nav-links{display:flex;gap:2px;margin-left:6px;align-items:center}
.nav-a{position:relative;padding:0 13px;height:62px;display:flex;align-items:center;font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--muted);white-space:nowrap;transition:color .15s}
.nav-a:after{content:"";position:absolute;left:13px;right:13px;bottom:14px;height:2px;background:var(--accent);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .2s ease}
.nav-a:hover,.nav-a.act{color:var(--ink-strong)}
.nav-a.act:after,.nav-a:hover:after{transform:scaleX(1)}
.nav-short{display:none}
.hdr-sp{flex:1}
.hdr-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.btn-code{display:inline-flex;align-items:center;gap:7px;background:rgba(224,178,82,.08);color:var(--gold-hi);border:1px solid rgba(224,178,82,.32);padding:8px 12px;border-radius:var(--r-sm);font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.4px;transition:border-color .15s,background .15s}
.btn-code:hover{border-color:var(--gold);background:rgba(224,178,82,.14)}
.btn-code .ic{width:14px;height:14px;color:var(--gold)}
.btn-log{background:transparent;color:var(--ink);border:1px solid var(--line);padding:9px 16px;border-radius:var(--r-sm);font-size:14px;font-weight:600;transition:all .15s}
.btn-log:hover{border-color:var(--accent);color:var(--ink-strong)}
.btn-reg{background:var(--accent);color:#fff;border:0;padding:10px 20px;border-radius:var(--r-sm);font-family:var(--font-display);font-weight:700;font-size:14px;transition:transform .15s,box-shadow .15s,background .15s;box-shadow:0 6px 20px var(--accent-glow)}
.btn-reg:hover{background:var(--accent-hi);transform:translateY(-1px);box-shadow:0 10px 28px var(--accent-glow)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;flex-shrink:0}
.burger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all .2s}

/* ---------- HERO ---------- */
#hero{position:relative;overflow:hidden;background:radial-gradient(120% 120% at 85% 10%,rgba(47,125,255,.14) 0%,transparent 55%),linear-gradient(180deg,#070f1e 0%,var(--bg) 100%);border-bottom:1px solid var(--line)}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.02fr);align-items:center;gap:24px;padding:0 24px;min-height:520px}
.hero-copy{display:flex;flex-direction:column;align-items:flex-start;gap:20px;padding:56px 0}
.hero-eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-size:12.5px;font-weight:600;color:var(--accent-hi);text-transform:uppercase;letter-spacing:1.4px}
.hero-eyebrow:before{content:"";width:26px;height:2px;background:var(--accent);border-radius:2px}
.hero-h1{font-family:var(--font-display);font-size:60px;font-weight:800;color:var(--ink-strong);line-height:1.02;letter-spacing:-1.5px;margin:0}
.hero-h1 em{font-style:normal;color:var(--accent-hi)}
.hero-sub{font-size:19px;color:var(--ink);line-height:1.5;max-width:540px;margin:0;font-weight:400}
.hero-desc{font-size:15px;color:var(--muted);line-height:1.75;max-width:560px;margin:0}
.hero-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero-cta{display:inline-flex;align-items:center;gap:9px;background:var(--accent);color:#fff;border:0;padding:16px 34px;border-radius:var(--r-md);font-family:var(--font-display);font-weight:700;font-size:16px;box-shadow:0 10px 34px var(--accent-glow);transition:transform .18s,box-shadow .18s,background .18s}
.hero-cta:hover{background:var(--accent-hi);transform:translateY(-2px);box-shadow:0 16px 44px var(--accent-glow)}
.hero-cta .ic{width:18px;height:18px;stroke-width:2}
.hero-secondary{border:1px solid var(--line);color:var(--ink);background:rgba(12,22,38,.6);padding:15px 24px;border-radius:var(--r-md);font-family:var(--font-display);font-weight:600;font-size:15px;transition:all .15s}
.hero-secondary:hover{border-color:var(--accent);color:var(--ink-strong)}
.hero-trust{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:2px}
.hero-trust span{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--muted)}
.hero-trust .ic{width:16px;height:16px;color:var(--accent-hi)}
.hero-media{position:relative;align-self:stretch;min-height:520px}
.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center right}
.hero-media:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--bg) 0%,transparent 24%,transparent 100%);pointer-events:none}
.hero-chip{position:absolute;left:0;bottom:34px;z-index:3;background:rgba(8,16,30,.78);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 18px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-2)}
.hero-chip-lbl{font-size:10px;color:var(--muted-2);text-transform:uppercase;letter-spacing:1px}
.hero-chip-val{font-family:var(--font-display);font-size:18px;font-weight:800;color:var(--gold);letter-spacing:1.5px}
.hero-chip-amt{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink-strong);padding-left:16px;border-left:1px solid var(--line)}
.hero-chip-amt small{display:block;font-size:11px;font-weight:400;color:var(--muted);letter-spacing:0}

/* ---------- PROMO TICKER ---------- */
.promo-strip{position:relative;background:var(--bg-2);border-bottom:1px solid var(--line);overflow:hidden;height:42px;display:flex;align-items:center}
.promo-scroll{display:flex;animation:scroll-promo 38s linear infinite;white-space:nowrap}
@keyframes scroll-promo{0%{transform:translateX(0)}to{transform:translateX(-50%)}}
.promo-item{display:inline-flex;align-items:center;gap:8px;padding:0 30px;font-size:13px;color:var(--muted);border-right:1px solid var(--line)}
.promo-item .ic{width:15px;height:15px;color:var(--accent-hi)}
.promo-item b{color:var(--gold);font-weight:700}
.promo-item .green{color:var(--accent-hi)}
.promo-pause{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:rgba(12,22,38,.85);border:1px solid var(--line);color:var(--muted);font-size:10px;width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;z-index:1;padding:0}
.promo-pause:hover{color:var(--ink-strong);border-color:var(--accent)}
@media (prefers-reduced-motion:reduce){.promo-scroll{animation:none}}

/* ---------- SECTION SCAFFOLD ---------- */
.section{padding:72px 24px;border-bottom:1px solid var(--line-soft)}
.section-inner{max-width:var(--maxw);margin:0 auto}
.sec-label{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--accent-hi);text-transform:uppercase;letter-spacing:1.6px;margin-bottom:14px}
.sec-label:before{content:"";width:22px;height:2px;background:var(--accent);border-radius:2px}
.sec-h2{font-family:var(--font-display);font-size:34px;font-weight:800;color:var(--ink-strong);letter-spacing:-.8px;margin-bottom:14px;line-height:1.1}
.sec-desc{font-size:15px;color:var(--muted);line-height:1.75;max-width:680px;margin-bottom:38px}
.sec-desc a{color:var(--accent-hi);font-weight:600}
.sec-desc a:hover{color:var(--ink-strong)}

/* ---------- WHY (feature cards w/ icons) ---------- */
#why{background:var(--bg)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.why-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 22px;transition:border-color .2s,transform .2s,background .2s}
.why-card:hover{border-color:var(--accent);transform:translateY(-3px);background:var(--surface-2)}
.why-ico{width:46px;height:46px;border-radius:12px;background:var(--accent-tint);color:var(--accent-hi);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.why-ico .ic{width:23px;height:23px}
.why-title{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--ink-strong);margin-bottom:9px}
.why-text{font-size:13.5px;color:var(--muted);line-height:1.7}

/* ---------- ABOUT ---------- */
#about{background:var(--bg-2)}
.two-col{display:grid;grid-template-columns:1.1fr 1fr;gap:34px;align-items:start}
.about-facts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:22px}
.about-fact{background:linear-gradient(180deg,rgba(28,46,78,.40),rgba(16,28,50,.30));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(91,155,255,.20);border-radius:var(--r-md);padding:16px;text-align:center}
.about-fact-v{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--ink-strong)}
.about-fact-l{font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.8px;margin-top:3px}
.info-table{width:100%;border-collapse:collapse;background:linear-gradient(180deg,rgba(28,46,78,.45),rgba(16,28,50,.35));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--r-md);overflow:hidden;border:1px solid rgba(91,155,255,.22);box-shadow:0 12px 40px rgba(0,0,0,.35)}
.info-table tr{border-bottom:1px solid var(--line)}
.info-table tr:last-child{border-bottom:none}
.info-table td{padding:13px 16px;font-size:13.5px}
.info-table td:first-child{color:var(--muted-2);width:42%}
.info-table td:last-child{color:var(--ink);font-weight:500}
.platform-preview{margin-top:34px}
.platform-preview-lbl{font-family:var(--font-display);font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:1.4px;margin-bottom:12px}
.platform-preview img{width:100%;border-radius:var(--r-md);border:1px solid var(--line)}

/* ---------- BONUSES ---------- */
#bonuses{background:var(--bg)}
.bonus-feature{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:26px}
.bonus-feature-media{position:relative;min-height:260px}
.bonus-feature-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bonus-feature-body{padding:34px;background:var(--surface);display:flex;flex-direction:column;justify-content:center;gap:14px}
.bonus-feature-body .why-ico{margin-bottom:4px}
.bonus-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.bonus-card{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--surface);display:flex;flex-direction:column;transition:border-color .2s,transform .2s}
.bonus-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.bonus-top{padding:26px 26px 20px;border-bottom:1px solid var(--line)}
.bonus-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.bonus-ico{width:48px;height:48px;border-radius:12px;background:var(--accent-tint);color:var(--accent-hi);display:flex;align-items:center;justify-content:center}
.bonus-ico.gold{background:rgba(224,178,82,.12);color:var(--gold)}
.bonus-type{font-family:var(--font-display);font-size:12px;color:var(--muted-2);text-transform:uppercase;letter-spacing:1px;margin-bottom:5px}
.bonus-amount{font-family:var(--font-display);font-size:30px;font-weight:800;color:var(--ink-strong);line-height:1.1}
.bonus-amount small{font-size:15px;font-weight:600;color:var(--muted)}
.bonus-amount span{font-size:13px;font-weight:400;color:var(--muted);display:block;margin-top:5px}
.bonus-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.bstat{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:var(--r-sm);padding:11px;text-align:center}
.bstat-v{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink-strong)}
.bstat-l{font-size:10.5px;color:var(--muted-2);text-transform:uppercase;margin-top:3px}
.bonus-code-row{background:rgba(224,178,82,.06);border:1px dashed rgba(224,178,82,.34);border-radius:var(--r-sm);padding:11px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;transition:border-color .15s}
.bonus-code-row:hover{border-color:var(--gold)}
.bcr-lbl{font-size:10px;color:var(--muted-2);letter-spacing:.6px;text-transform:uppercase;margin-bottom:3px}
.bcr-val{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--gold);letter-spacing:2px}
.bcr-copy{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink);background:var(--surface-2);border:1px solid var(--line);padding:6px 12px;border-radius:6px}
.bcr-copy .ic{width:14px;height:14px}
.bonus-body{padding:18px 26px;background:var(--surface)}
.bonus-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--accent);color:#fff;border:0;padding:13px;border-radius:var(--r-sm);font-family:var(--font-display);font-weight:700;font-size:14.5px;transition:background .15s;margin-top:16px}
.bonus-btn:hover{background:var(--accent-hi)}
.bonus-note{font-size:12px;color:var(--muted-2);line-height:1.7}
.bonus-note b{color:var(--muted)}

/* ---------- CASINO GAMES ---------- */
#casino{background:var(--bg-2)}
.casino-jump{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:30px}
.casino-jump a{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--muted);border:1px solid var(--line);border-radius:999px;transition:all .15s}
.casino-jump a:hover{color:var(--ink-strong);border-color:var(--accent);background:var(--accent-tint)}
.casino-jump a .ic{width:15px;height:15px}
.ct-panel{margin-top:36px}
.ct-h3{font-family:var(--font-display);font-size:21px;font-weight:700;color:var(--ink-strong);margin:0 0 7px;display:flex;align-items:center;gap:10px}
.ct-h3 .ic{width:21px;height:21px;color:var(--accent-hi)}
.ct-desc{color:var(--muted);font-size:14px;line-height:1.75;margin:0 0 22px;max-width:720px}
.games-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.game-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:border-color .15s,transform .15s}
.game-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.game-card:hover .gc-thumb img{transform:scale(1.06)}
.gc-thumb{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--surface-2)}
.gc-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.gc-thumb.placeholder{display:flex;align-items:center;justify-content:center;color:var(--faint)}
.gc-thumb.placeholder .ic{width:34px;height:34px}
.gc-tag{position:absolute;top:9px;left:9px;font-family:var(--font-display);font-size:10px;font-weight:700;color:#fff;background:rgba(47,125,255,.9);padding:3px 8px;border-radius:5px;letter-spacing:.4px;text-transform:uppercase}
.gc-body{padding:13px 14px}
.gc-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink-strong);margin:0 0 3px}
.gc-prov{display:block;font-size:11px;color:var(--muted-2);margin-bottom:7px}
.gc-rtp{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--muted)}
.gc-rtp .ic{width:13px;height:13px;color:var(--accent-hi)}

/* ---------- LIVE CASINO ---------- */
#live{background:var(--bg)}
.live-feature{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:28px}
.live-feature-media{position:relative;min-height:280px}
.live-feature-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.live-feature-body{padding:36px;background:var(--surface);display:flex;flex-direction:column;justify-content:center;gap:14px}
.live-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.live-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 20px;transition:border-color .2s,transform .2s}
.live-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.live-ico{width:44px;height:44px;border-radius:12px;background:var(--accent-tint);color:var(--accent-hi);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.live-ico .ic{width:22px;height:22px}
.live-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink-strong);margin-bottom:8px}
.live-text{font-size:13px;color:var(--muted);line-height:1.7}

/* ---------- PROVIDERS ---------- */
#providers{background:var(--bg-2)}
.prov-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.prov-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:20px}
.prov-card:hover{border-color:var(--accent)}
.prov-name{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--ink-strong);margin-bottom:6px}
.prov-desc{font-size:12.5px;color:var(--muted-2);line-height:1.65}

/* ---------- SPORTS GALLERY ---------- */
#sports-gallery{background:var(--bg)}
.sg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sg-card{position:relative;border-radius:var(--r-lg);overflow:hidden;display:block;aspect-ratio:16/10;border:1px solid var(--line)}
.sg-card:hover .sg-img{transform:scale(1.06)}
.sg-img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.sg-card.placeholder{display:flex;align-items:center;justify-content:center;background:var(--surface-2);color:var(--faint)}
.sg-card.placeholder .ic{width:42px;height:42px}
.sg-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(6,12,24,.86) 100%);display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;padding:18px 20px}
.sg-label{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-size:17px;font-weight:700;color:#fff;margin-bottom:4px}
.sg-label .ic{width:19px;height:19px}
.sg-cta{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--accent-hi);font-weight:600}
.sg-cta .ic{width:14px;height:14px}

/* ---------- SPORTS CARDS ---------- */
#sports{background:var(--bg-2)}
.sports-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sport-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;transition:border-color .2s,transform .2s}
.sport-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.sport-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.sport-ico{width:42px;height:42px;border-radius:11px;background:var(--accent-tint);color:var(--accent-hi);display:flex;align-items:center;justify-content:center}
.sport-ico .ic{width:21px;height:21px}
.sport-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink-strong)}
.sport-sub{font-size:11px;color:var(--muted-2);margin-top:2px}
.sport-text{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:14px}
.sport-tags{display:flex;flex-wrap:wrap;gap:6px}
.tag{background:var(--bg-2);border:1px solid var(--line);color:var(--accent-hi);font-size:11px;font-weight:600;padding:3px 10px;border-radius:999px}

/* ---------- COMPARISON ---------- */
#comparison{background:var(--bg)}
.comp-wrap{border:1px solid rgba(91,155,255,.22);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 12px 40px rgba(0,0,0,.35)}
.comp-table{width:100%;border-collapse:collapse;background:linear-gradient(180deg,rgba(28,46,78,.42),rgba(16,28,50,.32));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);min-width:680px}
.comp-th-feature{padding:16px;text-align:left;font-family:var(--font-display);font-size:13px;color:var(--muted);font-weight:600;background:var(--surface-2);border-bottom:1px solid var(--line);width:230px}
.comp-th{padding:16px 14px;text-align:center;background:var(--surface-2);border-bottom:1px solid var(--line);border-left:1px solid var(--line);font-family:var(--font-display);font-size:13px;color:var(--muted);font-weight:600}
.comp-th-winner{background:var(--accent-tint);border-bottom:2px solid var(--accent);color:var(--ink-strong)}
.comp-logo-img{height:22px;width:auto;margin:0 auto;object-fit:contain}
.comp-logo-gray{filter:grayscale(1) brightness(.7);opacity:.6}
.comp-td-feature{padding:13px 16px;font-size:13px;color:var(--ink);border-bottom:1px solid var(--line-soft)}
.comp-td{padding:13px 14px;font-size:13px;color:var(--muted);text-align:center;border-bottom:1px solid var(--line-soft);border-left:1px solid var(--line-soft)}
.comp-td-winner{color:var(--ink-strong);font-weight:600;background:rgba(47,125,255,.06);border-left:1px solid rgba(47,125,255,.2)}
.comp-row-even td{background:rgba(12,22,38,.4)}
.comp-row-even .comp-td-winner{background:rgba(47,125,255,.09)}
.comp-yes{color:var(--good);display:inline-flex}
.comp-no{color:var(--bad);display:inline-flex}
.comp-yes .ic,.comp-no .ic{width:18px;height:18px;stroke-width:2.2}

/* ---------- PAYMENTS ---------- */
#payments{background:var(--bg-2)}
.pay-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pay-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center;transition:border-color .15s}
.pay-card:hover{border-color:var(--accent)}
.pay-ico{width:42px;height:42px;border-radius:11px;background:var(--accent-tint);color:var(--accent-hi);display:flex;align-items:center;justify-content:center}
.pay-ico .ic{width:21px;height:21px}
.pay-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink-strong)}
.pay-detail{font-size:11.5px;color:var(--muted-2)}

/* ---------- REGISTRATION ---------- */
#registration{background:var(--bg)}
.reg-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:26px}
.rstep{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:22px;display:flex;gap:14px;align-items:flex-start}
.rstep-num{width:34px;height:34px;background:var(--accent);color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:15px;flex-shrink:0}
.rstep-text{font-size:13.5px;color:var(--muted);line-height:1.7}
.rstep-text b{color:var(--ink-strong);font-weight:600}
.reg-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.reg-note{font-size:12.5px;color:var(--muted-2);line-height:1.6}
.reg-screenshots{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:26px}
.reg-shot{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:border-color .2s}
.reg-shot:hover{border-color:var(--accent)}
.reg-shot img{width:100%;aspect-ratio:9/16;object-fit:cover}
.reg-shot-lbl{padding:10px;font-family:var(--font-display);font-size:12px;font-weight:600;color:var(--muted);text-align:center}

/* ---------- APP ---------- */
#app{background:var(--bg-2)}
.app-feature{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:28px}
.app-feature-media{position:relative;min-height:300px;background:#070f1e}
.app-feature-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.app-feature-body{padding:36px;background:var(--surface);display:flex;flex-direction:column;justify-content:center;gap:14px}
.app-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.app-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.app-top{padding:22px 24px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--line)}
.app-top-ico{width:46px;height:46px;border-radius:12px;background:var(--accent-tint);color:var(--accent-hi);display:flex;align-items:center;justify-content:center}
.app-top-ico .ic{width:24px;height:24px}
.app-top-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink-strong)}
.app-top-sub{font-size:12px;color:var(--muted-2);margin-top:2px}
.app-body{padding:22px 24px}
.app-steps{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.app-step{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--muted);line-height:1.6}
.app-n{width:24px;height:24px;background:var(--surface-3);color:var(--accent-hi);border-radius:7px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:12px;font-weight:700;flex-shrink:0;margin-top:1px}
.app-req{font-size:12px;color:var(--muted-2);margin-bottom:14px}
.app-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--accent);color:#fff;border:0;padding:12px;border-radius:var(--r-sm);font-family:var(--font-display);font-weight:700;font-size:14px;transition:background .15s}
.app-btn:hover{background:var(--accent-hi)}
.app-btn.secondary{background:var(--surface-2);border:1px solid var(--line);color:var(--ink)}
.app-btn.secondary:hover{border-color:var(--accent);background:var(--surface-3)}

/* ---------- FAQ ---------- */
#faq{background:var(--bg)}
.faq-list{display:flex;flex-direction:column;gap:8px;max-width:840px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:border-color .2s}
.faq-item[open]{border-color:var(--accent)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:17px 20px;cursor:pointer;font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--ink);user-select:none;list-style:none}
.faq-q::-webkit-details-marker{display:none}
.faq-q:hover{color:var(--ink-strong)}
.faq-arr{color:var(--muted-2);transition:transform .2s;flex-shrink:0}
.faq-item[open] .faq-arr{transform:rotate(180deg);color:var(--accent-hi)}
.faq-a{padding:0 20px 18px;font-size:14px;color:var(--muted);line-height:1.8}
.faq-a b{color:var(--ink)}

/* ---------- RESPONSIBLE ---------- */
#responsible{background:var(--bg-2)}
.resp-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
.resp-rules{display:flex;flex-direction:column;gap:10px}
.resp-rule{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:15px 16px;font-size:13.5px;color:var(--muted);line-height:1.6}
.resp-rule .ic{color:var(--accent-hi);margin-top:1px}
.resp-media{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:3/2}
.resp-media img{width:100%;height:100%;object-fit:cover}
.resp-links{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.resp-link{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);color:var(--ink);padding:10px 18px;border-radius:var(--r-sm);font-family:var(--font-display);font-size:13.5px;font-weight:600;transition:border-color .15s}
.resp-link:hover{border-color:var(--accent);color:var(--ink-strong)}
.resp-link .ic{width:16px;height:16px;color:var(--accent-hi)}

/* ---------- FOOTER ---------- */
footer{background:#040a14;padding:48px 24px 32px;border-top:1px solid var(--line)}
.footer-inner{max-width:var(--maxw);margin:0 auto}
.footer-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;margin-bottom:36px}
.footer-brand-block{max-width:300px}
.footer-brand-block .logo-img{height:30px;margin-bottom:14px}
.footer-brand-text{font-size:13px;color:var(--muted-2);line-height:1.7}
.footer-col-title{font-family:var(--font-display);font-size:12px;font-weight:700;color:var(--ink-strong);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:14px}
.footer-link{font-size:13.5px;color:var(--muted-2);padding:4px 0;display:block;transition:color .12s}
.footer-link:hover{color:var(--ink-strong)}
.footer-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;align-items:flex-start;gap:20px}
.footer-badges{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}
.footer-badge{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-size:11px;font-weight:600;color:var(--muted);background:var(--surface);border:1px solid var(--line);padding:7px 12px;border-radius:8px}
.footer-badge .ic{width:14px;height:14px;color:var(--accent-hi)}
.footer-disc{font-size:11.5px;color:var(--faint);line-height:1.7;flex:1}
.footer-disc a{color:var(--muted-2)}
.footer-disc a:hover{color:var(--muted)}

/* ---------- INNER PAGE LAYOUT ---------- */
.page-hero{background:radial-gradient(120% 140% at 90% 0%,rgba(47,125,255,.16) 0%,transparent 55%),linear-gradient(180deg,#070f1e,var(--bg));padding:42px 24px 38px;border-bottom:1px solid var(--line)}
.page-hero-inner{max-width:var(--maxw);margin:0 auto}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted-2);margin-bottom:14px;flex-wrap:wrap}
.breadcrumb a{color:var(--accent-hi)}
.breadcrumb a:hover{color:var(--ink-strong)}
.breadcrumb .ic{width:13px;height:13px;color:var(--faint)}
.page-h1{font-family:var(--font-display);font-size:38px;font-weight:800;color:var(--ink-strong);letter-spacing:-1px;line-height:1.08}
.page-lede{font-size:16px;color:var(--muted);line-height:1.6;max-width:680px;margin-top:12px}
.page-main{max-width:var(--maxw);margin:0 auto;padding:44px 24px;display:grid;grid-template-columns:1fr 290px;gap:38px;align-items:start}
.page-content{min-width:0}
.page-sidebar{position:sticky;top:84px}

.sidebar-cta{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;margin-bottom:16px}
.scta-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink-strong);margin-bottom:14px;text-align:center;text-transform:uppercase;letter-spacing:.6px}
.scta-card{border:1px solid var(--line);border-radius:var(--r-md);padding:14px;margin-bottom:12px;background:var(--bg-2)}
.scta-type{font-family:var(--font-display);font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:1px;margin-bottom:5px}
.scta-amount{font-family:var(--font-display);font-size:16px;font-weight:800;color:var(--ink-strong);margin-bottom:12px;line-height:1.3}
.scta-code{background:rgba(224,178,82,.06);border:1px dashed rgba(224,178,82,.34);border-radius:7px;padding:8px 11px;cursor:pointer;margin-bottom:10px;transition:border-color .15s}
.scta-code:hover{border-color:var(--gold)}
.scta-lbl{font-size:9.5px;color:var(--muted-2);letter-spacing:.6px;text-transform:uppercase;display:block;margin-bottom:3px}
.scta-val{font-family:var(--font-display);font-size:15px;font-weight:800;color:var(--gold);letter-spacing:2px}
.scta-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:11px;border-radius:var(--r-sm);font-family:var(--font-display);font-weight:700;font-size:13.5px;background:var(--accent);color:#fff;transition:background .15s}
.scta-btn:hover{background:var(--accent-hi)}
.scta-trust{display:flex;gap:10px;justify-content:center;margin-top:12px;font-size:11px;color:var(--muted-2);flex-wrap:wrap}
.sidebar-nav{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.snav-title{padding:13px 16px;font-family:var(--font-display);font-size:12px;font-weight:700;color:var(--ink-strong);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.snav-link{display:flex;align-items:center;gap:9px;padding:10px 16px;font-size:13.5px;color:var(--muted);border-bottom:1px solid var(--line-soft);transition:all .12s}
.snav-link:last-child{border-bottom:none}
.snav-link:hover{background:var(--surface-2);color:var(--ink-strong);padding-left:20px}
.snav-link .ic{width:15px;height:15px;color:var(--accent-hi)}

/* ---- article content typography ---- */
.page-content h2{font-family:var(--font-display);font-size:26px;font-weight:800;color:var(--ink-strong);margin:34px 0 14px;letter-spacing:-.5px}
.page-content h2:first-child{margin-top:0}
.page-content h3{font-family:var(--font-display);font-size:19px;font-weight:700;color:var(--ink);margin:24px 0 10px}
.page-content h4{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--ink);margin:18px 0 8px}
.page-content p{color:var(--muted);font-size:15px;line-height:1.85;margin-bottom:16px}
.page-content strong,.page-content b{color:var(--ink)}
.page-content ul,.page-content ol{color:var(--muted);font-size:15px;line-height:1.8;padding-left:22px;margin-bottom:16px}
.page-content li{margin-bottom:6px}
.page-content a{color:var(--accent-hi)}
.page-content a:hover{color:var(--ink-strong);text-decoration:underline}
.page-content hr{border:none;border-top:1px solid var(--line);margin:28px 0}
.page-content table{width:100%;border-collapse:collapse;background:linear-gradient(180deg,rgba(28,46,78,.42),rgba(16,28,50,.32));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(91,155,255,.22);border-radius:var(--r-md);overflow:hidden;margin-bottom:20px;font-size:14px;box-shadow:0 12px 40px rgba(0,0,0,.35)}
.page-content th{background:var(--surface-2);padding:12px 16px;text-align:left;color:var(--ink);font-family:var(--font-display);font-weight:600;border-bottom:1px solid var(--line)}
.page-content td{padding:11px 16px;color:var(--muted);border-bottom:1px solid var(--line-soft)}
.page-content tr:last-child td{border-bottom:none}
.page-content tr:hover td{background:rgba(47,125,255,.04)}
.page-content blockquote{border-left:3px solid var(--accent);padding:12px 18px;background:var(--surface);border-radius:0 var(--r-sm) var(--r-sm) 0;margin:16px 0}
.cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff!important;padding:12px 28px;border-radius:var(--r-md);font-family:var(--font-display);font-weight:700;font-size:14.5px;text-decoration:none!important;margin:6px 8px 16px 0;box-shadow:0 8px 24px var(--accent-glow);transition:transform .18s,box-shadow .18s,background .18s}
.cta-btn:hover{background:var(--accent-hi);transform:translateY(-2px);box-shadow:0 12px 32px var(--accent-glow)}
.cta-btn.secondary{background:var(--surface);border:1px solid var(--line);color:var(--ink)!important;box-shadow:none}
.cta-btn.secondary:hover{border-color:var(--accent)}
.info-box{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--r-sm);padding:16px 18px;margin:18px 0;font-size:14px;color:var(--muted);line-height:1.75}
.info-box strong{color:var(--ink)}
.context-links{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px 20px;margin:26px 0;color:var(--muted)}
.context-links h2{font-size:19px!important;margin:0 0 8px!important;color:var(--ink-strong)!important}
.context-links p{margin:0!important}
.context-links a{color:var(--accent-hi);font-weight:600}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1120px){
  .hdr-inner{padding:0 18px;gap:10px}
  .nav-a{padding:0 9px;font-size:13.5px}
  .nav-label{display:none}.nav-short{display:inline}
  .btn-code{display:none}
}
@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr;min-height:auto}
  .hero-copy{padding:48px 0 40px;align-items:flex-start;text-align:left}
  .hero-media{min-height:300px;border-radius:var(--r-lg);overflow:hidden;margin-bottom:48px}
  .hero-media:after{background:linear-gradient(180deg,transparent 60%,var(--bg) 100%)}
  .hero-chip{left:16px;bottom:16px}
  .hero-h1{font-size:48px}
  .why-grid,.live-grid,.prov-grid,.pay-grid{grid-template-columns:repeat(2,1fr)}
  .games-grid{grid-template-columns:repeat(3,1fr)}
  .sports-grid,.sg-grid{grid-template-columns:repeat(2,1fr)}
  .bonus-grid,.two-col,.resp-grid,.app-grid,.bonus-feature,.live-feature,.app-feature{grid-template-columns:1fr}
  .bonus-feature-media,.live-feature-media,.app-feature-media{min-height:220px}
  .page-main{grid-template-columns:1fr}
  .page-sidebar{position:static}
  .footer-cols{grid-template-columns:repeat(2,1fr);gap:26px}
}
@media (max-width:768px){
  .nav-links{display:none;flex-direction:column;position:absolute;top:62px;left:14px;right:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);z-index:199;box-shadow:var(--shadow-2);overflow:hidden;margin-left:0;padding:6px}
  .nav-links.open{display:flex}
  .nav-a{height:auto;width:100%;padding:13px 14px;border-radius:var(--r-sm);justify-content:flex-start}
  .nav-a:after{display:none}
  .nav-a.act,.nav-a:hover{background:var(--accent-tint)}
  .nav-label{display:inline}.nav-short{display:none}
  .hdr-actions{display:none}
  .burger{display:flex}.hdr-sp{display:none}
  .section{padding:48px 18px}
  .sec-h2{font-size:28px}
  .reg-steps{grid-template-columns:1fr}
  .reg-screenshots{grid-template-columns:repeat(2,1fr)}
  .page-content table{display:block;overflow-x:auto}
}
@media (max-width:520px){
  .hdr-inner{padding:0 14px;min-height:56px}
  .logo-img{height:26px}
  .nav-links{top:56px;left:10px;right:10px}
  .hero-copy{padding:36px 0 32px}
  .hero-h1{font-size:38px;letter-spacing:-1px}
  .hero-sub{font-size:17px}
  .hero-actions{width:100%}
  .hero-cta,.hero-secondary{width:100%;justify-content:center;text-align:center}
  .hero-chip{left:12px;right:12px;bottom:12px;padding:12px 14px}
  .section{padding:40px 14px}
  .sec-h2{font-size:24px}
  .why-grid,.live-grid,.prov-grid,.pay-grid,.sports-grid,.sg-grid,.reg-screenshots{grid-template-columns:1fr}
  .games-grid{grid-template-columns:repeat(2,1fr)}
  .about-facts{grid-template-columns:1fr 1fr}
  .bonus-feature-body,.live-feature-body,.app-feature-body,.bonus-body,.app-body{padding:24px 20px}
  .footer-cols{grid-template-columns:1fr;gap:22px}
  .footer-bottom{flex-direction:column;gap:16px}
  .page-h1{font-size:30px}
  .page-hero{padding:32px 16px 28px}
  .page-main{padding:32px 16px}
  .cta-btn{width:100%;justify-content:center;margin-right:0}
}

/* ---- feature banner image positioning (content sits on the right of these wide renders) ---- */
.bonus-feature-media img,.live-feature-media img,.app-feature-media img{object-position:center right}
.resp-media img{object-position:center}
.platform-preview img{object-position:center top}

/* ---- registration flow (illustrated numbered steps) ---- */
.reg-flow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.reg-flow .rstep{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 22px;display:block}
.reg-flow .rstep:hover{border-color:var(--accent)}
.reg-flow .rstep-num{position:absolute;top:18px;right:18px;width:30px;height:30px;background:var(--surface-2);color:var(--accent-hi);border-radius:9px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:14px}
.rstep-icon{width:48px;height:48px;border-radius:13px;background:var(--accent-tint);color:var(--accent-hi);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.rstep-icon .ic{width:24px;height:24px}
.rstep-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--ink-strong);margin-bottom:8px}
@media (max-width:960px){.reg-flow{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.reg-flow{grid-template-columns:1fr}}

/* =========================================================
   MOBILE OPTIMISATION  (touch targets, tap feedback, scroll)
   ========================================================= */
@media (hover:none) and (pointer:coarse){
  /* remove blue tap flash, keep our own states */
  a,button,summary,.faq-q,.bonus-code-row,.scta-code{-webkit-tap-highlight-color:transparent}
  /* comfortable tap targets for inline/footer links */
  .footer-link{padding:11px 0;font-size:14px}
  .snav-link{padding:14px 16px}
  .casino-jump a{padding:11px 16px}
  .breadcrumb a{padding:2px 0}
  /* copy buttons — bigger hit area */
  .bcr-copy{padding:9px 14px;font-size:13px}
  .scta-code{padding:12px}
  .promo-pause{width:30px;height:30px}
  /* tap feedback on cards */
  .why-card:active,.live-card:active,.sport-card:active,.game-card:active,
  .prov-card:active,.pay-card:active,.bonus-card:active,.rstep:active{transform:scale(.985)}
  .hero-cta:active,.bonus-btn:active,.app-btn:active,.cta-btn:active,.btn-reg:active{transform:translateY(1px)}
}

/* smooth, contained horizontal scroll for wide tables + scroll hint */
.comp-wrap,.page-content table{-webkit-overflow-scrolling:touch}
@media (max-width:768px){
  .comp-wrap{position:relative;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .comp-wrap:after{content:"";position:sticky;top:0;right:0;float:right;width:28px;height:1px;
    margin-left:-28px;pointer-events:none}
  /* fade hint on the right edge so users know to swipe */
  .table-scroll-hint{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted-2);
    margin:-8px 0 16px;font-family:var(--font-display)}
  .table-scroll-hint .ic{width:14px;height:14px;color:var(--accent-hi)}
}
@media (min-width:769px){.table-scroll-hint{display:none}}

/* prevent iOS text auto-inflation, keep sizes intentional */
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
/* avoid sub-16px only where it would force zoom on focus — n/a (no inputs), kept safe */

/* very small phones (360 and under) */
@media (max-width:380px){
  .hero-h1{font-size:34px}
  .sec-h2{font-size:22px}
  .page-h1{font-size:26px}
  .bonus-amount{font-size:26px}
  .hero-chip{gap:12px;padding:11px 13px}
  .hero-chip-val{font-size:16px}
  .hero-chip-amt{font-size:14px;padding-left:12px}
  .section{padding:36px 14px}
}

/* =========================================================
   IMAGE PLACEHOLDER (intentional branded fill, never looks broken)
   ========================================================= */
.img-ph{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;
  background:
    radial-gradient(120% 140% at 80% 10%, rgba(47,125,255,.18), transparent 55%),
    linear-gradient(180deg,#0b1730,#0a1322);
  border:1px solid var(--line)}
.img-ph:before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(91,155,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(91,155,255,.06) 1px,transparent 1px);
  background-size:26px 26px;mask-image:radial-gradient(circle at 75% 25%,#000,transparent 75%)}
.img-ph-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--accent-hi);text-align:center;padding:18px}
.img-ph-inner .ic{width:40px;height:40px;opacity:.9}
.img-ph-label{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.3px}

/* ---- inner page hero banner image ---- */
.page-hero-banner{margin-top:22px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);position:relative;aspect-ratio:21/6;box-shadow:var(--shadow-2)}
.page-hero-banner img{width:100%;height:100%;object-fit:cover;display:block}
.page-hero-banner:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,12,24,.55),transparent 45%,transparent 70%,rgba(6,12,24,.35))}
@media (max-width:768px){.page-hero-banner{aspect-ratio:16/7;margin-top:18px}}
@media (max-width:520px){.page-hero-banner{aspect-ratio:16/9}}
