/* ============================================================
   Gamelo Core — frontend styles (used in conjunction with theme)
   ============================================================ */

/* ---- Toasts / Flash messages ---- */
.gamelo-flash-stack{display:flex;flex-direction:column;gap:8px;margin:18px 0}
.gamelo-flash{padding:12px 16px;border-radius:10px;font-weight:600;border:1px solid transparent}
.gamelo-flash--success{background:rgba(34,197,94,.12);color:#15803d;border-color:rgba(34,197,94,.35)}
.gamelo-flash--error  {background:rgba(239,68,68,.12);color:#b91c1c;border-color:rgba(239,68,68,.35)}
.gamelo-flash--warning{background:rgba(245,158,11,.12);color:#92400e;border-color:rgba(245,158,11,.35)}
.gamelo-flash--info   {background:rgba(59,130,246,.12);color:#1e40af;border-color:rgba(59,130,246,.35)}

.g-toast{position:fixed;bottom:30px;left:30px;z-index:10000;background:#0F1120;color:#fff;padding:14px 20px;border-radius:12px;border:1px solid rgba(255,255,255,.1);box-shadow:0 12px 35px rgba(0,0,0,.45);font-weight:600;transition:transform .25s ease,opacity .25s ease;transform:translateY(0)}
.g-toast--success{border-color:rgba(183,246,66,.4)}
.g-toast--error  {border-color:rgba(255,61,138,.4)}
.g-toast--warning{border-color:rgba(255,200,69,.4)}
.g-toast.is-out  {opacity:0;transform:translateY(20px)}

/* ---- Live search ---- */
.g-live-results{position:absolute;top:100%;right:0;left:0;background:#0F1120;border:1px solid rgba(255,255,255,.08);border-radius:14px;margin-top:6px;max-height:420px;overflow-y:auto;z-index:50;display:none;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.g-live-results.is-open{display:block}
.g-live-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.05);color:#fff;text-decoration:none;transition:background .15s}
.g-live-row:hover{background:rgba(183,246,66,.08)}
.g-live-row img,.g-live-thumb-fb{width:48px;height:48px;object-fit:cover;border-radius:8px;background:#1D2240;display:flex;align-items:center;justify-content:center;color:var(--g-lime,#B7F642)}
.g-live-row strong{display:block;font-size:.95rem}
.g-live-row small{color:#9ca3af;font-size:.78rem}
.g-live-price{margin-inline-start:auto;color:var(--g-lime,#B7F642);font-family:monospace;font-weight:700}
.g-live-loading,.g-live-empty{padding:18px;text-align:center;color:#9ca3af}

/* ---- Floating WhatsApp button ---- */
.g-whatsapp-fab{position:fixed;bottom:24px;left:24px;z-index:9999;background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;box-shadow:0 14px 38px rgba(37,211,102,.45),0 0 0 12px rgba(37,211,102,.15);text-decoration:none;animation:gPulse 2.4s infinite}
.g-whatsapp-fab::after{content:attr(data-label);position:absolute;bottom:calc(100% + 8px);left:0;background:#0F1120;color:#fff;padding:6px 12px;border-radius:6px;font-size:.78rem;white-space:nowrap;opacity:0;transform:translateY(6px);transition:.2s}
.g-whatsapp-fab:hover::after{opacity:1;transform:translateY(0)}
@keyframes gPulse{0%,100%{box-shadow:0 14px 38px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,.7)}50%{box-shadow:0 14px 38px rgba(37,211,102,.45),0 0 0 18px rgba(37,211,102,0)}}

/* ---- Top utility bar (currency / lang / login) ---- */
.g-utility-bar{display:flex;gap:12px;align-items:center;justify-content:flex-end;font-size:.8rem;color:#9aa0bf}
.g-utility-bar a,.g-utility-bar button{color:#fff;background:transparent;border:1px solid rgba(255,255,255,.1);padding:5px 10px;border-radius:6px;text-decoration:none;font-size:.78rem;font-family:inherit;cursor:pointer;transition:.18s}
.g-utility-bar a:hover,.g-utility-bar button:hover{border-color:var(--g-lime,#B7F642);color:var(--g-lime,#B7F642)}
.g-utility-bar .is-active{background:var(--g-lime,#B7F642);color:#0A0B14 !important;border-color:transparent}
.g-utility-bar .g-balance-pill{background:rgba(183,246,66,.12);border:1px solid rgba(183,246,66,.3);color:#B7F642;padding:5px 12px;border-radius:999px;font-weight:700;font-family:monospace}

/* ---- Notification bell ---- */
.g-bell{position:relative;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.05);color:#fff;cursor:pointer;border:1px solid rgba(255,255,255,.08)}
.g-bell:hover{background:rgba(255,255,255,.1)}
.g-bell-count{position:absolute;top:-4px;left:-4px;background:#FF3D8A;color:#fff;min-width:18px;height:18px;border-radius:999px;font-size:11px;display:flex;align-items:center;justify-content:center;padding:0 5px;font-weight:700}
.g-bell-count.hide{display:none}
.g-bell-drawer{position:absolute;top:calc(100% + 10px);left:0;width:340px;background:#0F1120;border:1px solid rgba(255,255,255,.1);border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.45);display:none;z-index:200}
.g-bell-drawer.is-open{display:block}
.g-bell-drawer h4{padding:14px 16px;margin:0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.9rem;color:#fff}
.g-bell-item{display:block;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.05);color:#cbd0e8;text-decoration:none;font-size:.85rem}
.g-bell-item:hover{background:rgba(183,246,66,.05)}
.g-bell-item.is-read{opacity:.5}
.g-bell-item strong{color:#fff;display:block;margin-bottom:2px}
.g-bell-item small{color:#7c83a3;font-size:.72rem}

/* ---- Forms ---- */
.g-form label{display:block;margin-bottom:14px;color:#fff;font-weight:500}
.g-form input,.g-form select,.g-form textarea{
  width:100%;background:rgba(255,255,255,.04);color:#fff;border:1px solid rgba(255,255,255,.1);
  padding:12px 14px;border-radius:10px;font:inherit;font-family:inherit;margin-top:6px
}
.g-form input:focus,.g-form select:focus,.g-form textarea:focus{outline:none;border-color:var(--g-lime,#B7F642);box-shadow:0 0 0 3px rgba(183,246,66,.15)}
.g-form input.is-error,.g-form select.is-error{border-color:#ef4444}

/* ---- Generic content boxes ---- */
.g-hero-page{background:linear-gradient(135deg,#0F1120 0%,#1D2240 100%);padding:80px 0 50px;text-align:center;border-bottom:1px solid rgba(255,255,255,.05)}
.g-hero-page h1{font-size:clamp(2rem,4vw,3.2rem);color:#fff;margin:.6em 0 .3em}
.g-hero-page .lead{color:#a4aac8;max-width:680px;margin:0 auto;font-size:1.05rem}
.g-page-content{padding:50px 0 80px}
.g-page-content h2{color:#fff;margin:1.4em 0 .6em;font-size:1.5rem}
.g-page-content p,.g-page-content li{color:#cbd0e8;line-height:1.85;font-size:1rem}
.g-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:30px}
@media(max-width:768px){.g-grid-2{grid-template-columns:1fr}}
.g-cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:20px}
@media(max-width:900px){.g-cards-4{grid-template-columns:repeat(2,1fr)}}
.g-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);padding:24px;border-radius:14px;transition:.25s;text-align:center}
.g-card:hover{transform:translateY(-4px);border-color:var(--g-lime,#B7F642)}
.g-card i{font-size:2.2rem;color:var(--g-lime,#B7F642);margin-bottom:12px;display:inline-block}
.g-card h3{color:#fff;margin:10px 0;font-size:1.05rem}
.g-card p{color:#a4aac8;font-size:.9rem;line-height:1.6;margin:0}
.g-box{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);padding:30px;border-radius:16px}
.g-box h2{color:#fff;margin-top:0}
.g-box .btn{margin-top:18px}

.g-checks{list-style:none;padding:0}
.g-checks li{display:flex;align-items:flex-start;gap:10px;padding:6px 0;color:#cbd0e8}
.g-checks li i{color:#22c55e;margin-top:5px}
.g-x-list{list-style:none;padding:0}
.g-x-list li{display:flex;align-items:flex-start;gap:10px;padding:6px 0;color:#cbd0e8}
.g-x-list li i{color:#ef4444;margin-top:5px}

.g-alert{display:flex;gap:14px;align-items:flex-start;padding:18px 22px;border-radius:12px;margin:24px 0;border:1px solid;font-size:.95rem}
.g-alert i{font-size:1.4rem;margin-top:2px}
.g-alert--info{background:rgba(59,130,246,.08);border-color:rgba(59,130,246,.3);color:#a8c4ff}
.g-alert--warning{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.3);color:#fcd34d}
.g-alert--success{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.3);color:#86efac}
.g-alert--danger{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.3);color:#fca5a5}

.g-cta-box{margin-top:50px;display:flex;justify-content:space-between;align-items:center;gap:24px;background:linear-gradient(135deg,rgba(183,246,66,.08) 0%,rgba(255,61,138,.08) 100%);border:1px solid rgba(183,246,66,.2);padding:30px 36px;border-radius:18px;flex-wrap:wrap}
.g-cta-box h2{color:#fff;margin:0 0 6px}
.g-cta-box p{margin:0;color:#a4aac8}
.g-cta-actions{display:flex;gap:12px;flex-wrap:wrap}
.g-balance{font-size:2.4rem;color:var(--g-lime,#B7F642);margin:0;font-family:monospace;font-weight:800}

/* ---- Steps ---- */
.g-steps{list-style:none;padding:0;display:grid;grid-template-columns:1fr;gap:18px;counter-reset:s}
.g-steps li{display:flex;gap:18px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);padding:24px;border-radius:14px}
.g-steps .num{flex-shrink:0;width:56px;height:56px;border-radius:50%;background:var(--g-lime,#B7F642);color:#0A0B14;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.4rem;font-family:monospace}
.g-steps h3{color:#fff;margin:0 0 6px}
.g-steps p{color:#a4aac8;margin:0;line-height:1.7}
.g-steps a{color:var(--g-lime,#B7F642)}
.g-ol{padding-inline-start:1.4em}
.g-ol li{color:#cbd0e8;margin-bottom:10px;line-height:1.7}

/* ---- FAQ accordion ---- */
.g-faq{display:flex;flex-direction:column;gap:10px}
.g-faq-item{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:0;overflow:hidden}
.g-faq-item summary{padding:18px 22px;color:#fff;font-weight:600;cursor:pointer;display:flex;gap:12px;align-items:center;list-style:none}
.g-faq-item summary::-webkit-details-marker{display:none}
.g-faq-item summary i{margin-inline-start:auto;transition:transform .25s;color:var(--g-lime,#B7F642)}
.g-faq-item[open] summary i{transform:rotate(180deg)}
.g-faq-item summary .num{background:var(--g-lime,#B7F642);color:#0A0B14;font-family:monospace;font-weight:800;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem}
.g-faq-item p{padding:0 22px 18px 60px;color:#a4aac8;line-height:1.85;margin:0}

/* ---- Account dashboard ---- */
.g-account-wrap{display:grid;grid-template-columns:280px 1fr;gap:30px;padding:40px 0}
.g-account-side{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:16px;padding:24px;height:fit-content;position:sticky;top:30px}
.g-account-user{display:flex;align-items:center;gap:12px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.05);margin-bottom:14px}
.g-account-user img{width:54px;height:54px;border-radius:50%;object-fit:cover;background:#1D2240}
.g-account-user strong{display:block;color:#fff;font-size:1rem}
.g-account-user small{color:#a4aac8;font-size:.78rem;display:block;margin-top:2px}
.g-account-balance{background:linear-gradient(135deg,rgba(183,246,66,.15) 0%,rgba(91,233,255,.1) 100%);border:1px solid rgba(183,246,66,.3);padding:16px;border-radius:12px;margin-bottom:14px;text-align:center}
.g-account-balance small{display:block;color:#a4aac8;font-size:.74rem;margin-bottom:4px}
.g-account-balance strong{display:block;color:#B7F642;font-size:1.5rem;font-family:monospace;font-weight:800}
.g-account-balance .btn{margin-top:10px;font-size:.78rem}
.g-account-nav{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.g-account-nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:#cbd0e8;text-decoration:none;font-weight:500;font-size:.92rem;transition:.18s}
.g-account-nav a i{width:18px;text-align:center;color:var(--g-lime,#B7F642)}
.g-account-nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.g-account-nav a.is-active{background:rgba(183,246,66,.1);color:#fff}
.g-account-main{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:16px;padding:28px}
.g-account-pane{display:none}
.g-account-pane.is-active{display:block}
.g-account-pane h2{color:#fff;margin-top:0}

.g-table{width:100%;border-collapse:collapse;margin-top:16px}
.g-table th,.g-table td{padding:12px;border-bottom:1px solid rgba(255,255,255,.05);text-align:start;color:#cbd0e8;font-size:.88rem}
.g-table th{color:#a4aac8;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.5px}
.g-status-pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:700}
.g-status--new{background:rgba(59,130,246,.15);color:#93c5fd}
.g-status--pending_review{background:rgba(245,158,11,.15);color:#fbbf24}
.g-status--pending_data{background:rgba(217,70,239,.15);color:#e879f9}
.g-status--processing{background:rgba(91,233,255,.15);color:#5be9ff}
.g-status--completed{background:rgba(34,197,94,.15);color:#86efac}
.g-status--cancelled{background:rgba(156,163,175,.15);color:#cbd5e1}
.g-status--rejected{background:rgba(239,68,68,.15);color:#fca5a5}
.g-status--failed{background:rgba(239,68,68,.15);color:#fca5a5}
.g-status--expired{background:rgba(156,163,175,.15);color:#cbd5e1}

/* ---- Buy box ---- */
.g-buy-box{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);padding:24px;border-radius:14px;margin-top:20px}
.g-buy-box h3{margin-top:0;color:#fff}
.g-buy-box .row{display:flex;gap:10px;align-items:center;margin-top:10px}
.g-buy-box input[type="text"]{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:#fff;padding:10px 12px;border-radius:8px}
.g-buy-fields{display:grid;gap:12px;margin-top:14px}
.g-buy-fields label{color:#a4aac8;font-size:.88rem}
.g-buy-fields label .req{color:#FF3D8A;margin-inline-start:3px}

/* ---- Rating ---- */
.gamelo-rating-input{display:flex;gap:6px;font-size:1.6rem;cursor:pointer;color:#4b5563}
.gamelo-rating-input [data-star].is-selected,.gamelo-rating-input [data-star]:hover{color:#fbbf24}

/* ---- Buttons spinner ---- */
.btn.is-loading{position:relative;color:transparent !important;pointer-events:none}
.btn.is-loading::after{content:"";position:absolute;top:50%;inset-inline-start:50%;width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;transform:translate(-50%,-50%);animation:gSpin .8s linear infinite}
@keyframes gSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* ---- Currency switcher dropdown ---- */
.g-currency-dd{position:relative}
.g-currency-dd-menu{position:absolute;top:calc(100% + 6px);right:0;background:#0F1120;border:1px solid rgba(255,255,255,.1);border-radius:8px;min-width:120px;display:none;z-index:300;overflow:hidden}
.g-currency-dd.is-open .g-currency-dd-menu{display:block}
.g-currency-dd-menu button{display:block;width:100%;padding:8px 14px;background:transparent;border:none;color:#fff;text-align:start;cursor:pointer;font-size:.85rem;border-bottom:1px solid rgba(255,255,255,.04)}
.g-currency-dd-menu button:hover{background:rgba(183,246,66,.08);color:#B7F642}

/* ---- Payment gateways (top-up page) ---- */
.g-pay-box{margin-top:8px}
.g-pay-methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-top:18px}
.g-pay-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:6px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:18px;cursor:pointer;transition:border-color .15s,background .15s,transform .15s}
.g-pay-card:hover{border-color:rgba(183,246,66,.35);transform:translateY(-2px)}
.g-pay-card input[type="radio"]{position:absolute;opacity:0;inset-inline-start:14px;top:14px}
.g-pay-card:has(input:checked){border-color:#B7F642;background:rgba(183,246,66,.07);box-shadow:0 0 0 1px rgba(183,246,66,.25) inset}
.g-pay-card-icon{font-size:1.5rem;color:#5BE9FF}
.g-pay-card:has(input:checked) .g-pay-card-icon{color:#B7F642}
.g-pay-card-title{color:#fff;font-weight:700;font-size:.95rem}
.g-pay-card-sub{color:#a4aac8;font-size:.78rem}

.g-pay-amount-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.06)}
.g-pay-field{display:flex;flex-direction:column;gap:6px}
.g-pay-field label{color:#a4aac8;font-size:.8rem}
.g-pay-field input[type="number"]{width:160px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:#fff;padding:10px 12px;border-radius:8px;font-family:monospace}
.g-pay-field select{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:#fff;padding:10px 12px;border-radius:8px}
#gamelo_pay_submit{flex:1;min-width:160px}

.g-pay-msg{margin-top:14px;font-size:.88rem;color:#a4aac8}
.g-pay-msg.is-error{color:#fca5a5}
.g-pay-msg.is-success{color:#86efac}

.g-cliq-box{background:rgba(255,255,255,.03);border:1px dashed rgba(255,255,255,.15);border-radius:12px;padding:18px;margin-top:18px}
.g-cliq-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;color:#cbd0e8;font-size:.9rem}
.g-cliq-row strong{color:#B7F642;font-family:monospace}
.g-cliq-note{color:#a4aac8;font-size:.82rem;margin:10px 0 0}

#gamelo-hyperpay-container .wpwl-form{background:transparent;padding:0}

/* ---- Responsive ---- */
@media (max-width: 900px){
  .g-account-wrap{grid-template-columns:1fr}
  .g-account-side{position:relative;top:0}
}
@media (max-width: 540px){
  .g-utility-bar{display:none}
  .g-whatsapp-fab{bottom:18px;left:18px;width:54px;height:54px;font-size:1.6rem}
}

/* ---- Dropdown stacking fix: keep menus above page content ---- */
.g-bell-drawer,
.g-currency-dd-menu,
.g-live-results{z-index:9100 !important}
