/* ===================== RESET ===================== */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit;color:inherit}
:focus-visible{outline:2px solid var(--focus);outline-offset:2px}

/* ===================== TOKENS (mobile-first) ===================== */
:root{
  --bg:#0b0d12;--surface:#11151d;--surface-2:#151a24;--elev:#1c2330;
  --text:#eef1f7;--muted:#98a2b3;--line:rgba(255,255,255,.08);
  --primary:#ff7a45;--secondary:#38bdf8;--accent:#34d399;--focus:#9aa8ff;
  --grad:linear-gradient(135deg,var(--secondary),var(--primary));
  --radius:14px;--shadow:0 12px 28px rgba(0,0,0,.35);
  --container:960px;--grid-min:168px;
}

body[data-theme="ember"]{--primary:#ff7a45;--secondary:#ffb26a;--grad:linear-gradient(135deg,#ffb26a,#ff7a45)}
body[data-theme="lagoon"]{--primary:#38bdf8;--secondary:#34d399;--grad:linear-gradient(135deg,#38bdf8,#34d399)}
body[data-theme="olive"]{--bg:#0f1210;--surface:#131712;--surface-2:#171c16;--text:#e7eadf;--muted:#b6bda9;--primary:#b3a06b;--secondary:#5b6146;--grad:linear-gradient(135deg,#b3a06b,#5b6146)}
body[data-theme="mistnight"]{--bg:#0f1215;--surface:#10141b;--surface-2:#141924;--text:#e8ecf5;--muted:#9aa7b7;--primary:#86a7b0;--secondary:#373219;--grad:linear-gradient(135deg,#86a7b0,#373219)}

body{background:var(--bg);color:var(--text)}

/* ===================== LAYOUT ===================== */
.topbar{position:sticky;top:0;z-index:50;background:rgba(10,13,18,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar .row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;padding-top:calc(10px + env(safe-area-inset-top))}
.burger{width:44px;height:40px;border-radius:12px;border:1px solid var(--line);display:grid;place-items:center;background:var(--surface-2);cursor:pointer}
.brand{display:flex;align-items:center;gap:10px}
.logo{width:28px;height:28px;border-radius:8px;background:var(--grad)}
.name{font-weight:800}

/* Sidebar off-canvas (mobile-first) */
.sidebar{position:fixed;inset:0 auto 0 0;z-index:70;width:86vw;max-width:320px;background:var(--surface);border-right:1px solid var(--line);transform:translateX(-104%);transition:transform .25s ease;display:flex;flex-direction:column}
#sb-toggle:checked ~ .sidebar{transform:none}
.scrim{position:fixed;inset:0;z-index:69;background-color:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:.2s ease}
#sb-toggle:checked ~ .scrim{opacity:1;pointer-events:auto}

.nav{padding:12px;display:flex;flex-direction:column;gap:10px}
.group{color:var(--muted);font-size:12px;font-weight:800;letter-spacing:.4px;padding:6px 6px}
.nav__link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid transparent;color:#cfd7ea;background:transparent}
.nav__link:hover{background:rgba(255,255,255,.05);border-color:var(--line)}
.nav__link.active{background:linear-gradient(90deg,rgba(124,95,255,.18),rgba(108,140,255,.12));border-color:rgba(124,95,255,.35);color:#fff}
.nav__link.is-locked{opacity:.65}
.cta{display:grid;gap:8px;margin-top:auto}

/* Main */
main{padding:12px;width:min(100% - 16px,var(--container));margin-inline:auto}

/* Controls */
.btn{height:42px;padding:0 14px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);color:var(--text);font-weight:800;cursor:pointer}
.btn--primary{background:var(--grad);border-color:transparent;color:#0b0d12}
.btn--ghost{background:transparent}
.input,.select{height:42px;width:100%;padding:0 12px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);color:var(--text)}
.filters{display:flex;gap:8px;margin:8px 0}
.chips{display:flex;gap:8px;overflow:auto;padding-bottom:4px}
.chip{padding:8px 12px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.04);font-weight:700}
.chip.is-active{background:var(--grad);color:#0b0d12;border-color:transparent}
.center{display:flex;justify-content:center}

/* Palette popover */
.palette{position:relative}
.palette-btn{display:flex;align-items:center;gap:8px}
.palette .swatch{width:16px;height:16px;border-radius:4px;background:var(--grad);display:inline-block}
.panel{position:absolute;right:0;top:calc(100% + 6px);width:220px;padding:10px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transform:translateY(-6px);transition:.15s}
.panel.open{opacity:1;pointer-events:auto;transform:translateY(0)}
.opt{display:flex;align-items:center;gap:8px;padding:8px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);width:100%;text-align:left}

/* Hero */
.hero{padding:10px 0}
.hero-viewport{overflow:hidden;border-radius:14px;border:1px solid var(--line);background:var(--elev)}
.hero-track{display:flex;transform:translateX(0);transition:transform .35s ease}
.hero-slide{flex:0 0 100%;height:clamp(180px,48vw,320px)}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-dots{display:flex;gap:6px;justify-content:center;padding:8px 0}
.hero-dot{width:8px;height:8px;border-radius:999px;background:rgba(255,255,255,.35);border:0}
.hero-dot.is-active{background:#fff}

/* Sections */
.section{padding:12px 0}
.section__head{display:flex;align-items:center;justify-content:space-between;gap:8px}
h2{margin:0 0 8px;font-size:18px}

/* Grid + Card */
.grid{--min:var(--grid-min);display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--min),1fr));gap:10px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:14px;display:grid;gap:10px}
.game{position:relative;overflow:hidden;aspect-ratio:3/4;border-radius:12px;border:1px solid var(--line);background:#0f1322;display:flex;align-items:flex-end}
.game__info{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;background:rgba(17,21,33,.86);backdrop-filter:blur(4px)}
.game__title{font-weight:800;font-size:13px}
.badge{position:absolute;top:8px;left:8px;padding:6px 10px;border-radius:10px;font-size:11px;font-weight:800;color:#0b0d12;background:var(--grad);border:1px solid rgba(0,0,0,.08)}

/* Tournaments */
.tour-grid{display:grid;grid-template-columns:1fr;gap:12px}
.tour-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto}
.tour-media{height:clamp(160px,40vw,200px);background:#0f1322}
.tour-media img{width:100%;height:100%;object-fit:cover}
.tour-body{padding:12px;display:grid;gap:8px}
.tour-title{margin:0;font-size:18px}
.tour-rows{display:grid;gap:6px;color:var(--muted)}
.tour-row{display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap}
.tour-foot{padding:12px;display:flex;justify-content:flex-end}
.tour-pager{display:flex;gap:8px;justify-content:center;padding:12px 0 8px}
.tour-page{padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:var(--surface-2);color:var(--text)}
.tour-page.is-active{background:var(--grad);color:#0b0d12;border-color:transparent}

/* Promotions */
.promo-grid{display:grid;grid-template-columns:1fr;gap:12px}
.promo-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto}
.promo-media{height:clamp(160px,40vw,200px);background:#0f1322}
.promo-media img{width:100%;height:100%;object-fit:cover}
.promo-body{padding:12px;display:grid;gap:8px}
.promo-title{margin:0;font-size:18px}
.promo-rows{display:grid;gap:6px;color:var(--muted)}
.promo-row{display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap}
.promo-foot{padding:12px;display:flex;justify-content:flex-end}

/* VIP */
.vip-banner{position:relative;padding:12px;border:1px solid var(--line);border-radius:16px;background:var(--surface-2)}
.vip-hi{font-weight:800;font-size:18px}
.vip-stats{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.vip-pill{padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.04);font-weight:800}
.vip-meter{padding:12px 0}
.meter{height:14px;border:1px solid var(--line);background:#0f1322;border-radius:999px;overflow:hidden}
.meter span{display:block;height:100%;background:var(--grad)}
.vip-levels{display:grid;gap:10px;margin-top:8px}
.vip-level{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:10px}

/* Affiliate (compact) */
.aff-wrap{display:grid;gap:12px}
.aff-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px}
.aff-grid{display:grid;gap:12px}
.aff-link{display:flex;gap:8px}
.chart-box{height:240px;border:1px dashed var(--line);border-radius:12px;display:grid;place-items:center;color:var(--muted)}
.tab-head{display:flex;gap:8px;margin-bottom:8px}
.table{width:100%;border-collapse:collapse;display:block;overflow-x:auto}
.table th,.table td{padding:10px;border-top:1px solid var(--line);text-align:left;white-space:nowrap}
.table thead th{border-top:none;color:var(--muted)}

/* Scratch/Pick helpers */
.scratch{display:grid;grid-template-columns:repeat(5,56px);gap:8px}
.pick-row{display:flex;gap:10px;flex-wrap:wrap}
.chip{padding:8px 12px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.06);font-weight:800}

/* Footer */
.site-footer{margin-top:24px;border-top:1px solid var(--line)}
.footer-wrap{display:grid;gap:16px;padding:16px}
.f-logo{font-weight:800;font-size:22px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.footer-links h4{margin:0 0 6px}
.footer-links a{color:var(--muted)}
.social{display:flex;gap:10px}
.social a{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid var(--line)}
.subfooter{display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap;color:var(--muted);padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom))}

/* Modals (auth + promo) */
dialog{border:none;border-radius:16px;background:var(--surface);color:var(--text);max-width:100vw}
dialog::backdrop{background:rgba(0,0,0,.55)}
.cx-auth{padding:0;width:min(96vw,600px)}
.cx-auth__wrap{position:relative;padding:12px}
.cx-auth__close{position:absolute;right:10px;top:10px;width:36px;height:36px;display:grid;place-items:center;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);cursor:pointer}
.cx-auth__right{display:grid;gap:12px}
.cx-auth__tabs{display:flex;gap:8px}
.cx-auth__tab{height:36px;padding:0 14px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);color:var(--muted);font-weight:800;cursor:pointer}
.cx-auth__tab.is-active{background:var(--grad);color:#0b0d12;border-color:transparent}
.cx-auth__form{display:grid;gap:10px}
.cx-row{display:grid;gap:6px}
.cx-input{height:44px;padding:0 12px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2)}
.cx-btn{height:42px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);color:var(--text);font-weight:800;cursor:pointer}
.cx-btn--primary{background:var(--grad);border-color:transparent;color:#0b0d12}
.cx-btn--cta{width:100%}
.cx-forgot{display:flex;gap:8px}
.cx-link{color:var(--secondary);text-decoration:underline}
.is-hidden{display:none !important}

.promo-modal{padding:0;width:min(96vw,760px)}
.promo-modal__head{display:flex;align-items:center;gap:10px;padding:12px;border-bottom:1px solid var(--line)}
.promo-back{background:transparent;border:1px solid var(--line);border-radius:10px;padding:6px 10px;color:var(--text);cursor:pointer}
.promo-modal__media{height:clamp(180px,44vw,240px);background:#0f1322}
.promo-modal__media img{width:100%;height:100%;object-fit:cover}
.promo-modal__body{padding:12px;display:grid;gap:8px}

/* Responsive bumps */
@media (min-width:720px){
  .grid{--min:210px}
  .promo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .tour-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (min-width:1024px){
  .promo-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .tour-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .sidebar{position:sticky;transform:none;inset:auto;top:0;height:100dvh}
  .scrim{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}


/* layout */
.topbar .row{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; padding:8px 10px; background:var(--card2); border-bottom:1px solid var(--line);
}
.topbar .left{ display:flex; align-items:center; gap:6px; } /* tighter gap near burger */

/* burger */
.topbar .burger{
  display:grid; place-items:center; width:36px; height:36px;
  border-radius:10px; border:1px solid var(--line); background:var(--card);
}

/* brand tight to burger */
.topbar .brand{ display:flex; align-items:center; gap:6px; margin-left:-2px; }
.topbar .logo{ width:22px; height:22px; border-radius:6px; background:var(--grad); }
.topbar .name{ font-weight:800; font-size:14px; }

/* right actions */
.topbar .actions{ display:flex; align-items:center; gap:8px; }
.icon-btn.theme-mini{
  width:36px; height:36px; border-radius:10px;
  border:1px solid var(--line); background:var(--card2); cursor:pointer;
}
.profile-btn{ height:36px; padding:0 12px; border-radius:10px; }

/* super compact on very small widths */
@media (max-width:400px){
  .profile-btn .label{ display:none; }         /* icon-only */
  .topbar .name{ font-size:13px; }
}

/* Compact, softer (pill) profile button */
.profile-btn{
  height:32px;                 /* ↓ from 36px */
  padding:0 10px;              /* a bit tighter */
  border-radius:999px;         /* softer corners */
  display:inline-flex; align-items:center; gap:6px;
  line-height:1;
  border:0;                    /* cleaner with gradient */
  box-shadow:0 2px 10px rgba(0,0,0,.08);
}
.profile-btn .profile-icon{ font-size:14px; line-height:1; }
.profile-btn .label{ font-weight:700; font-size:13px; }

/* When label is hidden on small screens, keep it neat & round */
@media (max-width:400px){
  .profile-btn{ width:36px; padding:0; justify-content:center; }
}

/* Compact pill profile button (kept) */
.profile-btn{height:32px;padding:0 10px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;line-height:1;border:0;box-shadow:0 2px 10px rgba(0,0,0,.08)}
.profile-btn .profile-icon{font-size:14px}
.profile-btn .label{font-weight:700;font-size:13px}
@media (max-width:400px){.profile-btn{width:36px;padding:0;justify-content:center}.profile-btn .label{display:none}}

/* Dropdown menu */
.profile-menu{
  position: absolute; right:12px; top:58px; z-index:70;
  width:min(92vw, 300px);
  background:var(--card2); color:var(--text);
  border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow);
  padding:10px; display:grid; gap:10px;
}
.pm-head{display:flex; gap:10px; align-items:center; padding-bottom:8px; border-bottom:1px solid var(--line)}
.pm-avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--pill);border:1px solid var(--line)}
.pm-username{font-weight:800}
.pm-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.pm-stat{display:flex;align-items:center;justify-content:space-between;padding:8px;border:1px solid var(--line);border-radius:10px;background:var(--card)}
.pm-actions{display:flex;gap:8px;justify-content:space-between}
.pm-link{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--line);border-radius:10px;background:var(--card)}
.pm-logout{border:0;border-radius:10px;padding:8px 12px;background:var(--grad);color:#fff;font-weight:800;cursor:pointer}

/* Auth Pop */
.auth-pop{padding:0;border:none;border-radius:16px;background:var(--card2);color:var(--text);width:min(480px,95vw)}
.auth-pop::backdrop{background:rgba(0,0,0,.55)}
.ap-wrap{position:relative;padding:14px}
.ap-close{position:absolute;top:8px;right:8px;border:0;background:transparent;font:inherit;font-weight:800;cursor:pointer;color:var(--accent)}
.ap-tabs{display:flex;gap:8px;margin-bottom:10px}
.ap-tab{flex:0 0 auto;padding:8px 14px;border-radius:999px;border:1px solid var(--line);background:var(--card);cursor:pointer}
.ap-tab.is-active{background:var(--primary);color:#fff;border-color:transparent}
.ap-form{display:grid;gap:10px}
.ap-row{display:grid;gap:6px}
.ap-input{height:42px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--text);padding:0 12px}
.ap-btn{height:44px;border-radius:999px;border:0;font-weight:800;cursor:pointer}
.ap-btn--primary{background:var(--grad);color:#fff}
.ap-err{color:#c0392b;font-size:13px;margin:0}
.ap-note{font-size:12px;color:var(--muted);margin:0}
.is-hidden{display:none !important}

/* Auth popup tamamen opak olsun */
.auth-pop{
  background-color:#0f1318 !important; /* koyu, tam opak */
  color:#e5e7eb;
  box-shadow:0 20px 60px rgba(0,0,0,.6);
  backdrop-filter:none !important;
}

/* İç elemanlar da opak dursun */
.ap-input,
.ap-tab{
  background-color:#111827 !important;
  border-color:#1f2937 !important;
}
.ap-tab.is-active{
  background-color:#2563eb !important;
  color:#fff !important;
}


.profile-btn{
  --brand: #ff8c4a;
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.45rem .85rem;
  border-radius:999px;
  background:var(--brand);
  color:#0b0f14;
  font-weight:600;
  line-height:1;
  box-shadow:0 6px 18px rgba(255,140,74,.35);
}
.profile-btn .profile-icon{font-size:1rem; line-height:1}
@media (max-width:640px){
  .profile-btn{padding:.45rem .6rem}
  .profile-btn .label{display:none}
}

/* ========== Profile dropdown ========== */
.profile-menu{
  --bg:#161b26;
  --panel:#0f1420;
  --text:#e9edf7;
  --muted:#9aa6bd;
  --border:rgba(255,255,255,.08);
  position:absolute;
  right:1rem; top:64px;
  width:min(92vw,380px);
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:0 18px 40px rgba(0,0,0,.45);
  padding:14px;
  color:var(--text);
  display:none;
  z-index:1200;
}
.profile-menu.open{display:block; animation:pm-pop .18s ease both}
@keyframes pm-pop{
  from{transform:translateY(6px) scale(.98); opacity:0}
  to{transform:translateY(0) scale(1); opacity:1}
}
.profile-menu .pm-head{
  display:flex; align-items:center; gap:.75rem;
  padding:10px 10px 12px; 
  border-bottom:1px solid var(--border);
}
.profile-menu .pm-avatar{
  width:34px; height:34px; border-radius:999px;
  display:grid; place-items:center;
  background:linear-gradient(135deg,#7542ff,#ff8c4a);
  color:#fff; font-size:1rem; flex:0 0 auto;
}
.profile-menu #pmUser{font-weight:700}
.profile-menu .pm-balance{
  margin-left:auto; font-weight:700;
}
.profile-menu .pm-balance small{color:var(--muted); font-weight:600; margin-right:.35rem}

.profile-menu .pm-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:12px;
  padding:12px 10px 8px;
}
.profile-menu .pm-box{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:12px; padding:12px;
  display:grid; grid-template-columns:1fr auto; gap:6px; align-items:end;
}
.profile-menu .pm-box .k{color:var(--muted); font-weight:600}
.profile-menu .pm-box .v{font-weight:800; font-size:1.1rem}

.profile-menu .pm-actions{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px;
}
.profile-menu .pm-settings{
  background:transparent; color:var(--text);
  border:1px solid var(--border); padding:.5rem .75rem;
  border-radius:12px; font-weight:600; text-decoration:none;
}
.profile-menu .pm-logout{
  background:#ff7a70; color:#1a0f0f;
  border:0; padding:.6rem 1rem; font-weight:800;
  border-radius:14px; cursor:pointer;
  box-shadow:0 8px 20px rgba(255,122,112,.35);
}

/* Mobile: drop fills width a bit more */
@media (max-width:640px){
  .profile-menu{left:.75rem; right:.75rem; top:56px; width:auto}
}

/* ========== Auth Modal (solid, not transparent) ========== */
.auth-overlay{
  position:fixed; inset:0; background:rgba(0,0,0,.55);
  display:none; z-index:1100;
}
.auth-overlay.open{display:block}

.auth-modal{
  position:fixed; inset:0; display:none; place-items:center; z-index:1200;
}
.auth-modal.open{display:grid}
.auth-modal .sheet{
  --bg:#161b26;
  background:var(--bg);            /* solid panel */
  color:#e9edf7;
  width:min(92vw,420px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  box-shadow:0 24px 60px rgba(0,0,0,.55);
  padding:18px;
  animation:pm-pop .18s ease both;
}
.auth-modal .sheet h3{margin:0 0 .5rem; font-size:1.1rem}
.auth-modal .tabs{display:flex; gap:8px; margin-bottom:10px}
.auth-modal .tab{
  flex:1; padding:.6rem .75rem; text-align:center;
  border-radius:12px; border:1px solid rgba(255,255,255,.08);
  background:#0f1420; color:#c6d0e3; font-weight:700; cursor:pointer;
}
.auth-modal .tab.active{background:#ff8c4a; color:#0b0f14; border-color:transparent}
.auth-modal form .field{
  display:flex; flex-direction:column; gap:.35rem; margin:.55rem 0;
}
.auth-modal form .field input{
  background:#0f1420; border:1px solid rgba(255,255,255,.08);
  color:#e9edf7; padding:.7rem .8rem; border-radius:12px; outline:none;
}
.auth-modal .actions{
  display:flex; gap:.5rem; margin-top:.75rem;
}
.auth-modal .btn-primary{
  flex:1; background:#7c5cff; color:#fff; border:0; border-radius:12px;
  padding:.7rem .9rem; font-weight:800; cursor:pointer;
}
.auth-modal .btn-ghost{
  background:transparent; color:#c6d0e3;
  border:1px solid rgba(255,255,255,.08); border-radius:12px;
  padding:.7rem .9rem; font-weight:700; cursor:pointer;
}

/* Featured: 2x6 düzen (ilk 12 oyun) */
.section--featured .games-grid{
  display:grid;
  grid-template-columns: repeat(6, minmax(0,1fr));
  gap:12px;
}
.section--featured .games-grid .game-card:nth-child(n+13){ /* 2x6 = 12 */
  display:none;
}

/* Kartları ve iç elemanları ~%50 küçült (Featured + Live + Slots) */
.section--featured .game-card,
.section--live     .game-card,
.section--slots    .game-card{
  --card-pad: 6px;           /* daha küçük iç boşluk */
  --title-size: .82rem;      /* başlık boyutu */
  --icon-size: 16px;         /* ikon/badge/fav/provide ikonları */
  padding: var(--card-pad);
  border-radius: 14px;
}

/* Başlık/metin küçültme */
.section--featured .game-card .title,
.section--live     .game-card .title,
.section--slots    .game-card .title{
  font-size: var(--title-size);
}

/* Küçük ikon/badge’ler */
.section--featured .game-card .badge,
.section--featured .game-card .icon,
.section--featured .game-card .provider-logo,
.section--featured .game-card .fav-btn,
.section--live     .game-card .badge,
.section--live     .game-card .icon,
.section--live     .game-card .provider-logo,
.section--live     .game-card .fav-btn,
.section--slots    .game-card .badge,
.section--slots    .game-card .icon,
.section--slots    .game-card .provider-logo,
.section--slots    .game-card .fav-btn{
  width: var(--icon-size);
  height: var(--icon-size);
  font-size: calc(var(--icon-size) - 4px);
}

/* Live & Slots: kolon sayısını arttırarak kart genişliğini ~%50 düşür */
.section--live .games-grid,
.section--slots .games-grid{
  display:grid;
  grid-template-columns: repeat(6, minmax(0,1fr));
  gap:12px;
}

/* Responsive kırılımlar */
@media (max-width: 1200px){
  .section--featured .games-grid,
  .section--live .games-grid,
  .section--slots .games-grid{
    grid-template-columns: repeat(4, minmax(0,1fr));
  }
}
@media (max-width: 720px){
  .section--featured .games-grid,
  .section--live .games-grid,
  .section--slots .games-grid{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}



/* ===== Games compact 2x10 ===== */
#fgGrid, #csGrid, #slGrid, #lvGrid { --g-gap:10px; }
.grid--2x10{
  display:grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: var(--g-gap);
}

/* Kartları %50 kompaktlaştır */
.grid--2x10 .game{
  padding: 8px;
  border-radius: 10px;
}
.grid--2x10 .badge{ font-size: 10px; padding: 2px 6px; }
.grid--2x10 .game__title{ font-size: 12px; }
.grid--2x10 .game__info{ gap: 8px; }
.grid--2x10 .btn{ height: 28px; font-size: 12px; padding: 0 10px; }


.grid--2x10{
  display:grid;
  gap:12px;
  /* XL: 10 kolon (2x10 görünüm için 20 kart) */
  grid-template-columns: repeat(10, minmax(0,1fr));
}

/* Daha büyük kart oranı (yaklaşık %75–80 küçültme yerine orta boy) */
.grid--2x10 .game{ padding:12px; border-radius:12px; }
.grid--2x10 .badge{ font-size:11px; padding:3px 8px; }
.grid--2x10 .game__title{ font-size:14px; }
.grid--2x10 .game__info{ gap:10px; }
.grid--2x10 .btn{ height:32px; font-size:13px; padding:0 12px; }

/* Ekrana göre kolon sayısını artır/azalt (kartlar çok ufalmasın) */
@media (max-width: 1400px){ .grid--2x10{ grid-template-columns: repeat(8, 1fr); } }
@media (max-width: 1200px){ .grid--2x10{ grid-template-columns: repeat(6, 1fr); } }
@media (max-width: 900px) { .grid--2x10{ grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 640px) { .grid--2x10{ grid-template-columns: repeat(3, 1fr); } }

/* “Grid 3x” seçicisini mobile’da gizle */
@media (max-width: 768px){
  #fgDensity{ display:none !important; }
}

/* Chips container */
#fgChips.chips{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

/* Chip pill: küçük, dikdörtgen-ELİPTİK */
.chip{
  --chip-h: 36px;                /* önceki ~44px ise küçüldü */
  display:inline-flex;
  align-items:center;
  gap:8px;
  height:var(--chip-h);
  padding:0 14px;
  font-size:14px;
  line-height:1;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  /* eliptik köşe: yatay/dikey farklı yarıçap */
  border-radius:18px / 22px;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}

.chip:hover{ transform:translateY(-1px); }
.chip:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}

/* Aktif chip */
.chip.is-active{
  background:var(--primary);
  color:#0c0c0f;
  border-color:transparent;
}

/* İKONLAR: daha küçük */
.chip .icon,
.chip i,
.chip svg{
  width:16px;
  height:16px;
  display:inline-grid;
  place-items:center;
  font-size:13px;   /* emoji/ikon fontları için */
  opacity:.9;
}

/* Metin kısmı */
.chip > span:not(.icon){
  white-space:nowrap;
}

/* Çok dar ekranlarda chip’leri biraz daha ufalt */
@media (max-width: 420px){
  .chip{ --chip-h: 32px; padding:0 12px; font-size:13px; border-radius:16px / 20px; }
  .chip .icon, .chip i, .chip svg{ width:14px; height:14px; font-size:12px; }
}


/* Game card badge — smaller, pill */
.game .badge{
  position:absolute;
  top:8px;
  left:8px;
  padding:2px 6px;
  font-size:10px;
  font-weight:700;
  letter-spacing:.3px;
  line-height:1;
  border-radius:999px;
  color:#fff;
  background: rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(4px) saturate(120%);
}

/* 2x10 kompakt gridte daha da küçük */
.grid--2x10 .game .badge{
  top:6px;
  left:6px;
  padding:2px 5px;
  font-size:9px;
}

/* Başlık */
.game .game__title{
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.15;
  font-weight: 700;
}

/* Provider satırı (inline 12px'i ezmek için !important) */
.game .game__info .game__title + div{
  font-size: 11px !important;
  color: var(--muted) !important;
  line-height: 1.1;
  opacity: .9;
}

/* Info satırı hizalama */
.game .game__info{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px;
}

/* Play butonu */
.game .game__info .btn{
  height: 30px !important;   /* inline height'ı ez */
  padding: 0 10px;
  font-size: 12px;
  border-radius: 10px;
  white-space: nowrap;
}

/* === 2x10 kompakt gridte daha da kompakt === */
.grid--2x10 .game .game__title{ font-size: 13px; }
.grid--2x10 .game .game__info .game__title + div{ font-size: 10px !important; }
.grid--2x10 .game .game__info .btn{
  height: 28px !important;
  padding: 0 8px;
  font-size: 11px;
  border-radius: 9px;
}







/* Genel profil sayfası */
.profile-page {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: 60px 20px;
  animation: fadeIn .4s ease;
}

.profile-card {
  background: #fff;
  color: #333;
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.1);
  padding: 30px;
  width: 100%;
  max-width: 420px;
  text-align: center;
}

.profile-title {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 10px;
}

.profile-sub {
  font-size: 0.95rem;
  color: #666;
  margin-bottom: 20px;
}

/* Guest tab butonları */
.ap-tabs {
  display: flex;
  gap: 10px;
  justify-content: center;
}
.ap-tab {
  flex: 1;
  padding: 10px 16px;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  cursor: pointer;
  background: linear-gradient(135deg, #6a5acd, #836fff);
  color: #fff;
  font-weight: 600;
  transition: background .3s;
}
.ap-tab:hover {
  background: linear-gradient(135deg, #5946d2, #715aff);
}

/* Profil logged-in */
.pm-head {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
}
.pm-avatar {
  font-size: 2.5rem;
  margin-right: 15px;
}
.pm-meta {
  text-align: left;
}
.pm-username {
  font-weight: 600;
  font-size: 1.2rem;
}
.pm-balance {
  font-size: 0.95rem;
  color: #555;
}

.pm-stats {
  display: flex;
  justify-content: space-between;
  margin: 20px 0;
}
.pm-stat {
  flex: 1;
  background: #f9f9f9;
  border-radius: 10px;
  padding: 12px;
  margin: 0 5px;
  font-size: 0.9rem;
}
.pm-stat b {
  display: block;
  font-size: 1.1rem;
  margin-top: 6px;
  color: #222;
}

/* Actions */
.pm-actions {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.pm-link, .pm-logout {
  flex: 1;
  text-align: center;
  padding: 10px;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  transition: all .3s;
  text-decoration: none;
}
.pm-link {
  background: #eee;
  color: #333;
}
.pm-link:hover {
  background: #ddd;
}
.pm-logout {
  border: none;
  background: #ff4c4c;
  color: #fff;
}
.pm-logout:hover {
  background: #e43a3a;
}

/* Animasyon */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
/* Delta rozeti */
.bal-delta{
  margin-left:.35rem; font-style:normal; font-weight:800; font-size:.75rem;
  padding:.1rem .35rem; border-radius:999px; background:rgba(255,255,255,.15);
}
.bal-delta.up{   color:#16a34a; background:rgba(22,163,74,.15); }
.bal-delta.down{ color:#ef4444; background:rgba(239,68,68,.15); }

/* Chip ping animasyonu */
.bal-chip.--up{   box-shadow:0 0 0 0 rgba(52,211,153,.6); animation:balPingUp .9s ease; }
.bal-chip.--down{ box-shadow:0 0 0 0 rgba(239,68,68,.6); animation:balPingDown .9s ease; }
@keyframes balPingUp{
  from{box-shadow:0 0 0 0 rgba(52,211,153,.6)} to{box-shadow:0 0 0 12px rgba(52,211,153,0)}
}
@keyframes balPingDown{
  from{box-shadow:0 0 0 0 rgba(239,68,68,.6)} to{box-shadow:0 0 0 12px rgba(239,68,68,0)}
}


.profile-page {
  display: flex;
  justify-content: center;
  padding: 60px 20px;
  animation: fadeIn .4s ease;
}

.profile-card {
  background: #fff;
  color: #333;
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.1);
  padding: 30px;
  width: 100%;
  max-width: 420px;
  text-align: center;
}

.profile-title {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 10px;
}

.profile-sub {
  font-size: 0.95rem;
  color: #666;
  margin-bottom: 20px;
}

.ap-tabs {
  display: flex;
  gap: 10px;
  justify-content: center;
}
.ap-tab {
  flex: 1;
  padding: 10px 16px;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  cursor: pointer;
  background: linear-gradient(135deg, #6a5acd, #836fff);
  color: #fff;
  font-weight: 600;
  transition: background .3s;
}
.ap-tab:hover {
  background: linear-gradient(135deg, #5946d2, #715aff);
}

.pm-head {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
}
.pm-avatar {
  font-size: 2.5rem;
  margin-right: 15px;
}
.pm-meta {
  text-align: left;
}
.pm-username {
  font-weight: 600;
  font-size: 1.2rem;
}
.pm-balance {
  font-size: 0.95rem;
  color: #555;
}

.pm-stats {
  display: flex;
  justify-content: space-between;
  margin: 20px 0;
}
.pm-stat {
  flex: 1;
  background: #f9f9f9;
  border-radius: 10px;
  padding: 12px;
  margin: 0 5px;
  font-size: 0.9rem;
}
.pm-stat b {
  display: block;
  font-size: 1.1rem;
  margin-top: 6px;
  color: #222;
}

.pm-actions {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.pm-link, .pm-logout {
  flex: 1;
  text-align: center;
  padding: 10px;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  transition: all .3s;
  text-decoration: none;
}
.pm-link {
  background: #eee;
  color: #333;
}
.pm-link:hover {
  background: #ddd;
}
.pm-logout {
  border: none;
  background: #ff4c4c;
  color: #fff;
}
.pm-logout:hover {
  background: #e43a3a;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
[data-route][hidden], .profile-card[hidden] { display: none !important; }

/* HEADER chip + dropdown */
.topbar .row{ position:relative; } /* dropdown konumlamak için */

.bal-chip{
  display:inline-flex; align-items:center; gap:.35rem;
  height:32px; padding:0 .75rem; border:0; border-radius:999px;
  background:linear-gradient(135deg,#7c5cff,#ff8c4a); color:#0b0f14; font-weight:800;
  box-shadow:0 8px 20px rgba(124,92,255,.25);
}
.bal-chip small{opacity:.8; font-weight:800}

.wallet-btn{ height:32px; padding:0 .85rem; border-radius:999px; }

.bal-menu{
  position:absolute; right:12px; top:56px; z-index:1200;
  width:min(84vw,300px);
  background:#11161f; color:#e9edf7; border:1px solid rgba(255,255,255,.08);
  border-radius:14px; box-shadow:0 18px 40px rgba(0,0,0,.45);
  padding:10px; animation:pm-pop .18s ease both;
}
.bm-head{font-weight:800; opacity:.85; padding:.25rem .5rem .4rem}
.bm-item{
  width:100%; display:grid; grid-template-columns:auto 1fr auto; gap:.5rem;
  align-items:center; background:#0f1420; border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:.55rem .65rem; color:#cfe2ff; cursor:default;
}
.bm-item + .bm-item{ margin-top:8px; }
.bm-item .bm-ico{width:1.25rem; text-align:center}
.bm-item.-row{grid-template-columns:auto 1fr auto}
.bm-sep{height:1px; background:rgba(255,255,255,.08); margin:.5rem 0}

/* Wallet page */
#walletPage{ padding:16px; }
.wallet-card{
  background:var(--surface); border:1px solid var(--line); border-radius:16px; padding:14px;
  box-shadow:var(--shadow);
}
.wallet-tabs{ display:flex; gap:8px; margin-bottom:10px }
.wt-tab{
  flex:1; padding:.6rem; border-radius:12px; border:1px solid var(--line);
  background:var(--surface-2); color:var(--text); font-weight:800;
}
.wt-tab.is-active{ background:var(--grad); color:#0b0d12; border-color:transparent }

.bank-grid{
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; margin-bottom:12px;
}
.bank-card{
  display:grid; place-items:center; gap:6px; padding:16px;
  border:1px solid var(--line); border-radius:14px; background:var(--surface-2); color:var(--text);
  font-weight:800; cursor:pointer;
}
.bank-card .bank-ico{font-size:20px}
.bank-card.is-active{ outline:2px solid #7c5cff; outline-offset:2px }

.wallet-form{ display:grid; gap:10px; margin-top:6px }
.wallet-form h4{ margin:.25rem 0 .25rem }
.wf-row{ display:grid; gap:6px }
.wf-actions{ display:flex; gap:8px; }


/* ===== Toasts ===== */
.toasts{
  position:fixed; inset:auto 0 calc(12px + env(safe-area-inset-bottom)) 0;
  display:grid; place-items:center; gap:8px;
  pointer-events:none; z-index:4000;
}
.toasts.top{ inset: calc(12px + env(safe-area-inset-top)) 0 auto 0; }

.toast{
  width:min(92vw, 440px); pointer-events:auto;
  display:grid; grid-template-columns:auto 1fr auto; gap:12px; align-items:center;
  background:var(--surface); color:var(--text);
  border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow);
  padding:12px; transform:translateY(6px) scale(.98); opacity:0;
  animation:toast-in .18s ease forwards;
  touch-action:pan-y;
}
.toast .ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--line);font-size:18px}
.toast .txt{min-width:0}
.toast .title{margin:0;font-weight:800;font-size:14px;line-height:1.15}
.toast .msg{margin:.15rem 0 0;font-size:13px;color:var(--muted);line-height:1.2;word-break:break-word}
.toast .act{display:flex;gap:8px}
.toast .btn{
  background:transparent;border:1px solid var(--line);color:var(--text);
  border-radius:10px;padding:.35rem .55rem;font-weight:700;cursor:pointer
}
.toast .x{background:transparent;border:0;color:var(--muted);font-size:18px;cursor:pointer}

.toast.success .ico{background:rgba(22,163,74,.15);border-color:rgba(22,163,74,.35)}
.toast.error   .ico{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.35)}
.toast.warn    .ico{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.35)}
.toast.info    .ico{background:rgba(59,130,246,.15);border-color:rgba(59,130,246,.35)}

.toast .bar{
  grid-column:1 / -1; height:3px; border-radius:0 0 12px 12px;
  background:linear-gradient(90deg,var(--secondary),var(--primary));
  transform-origin:left; animation:toast-bar linear forwards;
}
@keyframes toast-in{to{transform:translateY(0) scale(1); opacity:1}}
@keyframes toast-out{to{transform:translateY(6px) scale(.98); opacity:0}}
@keyframes toast-bar{from{transform:scaleX(1)} to{transform:scaleX(0)}}

/* swipe dismiss feedback */
.toast.swiping{opacity:.9; transition:none}

#walletBtn .label {
  font-size: 12px;   /* küçük puntolu */
  font-weight: 500;  /* daha az kalın */
  line-height: 1.2;  /* dengeli hizalama */
}



/* Kutunun içindeki düzen */
#walletBtn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;               /* ikon ile yazı arası */
  padding: 6px 12px;
  border-radius: 12px;
  background: #1f2230;    /* mevcut tema rengine göre */
  font-size: 12px;
  font-weight: 500;
  color: #fff;
}
#walletBtn .icon {
  font-size: 14px;
}
#walletBtn .label {
  font-size: 12px;
}

.game-modal{ width:min(100vw,1024px); height:min(100vh,720px); border:none; padding:0; }
.game-modal::backdrop{ background:rgba(0,0,0,.6); }
.gm-head{ display:flex; gap:8px; align-items:center; padding:8px 10px; border-bottom:1px solid #2a2a2a; }
.gm-head .spacer{ flex:1 }
#gameFrame{ width:100%; height:calc(100% - 44px); border:0; display:block; }


/* 1) Kart kutusu sabit boy / responsive istersen aspect-ratio'yu açabilirsin */
.hero-viewport.card{
  width: 388px;           /* istersen % veya max-width kullan */
  height: 263px;
  /* alternatif (responsive): aspect-ratio: 388 / 263; height:auto; */
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  background: #0c1220;    /* görsel gelmezse */
  isolation: isolate;
}

/* 2) Slide ve medya elemanları alanı tamamen kaplasın */
.hero-viewport.card .slide,
.hero-viewport.card figure,
.hero-viewport.card picture{
  position: absolute;
  inset: 0;               /* top/right/bottom/left = 0 */
  margin: 0;
}

/* 3) IMG’ler kutuyu %100 doldursun, merkezden kırpsın (cover) */
.hero-viewport.card img{
  width: 100%;
  height: 100%;
  display: block;         /* inline boşluklarını kaldır */
  object-fit: cover;      /* alanı tamamen doldurur (gerekirse kırpar) */
  object-position: center;
  /* bazı temalarda bozan max-width/max-height kurallarını ezelim: */
  max-width: none;
  max-height: none;
}

/* 4) Eğer bazı slide'lar background-image ile geliyorsa */
.hero-viewport.card .bg-cover{
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* 5) Swiper/keen gibi kütüphaneler için yükseklik garantisi */
.hero-viewport.card .swiper,
.hero-viewport.card .swiper-wrapper,
.hero-viewport.card .swiper-slide{
  height: 100%;
}

/* 6) Pager/bullets overlay (opsiyonel) */
.hero-viewport.card .hero-dots{
  position: absolute; left: 50%; bottom: 8px; transform: translateX(-50%);
  display: flex; gap: 8px; z-index: 3;
}
.hero-viewport.card .hero-dots > span{
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255,255,255,.35);
}
.hero-viewport.card .hero-dots > span.is-active{ background: #fff; }

/* Kart boyu – sabitse böyle bırak; responsive istersen aspect-ratio notuna bak */
.hero-viewport.card{
  width: 388px;
  height: 263px;
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  background: #0c1220; /* görsel gelmezse */
  isolation: isolate;
}

/* Track alanı kartı tamamen kaplasın */
.hero-viewport.card .hero-track{
  position: absolute;
  inset: 0;            /* top/right/bottom/left = 0 */
  display: flex;       /* slider mantığı için yan yana */
  height: 100%;
}

/* JS’nin eklediği her slide tam sayfa olsun (sınıf ismi yoksa da çalışır) */
.hero-viewport.card .hero-track > *,
.hero-viewport.card .hero-slide{
  flex: 0 0 100%;
  height: 100%;
  position: relative;
}

/* Görsel kartı eksiksiz doldursun (gerekirse kırpar) */
.hero-viewport.card .hero-track img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;     /* alanı tamamen doldurur */
  object-position: center;
  max-width: none;       /* global img kurallarını ezer */
  max-height: none;
}

/* Dots/pager overlay (opsiyonel) */
.hero-viewport.card .hero-dots{
  position: absolute;
  left: 50%;
  bottom: 10px;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 3;
}
.hero-viewport.card .hero-dots > span{
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255,255,255,.35);
}
.hero-viewport.card .hero-dots > span.is-active{ background: #fff; }

/* İstersen responsive: sabit width/height yerine şunu kullan
.hero-viewport.card{ width:100%; aspect-ratio: 388 / 263; height:auto; }
*/


.vip-level p { display:flex; align-items:center; gap:.35rem; }

section[data-route][hidden] { display: none !important; }

.vip-level .vip-benefits{margin:.4rem 0 0;padding:0;list-style:none;font-size:.9rem;line-height:1.35}
.vip-level .vip-benefits li{display:flex;gap:.4rem;align-items:center;white-space:nowrap}
.vip-level p{margin:.15rem 0 .3rem}


/* grid temel */
.grid{ display:grid; gap:12px; }

/* 2 kolon düzeni */
.grid--2col{ grid-template-columns: repeat(2, minmax(0,1fr)); }

/* Mevcutta #fgGrid 'grid--2x10' ile geliyorsa, onu da 2 kolona zorla */
#fgGrid.grid--2x10{ grid-template-columns: repeat(2, minmax(0,1fr)); }

/* Kart oranını koru (taşma olmasın) */
.game{ position:relative; aspect-ratio: 3 / 4; } /* istersen 4/5 de yapabilirsin */


/* Oyun kartı kutusu */
.game{
  position: relative;
  overflow: hidden;               /* dışarı taşma yok */
  border-radius: 16px;
  background: #0c0f16;
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
  aspect-ratio: 3 / 4;            /* 188x250 ≈ 0.75; istersen 4/5 yapabilirsin */
}

/* Görsel tam dolsun */
.game_media,
.game_media > img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;              /* TAŞMA YOK: crop */
}

/* HOT vb. rozet */
.game_badge{
  position: absolute;
  z-index: 3;
  top: 8px; left: 8px;
  padding: 3px 8px;
  font-size: 10px;
  letter-spacing: .4px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  border-radius: 999px;
  backdrop-filter: blur(2px);
}

/* Üstteki içerik (ikon + başlık + butonlar) */
.game_overlay{
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;            /* yatay orta */
  justify-content: center;        /* dikey orta */
  gap: 6px;
  padding: 10px;
  text-align: center;
  /* okunabilirlik için hafif karartma */
  background: linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,.45) 60%, rgba(0,0,0,.55) 100%);
}

/* Sağlayıcı ikonu (logo yoksa inisyal rozet) */
.game_provider{
  width: 30px; height: 30px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 700; font-size: 12px;
  background: rgba(255,255,255,.9);
  color: #111;
  padding: 2px;
  box-shadow: 0 2px 6px rgba(0,0,0,.25);
  user-select: none;
}

/* Başlık & vendor */
.game_title{
  margin: 2px 0 0;
  font-size: 14px;
  line-height: 1.1;
  color: #fff;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.game_vendor{
  margin: 0;
  font-size: 11px;
  color: #cbd1e2;
}

/* Butonlar */
.game_actions{
  display: flex;
  gap: 8px;
  margin-top: 4px;
}
.game_actions .btn{
  padding: 6px 10px;
  font-size: 12px;
  border-radius: 10px;
}
.game_actions .btn--ghost{
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
}
.game_actions .btn--primary{
  background: var(--primary, #ff9550);
  color: #111;
}


/* Kart iskeleti */
.game{
  position: relative;
  overflow: hidden;           /* taşmaları engelle */
  border-radius: 12px;
  /* kart oranını istediğin gibi ayarla */
  aspect-ratio: 16 / 9;       /* istersen kaldırıp height ver */
  background: #111;           /* görsel geç gelirse zemin */
  box-sizing: border-box;
}

/* Görsel tüm kartı kaplasın */
.game__media{
  position: absolute;
  inset: 0;
  z-index: 0;
}
.game__img{
  width: 100%;
  height: 100%;
  object-fit: cover;          /* taşmadan doldur */
  object-position: center;
  display: block;
  pointer-events: none;       /* tıklamaları engellemesin */
}

/* Üstteki rozet */
.game .badge{
  position: absolute;
  top: 10px; left: 10px;
  z-index: 3;
}

/* Alttaki bilgi+aksiyon barı */
.game__info{
  position: absolute;
  left: 0; right: 0; bottom: 0;
  z-index: 2;

  display: flex;
  align-items: center;
  gap: 12px;

  padding: 12px 12px;
  min-height: 72px;

  /* okunabilirlik için alttan degrade */
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.55) 20%, rgba(0,0,0,.75) 100%);
  color: #fff;
}

/* Soldaki bilgi bloğu (başlık + provider) */
.game__info > div:first-child{
  display: flex;
  flex-direction: column;
  gap: 2px;

  flex: 1 1 auto;  /* alanın çoğunu alsın */
  min-width: 0;    /* ellipsis için şart */
}

/* Başlık ve provider taşmasın */
.game__title{
  font-weight: 700;
  font-size: 16px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.game .muted{
  color: rgba(255,255,255,.8);
  font-size: 12px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Sağdaki aksiyon buton grubu */
.game__actions{
  margin-left: auto;     /* en sağa it */
  display: flex;
  gap: 8px;
  flex-shrink: 0;        /* daralmayı engelle */
}

/* Butonlar kart içinde kalsın */
.game__actions .btn{
  white-space: nowrap;
}

/* Küçük ekran ayarı (opsiyonel) */
@media (max-width: 420px){
  .game__title{ font-size: 14px; }
  .game__info{ padding: 10px; gap: 8px; }
}
/* ====== Kart: portre oran ve taşma kontrolü ====== */
.game{
  position: relative;
  overflow: hidden;          /* hiçbir çocuk dışarı taşmasın */
  border-radius: 14px;
  aspect-ratio: 3 / 4;       /* yükseklik > genişlik (portre) */
  background: #0b0b0b;       /* görsel geç gelirse zemin */
  box-sizing: border-box;
}

/* Görsel tüm kartı kaplasın */
.game__media{ position: absolute; inset: 0; z-index: 0; }
.game__img{
  width: 100%;
  height: 100%;
  object-fit: cover;         /* taşıp kırparak doldurur */
  object-position: center;
     /* hafif büyüt → tam yayılma hissi */
  display: block;
  pointer-events: none;
}

/* Rozet */
.game .badge{
  position: absolute;
  top: 8px; left: 8px;
  z-index: 3;
}

/* Orta bant: info solda, butonlar sağda */
.game__info{
  position: absolute;
  left: 10px; right: 10px;
  top: 50%; transform: translateY(-50%);  /* dikeyde ortala */
  z-index: 2;

  display: flex;
  align-items: center;
  gap: 12px;

  padding: 12px 14px;
  border-radius: 14px;
  color: #fff;

  /* cam efekti – okunabilirlik */
  background: rgba(0,0,0,.28);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

/* Soldaki metin bloğu */
.game__info > div:first-child{
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1 1 auto;   /* boş alanı alsın */
  min-width: 0;     /* ellipsis çalışsın */
}

.game__title{
  font-weight: 800;
  font-size: 16px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.game .muted{
  color: rgba(255,255,255,.85);
  font-size: 12px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Sağdaki aksiyon butonları */
.game__actions{
  margin-left: auto;      /* en sağa it */
  display: flex;
  gap: 8px;
  flex-shrink: 0;         /* daralmayı engelle */
}
.game__actions .btn{ white-space: nowrap; }

/* Izgara örneği (opsiyonel) */
.games{
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}

/* Küçük ekran rötuşları (opsiyonel) */
@media (max-width: 420px){
  .game__title{ font-size: 14px; }
  .game__info{ padding: 10px 12px; gap: 8px; }
}

/* ORTA DEĞİL: DİBE YAPIŞIK */
.game__info{
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;   /* ⬅️ dibe */
  top: auto;      /* ⬅️ orta hizalamayı kapat */
  transform: none;/* ⬅️ translateY(-50%) kalktı */

  z-index: 2;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  color: #fff;
  background: rgba(0,0,0,.28);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.game__info{ left:0; right:0; bottom:0; border-radius:0; padding:12px 14px; }

/* Kartın içinde boşluk istemiyorsak padding 0 olmalı */
.game{
  padding: 0;
  position: relative;
  overflow: hidden;
  border-radius: 14px;      /* istersen */
  aspect-ratio: 3 / 4;      /* portre oran */
  background:#000;          /* yedek zemin */
}

/* UA default: figure'ın margin'i vardır → boşluk yapar */
.game__media{
  position: absolute;
  inset: 0;                 /* soldan-sağdan-üstten-alttan 0 */
  margin: 0;                /* figure default margin sıfırla */
  padding: 0;
  z-index: 0;
}

/* Görseli tam doldur: hiçbir kenarda boşluk kalmaz */
.game__img{
  display: block;           /* alt boşluk (baseline gap) olmasın */
  width: 100%;
  height: 100%;
  object-fit: cover;        /* kenarlarda bar yok */
  object-position: center;
  /* transform: scale(1.06);  <- BUNU KALDIR (gerekirse 1.01 yap) */
  border-radius: inherit;   /* kartın yuvarlağıyla aynı olsun */
  pointer-events: none;
}


/* === Taban değişkenler (fallback) === */
:root{
  --radius: 14px;

  --bg: #0b0b0b;                   /* sayfa zemini */
  --text: #fff;
  --muted: #c8ced6;

  --card-bg: #111;                 /* .game boşta kalırsa */
  --badge-bg: rgba(255,255,255,.12);
  --badge-text: #fff;

  --glass: rgba(0,0,0,.35);        /* .game__info cam katman */
  --glass-blur: 8px;

  --btn-grad: linear-gradient(135deg,#ff9a3d,#ff6a00);
  --btn-text: #111;
  --btn-ghost-bg: transparent;
  --btn-ghost-bd: rgba(255,255,255,.45);
  --btn-ghost-text: #fff;

  --tint: transparent;             /* görsel üstü tema rengi (opsiyonel) */
  --tint-blend: multiply;
}

/* === Değişkenlerin kullanımı === */
html,body{height:100%}
body{
  background: var(--bg);
  color: var(--text);
}
.game{ 
  background: var(--card-bg);
  border-radius: var(--radius);
}
.game .badge{
  background: var(--badge-bg);
  color: var(--badge-text);
}
.game__info{
  background: var(--glass);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
}
.btn--primary{
  background: var(--btn-grad);
  color: var(--btn-text);
  border: none;
}
.btn--ghost{
  background: var(--btn-ghost-bg);
  border: 1px solid var(--btn-ghost-bd);
  color: var(--btn-ghost-text);
}
.game::after{                       /* kart görseline tema tonu */
  content:"";
  position:absolute; inset:0;
  pointer-events:none;
  background: var(--tint);
  mix-blend-mode: var(--tint-blend);
}



/* 1) OBSIDIAN (AMOLED + turuncu aksan) */
[data-theme="obsidian"]{
  --bg: radial-gradient(120% 80% at 50% -10%, #151515 0%, #050505 60%, #000 100%);
  --btn-grad: linear-gradient(135deg,#ffa94d,#ff6a00);
  --badge-bg: rgba(255,255,255,.14);
  --glass: rgba(0,0,0,.45);
  --glass-blur: 10px;
  --tint: rgba(0,0,0,.08);
   transition: background-color .2s, color .2s, border-color .2s;
}

/* 2) BRONZE (sıcak altın/bronze) */
[data-theme="bronze"]{
  --bg: linear-gradient(180deg,#2c1a10 0%, #1a0f0a 50%, #0b0806 100%);
  --btn-grad: linear-gradient(135deg,#d4af37,#a5742b);
  --badge-bg: rgba(212,175,55,.18);
  --badge-text: #f7e7b2;
  --glass: rgba(33,20,13,.55);
  --tint: linear-gradient(180deg,rgba(212,175,55,.10),rgba(165,116,43,.08));
   transition: background-color .2s, color .2s, border-color .2s;
}

/* 3) EMERALD (okyanus/yeşil) */
[data-theme="emerald"]{
  --bg: radial-gradient(80% 60% at 50% 0%, #103630 0%, #0a221e 55%, #040b0a 100%);
  --btn-grad: linear-gradient(135deg,#8ef6d8,#10d4a5);
  --badge-bg: rgba(16,212,165,.18);
  --badge-text: #d7fff3;
  --glass: rgba(7,30,27,.55);
  --tint: linear-gradient(180deg,rgba(16,212,165,.10),rgba(4,80,68,.10));
   transition: background-color .2s, color .2s, border-color .2s;
}

/* 4) NEON/AURORA (mor-mavi neon) */
[data-theme="neon"]{
  --bg: radial-gradient(120% 90% at 0% 0%, #1a1030 0%, #0f1235 40%, #07091a 100%);
  --btn-grad: linear-gradient(135deg,#a78bfa,#6366f1);
  --badge-bg: rgba(160,120,255,.22);
  --badge-text: #eef;
  --glass: rgba(12,10,30,.55);
  --tint: linear-gradient(180deg,rgba(167,139,250,.12),rgba(99,102,241,.12));
   transition: background-color .2s, color .2s, border-color .2s;
}

/* ——— Profil Kart ——— */
.profile-card{
  position: relative;
  padding: 16px;
  border-radius: 16px;
  background: var(--glass, rgba(0,0,0,.45));
  -webkit-backdrop-filter: blur(var(--glass-blur,10px)) saturate(1.1);
  backdrop-filter: blur(var(--glass-blur,10px)) saturate(1.1);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s;
}
.profile-card:hover{
  transform: translateY(-2px);
  border-color: color-mix(in oklab, var(--accent, #ff7a38) 40%, #fff 0%);
  box-shadow: 0 14px 40px rgba(0,0,0,.32);
}
/* dışa ince parıltı */
.profile-card::after{
  content:"";
  position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset,
              0 0 40px -8px color-mix(in oklab, var(--accent,#ff7a38) 50%, transparent) inset;
}

/* ——— Head ——— */
.pm-head{ display:flex; align-items:center; gap:12px; }

/* avatar: canlı halka ve hafif animasyon */
.pm-avatar{
  position: relative;
  width: 56px; height: 56px;
  display:grid; place-items:center;
  border-radius: 50%;
  background: radial-gradient(120% 120% at 30% 30%,
              rgba(255,255,255,.18) 0%, rgba(255,255,255,.06) 55%, transparent 60%);
  font-size: 26px;
  color: #fff;
}
.pm-avatar::after{
  content:"";
  position:absolute; inset:-2px; border-radius:inherit;
  background: conic-gradient(from 0deg,
              color-mix(in oklab, var(--accent,#ff7a38) 75%, #fff 0%) 0 25%,
              transparent 25% 50%,
              color-mix(in oklab, var(--accent,#ff7a38) 55%, #fff 0%) 50% 75%,
              transparent 75% 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding: 2px;               /* sadece halka görünür */
  animation: ring 6s linear infinite;
  opacity:.9;
}
@keyframes ring { to { transform: rotate(1turn); } }

/* meta */
.pm-meta{ min-width:0; }
.pm-username{
  font-weight: 800; letter-spacing:.2px;
  font-size: 16px; color:#fff;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.pm-balance{ color: var(--muted, #c8ced6); margin-top:2px; }
.pm-balance b{
  background: linear-gradient(135deg,
              color-mix(in oklab, var(--accent,#ff7a38) 95%, #fff 0%),
              color-mix(in oklab, var(--accent,#ff7a38) 70%, #000 0%));
  color:#111; padding:3px 10px; border-radius: 999px; font-weight:800;
  box-shadow: 0 6px 16px color-mix(in oklab, var(--accent,#ff7a38) 40%, transparent);
}

/* ——— Stats ——— */
.pm-stats{
  display:grid; grid-template-columns: 1fr 1fr; gap:10px;
  margin-top:14px;
}
.pm-stat{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; border-radius:12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  transition: transform .15s ease, border-color .15s ease;
}
.pm-stat:hover{ transform: translateY(-1px); border-color: rgba(255,255,255,.2); }
.pm-stat span{ font-size:12px; color:var(--muted,#c8ced6); }
.pm-stat b{ font-size:18px; color:#fff; }

/* ——— Actions ——— */
.pm-actions{ display:flex; gap:10px; margin-top:14px; }
.pm-link, .pm-logout{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 14px; border-radius:999px; line-height:1;
  font-weight:700; cursor:pointer; text-decoration:none;
  transition: transform .12s ease, box-shadow .12s ease, background .12s, border-color .12s;
}
.pm-link{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.22);
  color:#fff;
}
.pm-link:hover{
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--accent,#ff7a38) 50%, #fff 0%);
  box-shadow: 0 8px 18px color-mix(in oklab, var(--accent,#ff7a38) 30%, transparent);
}
.pm-logout{
  background: linear-gradient(135deg, #ff5b57, #ff2f6c);
  color:#fff; border: none;
  box-shadow: 0 10px 22px rgba(255,79,96,.35);
}
.pm-logout:hover{ transform: translateY(-1px) scale(1.01); }

:root{ --accent:#ff7a38; }                     /* fallback */
[data-theme="obsidian"]{ --accent:#ff6a00; }
[data-theme="bronze"]  { --accent:#d4af37; }
[data-theme="emerald"] { --accent:#10d4a5; }
[data-theme="neon"]    { --accent:#8b5cf6; }


/* ===========================
   WALLET / CARD KABUĞU
=========================== */
#walletPage{ padding: 20px; }

.wallet-card{
  position: relative;
  border-radius: 18px;
  padding: 16px;
  background: color-mix(in oklab, var(--glass, rgba(0,0,0,.45)) 80%, transparent);
  -webkit-backdrop-filter: blur(var(--glass-blur,10px)) saturate(1.1);
  backdrop-filter: blur(var(--glass-blur,10px)) saturate(1.1);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 20px 50px rgba(0,0,0,.35);
  overflow: hidden;
}

/* animasyonlu dış parıltı çerçevesi */
.wallet-card::before{
  content:""; position:absolute; inset:-1px; border-radius:inherit; pointer-events:none;
  background: conic-gradient(from 0deg,
              color-mix(in oklab,var(--accent,#ff7a38) 60%, transparent) 0 25%,
              transparent 25% 50%,
              color-mix(in oklab,var(--accent,#ff7a38) 40%, transparent) 50% 75%,
              transparent 75% 100%);
  filter: blur(18px); opacity:.35;
  animation: spin 9s linear infinite;
}
@keyframes spin { to { transform: rotate(1turn); } }

/* hafif film greni (doku) */
.wallet-card::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image: radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 3px 3px; opacity:.15; mix-blend-mode: overlay;
}

/* ===========================
   TABS (Deposit / Withdraw)
=========================== */
.wallet-tabs{
  position: relative;
  display: flex; gap: 8px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12);
  padding: 6px; border-radius: 14px; isolation:isolate;
  margin-bottom: 14px;
}

/* aktif sekmenin altına kayan highlight */
.wallet-tabs::after{
  content:""; position:absolute; z-index:0;
  top:6px; bottom:6px; left:6px; width:calc(50% - 6px);
  border-radius: 10px;
  background: linear-gradient(135deg,
              color-mix(in oklab,var(--accent,#ff7a38) 90%, #fff 0%),
              color-mix(in oklab,var(--accent,#ff7a38) 60%, #000 0%));
  box-shadow: 0 10px 25px color-mix(in oklab,var(--accent,#ff7a38) 35%, transparent);
  transition: transform .28s ease;
}
/* :has ile hangi tab aktifse highlight oraya kayar */
.wallet-tabs:has(.wt-tab:nth-child(2).is-active)::after{ transform: translateX(100%); }

.wt-tab{
  position: relative;
  z-index:1;
  flex: 1 1 0;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.15);
  background: transparent;
  color: var(--muted,#c8ced6);
  font-weight: 800; letter-spacing:.2px;
  cursor: pointer;
  transition: color .2s ease, transform .12s ease, border-color .2s;
}
.wt-tab:hover{ transform: translateY(-1px); border-color: rgba(255,255,255,.25); }
.wt-tab.is-active{ color:#111; }

/* ===========================
   BANKA KARTLARI GRID
=========================== */
.bank-grid{
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  margin-bottom: 14px;
}

.bank-card{
  position: relative;
  aspect-ratio: 16/9;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.15);
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  overflow: hidden;
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: 12px;
  color:#fff; text-align:left; gap: 8px;
  transform-style: preserve-3d;
  transition: transform .18s ease, border-color .2s ease, box-shadow .2s ease;
  animation: float 5s ease-in-out infinite;
}
@keyframes float {
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-3px); }
}

.bank-card::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(120% 120% at -10% -10%,
      color-mix(in oklab,var(--accent,#ff7a38) 25%, transparent) 0%,
      transparent 50%);
  opacity:.6; transition: opacity .2s ease;
}
.bank-card:hover{
  transform: translateY(-3px) scale(1.015) rotateX(2deg);
  border-color: color-mix(in oklab,var(--accent,#ff7a38) 55%, #fff 0%);
  box-shadow: 0 20px 35px rgba(0,0,0,.35);
}
.bank-card:hover::before{ opacity: .9; }

.bank-card.is-selected{
  border-color: color-mix(in oklab,var(--accent,#ff7a38) 75%, #fff 0%);
  box-shadow: 0 25px 45px color-mix(in oklab,var(--accent,#ff7a38) 25%, transparent);
  animation: none; transform: translateY(-2px);
}

.bank-ico{ font-size: 22px; transform: translateZ(20px); }
.bank-card b{
  margin-left: auto; font-weight:900; letter-spacing:.2px; transform: translateZ(20px);
}

/* klavye erişilebilirlik */
.bank-card:focus-visible{
  outline: 2px solid color-mix(in oklab,var(--accent,#ff7a38) 70%, #fff 0%);
  outline-offset: 2px;
}

/* ===========================
   FORMLAR
=========================== */
.wallet-form{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 14px;
  padding: 14px;
  color:#fff;
  box-shadow: 0 18px 40px rgba(0,0,0,.28);
  animation: pop .28s ease;
}
@keyframes pop{
  from { opacity: 0; transform: translateY(6px) scale(.98); }
  to   { opacity: 1; transform: translateY(0)   scale(1); }
}
.wallet-form h4{
  margin: 0 0 10px 0;
  font-size: 16px; font-weight: 900; letter-spacing:.2px;
}

/* satır: label+input düzeni */
.wf-row{
  display: grid;
  grid-template-columns: 160px 1fr;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  transition: border-color .2s ease, box-shadow .2s ease, transform .12s;
  margin-bottom: 10px;
}
.wf-row:has(input:focus){
  border-color: color-mix(in oklab,var(--accent,#ff7a38) 55%, #fff 0%);
  box-shadow: 0 10px 24px color-mix(in oklab,var(--accent,#ff7a38) 25%, transparent);
  transform: translateY(-1px);
}
.wf-row > span{ color: var(--muted,#c8ced6); font-size: 12px; }

/* input’lar */
.input{
  width: 100%;
  height: 40px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.35);
  color:#fff; padding: 0 12px;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.input::placeholder{ color: rgba(255,255,255,.45); }
.input:focus{
  border-color: color-mix(in oklab,var(--accent,#ff7a38) 60%, #fff 0%);
  box-shadow: 0 10px 24px color-mix(in oklab,var(--accent,#ff7a38) 25%, transparent);
}

/* form butonları */
.wf-actions{
  display: flex; gap: 10px; justify-content: flex-end; margin-top: 6px;
}
.btn{
  border-radius: 999px; padding: 10px 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.22);
  color:#fff; font-weight:800; cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, background .12s, border-color .12s;
}
.btn:hover{ transform: translateY(-1px); }
.btn:active{ transform: translateY(0); }
.btn.btn--primary{
  background: linear-gradient(135deg,
              color-mix(in oklab,var(--accent,#ff7a38) 95%, #fff 0%),
              color-mix(in oklab,var(--accent,#ff7a38) 70%, #000 0%));
  border: none; color:#111;
  box-shadow: 0 14px 30px color-mix(in oklab,var(--accent,#ff7a38) 35%, transparent);
  animation: pulse 2.6s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ filter: brightness(1); }
  50%{ filter: brightness(1.08); }
}

/* gizleme (native hidden attr) */
.wallet-form[hidden]{ display:none !important; }

/* responsive */
@media (max-width: 560px){
  .wf-row{ grid-template-columns: 1fr; }
  .wallet-tabs{ gap:6px; }
  .bank-grid{ grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
}
.bank-card:nth-child(1){ animation-delay:.0s }
.bank-card:nth-child(2){ animation-delay:.2s }
.bank-card:nth-child(3){ animation-delay:.4s }
.bank-card:nth-child(4){ animation-delay:.6s }

/* ===== Balance Menu ===== */
.bal-menu{
  position: relative;
  padding: 14px;
  border-radius: 16px;
  background: color-mix(in oklab, var(--glass, rgba(0,0,0,.45)) 85%, transparent);
  -webkit-backdrop-filter: blur(var(--glass-blur,10px)) saturate(1.1);
  backdrop-filter: blur(var(--glass-blur,10px)) saturate(1.1);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 16px 40px rgba(0,0,0,.3);
  color: #fff;
  overflow: hidden;
}

/* ambient parıltı */
.bal-menu::before{
  content:""; position:absolute; inset:-1px; border-radius:inherit; pointer-events:none;
  background: conic-gradient(from 0deg,
      color-mix(in oklab, var(--accent,#ff7a38) 55%, transparent) 0 25%,
      transparent 25% 50%,
      color-mix(in oklab, var(--accent,#ff7a38) 35%, transparent) 50% 75%,
      transparent 75% 100%);
  filter: blur(20px); opacity:.35; animation: spin 10s linear infinite;
}
@keyframes spin { to { transform: rotate(1turn); } }

/* Başlık */
.bm-head{
  font-weight: 900; letter-spacing:.3px;
  font-size: 14px; color: var(--muted,#c8ced6);
  text-transform: uppercase;
  margin: 2px 2px 10px 2px;
  position: relative;
  padding-bottom: 8px;
}
.bm-head::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:2px;
  background: linear-gradient(90deg,
      color-mix(in oklab,var(--accent,#ff7a38) 90%, #fff 0%) 0%,
      transparent 60%);
  background-size: 160% 100%;
  animation: underlineMove 3.2s ease-in-out infinite;
}
@keyframes underlineMove{
  0%,100%{ background-position: 0% 0; }
  50%{ background-position: 100% 0; }
}

/* Liste öğeleri */
.bm-item{
  width: 100%;
  display: grid;
  grid-template-columns: 38px 1fr auto; /* icon | label | value */
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  margin: 6px 0;
  border-radius: 12px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12);
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease, background .15s;
}

/* buton gibi olanlar */
button.bm-item{ cursor: pointer; text-align: left; }
button.bm-item:hover{
  transform: translateY(-1px);
  border-color: color-mix(in oklab,var(--accent,#ff7a38) 50%, #fff 0%);
  background: rgba(255,255,255,.07);
  box-shadow: 0 12px 26px color-mix(in oklab,var(--accent,#ff7a38) 22%, transparent);
}
button.bm-item:active{ transform: translateY(0); }

/* satır türü (klik olmayan) */
.bm-item.-row{ cursor: default; }

/* ikon kabı */
.bm-ico{
  width: 38px; height: 38px; display:grid; place-items:center;
  border-radius: 10px;
  background:
    radial-gradient(120% 120% at 30% 30%, rgba(255,255,255,.18) 0%, rgba(255,255,255,.06) 55%, transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 6px 16px rgba(0,0,0,.25);
  transition: transform .18s ease, box-shadow .18s ease;
}
.bm-item:hover .bm-ico{
  transform: scale(1.06) rotate(-2deg);
  box-shadow: 0 10px 22px rgba(0,0,0,.3);
}

/* metin ve değer */
.bm-item > span:nth-of-type(2){ /* label */
  color:#fff; font-weight:700; letter-spacing:.2px;
}
.bm-item b{                      /* value */
  font-weight: 900;
  font-variant-numeric: tabular-nums; /* sayılar hizalı */
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.2);
  box-shadow: 0 6px 14px rgba(0,0,0,.18);
  min-width: 40px; text-align: right;
  transition: transform .12s ease, box-shadow .12s ease, border-color .15s ease, background .15s;
}
button.bm-item:hover b{
  border-color: color-mix(in oklab,var(--accent,#ff7a38) 50%, #fff 0%);
  box-shadow: 0 10px 22px color-mix(in oklab,var(--accent,#ff7a38) 25%, transparent);
}

/* separator */
.bm-sep{
  height: 1px; margin: 8px 4px;
  background: linear-gradient(90deg,
      transparent 0%,
      color-mix(in oklab,var(--accent,#ff7a38) 55%, #fff 0%) 20%,
      transparent 40%,
      color-mix(in oklab,var(--accent,#ff7a38) 35%, #fff 0%) 60%,
      transparent 100%);
  background-size: 200% 100%;
  animation: shimmer 2.8s linear infinite;
  opacity:.7;
}
@keyframes shimmer{
  0%{ background-position: 0% 0; }
  100%{ background-position: 200% 0; }
}

/* giriş animasyonu – sırayla gelsin */
.bal-menu > .bm-head{ animation: rise .28s ease both; }
.bal-menu > .bm-item:nth-of-type(1){ animation: rise .28s .05s ease both; }
.bal-menu > .bm-item:nth-of-type(2){ animation: rise .28s .10s ease both; }
.bal-menu > .bm-item:nth-of-type(3){ animation: rise .28s .15s ease both; }
.bal-menu > .bm-item:nth-of-type(4){ animation: rise .28s .20s ease both; }
.bal-menu > .bm-sep{               animation: rise .28s .25s ease both; }
.bal-menu > .bm-item.-row{         animation: rise .28s .30s ease both; }

@keyframes rise{
  from { opacity: 0; transform: translateY(6px) }
  to   { opacity: 1; transform: translateY(0) }
}

/* erişilebilirlik */
.bm-item:focus-visible{
  outline: 2px solid color-mix(in oklab,var(--accent,#ff7a38) 70%, #fff 0%);
  outline-offset: 2px;
}

/* küçük ekran */
@media (max-width: 420px){
  .bm-item{ padding: 10px; grid-template-columns: 34px 1fr auto; }
  .bm-ico{ width:34px; height:34px; border-radius:9px; }
  .bm-item b{ padding: 5px 9px; }
}

.bm-item b{ animation: statPulse 3s ease-in-out infinite; }
@keyframes statPulse{ 50%{ filter: brightness(1.08); } }
.header-right, #balChipWrap, .profile-card { position: relative; }
/* Overlay davranışı: yer kaplamaz, üstte durur */
#balMenu{
  position: absolute;         /* veya sabit istiyorsan: fixed */
  top: calc(100% + 8px);      /* tetikleyicinin altına aç */
  right: 0;
  z-index: 9999;

  width: 280px;
  max-height: min(65vh, 420px);
  overflow: auto;

  margin: 0 !important;       /* olası dış boşlukları iptal */
  /* aç/kapa animasyonu */
  opacity: 0;
  transform: translateY(-6px) scale(.98);
  visibility: hidden;
  pointer-events: none;
  transition: opacity .16s ease, transform .16s ease, visibility 0s .16s;
}

/* Açık durum */
#balMenu.is-open{
  opacity: 1;
  transform: translateY(0) scale(1);
  visibility: visible;
  pointer-events: auto;
  transition: opacity .16s ease, transform .16s ease;
}

/* küçük ok (tetikleyiciye doğru) — isteğe bağlı */
#balMenu::marker{ content:""; } /* Safari çizgi bug'ı için no-op */
#balMenu::before{
  content:"";
  position:absolute;
  top:-8px; right:16px;
  width:12px; height:12px;
  background: inherit;        /* kartın arka planını kullanır */
  border: inherit;            /* kenarlık uyumlu */
  border-bottom:none; border-right:none;
  transform: rotate(45deg);
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.25));
}

/* Bal menu: overlay, layout’u itmez */
#balMenu{
  position: fixed;
  top: calc(var(--header-h) + 8px);  /* header’ın hemen altı */
  right: max(16px, env(safe-area-inset-right));  /* en sağ */
  z-index: 9999;

  width: 280px;                       /* gerekirse 300px yap */
  max-height: min(65vh, 420px);
  overflow: auto;

  margin: 0 !important;
  /* aç/kapa animasyonu */
  opacity: 0; transform: translateY(-6px) scale(.98);
  visibility: hidden; pointer-events: none;
  transition: opacity .16s ease, transform .16s ease, visibility 0s .16s;
}
#balMenu.is-open{
  opacity: 1; transform: none;
  visibility: visible; pointer-events: auto;
  transition: opacity .16s ease, transform .16s ease;
}

/* küçük ok (isteğe bağlı) */
#balMenu::before{
  content:"";
  position:absolute; top:-8px; right:16px;
  width:12px; height:12px; transform: rotate(45deg);
  background: inherit;     /* menüyle aynı cam arka plan */
  border: inherit; border-bottom:none; border-right:none;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.25));
}

#balMenu{
  position: fixed; z-index: 9999;
  width: 280px; max-height: min(65vh, 420px); overflow:auto;
  margin:0 !important; opacity:0; transform: translateY(-6px) scale(.98);
  visibility:hidden; pointer-events:none; transition: opacity .16s, transform .16s, visibility 0s .16s;
}
#balMenu.is-open{ opacity:1; transform:none; visibility:visible; pointer-events:auto; }
#balMenu::before{
  content:"";
  position:absolute;
  top:-8px;
  right: var(--caret-right, 55px); /* JS’te ayarlanır */
  width:12px; height:12px; transform: rotate(45deg);
  background: inherit; border: inherit; border-bottom:none; border-right:none;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.25));
}





/* ====== SIDEBAR KABUK ====== */
.sidebar{
          
  top: var(--header-h, 64px);
  height: calc(100dvh - var(--header-h, 64px));
  width: 260px;
  padding: 14px;
  border-radius: 18px;
  background: color-mix(in oklab, var(--glass, rgba(0,0,0,.45)) 85%, transparent);
  backdrop-filter: blur(var(--glass-blur,10px)) saturate(1.1);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
}





/* Bank cards: logo + ad yan yana, metin 2 satıra kadar sarılsın */
.bank-grid .bank-card{
  display: grid !important;
  grid-template-columns: 44px 1fr;
  align-items: center;
  justify-content: start;
  gap: 10px;
  padding: 12px !important;

  /* sabit oran kesiyordu, kaldırıyoruz */
  aspect-ratio: auto !important;
  min-height: 64px;
}

/* Logo güvenli kutu (beyaz zemin), taşma yok */
.bank-grid .bank-logo{
  width: 44px; height: 44px;
  object-fit: contain;
  background: #fff;
  border-radius: 8px;
  padding: 6px;
}

/* İsim: sar, 2 satıra kadar göster, taşanı gizle */
.bank-grid .bank-name{
  display: -webkit-box;
  -webkit-line-clamp: 2;        /* en fazla 2 satır */
  -webkit-box-orient: vertical;
  overflow: hidden;
  white-space: normal;
  text-align: left;

  font-weight: 800;
  font-size: 14px;
  line-height: 1.15;
  word-break: break-word;        /* uzun kelimeleri kır */
  overflow-wrap: anywhere;
}

/* Önceki .bank-card b stilini tamamen bastır */
.bank-grid .bank-card b{ display:none !important; }
 /* Basit kart düzeni (temana uyumlu, hafif) */
  .aff-wrap{display:grid;gap:12px;align-content:start}
  .aff-card{border:1px solid var(--border,#1f2733);border-radius:12px;background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));padding:14px 16px}
  .aff-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .aff-grid .input{width:100%}
  .aff-grid .center{grid-column:1/-1;text-align:center}
  .aff-link{display:flex;gap:8px;align-items:center}
  .chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border,#1f2733);cursor:pointer;opacity:.9}
  .chip.is-active{background:rgba(255,255,255,.04)}
  .muted{opacity:.75}
  @media (max-width:720px){ .aff-grid{grid-template-columns:1fr} .aff-link{flex-direction:column;align-items:stretch} }

  /* ==== VIP 2025 ==== */
.vip-wrap{display:grid;gap:16px}
.vip-hero{position:relative;overflow:hidden;border-radius:18px;padding:18px;
  background: radial-gradient(1200px 400px at 80% -10%, rgba(255,255,255,.08), transparent 50%),
              linear-gradient(135deg, #1f1c2c 0%, #928DAB 100%);
  color:#fff; box-shadow:0 10px 30px rgba(0,0,0,.25); isolation:isolate; min-height:140px}
@keyframes vipFloat { from { transform: translateY(-10px) } to { transform: translateY(10px) } }
.vip-hero::after{content:""; position:absolute; inset:-40%;
  background:
    radial-gradient(closest-side, rgba(255,255,255,.12), transparent 60%) 20% 30% / 40% 40% no-repeat,
    radial-gradient(closest-side, rgba(255,255,255,.08), transparent 60%) 70% 60% / 50% 50% no-repeat;
  filter: blur(8px); z-index:0; animation: vipFloat 12s ease-in-out infinite alternate;}
.vip-hero__row{position:relative;z-index:1;display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.vip-left{display:flex;align-items:center;gap:14px}
.vip-badge{width:64px;height:64px;border-radius:16px;background: linear-gradient(135deg,#ffd479,#ff9b4a);
  box-shadow: 0 10px 25px rgba(255,170,80,.35); display:grid;place-items:center;font-size:28px}
.vip-title{font-weight:800;font-size:22px;letter-spacing:.2px}
.vip-sub{opacity:.9;font-size:13px;margin-top:4px}
.vip-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.vip-chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);padding:6px 10px;border-radius:999px;font-size:12px}
.vip-ring{position:relative;width:140px;height:140px}
.vip-ring__center{position:absolute;inset:0;display:grid;place-items:center;text-align:center;font-weight:700;color:#fff}
.vip-ring__center b{font-size:24px;display:block}
.vip-ring__center small{opacity:.85}
.vip-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.vip-card{grid-column: span 12;background: var(--card-bg, #111);
  color: var(--card-fg, #ddd); border-radius:16px;padding:14px 14px 12px; 
  box-shadow:0 6px 18px rgba(0,0,0,.18); border:1px solid rgba(255,255,255,.08); overflow:hidden}
[data-theme="lagoon"] .vip-card{--card-bg:#0b1720;--card-fg:#e8f2ff}
.vip-card h4{margin:0 0 8px;font-size:14px;opacity:.9}
.vip-stats{display:flex;gap:8px;flex-wrap:wrap}
.vip-pill{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:8px 10px;display:flex;gap:8px;align-items:center}
.vip-num{font-weight:800;font-size:18px}
.vip-muted{opacity:.75;font-size:12px}
.vip-tl{display:grid;gap:10px}
.vip-tl__row{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:10px;border-radius:12px}
.vip-tl__row b{font-size:14px}
.vip-tl__row small{opacity:.8}
.vip-rules{font-size:13px;line-height:1.55}
.vip-rules ul{margin:8px 0 0;padding-left:18px}
.vip-rules code{background:rgba(255,255,255,.06);padding:2px 6px;border-radius:8px}
.vip-confetti{pointer-events:none;position:fixed;inset:0;z-index:9999}
.profile-card { padding:16px; border-radius:12px; background:var(--card-bg,#111); box-shadow:0 1px 0 rgba(255,255,255,.06) inset, 0 6px 24px rgba(0,0,0,.25); }
.settings-grid { display:grid; grid-template-columns:1fr; gap:16px; }
.set-card { border:1px solid rgba(255,255,255,.06); border-radius:12px; padding:14px; background:rgba(255,255,255,.02); }
.set-head { margin:0 0 12px; font-size:1rem; opacity:.9; }
.form-grid.two { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.form-grid .f { display:flex; flex-direction:column; gap:6px; }
.row-actions { display:flex; gap:8px; align-items:center; margin-top:10px; }
.row-actions.end { justify-content:flex-end; }
.row-actions.start { justify-content:flex-start; }
.row-actions.between { justify-content:space-between; }
.chk { display:flex; align-items:center; gap:8px; }
@media (max-width: 720px){
  .form-grid.two { grid-template-columns:1fr; }
}
