@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500;600;700;800;900&display=swap');

:root{
  --bg:#f4f6fa;
  --ink:#1f2530;
  --ink-2:#303743;
  --muted:#7a8290;
  --line:#dce2ea;
  --line-2:#d3d9e2;
  --card:#ffffff;
  --soft:#eef1f6;
  --accent:#ff746b;
  --accent-2:#ff8b83;
  --dark:#202832;
  --dark-2:#121820;
  --success:#2f6f4e;
  --danger:#b42318;
  --shadow-sm:0 8px 20px rgba(31,37,48,.06);
  --shadow-md:0 16px 34px rgba(31,37,48,.12);
  --shadow-lg:0 28px 70px rgba(31,37,48,.22);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--dark-2) var(--soft)}
body{margin:0;min-height:100vh;overflow-x:hidden;background:var(--bg);color:var(--ink);font-family:'Montserrat',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif}
body.modal-open{overflow:hidden}
a{color:inherit;text-decoration:none}
button,input{font:inherit}
button{cursor:pointer}
svg{display:block}
img{display:block;max-width:100%}
[hidden]{display:none!important}

::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-track{background:var(--soft)}
::-webkit-scrollbar-thumb{background:var(--dark-2);border:2px solid var(--soft);border-radius:999px}
::-webkit-scrollbar-thumb:hover{background:#000}

.lobby-shell{min-height:100vh;display:flex;flex-direction:column}
.top-header{position:sticky;top:0;z-index:40;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 6px 24px rgba(31,37,48,.06)}
.header-row{height:78px;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:0 48px}
.brand,.brand--text{color:var(--ink-2);font-size:25px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;line-height:1;white-space:nowrap}
.header-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;flex-wrap:wrap}
.header-btn{height:44px;min-width:126px;border:1px solid var(--line-2);border-radius:10px;background:#fff;color:var(--ink);padding:0 30px;font-size:15px;font-weight:900;letter-spacing:.02em;display:inline-flex;align-items:center;justify-content:center;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,color .18s ease}
.header-btn--gold,.header-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 14px 26px rgba(255,116,107,.22);transform:translateY(-1px)}
.header-btn--outline{background:#fff;color:var(--ink);border-color:var(--line-2)}
.session-chip{min-height:42px;border:1px solid #d8dee8;background:#fff;border-radius:10px;padding:0 15px;display:inline-flex;align-items:center;gap:9px;font-weight:800;color:#252c36;box-shadow:none}
.session-chip svg{width:18px;height:18px;fill:var(--accent)}
.session-chip--balance strong{font-weight:900}

.hero-slider{position:relative;width:100%;margin:0;padding:0;background:var(--dark)}
.hero-slider__viewport{position:relative;height:min(480px,42vw);min-height:330px;overflow:hidden;background:var(--dark)}
.hero-slide{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .42s ease}
.hero-slide.is-active{opacity:1;pointer-events:auto}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-slide__overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(22,28,36,.80) 0%,rgba(22,28,36,.45) 42%,rgba(22,28,36,.16) 100%)}
.hero-slide__content{position:absolute;left:70px;bottom:58px;z-index:2;max-width:680px;color:#fff}
.hero-slide__eyebrow{display:inline-flex;align-items:center;border:1px solid rgba(255,255,255,.14);border-radius:10px;background:rgba(255,255,255,.14);padding:9px 14px;margin-bottom:16px;color:#fff;font-size:12px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;backdrop-filter:blur(10px)}
.hero-slide__content h1,.hero-slide__content h2{margin:0 0 12px;color:#fff;font-size:clamp(42px,5.8vw,76px);font-weight:900;line-height:.94;letter-spacing:-.055em;text-transform:uppercase;text-shadow:0 8px 28px rgba(0,0,0,.25)}
.hero-slide__content p{max-width:610px;margin:0;color:rgba(255,255,255,.92);font-size:18px;font-weight:700;line-height:1.6}
.hero-slider__nav{position:absolute;top:50%;z-index:3;display:grid;place-items:center;width:46px;height:46px;border:1px solid rgba(255,255,255,.18);border-radius:10px;background:rgba(31,37,48,.68);box-shadow:0 12px 30px rgba(0,0,0,.18);color:#fff;font-size:30px;line-height:1;transform:translateY(-50%);transition:.18s ease}
.hero-slider__nav:hover{background:var(--accent);color:#fff}
.hero-slider__nav--prev{left:34px}
.hero-slider__nav--next{right:34px}
.hero-slider__dots{position:absolute;left:50%;bottom:20px;z-index:3;display:flex;align-items:center;gap:10px;transform:translateX(-50%)}
.hero-slider__dot{width:8px;height:8px;border:0;border-radius:999px;background:rgba(255,255,255,.42);padding:0;transition:.18s ease}
.hero-slider__dot.is-active{width:32px;background:var(--accent)}

.catalog-panel{width:100%;margin:0 auto 32px;padding:26px 48px 0;background:var(--bg)}
.toolbar-section.toolbar-section--search-only{display:block;margin-bottom:18px}
.search-box{width:min(100%,560px);height:44px;border:1px solid #d9dee8;border-radius:9px;background:#fff;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:11px;padding:0 15px}
.search-icon{width:19px;height:19px;flex:0 0 auto;fill:#596273}
.search-box input{width:100%;height:100%;min-width:0;border:0;outline:0;background:transparent;color:var(--ink);font-size:14px;font-weight:800;padding:0}
.search-box input::placeholder{color:#8a93a2}

.category-strip{display:flex;gap:10px;overflow-x:auto;padding:0 0 18px;margin:8px 0 12px;border-bottom:1px solid var(--line)}
.cat-btn{height:46px;min-width:150px;border:1px solid #d7dde7;border-radius:9px;background:#fff;color:#2d3540;display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:0 16px;font-size:14px;font-weight:900;box-shadow:0 8px 20px rgba(31,37,48,.045);transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease,border-color .18s ease}
.cat-btn:hover,.cat-btn.is-active{background:var(--dark);border-color:var(--dark);color:#fff;box-shadow:0 12px 26px rgba(31,37,48,.16);transform:translateY(-1px)}
.cat-btn.is-hidden{display:none}
.cat-icon{width:20px;height:20px;object-fit:contain}
.cat-btn:not(.is-active):not(:hover) .cat-icon{filter:brightness(0) saturate(100%) opacity(.85)}
.cat-btn.is-active .cat-icon,.cat-btn:hover .cat-icon{filter:brightness(0) invert(1)}
.cat-count{min-width:22px;height:22px;border-radius:999px;background:#edf0f4;color:#596273;display:inline-flex;align-items:center;justify-content:center;padding:0 7px;font-size:11px;font-weight:900;line-height:1}
.cat-btn.is-active .cat-count,.cat-btn:hover .cat-count{background:rgba(255,255,255,.16);color:#fff}

.catalog-status{min-height:28px;color:#667081;font-size:14px;font-weight:900;margin:10px 0 18px}
.catalog-status.is-ok{color:var(--success)}
.catalog-status.is-error{color:var(--danger)}
.games-section{width:100%}
.games-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:24px 18px}
.game-card{min-width:0}
.game-card__media{position:relative;display:block;width:100%;aspect-ratio:4/3;border:0;border-radius:12px;overflow:hidden;background:#e5e9f0;box-shadow:var(--shadow-md);padding:0;transition:transform .22s ease,box-shadow .22s ease,filter .22s ease}
.game-card__media:hover{transform:translateY(-3px);box-shadow:0 22px 42px rgba(31,37,48,.17);filter:saturate(1.04)}
.game-card__media img{width:100%;height:100%;object-fit:cover;background:#fff}
.game-card--fallback .game-card__media{background:#fff;border:1px solid #e4e8ef;box-shadow:0 14px 30px rgba(31,37,48,.08)}
.game-card--fallback .game-card__media img{object-fit:contain;padding:32px;background:#fff}
.game-badge{position:absolute;top:10px;left:10px;z-index:2;border-radius:7px;background:var(--dark);color:#fff;padding:7px 10px;font-size:11px;font-weight:900;backdrop-filter:blur(8px)}
.game-favorite{position:absolute;top:10px;right:10px;z-index:2;width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.9);color:var(--dark);display:grid;place-items:center;font-size:20px;font-weight:900;box-shadow:0 8px 18px rgba(31,37,48,.12)}
.game-title{margin:10px 0 0;text-align:center;font-size:14px;line-height:1.28;font-weight:900;color:#252c36}
.game-provider{display:block;margin-top:4px;text-align:center;font-size:11px;font-weight:900;color:#8b6260;text-transform:uppercase;letter-spacing:.08em}
.empty-card{grid-column:1/-1;min-height:170px;border:1px dashed #cfd6e1;border-radius:12px;background:#fff;padding:32px;display:grid;place-items:center;text-align:center;color:#6b7280;font-weight:900}
.empty-card small{display:block;margin-top:8px;color:#8a93a2}


.auth-modal-backdrop,.account-modal-backdrop,.game-modal-backdrop{position:fixed;inset:0;background:rgba(17,24,32,.62);backdrop-filter:blur(12px);z-index:80}
.auth-modal,.account-modal,.game-modal{position:fixed;inset:0;z-index:81;display:grid;place-items:center;padding:18px}
.auth-modal-card,.account-modal-card{position:relative;width:min(100%,520px);max-height:calc(100dvh - 36px);overflow:auto;background:#fff;border:1px solid #d7dde7;border-radius:14px;box-shadow:var(--shadow-lg);padding:30px}
.auth-modal-card--sm{width:min(100%,440px)}
.auth-close,.account-close{position:absolute;top:14px;right:16px;width:36px;height:36px;border:0;border-radius:9px;background:#edf0f4;color:var(--ink);font-size:28px;line-height:1}
.auth-close:hover,.account-close:hover{background:var(--dark);color:#fff}
.auth-modal-card h2,.account-modal-card h2{margin:0 0 20px;text-align:center;font-size:28px;font-weight:900}
.auth-alert{border-radius:12px;background:#fef3f2;color:var(--danger);border:1px solid #fecdca;padding:12px 14px;margin-bottom:16px;font-weight:800;font-size:13px}
.auth-form{display:flex;flex-direction:column;gap:12px}
.auth-field{display:flex;flex-direction:column;gap:7px;color:#374151;font-weight:800;font-size:13px}
.auth-field input{height:48px;border:1.5px solid #d7dde7;border-radius:10px;background:#fff;color:var(--ink);padding:0 14px;outline:0;font-weight:700}
.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(255,116,107,.16)}
.password-wrap{display:flex;align-items:center;position:relative}
.password-wrap input{width:100%;padding-right:52px}
.password-toggle{position:absolute;right:6px;width:40px;height:40px;border:0;background:transparent;border-radius:8px}
.auth-check{display:flex;align-items:flex-start;gap:10px;font-size:12px;line-height:1.45;color:#4b5563;font-weight:700}
.auth-check input{margin-top:3px;accent-color:var(--accent)}
.auth-submit,.account-option{min-height:52px;border:0;border-radius:9px;background:var(--accent);color:#fff;font-weight:900;margin-top:8px;box-shadow:0 12px 24px rgba(255,116,107,.2)}
.auth-submit:hover,.account-option:hover{background:#ec655d}
.account-summary{border-radius:12px;background:#f8fafc;border:1px solid #d7dde7;padding:18px;display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.account-summary strong{font-size:24px}
.account-summary small{font-weight:800;color:#6b7280}
.account-option{width:100%}

.game-modal{place-items:stretch;padding:0}
.game-modal-card{width:100%;height:100%;background:#0b0d12;border-radius:0;box-shadow:none;overflow:hidden;display:flex;flex-direction:column}
.game-modal-header{height:58px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 18px;background:#111820;color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
.game-modal-header strong{font-weight:900}
.game-modal-actions{display:flex;align-items:center;gap:8px}
.game-modal-actions button{width:38px;height:38px;border:1px solid rgba(255,255,255,.16);border-radius:8px;background:rgba(255,255,255,.08);color:#fff;font-size:22px;line-height:1}
.game-modal-actions button:hover{background:var(--accent)}
#gameFrame{width:100%;height:100%;border:0;background:#000;flex:1}

@media (min-width:1680px){
  .games-grid{grid-template-columns:repeat(6,minmax(0,1fr))}
}
@media (max-width:1280px){
  .games-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
  .hero-slider__viewport{height:420px;min-height:300px}
}
@media (max-width:1024px){
  .header-row{padding:0 22px}
  .hero-slide__content{left:36px;right:36px;bottom:42px}
  .hero-slider__nav--prev{left:22px}
  .hero-slider__nav--next{right:22px}
  .catalog-panel{padding-left:22px;padding-right:22px}
  .search-box{max-width:none;width:100%}
  .games-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (max-width:900px){
  .games-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:760px){
  .header-row{min-height:68px;height:auto;padding:10px 14px}
  .brand,.brand--text{font-size:18px;letter-spacing:.05em}
  .header-actions{gap:8px}
  .header-btn{height:38px;min-width:92px;border-radius:8px;font-size:12px;padding:0 14px}
  .session-chip{min-height:36px;font-size:12px;padding:0 10px}
  .hero-slider__viewport{height:260px;min-height:240px}
  .hero-slide__content{left:18px;right:18px;bottom:22px}
  .hero-slide__content h1,.hero-slide__content h2{font-size:32px}
  .hero-slide__content p{font-size:13px;max-width:330px}
  .hero-slide__eyebrow{font-size:10px;border-radius:8px;padding:7px 10px}
  .hero-slider__nav{width:36px;height:36px;border-radius:8px;font-size:23px}
  .catalog-panel{padding:18px 14px 0}
  .toolbar-section.toolbar-section--search-only{margin-bottom:12px}
  .search-box{height:42px;border-radius:8px}
  .search-box input{font-size:13px}
  .search-icon{width:18px;height:18px}
  .provider-btn,.cat-btn{height:42px;border-radius:8px;font-size:12px}
  .cat-btn{min-width:126px}
  .cat-count{height:20px;min-width:20px;font-size:10px}
  .games-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:17px 12px}
  .game-card__media{border-radius:10px}
  .game-title{font-size:12px}
  .game-provider{font-size:10px}
  .auth-modal-card,.account-modal-card{padding:24px 18px}
}


/* Casino Jeff v1.9 - catálogo 184x184 / 6 columnas compacto */
.catalog-panel{padding-left:40px;padding-right:40px}
.games-grid{
  display:grid;
  grid-template-columns:repeat(6,184px) !important;
  justify-content:start;
  align-items:start;
  column-gap:14px;
  row-gap:28px;
}
.game-card{width:184px;min-width:184px;max-width:184px;margin:0}
.game-card__media{
  width:184px;
  height:184px;
  aspect-ratio:auto;
  border-radius:12px;
  background:#fff;
  box-shadow:0 12px 26px rgba(31,37,48,.09);
}
.game-card__media img{width:100%;height:100%;object-fit:cover;background:#fff}
.game-title{font-size:13px;line-height:1.25;margin-top:10px;min-height:32px;display:flex;align-items:flex-start;justify-content:center;text-align:center}
.game-provider{font-size:10px;margin-top:3px;letter-spacing:.12em;color:#8b6260}
.game-card--fallback .game-card__media{border:1px solid #e4e8ef;background:linear-gradient(145deg,#f8fafc 0%,#edf1f6 100%);box-shadow:0 10px 24px rgba(31,37,48,.07)}
.game-card--fallback .game-card__media img{display:none}
.game-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:18px;text-align:center;background:#fff}
.game-placeholder::before{content:"";position:absolute;inset:16px;border:1px solid rgba(31,37,48,.08);border-radius:10px;pointer-events:none}
.game-placeholder__logo{width:58px;height:58px;object-fit:contain;opacity:.86;display:block!important;background:transparent!important}
.game-badge{top:8px;left:8px;border-radius:7px;padding:6px 9px;font-size:10px}
.game-favorite{top:8px;right:8px;width:32px;height:32px;border-radius:8px;font-size:19px}
@media (max-width:1440px){
  .catalog-panel{padding-left:34px;padding-right:34px}
  .games-grid{grid-template-columns:repeat(6,184px) !important;justify-content:start;column-gap:12px}
}
@media (max-width:1260px){
  .catalog-panel{padding-left:24px;padding-right:24px}
  .games-grid{grid-template-columns:repeat(6,184px) !important;justify-content:start;column-gap:8px}
}
@media (max-width:1180px){
  .games-grid{grid-template-columns:repeat(5,184px) !important;justify-content:start;column-gap:12px}
}
@media (max-width:1020px){
  .games-grid{grid-template-columns:repeat(4,184px) !important;justify-content:start;column-gap:12px}
}
@media (max-width:820px){
  .games-grid{grid-template-columns:repeat(3,184px) !important;justify-content:start;column-gap:12px}
}
@media (max-width:660px){
  .catalog-panel{padding-left:14px;padding-right:14px}
  .games-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:20px 12px}
  .game-card{width:100%;min-width:0;max-width:none}
  .game-card__media{width:100%;height:auto;aspect-ratio:1/1;border-radius:10px}
}
