/* Mejores Casinos — emerald trust. Shared across GT + PA. */
*,*::before,*::after{box-sizing:border-box}
:root{
  --bg:#f4f8f6;--surface:#fff;--surface-2:#f3fbf7;
  --accent:#0E9F6E;--accent-d:#0a7d56;--accent-soft:#e6f6ef;
  --star:#F59E0B;--ink:#0b1f17;--muted:#5b6b64;--line:#e7efea;
  --radius:14px;--radius-s:10px;--shadow:0 1px 2px rgba(11,31,23,.04),0 8px 24px rgba(11,31,23,.06);
  --wrap:1100px;
}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-d);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-weight:700;border-radius:var(--radius-s);border:0;cursor:pointer;
  padding:.7em 1.4em;font-size:.98rem;line-height:1;transition:.15s ease;text-decoration:none}
.btn--play{background:var(--accent);color:#fff}
.btn--play:hover{background:var(--accent-d);text-decoration:none}
.btn--ghost{background:var(--accent-soft);color:var(--accent-d)}
.btn--ghost:hover{background:#d8f0e5;text-decoration:none}
.btn--lg{padding:.95em 1.9em;font-size:1.05rem}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;gap:18px;height:68px}
.brand{display:flex;align-items:center;gap:11px;flex:0 0 auto}
.brand:hover{text-decoration:none}
.brand img{width:38px;height:38px}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text b{font-size:1.02rem;font-weight:800;letter-spacing:-.01em;color:var(--ink)}
.brand-text span{font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--accent-d)}
.main-nav{display:flex;gap:4px;margin-left:auto;align-items:center}
.main-nav a{color:var(--ink);font-weight:600;font-size:.95rem;padding:.5em .8em;border-radius:8px}
.main-nav a:hover{background:var(--accent-soft);color:var(--accent-d);text-decoration:none}
.nav-dd{position:relative}
.nav-dd-top{display:inline-flex;align-items:center;gap:5px}
.nav-dd .caret{width:11px;height:11px;transition:transform .15s}
.nav-dd:hover .caret{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:230px;background:#fff;
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:8px;
  display:none;flex-direction:column;gap:1px;z-index:60;max-height:72vh;overflow:auto}
.nav-dd:hover .dropdown{display:flex}
.dropdown a{padding:.5em .8em;border-radius:8px;color:var(--ink);font-weight:600;font-size:.92rem;white-space:nowrap}
.dropdown a:hover{background:var(--accent-soft);color:var(--accent-d);text-decoration:none}
.dropdown a:first-child{font-weight:800;color:var(--accent-d);border-bottom:1px solid var(--line);
  border-radius:0;margin-bottom:4px;padding-bottom:.6em}
.lang{display:flex;gap:2px;align-items:center;margin-left:8px;
  background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:3px}
.lang a{font-size:.82rem;font-weight:800;color:var(--muted);padding:.25em .6em;border-radius:6px}
.lang a:hover{text-decoration:none;color:var(--ink)}
.lang a.active{background:var(--accent);color:#fff}
.burger{display:none;margin-left:auto;width:42px;height:42px;border:1px solid var(--line);
  background:var(--surface);border-radius:10px;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:20px;height:2px;background:var(--ink);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink)}
.burger span::before{top:-6px}.burger span::after{top:6px}
.mobile-nav{display:none;border-top:1px solid var(--line);background:var(--surface)}
.mobile-nav.open{display:block}
.mobile-nav nav{display:flex;flex-direction:column;padding:8px 0}
.mobile-nav a{padding:.8em 20px;color:var(--ink);font-weight:600;border-bottom:1px solid var(--line)}
.mobile-nav .mn-lang{display:flex;gap:8px;padding:14px 20px}
.mobile-nav .mn-lang a{flex:0 0 auto;border:1px solid var(--line);border-radius:8px;
  padding:.4em 1em;font-weight:800;font-size:.85rem;color:var(--muted)}
.mobile-nav .mn-lang a.active{background:var(--accent);color:#fff;border-color:transparent}
.mobile-nav .mn-group{border-bottom:1px solid var(--line)}
.mobile-nav .mn-group .mn-h{display:block;padding:.7em 20px .15em;font-size:.7rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.mobile-nav .mn-group a{display:block;padding:.5em 20px .5em 34px;border-bottom:0;font-weight:600;font-size:.93rem}
.mobile-nav .mn-group a:first-of-type{color:var(--accent-d);font-weight:700}

/* ---------- hero ---------- */
.hero{background:linear-gradient(180deg,var(--accent-soft),var(--bg));border-bottom:1px solid var(--line)}
.hero .wrap{padding:54px 20px 46px;text-align:center}
.hero h1{font-size:clamp(1.9rem,4.4vw,2.9rem);line-height:1.15;margin:0 0 16px;
  letter-spacing:-.02em;font-weight:800}
.hero p.lead{font-size:1.12rem;color:var(--muted);max-width:680px;margin:0 auto 22px}
.trust-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 0 26px}
.chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface);
  border:1px solid var(--line);border-radius:999px;padding:.45em 1em;font-size:.85rem;
  font-weight:700;color:var(--ink);box-shadow:var(--shadow)}
.chip svg{width:15px;height:15px;color:var(--accent)}

/* ---------- ranking ---------- */
.ranking{margin:-30px auto 0;position:relative;z-index:2}
.rank-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden}
.rank-card__title{display:flex;align-items:center;gap:10px;padding:18px 22px;border-bottom:1px solid var(--line)}
.rank-card__title h2{margin:0;font-size:1.15rem;font-weight:800}
.rank-card__title .badge-live{margin-left:auto;font-size:.74rem;font-weight:800;color:var(--accent-d);
  background:var(--accent-soft);border-radius:999px;padding:.3em .8em}
.rank-head,.rank-row{display:grid;grid-template-columns:46px 1.3fr 1.4fr auto auto;
  align-items:center;gap:16px;padding:14px 22px}
.rank-head{font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  color:var(--muted);border-bottom:1px solid var(--line);background:#fbfdfc}
.rank-row{border-bottom:1px solid var(--line)}
.rank-row:last-child{border-bottom:0}
.rank-row:hover{background:#fbfdfc}
.rank-row.is-top{background:var(--surface-2)}
.rank-badge{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:1rem;background:#eef2f0;color:var(--muted)}
.rank-row.is-top .rank-badge{background:var(--accent);color:#fff}
.brand-cell{display:flex;align-items:center}
.brand-chip{display:inline-flex;align-items:center;height:36px;padding:0 16px;border-radius:9px;
  font-weight:800;font-size:1.02rem;letter-spacing:-.01em;background:var(--chip,#1a5dab);color:#fff;white-space:nowrap}
.brand-chip.is-dark{color:var(--ink)}
.brand-logo{display:inline-flex;align-items:center;justify-content:center;width:174px;height:58px;
  padding:8px 14px;background:#fff;border:1px solid var(--line);border-radius:10px;flex:0 0 auto}
.brand-logo img{width:146px;height:auto;max-height:46px;object-fit:contain;display:block}
.brand-logo--dark{background:#16243f;border-color:#16243f}
.bonus-cell{display:flex;flex-direction:column;gap:1px}
.bonus-cell .lbl{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.bonus-cell .val{font-size:.96rem;font-weight:600;line-height:1.3}
.score-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:64px;gap:3px}
.stars{font-size:17px;letter-spacing:2px;line-height:1;
  background:linear-gradient(90deg,var(--star) var(--pct,100%),#d7dee0 var(--pct,100%));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.score-num{display:block;font-weight:800;font-size:.92rem;margin-top:3px;color:var(--ink)}
.rank-card__foot{padding:14px 22px;font-size:.8rem;color:var(--muted);background:#fbfdfc;text-align:center}

/* ---------- method strip ---------- */
.section{padding:46px 0}
.section-eyebrow{text-align:center;font-size:.78rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.1em;color:var(--accent-d);margin:0 0 6px}
.section-title.as-h{text-align:center;font-size:1.6rem;font-weight:800;margin:0 0 28px;letter-spacing:-.01em}
.faq-section .section-title.as-h{margin-bottom:22px}
.method .m-title{margin:0 0 6px;font-size:1.05rem;font-weight:800}
.end-cta .cta-h{font-size:1.35rem;font-weight:800;margin:0 0 8px}
.methods{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.method{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.method .ic{width:42px;height:42px;border-radius:11px;background:var(--accent-soft);
  display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.method .ic svg{width:22px;height:22px;color:var(--accent-d)}
.method h3{margin:0 0 6px;font-size:1.05rem;font-weight:800}
.method p{margin:0;font-size:.92rem;color:var(--muted);line-height:1.55}

/* ---------- article ---------- */
.article-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:38px 44px;margin:0 0 30px}
.article{font-size:1.02rem}
.article h1{font-size:clamp(1.7rem,3.4vw,2.3rem);line-height:1.2;margin:0 0 20px;letter-spacing:-.02em;font-weight:800}
.article h2{font-size:1.42rem;font-weight:800;margin:36px 0 14px;padding-top:6px;letter-spacing:-.01em}
.article h3{font-size:1.14rem;font-weight:700;margin:26px 0 10px}
.article p{margin:0 0 16px}
.article ul,.article ol{margin:0 0 18px;padding-left:1.4em}
.article li{margin:0 0 8px}
.article strong{font-weight:700}
.article a{color:var(--accent-d);font-weight:600}
.article table{width:100%;border-collapse:collapse;margin:0 0 22px;font-size:.95rem;
  table-layout:fixed;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.article th,.article td{padding:.7em .85em;text-align:left;border-bottom:1px solid var(--line);
  overflow-wrap:anywhere;word-break:break-word;vertical-align:top}
.article thead th{background:var(--accent-soft);color:var(--accent-d);font-weight:800;
  font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}
.article tbody tr:nth-child(even){background:#fbfdfc}
.article tbody tr:last-child td{border-bottom:0}

/* ---------- breadcrumbs ---------- */
.crumbs{font-size:.85rem;color:var(--muted);padding:20px 0 0}
.crumbs a{color:var(--muted);font-weight:600}
.crumbs a:hover{color:var(--accent-d)}
.crumbs span{margin:0 .5em;opacity:.6}

/* ---------- top-3 mini widget ---------- */
.top3{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:24px;margin:0 0 30px}
.top3 h2{margin:0 0 16px;font-size:1.15rem;font-weight:800;display:flex;align-items:center;gap:8px}
.top3 h2 svg{width:18px;height:18px;color:var(--star)}
.top3 .t3-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.top3 .t3-grid li{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;text-align:center;border:1px solid var(--line);border-radius:12px;padding:22px 14px;background:#fbfdfe}
.top3 .t3-rank{position:absolute;top:10px;left:10px;width:24px;height:24px;border-radius:7px;
  background:var(--accent);color:#fff;font-weight:800;font-size:.8rem;display:flex;align-items:center;justify-content:center}
.top3 .brand-logo{width:148px;height:52px}
.top3 .brand-logo img{width:122px;height:auto;max-height:32px}
.top3 .t3-rate{display:flex;flex-direction:column;align-items:center;gap:3px;line-height:1}
.top3 .t3-rate .stars{font-size:15px}
.top3 .t3-rate b{font-size:1rem;color:var(--accent-d)}
.top3 .t3-all{width:100%;margin-top:16px}
@media (max-width:620px){
  .top3 .t3-grid{grid-template-columns:1fr}
  .top3 .t3-grid li{flex-direction:row;justify-content:flex-start;gap:14px;padding:12px 14px 12px 44px;text-align:left}
  .top3 .t3-rate{margin-left:auto;align-items:flex-end}
}

/* ---------- end-cta ---------- */
.end-cta{background:linear-gradient(135deg,var(--accent),var(--accent-d));color:#fff;
  border-radius:var(--radius);padding:30px;text-align:center;margin:0 0 30px}
.end-cta h2{margin:0 0 8px;font-size:1.3rem;font-weight:800;color:#fff}
.end-cta p{margin:0 0 18px;opacity:.92}
.end-cta .btn{background:#fff;color:var(--accent-d)}
.end-cta .btn:hover{background:#f0fff8}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:12px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-s);overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:18px 20px;
  font-weight:700;font-size:1.02rem;color:var(--ink);display:flex;align-items:center;gap:12px}
.faq-q::after{content:"";margin-left:auto;width:10px;height:10px;border-right:2px solid var(--accent-d);
  border-bottom:2px solid var(--accent-d);transform:rotate(45deg);transition:.2s;flex:0 0 auto}
.faq-item.open .faq-q::after{transform:rotate(-135deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;padding:0 20px}
.faq-item.open .faq-a{max-height:600px;padding:0 20px 18px}
.faq-a p{margin:0;color:var(--muted)}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#cdd8d2;margin-top:40px}
.site-footer .wrap{padding:40px 20px 30px}
.foot-top{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between;
  padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand{max-width:330px}
.foot-brand .brand-text b{color:#fff}
.foot-brand p{font-size:.86rem;color:#94a59d;margin:12px 0 0;line-height:1.6}
.foot-nav{display:flex;gap:46px;flex-wrap:wrap}
.foot-nav .col .col-title{font-size:.95rem;font-weight:700;letter-spacing:.01em;color:#fff;margin:0 0 12px}
.foot-nav .col a{display:block;color:#94a59d;font-size:.9rem;padding:4px 0}
.foot-nav .col a:hover{color:#fff;text-decoration:none}
.foot-bottom{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;padding-top:22px}
.foot-bottom p{margin:0;font-size:.8rem;color:#7e8f88}
.age-badge{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;font-weight:700;color:#cdd8d2}
.age-badge b{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;
  border:2px solid #e85b5b;color:#e85b5b;border-radius:50%;font-size:.72rem}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .main-nav,.lang{display:none}
  .burger{display:flex}
  .methods{grid-template-columns:1fr 1fr}
  .article-wrap{padding:28px 22px}
  .rank-head{display:none}
  .rank-row{grid-template-columns:34px 1fr auto;
    grid-template-areas:"badge brand score" "bonus bonus cta";
    column-gap:12px;row-gap:12px;padding:16px 16px;align-items:center}
  .rank-row .rank-badge{grid-area:badge;align-self:center}
  .brand-cell{grid-area:brand;justify-self:start}
  .bonus-cell{grid-area:bonus;align-self:center}
  .score-cell{grid-area:score;align-self:center;justify-self:end}
  .rank-row .rank-cta{grid-area:cta;justify-self:end;align-self:center}
  .brand-logo{width:138px;height:50px;padding:6px 10px}
  .brand-logo img{width:114px;height:auto;max-height:34px}
  .rank-card__title{flex-wrap:wrap;gap:8px;padding:16px 18px}
  .rank-card__title h2{font-size:1.08rem}
  .rank-card__title .badge-live{font-size:.66rem;padding:.28em .6em;white-space:nowrap;margin-left:0}
}
@media (max-width:560px){
  body{font-size:16px}
  .hero .wrap{padding:40px 20px 40px}
  .methods{grid-template-columns:1fr}
  .article-wrap{padding:24px 18px}
  .article table{font-size:.8rem}
  .article thead th{padding:.5em .5em;font-size:.66rem}
  .article tbody td{padding:.5em .5em}
  .brand-chip{font-size:.92rem;padding:0 12px;height:32px}
  .foot-nav{gap:30px}
}
