:root{
  /* Gold theme */
  --bg:#07080d;
  --panel:#0f1220;
  --panel2:#11162a;
  --border:#7a5a1f;
  --accent:#d4af37;
  --text:#e9e9f0;
  --muted:#a9a9c0;
  --good:#2ad17b;
  --bad:#ff4d6d;
}
*{box-sizing:border-box}
body{
  margin:0; font-family:system-ui, -apple-system, Segoe UI, Roboto, Arial;
  background:var(--bg); color:var(--text);
}
a{color:inherit; text-decoration:none}
.cakitos-translate{
  position:fixed;
  top:10px;
  right:10px;
  z-index:9999;
  padding:6px 8px;
  border-radius:12px;
  border:1px solid rgba(212,175,55,.22);
  background:rgba(15,18,32,.75);
  backdrop-filter: blur(10px);
}
.cakitos-translate .goog-te-gadget{font-family:inherit; color:var(--text); font-size:12px}
.cakitos-translate select{width:auto; padding:6px 8px; border-radius:10px}
/* Hide Google Translate top banner (keeps UI clean) */
.goog-te-banner-frame{display:none !important}
body{top:0 !important}

/* Global responsive guardrails (safe, non-destructive) */
html, body{max-width:100%; overflow-x:hidden}
img, video, canvas, svg{max-width:100%; height:auto}
iframe{max-width:100%}
pre, code{max-width:100%; overflow:auto}
.wrap{display:flex; min-height:100vh}
.sidebar{
  width:260px; background:linear-gradient(180deg, #1a1205, #0f0b04);
  border-right:1px solid rgba(212,175,55,.22);
  padding:16px;
}
.brand{
  font-weight:800; letter-spacing:.5px;
  padding:10px 12px; border:1px solid rgba(212,175,55,.35);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(212,175,55,.10), rgba(0,0,0,.08));
  margin-bottom:14px;
}
.brand-inline{margin:0}
.nav a{
  display:block; padding:12px 12px; border-radius:12px;
  margin:6px 0; border:1px solid rgba(212,175,55,.15);
  background:rgba(0,0,0,.12);
}
.nav a:hover{border-color:rgba(212,175,55,.55)}
.nav a.active{border-color:rgba(212,175,55,.85); background:rgba(212,175,55,.12)}
.main{flex:1; display:flex; flex-direction:column}
.header{
  height:58px; display:flex; align-items:center; justify-content:space-between;
  padding:0 18px;
  background:rgba(15,18,32,.9);
  border-bottom:1px solid rgba(212,175,55,.22);
  position:sticky; top:0;
}
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.02)), var(--panel);
  border:1px solid rgba(212,175,55,.22);
  border-radius:18px; padding:16px;
  box-shadow:0 12px 30px rgba(0,0,0,.35);
}
.grid{display:grid; gap:14px; padding:18px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px; border-radius:12px;
  border:1px solid rgba(212,175,55,.55);
  background:linear-gradient(180deg, rgba(212,175,55,.28), rgba(212,175,55,.12));
  cursor:pointer;
  box-shadow:0 10px 22px rgba(0,0,0,.25);
}
.btn:hover{background:linear-gradient(180deg, rgba(212,175,55,.38), rgba(212,175,55,.18))}
.btn.good{border-color:rgba(42,209,123,.55); background:rgba(42,209,123,.12)}
.btn.bad{border-color:rgba(255,77,109,.55); background:rgba(255,77,109,.12)}
.small{color:var(--muted); font-size:.92rem}
input,select{
  width:100%; padding:10px 12px; border-radius:12px;
  border:1px solid rgba(212,175,55,.20);
  background:var(--panel2); color:var(--text);
}
table{width:100%; border-collapse:collapse}
th,td{padding:10px; border-bottom:1px solid rgba(212,175,55,.16); text-align:left}
.badge{padding:4px 10px; border-radius:999px; border:1px solid rgba(212,175,55,.35); font-size:.85rem}
.badge.ok{border-color:rgba(42,209,123,.5); color:var(--good)}
.badge.p{opacity:.9}
.badge.bad{border-color:rgba(255,77,109,.5); color:var(--bad)}
.notice{padding:10px 12px; border-radius:14px; border:1px solid rgba(212,175,55,.22); background:rgba(212,175,55,.08)}
.notice.bad{border-color:rgba(255,77,109,.35); background:rgba(255,77,109,.08)}
.notice.ok{border-color:rgba(42,209,123,.35); background:rgba(42,209,123,.08)}
hr{border:0; border-top:1px solid rgba(212,175,55,.16); margin:14px 0}

/* ===== Public top bar (home/login/register) ===== */
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(7,8,13,.75);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(212,175,55,.20);
}
.topbar-inner{
  max-width:1100px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 18px;
}
.topnav{display:flex; gap:10px; flex-wrap:wrap;}
.navlink{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 12px; border-radius:12px;
  border:1px solid rgba(212,175,55,.18);
  background:rgba(0,0,0,.10);
}
.navlink:hover{border-color:rgba(212,175,55,.50); background:rgba(212,175,55,.08)}
.public-wrap{min-height:calc(100vh - 62px)}

/* ===== Home components ===== */
.hero{
  position:relative;
  overflow:hidden;
  border-color:rgba(212,175,55,.28);
  background:
    radial-gradient(800px 250px at 15% 10%, rgba(212,175,55,.18), transparent 55%),
    radial-gradient(700px 300px at 90% 0%, rgba(212,175,55,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.02)),
    var(--panel);
}
.hero-inner{display:grid; gap:16px; grid-template-columns: 1.35fr .9fr; align-items:start;}
@media (max-width: 900px){ .hero-inner{grid-template-columns: 1fr;} }
.hero-title{margin:10px 0 10px; font-size:2rem; letter-spacing:.2px}
.hero-sub{max-width:58ch;}
.hero-cta{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px}
.hero-highlights{display:flex; gap:8px; flex-wrap:wrap; margin-top:14px}
.pill{
  padding:8px 10px; border-radius:999px;
  border:1px solid rgba(212,175,55,.18);
  background:rgba(0,0,0,.12);
  font-size:.92rem;
}
.hero-card{
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(212,175,55,.20);
  background:linear-gradient(180deg, rgba(212,175,55,.12), rgba(0,0,0,.10));
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
}
.hero-card-title{font-weight:800; margin-bottom:10px}
.dot{width:10px; height:10px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 6px rgba(212,175,55,.14)}
.kicker{font-weight:800; letter-spacing:.2px;}
.card-inner{padding:14px}

details.faq{border:1px solid rgba(212,175,55,.18); border-radius:14px; padding:10px 12px; background:rgba(0,0,0,.10); margin:10px 0}
details.faq summary{cursor:pointer; font-weight:700}
details.faq[open]{background:rgba(212,175,55,.06); border-color:rgba(212,175,55,.30)}

/* ===== Cookie banner ===== */
.cookie{
  position:fixed; left:14px; right:14px; bottom:14px;
  display:block;
}
.cookie-inner{
  max-width:1100px; margin:0 auto;
  display:flex; gap:14px; align-items:center; justify-content:space-between;
  padding:14px 14px;
  border-radius:18px;
  border:1px solid rgba(212,175,55,.24);
  background:rgba(15,18,32,.92);
  box-shadow:0 18px 50px rgba(0,0,0,.45);
}
.cookie-title{font-weight:800; white-space:nowrap}
.cookie-text{color:var(--muted); font-size:.92rem; line-height:1.4}
.cookie-actions{display:flex; gap:10px; flex-wrap:wrap}
@media (max-width: 900px){
  .cookie-inner{flex-direction:column; align-items:flex-start}
  .cookie-title{white-space:normal}
}
/* --- AJUSTES RESPONSIVE PARA MÓVILES --- */

@media (max-width: 768px) {
    /* El contenedor principal ya no divide en columnas, sino en filas */
    .wrap {
        display: flex;
        flex-direction: column;
    }

    /* El menú lateral (sidebar) ahora se vuelve una barra superior o se adapta */
    .sidebar {
        width: 100% !important;
        height: auto !important;
        padding: 10px !important;
        position: relative !important;
        border-right: none !important;
        border-bottom: 1px solid rgba(255,255,255,0.1);
    }

    /* Los botones del menú se ponen uno al lado del otro con scroll si es necesario */
    .sidebar nav {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        justify-content: center;
    }

    .sidebar a {
        padding: 8px 12px !important;
        font-size: 13px !important;
        margin-bottom: 0 !important;
    }

    /* La zona principal ocupa todo el ancho */
    .main {
        padding: 15px !important;
    }

    /* Las tarjetas (Saldo, Resumen) se ponen una debajo de otra */
    .grid.two, .grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
    }

    /* Ajuste de textos para que no se corten */
    h1 { font-size: 28px !important; }
    .card h3 { font-size: 18px !important; }
    
    /* El header del usuario se ajusta */
    .header-user {
        flex-direction: column;
        gap: 10px;
        text-align: center;
    }
}

/* Ajuste para tablets */
@media (min-width: 769px) and (max-width: 1024px) {
    .sidebar { width: 200px !important; }
    .grid.two { grid-template-columns: 1fr 1fr !important; }
}

/* ============================================================
   SOLO PARA MÓVILES (No afecta a la PC)
   ============================================================ */
@media (max-width: 850px) {
    
    /* Centramos el contenedor principal */
    .wrap {
        display: block !important;
        width: 100% !important;
        margin: 0 auto !important;
    }

    /* Sidebar: Se convierte en un encabezado centrado */
    .sidebar {
        width: 100% !important;
        height: auto !important;
        position: relative !important;
        padding: 20px 10px !important;
        border-right: none !important;
        border-bottom: 1px solid rgba(255,215,0,0.3); /* Línea dorada sutil */
        text-align: center !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
    }

    /* Navegación: Botones en bloque centrados */
    .sidebar nav {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important; /* Dos botones por fila */
        gap: 10px !important;
        width: 100% !important;
        max-width: 400px !important; /* Para que no se estiren demasiado */
        margin: 15px auto 0 !important;
    }

    .sidebar a {
        margin-bottom: 0 !important;
        justify-content: center !important; /* Centra el icono/texto dentro del botón */
        padding: 12px !important;
        border-radius: 12px !important;
    }

    /* Contenido principal: Centrado y con aire */
    .main {
        width: 100% !important;
        padding: 20px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important; /* Centra las tarjetas */
    }

    /* Header del usuario (Saldo y Botón Salir) */
    header {
        width: 100% !important;
        flex-direction: column !important;
        gap: 15px !important;
        text-align: center !important;
        margin-bottom: 25px !important;
    }

    /* Las tarjetas: Ahora se apilan y se centran */
    .grid.two, .grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 20px !important;
        width: 100% !important;
        max-width: 450px !important; /* Ancho ideal de lectura en móvil */
    }

    .card {
        text-align: center !important; /* Todo el texto de la tarjeta al centro */
        padding: 25px !important;
        width: 100% !important;
    }

    /* Botones dentro de las tarjetas */
    .card .btn {
        display: inline-block !important;
        width: 100% !important;
        margin: 5px 0 !important;
    }
}

/* Ajuste para teléfonos muy delgados */
@media (max-width: 400px) {
    .sidebar nav {
        grid-template-columns: 1fr !important; /* Un botón por fila si es muy pequeño */
    }
}

/* ===== Site Banners (Home + User + Sidebar) ===== */
.site-banner{
  margin:12px 0;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(148,163,184,.18);
  background:rgba(255,255,255,.03);
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:60px;
}
.site-banner .site-banner-link{display:block;width:100%}
.site-banner .site-banner-img{display:block;width:100%;height:auto;max-height:250px;object-fit:contain}
.site-banner.sidebar-slot{margin:10px 0;min-height:50px}
.site-banner.home-slot{margin:16px 0;min-height:70px}