:root{
  --bg:#09111f;
  --bg-2:#0d1930;
  --panel:#111b2e;
  --panel-2:#16233c;
  --soft:#f8fafc;
  --card:#ffffff;
  --line:#dbe2ea;
  --text:#0f172a;
  --muted:#475569;
  --brand:#22c55e;
  --brand-2:#86efac;
  --brand-3:#16a34a;
  --accent:#2563eb;
  --accent-2:#1d4ed8;
  --success:#166534;
  --warning:#b45309;
  --shadow:0 18px 45px rgba(9,17,31,.09);
  --radius:22px;
  --max:1220px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:#edf5ef;
  line-height:1.72;
}
img{max-width:100%;height:auto}
a{color:#166534;text-decoration:none}
a:hover{text-decoration:underline}
code{
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;
  background:#edf2f7;padding:.15rem .35rem;border-radius:.4rem
}
.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden
}
.skip-link:focus{
  left:16px;top:16px;width:auto;height:auto;z-index:999;
  background:#fff;padding:10px 14px;border-radius:10px;box-shadow:var(--shadow)
}

.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(9,17,31,.92);
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
}
.header-inner{
  max-width:var(--max);margin:0 auto;padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:20px
}
.brand-wrap{display:flex;align-items:center;gap:12px;color:#fff;min-width:0}
.brand-wrap:hover{text-decoration:none}
.brand-wrap img{width:46px;height:46px;flex:0 0 auto}
.brand-text{display:flex;flex-direction:column;min-width:0}
.brand-title{font-weight:900;letter-spacing:.01em}
.brand-subtitle{font-size:.87rem;color:#d7dee9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:440px}
.nav-toggle{
  display:none;
  border:1px solid rgba(255,255,255,.18);
  background:transparent;color:#fff;border-radius:12px;
  padding:10px 14px;font-weight:800
}
.nav-links{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.nav-links a{color:#e8eef6;font-weight:700}
.nav-links .header-cta{
  padding:11px 16px;border-radius:999px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#0f172a;box-shadow:0 14px 26px rgba(244,180,0,.28)
}

.hero{
  padding:66px 20px 42px;
  color:#fff;
  background:
    radial-gradient(circle at 8% 10%, rgba(244,180,0,.14), transparent 28%),
    radial-gradient(circle at 88% 18%, rgba(249,115,22,.18), transparent 32%),
    linear-gradient(180deg,var(--bg) 0%, var(--bg-2) 100%);
}
.hero-inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:start
}
.eyebrow{
  display:inline-flex;gap:10px;align-items:center;flex-wrap:wrap;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:#fff6d5;
  padding:10px 14px;border-radius:999px;
  margin-bottom:18px;font-size:.95rem
}
.hero h1{
  font-size:clamp(2.2rem,5vw,4rem);
  line-height:1.04;
  margin:0 0 16px;
  letter-spacing:-.02em
}
.hero .lead{
  font-size:1.08rem;
  color:#dbe5f3;
  max-width:790px;
  margin:0 0 18px
}
.hero .lead strong{color:#fff}
.hero-points{
  margin:0;padding:0;list-style:none;
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px
}
.hero-points li{
  padding:14px 15px;border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:#eaf1fb
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:20px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;border-radius:999px;padding:14px 18px;
  font-weight:900;cursor:pointer;text-decoration:none
}
.btn:hover{text-decoration:none}
.btn-primary{
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#0f172a;box-shadow:0 14px 24px rgba(244,180,0,.28)
}
.btn-secondary{
  background:rgba(255,255,255,.09);
  color:#fff;border:1px solid rgba(255,255,255,.14)
}
.notice{
  margin-top:18px;padding:14px 16px;
  border-radius:16px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);color:#dbe7f5
}
.hero-card{
  background:#fff;color:var(--text);
  border-radius:24px;padding:24px;box-shadow:var(--shadow)
}
.hero-card h2{margin:0 0 10px;font-size:1.35rem;line-height:1.2}
.hero-card p{margin:0 0 14px;color:var(--muted)}
.hero-card img{display:block;width:100%;border-radius:18px;border:1px solid var(--line);background:#f3f7fb}
.hero-stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:16px
}
.hero-stat{
  border:1px solid var(--line);border-radius:18px;background:#f8fafc;padding:14px
}
.hero-stat strong{display:block;font-size:1.3rem;line-height:1}
.hero-stat span{display:block;margin-top:6px;color:var(--muted);font-size:.94rem}
.inline-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.inline-badges span{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  background:#fff8e1;border:1px solid #f6d87f;color:#7a5200;
  font-size:.9rem;font-weight:700
}

main{padding:28px 20px 60px}
.section{
  max-width:var(--max);margin:0 auto 28px;
  background:#fff;border:1px solid var(--line);border-radius:26px;
  padding:30px;box-shadow:var(--shadow)
}
.section-dark{
  background:linear-gradient(180deg,#0f172a 0%, #16223a 100%);
  color:#fff;border-color:rgba(255,255,255,.08)
}
.section-dark p,.section-dark li,.section-dark .small{color:#d9e4f2}
.kicker{
  display:inline-block;
  font-weight:900;color:#975f00;
  letter-spacing:.08em;text-transform:uppercase;
  font-size:.82rem;margin-bottom:10px
}
.section-dark .kicker{color:#ffe09a}
.section h2{
  margin:0 0 12px;font-size:clamp(1.55rem,3vw,2.35rem);
  line-height:1.12;letter-spacing:-.02em
}
.section h3{
  margin:18px 0 10px;font-size:1.2rem;line-height:1.25
}
.lead{font-size:1.05rem;color:var(--muted);margin-top:0}
.section-dark .lead{color:#dce8f6}
.quick-links{
  display:flex;flex-wrap:wrap;gap:12px
}
.quick-links a{
  padding:11px 14px;border-radius:999px;
  background:#f8fafc;border:1px solid var(--line);
  color:var(--text);font-weight:800
}
.metrics-grid,.info-grid,.cards-grid,.bonus-grid,.game-grid,.criteria-grid,.steps-grid,.policy-grid,.faq-grid,.compact-grid{
  display:grid;gap:18px
}
.metrics-grid{grid-template-columns:repeat(4,1fr)}
.info-grid{grid-template-columns:repeat(3,1fr)}
.cards-grid{grid-template-columns:repeat(3,1fr)}
.compact-grid{grid-template-columns:repeat(2,1fr)}
.bonus-grid,.game-grid,.policy-grid{grid-template-columns:repeat(3,1fr)}
.criteria-grid{grid-template-columns:repeat(3,1fr)}
.steps-grid{grid-template-columns:repeat(4,1fr)}

.metric-card,.info-card,.brand-card,.bonus-card,.game-card,.criteria-card,.step-card,.policy-card,.faq-card,.compact-card{
  border:1px solid var(--line);border-radius:20px;
  background:#f8fafc;padding:18px
}
.section-dark .metric-card,
.section-dark .info-card,
.section-dark .criteria-card,
.section-dark .policy-card,
.section-dark .step-card{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.12)
}
.metric-card strong{display:block;font-size:1.7rem;line-height:1}
.metric-card span,.info-card p,.brand-card p,.bonus-card p,.game-card p,.criteria-card p,.step-card p,.policy-card p,.compact-card p{color:var(--muted);margin:.45rem 0 0}
.section-dark .metric-card span,.section-dark .info-card p,.section-dark .criteria-card p,.section-dark .step-card p,.section-dark .policy-card p{color:#d7e4f1}
.brand-card{
  overflow:hidden;background:#fff
}
.brand-card img{
  display:block;width:100%;aspect-ratio:16/9;
  object-fit:cover;border-radius:14px;border:1px solid var(--line);
  background:#0d1930
}
.brand-body{padding-top:16px}
.brand-head{
  display:flex;justify-content:space-between;gap:12px;align-items:flex-start;
  margin-bottom:8px
}
.brand-head h3{margin:0;font-size:1.15rem}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;background:#fff6dd;border:1px solid #f7d679;
  font-size:.86rem;font-weight:900;color:#744800
}
.rank-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 12px;border-radius:999px;
  background:#eef5ff;border:1px solid #c8dbfb;
  color:#163b6b;font-weight:900;font-size:.84rem
}
.meta-row{
  display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 14px
}
.meta-row span{
  padding:8px 10px;border-radius:999px;background:#f8fafc;border:1px solid var(--line);
  font-size:.88rem;color:#334155
}
.score-pill{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:74px;padding:9px 12px;border-radius:999px;
  background:#10203d;color:#fff;font-weight:900
}
.compare-wrap{
  overflow:auto;border:1px solid var(--line);border-radius:20px;background:#fff
}
.compare-table{width:100%;border-collapse:collapse;min-width:980px}
.compare-table th,.compare-table td{
  padding:14px;border-bottom:1px solid var(--line);vertical-align:top
}
.compare-table thead th{
  background:#fff8e7;color:#6c4a00;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em
}
.compare-table tbody tr:hover{background:#fbfcfe}
.compare-table .brand-cell strong{display:block}
.compare-table .brand-cell span{display:block;color:var(--muted);font-size:.92rem}
.review-entry{
  border:1px solid var(--line);border-radius:24px;background:#fff;padding:24px;margin-bottom:20px
}
.review-layout{
  display:grid;grid-template-columns:320px 1fr;gap:22px;align-items:start
}
.review-figure{
  margin:0;border:1px solid var(--line);border-radius:18px;background:#f8fafc;padding:14px;
  position:sticky;top:92px
}
.review-figure img{
  width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:14px;border:1px solid var(--line);background:#0d1930
}
.review-figure figcaption{font-size:.93rem;color:var(--muted);margin-top:12px}
.review-head{
  display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap
}
.review-head h3{margin:0}
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.panel{
  border:1px solid var(--line);border-radius:18px;background:#f8fafc;padding:18px
}
.panel h4{margin:0 0 10px}
.list-check,.list-x,.list-clean{
  margin:0;padding-left:1.2rem
}
.list-check li::marker{color:var(--success)}
.list-x li::marker{color:var(--accent)}
.list-clean li{margin-bottom:8px}
.section-visual{
  display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:start
}
.sticky-card{
  position:sticky;top:92px;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff
}
.sticky-card img{display:block;width:100%}
.sticky-card .sticky-body{padding:18px}
.highlight{
  border-left:4px solid var(--brand);
  background:#fff8e7;padding:14px 16px;border-radius:14px;
  color:#6f4900;margin:16px 0
}
.warning{
  border-left:4px solid #f97316;
  background:#fff7ed;padding:14px 16px;border-radius:14px;
  color:#9a3412;margin:16px 0
}
.table-slim{width:100%;border-collapse:collapse}
.table-slim th,.table-slim td{padding:12px;border-bottom:1px solid var(--line);vertical-align:top}
.table-slim th{background:#f8fafc;text-align:left}
.author-box{
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center
}
.author-box img{
  width:92px;height:92px;border-radius:50%;
  border:1px solid var(--line);background:#fff
}
.cta-bar{
  display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap;
  padding:18px 20px;border-radius:18px;
  background:linear-gradient(135deg,#fff8e8,#fff3d2);
  border:1px solid #f7d27a
}
.faq-item{
  border:1px solid var(--line);border-radius:18px;background:#fff;overflow:hidden
}
.faq-question{
  width:100%;border:none;background:#fff;padding:18px;
  display:flex;justify-content:space-between;align-items:flex-start;gap:16px;
  font:inherit;font-weight:900;text-align:left;color:var(--text);cursor:pointer
}
.faq-answer{display:none;padding:0 18px 18px;color:var(--muted)}
.faq-item.open .faq-answer{display:block}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
label{display:block;font-weight:800;margin-bottom:8px}
input,textarea{
  width:100%;padding:14px;border:1px solid var(--line);border-radius:14px;
  font:inherit;background:#fff
}
textarea{min-height:170px;resize:vertical}
.small{font-size:.92rem;color:#64748b}
.breadcrumbs{font-size:.92rem;color:#dbe5f3;margin-bottom:12px}
.breadcrumbs a{color:#ffebad}
.hero-simple{
  background:linear-gradient(180deg,var(--bg) 0%, var(--bg-2) 100%);
  color:#fff;padding:52px 20px 34px
}
.hero-simple-inner{max-width:var(--max);margin:0 auto}
.page-shell{max-width:var(--max);margin:0 auto}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:24px
}
.site-footer{
  background:#09111f;color:#e6eef8;padding:44px 20px 24px;margin-top:34px
}
.footer-inner{max-width:var(--max);margin:0 auto}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.footer-brand img{width:44px;height:44px}
.site-footer a{color:#ffe7a1}
.site-footer h4{margin:0 0 10px;color:#fff}
.footer-list{list-style:none;padding:0;margin:0}
.footer-list li{margin:0 0 8px}
.legal-note{
  margin-top:22px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12)
}
.hidden-text{
  position:absolute;left:-9999px
}

@media (max-width:1100px){
  .hero-inner,
  .section-visual,
  .review-layout,
  .footer-grid,
  .metrics-grid,
  .info-grid,
  .cards-grid,
  .bonus-grid,
  .game-grid,
  .criteria-grid,
  .steps-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .nav-toggle{display:inline-flex}
  .nav-links{
    display:none;position:absolute;left:14px;right:14px;top:72px;
    flex-direction:column;align-items:flex-start;gap:14px;
    background:#111b2e;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:16px
  }
  .nav-links.open{display:flex}
  .hero-inner,
  .hero-points,
  .hero-stats,
  .metrics-grid,
  .info-grid,
  .cards-grid,
  .bonus-grid,
  .game-grid,
  .criteria-grid,
  .steps-grid,
  .section-visual,
  .review-layout,
  .proscons,
  .author-box,
  .footer-grid,
  .compact-grid,
  .form-grid{grid-template-columns:1fr}
  .review-figure,.sticky-card{position:static}
  .section,.hero,.hero-simple,main,.site-footer,.header-inner{padding-left:14px;padding-right:14px}
  .section{padding:22px}
  .brand-subtitle{max-width:220px}
}
@media (max-width:520px){
  .hero h1{font-size:2.15rem}
  .section{padding:18px;border-radius:22px}
  .btn{width:100%}
}


.vendor-logo{
  display:flex;align-items:center;justify-content:center;
  min-height:84px;border:1px solid var(--line);border-radius:18px;
  background:#fff;padding:12px;margin-bottom:12px
}
.logo-strip{display:flex;flex-wrap:wrap;gap:12px}
.logo-chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:999px;background:#f1f5f9;border:1px solid var(--line);
  font-weight:800;color:var(--text)
}
.topic-list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px
}
.quote-box{
  border-left:4px solid var(--brand);
  background:#f0fdf4;border-radius:16px;padding:16px 18px;color:#14532d
}
.two-col{
  display:grid;grid-template-columns:1fr 1fr;gap:20px
}
@media (max-width:820px){
  .topic-list,.two-col{grid-template-columns:1fr}
}
