:root{
    /* Paleta base (azules del tema) */
    --primary: #3b5c9a;
    --primary-600:#37518c;
    --primary-700:#2b416e;
    --primary-800:#1a2940;
    --primary-50:#eaf1ff;

    --accent:#2f4a7d;
    --accent-2:#4b6cb7;

    --ok:#38bdf8;      /* azulado en positivo */
    --warn:#f59e0b;
    --danger:#ef4444;

    --bg: #1c1a17;
    --bg-texture: radial-gradient(1200px 600px at 20% 0%, #2b2620 0%, #1c1a17 60%, #161410 100%);
    --paper: #e7dcc7;
    --ink: #2a1d0d;
    --gold: #c7a768;
    --blood: #7c2d2d;
    --wood-light: #d6b58c;
    --wood-dark: #6b4b2a;

    --card: #221e19cc;
    --card-border: #3c332b;
    --shadow: 0 10px 30px rgba(0,0,0,.4);

    /* Tipografía y radios */
    --font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans", "Helvetica Neue", Arial, "Apple Color Emoji", "Segoe UI Emoji";
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --btn-h: 44px;

    /* Efectos */
    --focus-ring: 0 0 0 3px rgba(168,198,255,.35);
}

*{ box-sizing:border-box; }
html, body { height:100%; }
body{
    margin:0;
    font-family: var(--font-sans); /* 🔹 fuente más limpia y moderna */
    color:#e0e8ff;
    background: var(--bg-texture), var(--bg);
    background: linear-gradient(135deg, rgba(30,60,100,0.9), rgba(10,20,40,1)),
                url("/assets/texturas/dark-mosaic.png");
    background-size: cover;
    background-attachment: fixed;
}

/* Halo suave */
body::before{
    content:"";
    position:fixed; inset:0;
    background: radial-gradient(circle at center, rgba(100,150,220,0.15), transparent 70%);
    pointer-events:none;
}
.cc-header{ margin-bottom:10px; }
#board{ max-width:540px; margin:0 auto; }
h3{
    display: none;
    visibility: hidden;
}
/*.cc-sidebar{ }*/
.timers{
    display:flex;
    justify-content:space-between;
    flex-wrap: wrap;
    margin:16px 0; }
.timers .t{ font-size:16px; }
.toolbar ul {
    list-style: none;
    padding: 0;
    margin-top: 1.5em;
    text-align: center;
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    align-content: stretch;
    justify-content: flex-start;
}
.toolbar li{ display:inline-block; }
.clickable{ cursor:pointer; }
.label-nick{
    font-weight: 700;
    padding: 0 25px 0 25px;
    margin: 1em;
    background: #5bc0de00;
}
#nicki{
font-size: 2em;
}

#info-usuarios{
    text-align: center;
}
.cc-panel .mi-usuario td{
    background:#4da6ff!important;
    color:#fff!important;
    font-weight:700;
}

/* ===================== TABLAS ===================== */
table{ width:100%; border-collapse:collapse; font-size:14px; margin:0 auto; }
table th{
    background:#1b2640;
    color:#e0e8ff;
    font-weight:700;
    text-align:center;
    padding:10px;
    border:1px solid #23345e;
}
table tr:nth-child(odd){ background:#0f1b33; color:#dbe8ff; }
table tr:nth-child(even){ background:#0b1528; color:#cfe1ff; }
table td{ padding:8px 10px; border:1px solid #1f2f52; }
table tr:hover{ background:#2a3f6b; color:#fff; }

/* ===================== INTERACCIÓN TÁCTIL ===================== */
html, body{
    overscroll-behavior:none;
    -webkit-overflow-scrolling:touch;
}
#board, .chessboard{
    touch-action:none; user-select:none; -webkit-user-select:none;
    -webkit-touch-callout:none; -webkit-tap-highlight-color:rgba(0,0,0,0);
}

/* ===================== BOTONES (renovados) ===================== */
button, .btn{
    --bg: var(--primary);
    --fg: #fff;
    --bd: var(--primary-700);

    min-height: var(--btn-h);
    padding: 12px 16px;
    font-size: 16px;
    line-height: 1.2;
    border-radius: var(--radius-md);

   background: linear-gradient(180deg, var(--bg), var(--primary-700));

    color: var(--fg);
    cursor: pointer;
    box-shadow: 0 6px 18px rgba(0,0,0,.25);
    transition: transform .12s ease, filter .12s ease, background .2s ease, box-shadow .2s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    text-decoration: none;
    touch-action: manipulation;
}
button:hover, .btn:hover{
    filter: brightness(1.06);
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(0,0,0,.28);
    color: white !important;
}
button:active, .btn:active{
    transform: translateY(0);
    filter: brightness(.98);
}
button:focus-visible, .btn:focus-visible{ outline: none; box-shadow: var(--focus-ring), 0 6px 18px rgba(0,0,0,.25); }
button:disabled, .btn:disabled, .is-disabled{
    opacity:.6; cursor:not-allowed; filter:grayscale(.2);
}

/* Variantes semánticas */
.btn-primary{ --bg: var(--primary); --bd: var(--primary-700); }
.btn-success{ --bg: #3b5c9a; --bd: #1e40af; }  /* azul brillante como confirmación */
.btn-warning{ --bg: #3b5c9a; --bd:#92400e; }
.btn-danger { --bg: #3b5c9a; --bd:#7f1d1d; }

/* Contorno (outline) */
.btn-outline{
    --fg: #e0e8ff;
    background: transparent;
    color: var(--fg);
    border: 1px solid var(--accent);
}
.btn-outline:hover{
    background: rgba(59,92,154,.15);
    border-color: var(--accent-2);
}

/* Fantasma (ghost) */
.btn-ghost{
    background: #00000020;
    color: #e0e8ff;
    border: 1px solid transparent;
}
.btn-ghost:hover{
    background: #00000035;
    border-color: var(--accent);
}

/* Sólido estilo tema (coherente con tus azules) */
.btn-solid{
    --bg: var(--primary);
    --bd: var(--accent);
    background: linear-gradient(180deg, var(--primary), var(--primary-700));
    color: #fff;
    border: 1px solid var(--accent);
}
.btn-solid:hover{ background: linear-gradient(180deg, var(--accent-2), var(--primary-700)); }

/* Tamaños */
.btn-xs{ min-height:36px; padding:8px 12px; font-size:14px; }
.btn-sm{ min-height:40px; padding:10px 14px; font-size:15px; }
.btn-lg{ min-height:52px; padding:14px 18px; font-size:17px; border-radius: var(--radius-lg); }

/* Botón con icono alineado */
.btn .icon{ width:1.1em; height:1.1em; display:inline-block; line-height:1; }

/* Estado cargando */
.is-loading{ position:relative; pointer-events:none; }
.is-loading::after{
    content:"";
    width:1em; height:1em; border-radius:50%;
    border:2px solid rgba(255,255,255,.6);
    border-top-color: transparent;
    display:inline-block; margin-left:.5rem;
    animation: spin .9s linear infinite;
}
@keyframes spin{ to{ transform: rotate(360deg); } }

/* Botones en toolbars/paneles específicos (coherencia con tema actual) */
.cc-sidebar .panel-heading .btn{
    background: linear-gradient(180deg, var(--primary), var(--primary-700));
    border:1px solid var(--accent);
    color:#fff; font-size:.85em; border-radius:6px; padding:.35em .7em;
}
.cc-sidebar .panel-heading .btn:hover{ background: linear-gradient(180deg, var(--accent-2), var(--primary-700)); }

.btn-desafiar{
    background: linear-gradient(180deg, var(--primary), var(--primary-700));
    border:1px solid var(--accent);
    color:#fff; border-radius:6px; font-size:.85em; padding:.35em .75em;
    transition: transform .1s ease, background .2s ease;
}
.btn-desafiar:hover{ background: linear-gradient(180deg, var(--accent-2), var(--primary-700)); transform: translateY(-2px); }

/* ===================== TABLERO ===================== */
#board{ width:100%; max-width:520px; margin:0 auto; aspect-ratio:1/1; }

@media (max-width:768px){
    .action-bar{
        position:fixed; left:0; right:0; bottom:0;
        background:#111; color:#fff; display:flex; gap:8px; justify-content:center;
        padding:8px env(safe-area-inset-right) calc(8px + env(safe-area-inset-bottom)) env(safe-area-inset-left);
        z-index:999;
    }
    .action-bar .btn{ flex:1; }
    body{ padding-bottom:64px; }
}

/* ======= Modal de coronación ======= */
#bot-promo-modal{
    background-color: #4262cfba !important;
}
.promo-modal{
    position:fixed; inset:0; background:rgba(0,0,0,.6);
    display:none; align-items:center; justify-content:center; z-index:9999;
}
.promo-modal.is-open{ display:flex; }
.promo-card{
    background:#2b2b2b; color:#f5f5f5;
    min-width:280px; max-width:420px; width:92vw;
    border-radius:14px; box-shadow:0 10px 30px rgba(0,0,0,.35);
    padding:18px 16px 14px; border:1px solid #3f3f3f;
}
.promo-title{ margin:0 0 6px; font-size:18px; font-weight:700; text-align:center; }
.promo-subtitle{ margin:0 0 14px; font-size:14px; color:#d0d0d0; text-align:center; }
.promo-grid{
    display:grid; grid-template-columns:repeat(4, minmax(50px, 1fr));
    gap:10px; margin:0 auto 12px; align-items:center; justify-items:center;
}
.promo-item{
    appearance:none; border:1px solid #4a4a4a; background:#1f1f1f; border-radius:10px;
    padding:8px; width:64px; height:64px; display:grid; place-items:center; cursor:pointer;
    transition: transform .08s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
}
.promo-item:hover{ transform:translateY(-1px); box-shadow:0 6px 16px rgba(0,0,0,.35); border-color:#6f6f6f; background:#262626; }
.promo-item:focus{ outline:2px solid #a6c8ff; outline-offset:2px; }
.promo-icon{ width:44px; height:44px; background-size:contain; background-repeat:no-repeat; background-position:center; display:block; }
.promo-actions{ display:flex; justify-content:center; gap:10px; }
.promo-close{
    appearance:none; border:1px solid #555; background:#3a3a3a; color:#fff;
    padding:8px 14px; border-radius:8px; cursor:pointer;
}
.promo-close:hover{ background:#454545; }
.promo-item .promo-unicode{ font-size:38px; line-height:1; }

/* Alertify centrado */
.ajs-message.ajs-visible{ left:50%!important; transform:translateX(-50%)!important; }

/* ===================== HEADER / FOOTER ===================== */
.site-header, .site-footer{
    padding:.75em 1em; display:flex; align-items:center; justify-content:space-between;
    background: linear-gradient(180deg, #1a2233, #121a29);
    border-bottom:1px solid var(--card-border);
}
.site-footer{ border-top:1px solid var(--card-border); border-bottom:none; justify-content:center; }

.brand{ display:flex; gap:.6em; align-items:center; }
.logo{ font-size:1.6em; filter: drop-shadow(0 2px 2px rgba(0,0,0,.6)); }
.title{ font-family: "UnifrakturCook", serif; font-size:1.6em; margin:0; letter-spacing:.5px; }
.title span{ color: var(--gold); }

.top-nav{ display:flex; gap:.5em; align-items:center; }
.nav-link{
    color:#e0e8ff; text-decoration:none; padding:.4em .7em; border-radius:.5em; border:1px solid transparent;
}
.nav-link:hover{ border-color: var(--gold); color: var(--gold); }
/* ===== PATCH [+] Controles de partida (no colisiona con tus clases) ===== */
#cc-controles{
  display:flex; gap:.5rem; align-items:center; justify-content:center;
  margin:1.5rem 0 0 0; flex-wrap:wrap;
}
#cc-controles .btn{ min-width:140px; }
.cc-estado{ display: none; margin-left:.25rem; font-size:.95rem; color:#a8c6ff; }

.cc-toast{
  position:fixed; right:1rem; bottom:1rem;
  background:#222; color:#fff; padding:.6rem .8rem; border-radius:8px; box-shadow: var(--shadow);
  max-width:60ch; z-index:99999;
}

/* Botones de cabecera coherentes con nuevas variantes */
.btn-ghost, .btn-solid, .btn-outline{
    appearance:none; cursor:pointer; font:inherit; padding:.55em .9em; border-radius:.6em; border:1px solid var(--card-border);
}
.btn-ghost{ background:#00000020; color:#e0e8ff; }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold); }
.btn-solid{
    background: linear-gradient(180deg, var(--primary), var(--primary-700));
    border-color: var(--accent);
    color:#fff; box-shadow: var(--shadow);
}
.btn-solid:hover{ filter:brightness(1.05); }
.btn-outline{
   background: linear-gradient(180deg, #6f5387, var(--primary-700));
    color:#ffffff; border-color: var(--gold); }
.btn-outline:hover{ background:#00000030; }

#btn_refresh_oponentes{
    display: none;
}
/* ===================== LAYOUT / CARDS ===================== */
.layout{
    display:grid; grid-template-columns:320px 1fr; gap:1em; padding:1em;
    min-height: calc(100dvh - 120px);
}
.sidebar{ display:flex; flex-direction:column; gap:1em; }
.card{
    background: var(--card);
    border: 1px solid var(--card-border);
    border-radius: 16px;
    box-shadow: var(--shadow);
    padding: .9em;
}
.card-title{ margin:0 0 .6em; font-family:"UnifrakturCook", serif; letter-spacing:.3px; color: var(--gold); }

#promo-modal{ width:85%; background-color: rgba(10,20,40,0.9); }

.list{ margin:0; padding-left:1em; }
.helpers a{ display:block; width:100%; margin-bottom:.5em; text-align:center; }
.helpers .btn-solid, .helpers .btn-outline{ width:100%; margin-bottom:.5em; }

/* ======= Tablero y casillas (azules) ======= */
.board-wrap{
    display:grid; place-items:center;
    background: radial-gradient(circle at center, rgba(20,40,70,0.9) 0%, rgba(10,20,40,0.95) 100%);
    border: 4px solid #2f4a7d; border-radius:14px;
    box-shadow: 0 0 25px rgba(0,50,100,.8), inset 0 0 15px rgba(0,20,50,.6);
    padding:.5rem;
}
#board{ width:100%; aspect-ratio:1/1; border-radius:12px; overflow:hidden; box-shadow: inset 0 0 20px rgba(0,0,0,.7); }
.white-1e1d7{
    background: linear-gradient(135deg, #5c7fa8, #3b5c9a);
    box-shadow: inset 0 0 6px rgba(0,0,0,.5);
}
.black-3c85d{
    background: linear-gradient(135deg, #2b416e, #1a2940);
    box-shadow: inset 0 0 8px rgba(0,0,0,.6);
}
.square-55d63.highlight1{ background-color: rgba(168,198,255,0.5)!important; }
.square-55d63.highlight2{ background-color: rgba(47,74,125,0.6)!important; }
.piece-417db{ transition: transform .15s ease; }

/* Responsivo */
@media (max-width:1000px){
    .layout{ grid-template-columns:1fr; }
    .sidebar{ order:2; }
    .board-wrap{ order:1; }
}

/* Marquesina */
.marquee{
    position:relative; overflow:hidden; white-space:nowrap; width:100%;
    height:2em; line-height:2em; border-top:1px solid var(--card-border); border-bottom:1px solid var(--card-border);
}
.marquee span{
    display:inline-block; padding-left:100%; animation:scroll-left 12s linear infinite;
}
@keyframes scroll-left{ from{ transform:translateX(0);} to{ transform:translateX(-100%);} }

/* ===================== DIALOG CONFIG ===================== */
.config-dialog{
    border:1px solid var(--card-border); background:#1f1b17; color:var(--paper);
    border-radius:18px; width:min(720px,92vw); padding:0; box-shadow:var(--shadow);
}
.config-dialog::backdrop{ background:rgba(0,0,0,.6); }
.cfg-header{ padding:1em 1em .5em; border-bottom:1px solid var(--card-border); }
.cfg-header h3{ margin:0; font-family:"UnifrakturCook",serif; color:var(--gold); }
.cfg-form{ display:grid; gap:1em; }
.cfg-grid{ display:grid; gap:.8em; padding:1em; grid-template-columns:repeat(2,1fr); }
.field{ display:grid; gap:.25em; }
.field span{ font-weight:700; color:var(--gold); }
.cfg-footer{ display:flex; justify-content:flex-end; gap:.5em; padding:1em; border-top:1px solid var(--card-border); }

/* ======= Alertify (azul oscuro translúcido) ======= */
.alertify .ajs-dialog{
    background: rgba(10,20,40,0.9);
    color:#e0e8ff;
    border:4px solid #2f4a7d;
    border-radius:12px;
    box-shadow: 0 0 20px rgba(0,50,100,.8), inset 0 0 15px rgba(0,20,50,.7);
    font-family: var(--font-sans);
}
.alertify .ajs-header{
    background: linear-gradient(180deg, rgba(20,40,70,0.9), rgba(10,20,40,0.8));
    color:#a8c6ff; font-weight:700; font-size:1.5em;
    border-bottom:2px solid #2f4a7d; text-align:center; letter-spacing:.5px;
}
.alertify .ajs-body .ajs-content{ padding:16px 24px 16px 16px; font-size:1.1em; text-align:center; }
.alertify .ajs-footer .ajs-buttons .ajs-button.ajs-ok{ color:#ced7dd; font-size:1em; }
.alertify .ajs-close{
    color:#a8c6ff; text-shadow:none; background:transparent; border:none; font-size:1.4em;
    opacity:.7; transition:opacity .2s ease;
}
.alertify .ajs-close:hover{ opacity:1; cursor:pointer; }
.alertify .ajs-body{ padding:1em; font-size:1em; color:#f0f4ff; }
.alertify .ajs-footer{
    background: rgba(20,40,70,0.8); border-top:2px solid #2f4a7d; padding:.8em; text-align:center;
    font-size:1.05em; font-weight:600; color:#e0e8ff;
}
.alertify .ajs-footer .ajs-buttons .ajs-button{
    background: linear-gradient(180deg, var(--primary), var(--primary-700));
    color:#fff; border:1px solid var(--accent); border-radius:6px; padding:.5em 1.2em;
    font-size:.95em; font-weight:700; box-shadow: inset 0 0 6px rgba(0,0,0,.4);
    transition: background .2s ease, transform .1s ease;
}
.alertify .ajs-footer .ajs-buttons .ajs-button:hover{ background: linear-gradient(180deg, var(--accent-2), var(--primary-700)); transform: translateY(-2px); }
.alertify .ajs-footer .ajs-buttons .ajs-button.ajs-cancel{
    background: linear-gradient(180deg, #253a60, #1a2940);
    border-color:#1a2940;
}

/* ======= Panel lateral azul translúcido ======= */
/**/
.cc-sidebar .panel{
    background: rgba(10,20,40,0.9);
    border:3px solid #2f4a7d; border-radius:12px;
    box-shadow: 0 0 18px rgba(0,50,100,.6), inset 0 0 10px rgba(0,20,50,.7);
    color:#e0e8ff; font-family: var(--font-sans); margin-bottom:1em;
}
/**/
.cc-sidebar .panel-heading{
    background: linear-gradient(180deg, rgba(30,50,90,.95), rgba(15,30,60,.9));
    color:#a8c6ff;
    font-weight:700;
    font-size:1em;
  /* */
  border-bottom:2px solid #2f4a7d;
    padding:.6em .8em;
    border-radius:9px 9px 0 0;
  /**/
}

.panel-body.cc-panel {
    max-height: 500px;   /* o la altura que quieras */
    overflow-y: auto;    /* activa scroll vertical */
    overflow-x: hidden;  /* opcional: evita scroll horizontal feo */
}

/* tu CSS actual de la tabla */
.cc-sidebar table {
    margin:0;
    border:none;
    background: rgba(15,30,60,.85);
    color:#f0f4ff;
    border-collapse:collapse;
}

.cc-sidebar thead{ background: rgba(20,40,80,.95); color:#a8c6ff; font-weight:600; border:none; }
.cc-sidebar th, .cc-sidebar td{ padding:.5em .8em; border:none; }
.cc-sidebar tbody tr:hover{ background: rgba(47,74,125,.4); }

/* Overrides de tablas específicas */
.table > tbody > tr > td{
    font-size:1.3em; font-weight:800; vertical-align:baseline; text-align:center;
    border:none; background:#fff; color:#000;
}
.table-striped > tbody > tr:nth-of-type(2n+1){
    background:#5090c8; color:#fff; border:none;
}
.table-striped > tbody > tr:nth-of-type(2n+1):hover{ background: rgba(47,74,125,.4); }

#promo-modal .title{ font-size:14px; color:#000; }

/* === Overrides azulados para configuración y promo === */
#cfg_panel{
    background: linear-gradient(180deg, rgba(15,23,42,0.92), rgba(8,15,30,0.94)) !important;
    color:#e0e8ff !important;
    border:1px solid rgba(168,198,255,0.22) !important;
    border-radius:16px;
    box-shadow: 0 18px 50px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.05) inset;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding:0 !important;
    overflow:hidden;
    width:min(420px, calc(100vw - 32px)) !important;
    min-width: 320px !important;
    max-width: calc(100vw - 32px) !important;
}
#cfg_panel .cfg_head, #cfg_panel .cfg_body, #cfg_panel .foot{
    background: rgba(12,18,30,0.82) !important;
    color:inherit;
    border-color:#2f4a7d;
    overflow:hidden!important;
    flex:none!important;
    flex-wrap: nowrap !important;
}
#cfg_panel .cfg_body{
    background: linear-gradient(180deg, rgba(12,18,30,0.86), rgba(9,14,24,0.90)) !important;
}
#cfg_panel .foot{
    background: linear-gradient(180deg, rgba(14,22,38,0.92), rgba(9,14,24,0.96)) !important;
    border-top:1px solid rgba(168,198,255,0.16) !important;
}
#cfg_panel .cfg_head{
    color:#ffffff !important;
    background: linear-gradient(180deg, rgba(34,57,96,.92), rgba(18,32,58,.92)) !important;
    font-size:1.05rem !important;
    padding: 14px 18px !important;
    border-bottom: 1px solid rgba(168,198,255,0.16);
}
#cfg_panel label{
    color:#f8fbff !important;
    background: transparent !important;
    font-size:1rem !important;
    line-height:1.35;
}
#cfg_panel .cfg_body{
    padding: 16px 18px !important;
    background: transparent !important;
}
#cfg_panel .foot{
    padding: 14px 18px !important;
    background: linear-gradient(180deg, rgba(18,32,58,.88), rgba(12,22,42,.92)) !important;
    border-top: 1px solid rgba(168,198,255,0.14);
}
#cfg_panel .foot .btn-primary{
    background: linear-gradient(180deg, var(--primary), var(--primary-700));
    border:1px solid var(--accent); color:#fff;
}
#cfg_panel .foot .btn-default{
    background: rgba(51,122,183,.10); border-color: rgba(51,122,183,.45); color:#e0e8ff;
}
#cfg_panel .foot .btn-default:hover{
    background: rgba(51,122,183,.16); border-color: var(--accent-2);
}
#promo-modal{
    background-color: rgba(123, 155, 217, 0.9) !important;
              border:2px solid #2f4a7d;
}
#promo-modal .title{ color:#e0e8ff !important; }
#cfg_panel select.form-control{
    background:#fff; color:#000;
    font-size:1em !important;
    font-weight:800;
    background-image:
        linear-gradient(45deg, transparent 50%, #a8c6ff 50%),
        linear-gradient(135deg, #a8c6ff 50%, transparent 50%),
        linear-gradient(to right, rgba(51,122,183,.15), rgba(51,122,183,.15));
}

/* Ocultar botón flotante si abierto */
body.cfg-open #btn_cfg{ opacity:0; pointer-events:none; }

/* Tablero responsivo */
#board{
    width:100%;
    max-width:640px;
    aspect-ratio:1/1;
    margin:0 auto;
    box-shadow: 9px 13px 39px 6px rgba(0,0,0,0.7);
-webkit-box-shadow: 9px 13px 39px 6px rgba(0,0,0,0.7);
-moz-box-shadow: 9px 13px 39px 6px rgba(0,0,0,0.7);
}
@media (max-width:480px){ #board{ max-width:92vw; } }
/* === FIX móvil: panel de configuración === */
/* Menos transparencia, tamaño contenido, scroll interno y footer fijo */
@media (max-width: 768px){
  /* Contenedor del panel (usa el que tengas: #cfg_panel o .config-dialog) */
  #cfg_panel,
  .config-dialog{
    /* Más opaco en móvil */
    background: rgba(10,20,40,0.96) !important;
    /* Tamaño y centrado razonables */
    width: 96vw;
    max-width: 96vw;
    max-height: 92vh;
    border-width: 2px;
    border-radius: 14px;
    overflow: hidden;               /* el scroll va dentro del body */
    padding: 0 !important;          /* quitamos relleno externo para aprovechar altura */
  }

  /* Cabecera fija arriba para que no se pierda el título */
  #cfg_panel .cfg_head,
  .config-dialog .cfg-header{
    position: sticky;
    top: 0;
    z-index: 2;
    background: linear-gradient(180deg, rgba(20,40,70,0.96), rgba(10,20,40,0.94)) !important;
    border-bottom: 1px solid #2f4a7d;
    padding: .8em 1em !important;
  }

  /* Pie con botones fijo abajo, siempre accesible */
  #cfg_panel .foot,
  .config-dialog .cfg-footer{
    position: sticky;
    bottom: 0;
    z-index: 2;
    background: rgba(20,40,70,0.94) !important;
    border-top: 1px solid #2f4a7d;
    padding: .7em .9em !important;
    backdrop-filter: blur(2px);
  }

  /* Cuerpo con scroll vertical propio */
  #cfg_panel .cfg_body,
  .config-dialog .cfg-form{
    /* Altura = total - cabecera - pie (aprox) */
    max-height: calc(92vh - 140px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 1em !important;
  }

  /* Rejilla en 1 columna para pantallas estrechas */
  .cfg-grid{
    grid-template-columns: 1fr !important;
    gap: .75em !important;
  }

  /* Campos algo más compactos para ganar altura útil */
  .cfg-grid .field input,
  .cfg-grid .field select,
  .cfg-grid .field textarea,
  #cfg_panel select.form-control{
    min-height: 40px;
    font-size: 15px;
  }
}

/* Aún más compacto en móviles muy pequeños / apaisado */
@media (max-width: 480px), (max-height: 540px){
  #cfg_panel,
  .config-dialog{
    max-height: 88vh;
  }
  #cfg_panel .cfg_body,
  .config-dialog .cfg-form{
    max-height: calc(88vh - 128px);
  }
}

/* ===================== CIBERCHESS · PATCH UI NO-DESTRUCTIVO ===================== */
/* ⚠️ No borra nada. Solo añade estilos si existen los elementos/IDs */

/* --- Config: selector de tiempo creado dinámicamente --- */
#cfg_time_preset{
  background:#0a0f1a;
  color:#e5e7eb;
  border:1px solid #1f2937;
  border-radius:10px;
  padding:10px 12px;
  min-width: 160px;
  font-weight: 700;
}
#cfg_time_preset:focus{ outline:none; box-shadow: var(--focus-ring); }

/* --- Badges ligeros para previews (si los añades desde JS) --- */
.badge-pill{
  display:inline-block; padding:2px 8px; border-radius:999px;
  background:rgba(56,189,248,.15); color:#93c5fd; font-size:12px; font-weight:600;
  border:1px solid rgba(255,255,255,.12);
  vertical-align:middle; margin-left:8px;
}

/* --- Grupo de color en configuración (radios -> "pills" visuales, sin cambiar HTML) --- */
.cfg-color-group label{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  margin-right:6px; cursor:pointer; user-select:none;
}
.cfg-color-group input[type="radio"]{
  appearance:none; width:14px; height:14px; border-radius:999px;
  border:2px solid #94a3b8; background:transparent;
}
.cfg-color-group input[type="radio"]:checked{
  border-color:#fff; background:#fff; box-shadow: 0 0 0 3px rgba(56,189,248,.35);
}

/* --- Botones "Tablas" y "Rendirse" con aspecto coherente --- */
/* Mapeamos varios IDs comunes. Si alguno coincide, se ve con estilo nuevo automáticamente */
#btn_tablas, #btn_ofrecer_tablas, #btn_aceptar_tablas, #btn_rechazar_tablas{
  min-height: var(--btn-h);
  padding: 10px 14px;
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, var(--primary), var(--primary-700));
  border:1px solid var(--accent);
  color:#fff;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
#btn_tablas:hover, #btn_ofrecer_tablas:hover, #btn_aceptar_tablas:hover, #btn_rechazar_tablas:hover{
  filter: brightness(1.06);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
}

/* Rendirse: variante de peligro si alguno de estos IDs existe */
#btn_rendirse, #btn_resign, #btn_abandonar{
  min-height: var(--btn-h);
  padding: 10px 14px;
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, #b91c1c, #7f1d1d);
  border:1px solid #7f1d1d;
  color:#fff;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
#btn_rendirse:hover, #btn_resign:hover, #btn_abandonar:hover{
  filter: brightness(1.06);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
}

/* --- Panel de configuración: filas compactas si usas estas clases desde JS (opcionales) --- */
.cfg-row{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.cfg-label{ font-weight:600; margin-right:6px; }

/* --- Action bar inferior (por si alojas aquí los botones de tablas/rendirse) --- */
.action-bar .btn-draw{
  background: linear-gradient(180deg, var(--accent), var(--primary-700));
  border:1px solid var(--accent-2); color:#fff;
}
.action-bar .btn-resign{
  background: linear-gradient(180deg, #b91c1c, #7f1d1d);
  border:1px solid #7f1d1d; color:#fff;
}
/* ===================== AJUSTES SOLICITADOS 04/10 ===================== */

/* 1️⃣ Botones "Ofrecer Tablas" y "Rendirse" — igual estilo que Salir/Opciones */
#btn_ofrecer_tablas, #btn_rendirse {
  min-height: var(--btn-h);
  padding: 10px 16px;
  font-size: 16px;
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, var(--primary), var(--primary-700));
  border: 1px solid var(--accent);
  color: #fff;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.25);
  cursor: pointer;
  transition: transform .12s ease, filter .12s ease, background .2s ease;
}
#btn_ofrecer_tablas:hover, #btn_rendirse:hover {
  filter: brightness(1.06);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
}

/* Si "Rendirse" debe tener color peligro coherente con el tema */
#btn_rendirse {
  background: linear-gradient(180deg, #b91c1c, #7f1d1d);
  border: 1px solid #7f1d1d;
}

/* 2️⃣ Ocultar botón de refrescar lista de oponentes */
#btn_refrescar_usuarios,
#btn_refrescar_oponentes,
#btn_refrescar {
  display: none !important;
}

/* 3️⃣ Campo del nick — coherente con los demás controles */
#nicki input[type="text"],
#nicki input[type="text"]:focus,
#nicki input[type="text"]:hover {
  background: rgba(15, 30, 60, 0.85);
  border: 1px solid var(--accent);
  color: #e0e8ff;
  font-size: 16px;
  font-weight: 600;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
}
#nicki input[type="text"]:focus {
  box-shadow: var(--focus-ring);
  border-color: var(--accent-2);
}

/* === PWA / panel de opciones legible en todos los anchos === */
#cfg_panel .cfg-grid,
#cfg_panel .field,
#cfg_panel .opt-card,
#cfg_panel .banner-picker,
#cfg_panel .cfg-color-group,
#cfg_panel .cc-swatch-row{
  background: rgba(14,22,38,.72) !important;
  border: 1px solid rgba(168,198,255,.12);
  border-radius: 12px;
}
#cfg_panel .field,
#cfg_panel .opt-card,
#cfg_panel .banner-picker,
#cfg_panel .cfg-color-group,
#cfg_panel .cc-swatch-row{
  padding: 12px;
  margin-bottom: 10px;
}
#cfg_panel input,
#cfg_panel select,
#cfg_panel textarea,
#cfg_panel .form-control{
  background: rgba(245,248,255,.96) !important;
  color:#0f172a !important;
  border:1px solid rgba(148,163,184,.65) !important;
  box-shadow:none !important;
}
#cfg_panel input::placeholder,
#cfg_panel textarea::placeholder{ color:#475569 !important; }
#cfg_panel .cfg-color-group label,
#cfg_panel .banner-picker label,
#cfg_panel .cc-swatch-row label{
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  padding: 8px 10px;
}
#cfg_panel .cfg-color-group{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}
#cfg_panel .cfg-color-group label{
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:0;
  margin:0 !important;
}
#cfg_panel .foot .btn,
#cfg_panel .foot button{
  min-height: 42px;
}
@media (min-width: 768px){
  #cfg_panel{
    background: linear-gradient(180deg, rgba(15,23,42,0.90), rgba(8,15,30,0.93)) !important;
  }
}
@media (max-width: 768px){
  #cfg_panel,
  .config-dialog{
    left: 16px !important;
    right: 16px !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    border-radius: 16px 16px 12px 12px;
    padding-bottom: max(0px, env(safe-area-inset-bottom));
  }
  #cfg_panel .cfg_body,
  .config-dialog .cfg-form{
    padding: 14px !important;
  }
}
@media (max-width: 430px){
  #cfg_panel .cfg-color-group{
    gap: 6px;
  }
  #cfg_panel .cfg-color-group label{
    padding: 6px 4px;
    font-size: .84rem !important;
  }
}

/* =========================================================
   AJUSTE FINAL · PANEL DE CONFIGURACIÓN MÁS GRANDE Y LEGIBLE
   - evita efecto "empequeñecido"
   - colores más sólidos y coherentes
   - selects visualmente consistentes
   ========================================================= */

:root{
  --cfg-bg-1:#14233f;
  --cfg-bg-2:#0d172b;
  --cfg-head-1:#2f4f87;
  --cfg-head-2:#1b3158;
  --cfg-line:rgba(185, 210, 255, 0.18);
  --cfg-text:#eef4ff;
  --cfg-soft:#c6d8ff;
  --cfg-input-bg:#f4f8ff;
  --cfg-input-text:#162338;
}

/* panel principal: más ancho, más estable y sin sensación de miniatura */
#cfg_panel,
.config-dialog{
  width:min(520px, calc(100vw - 28px)) !important;
  min-width:420px !important;
  max-width:calc(100vw - 28px) !important;
  max-height:min(92vh, 900px) !important;
  background:linear-gradient(180deg, rgba(20,35,63,.985), rgba(13,23,43,.985)) !important;
  color:var(--cfg-text) !important;
  border:1px solid var(--cfg-line) !important;
  border-radius:18px !important;
  box-shadow:0 22px 55px rgba(0,0,0,.52), 0 0 0 1px rgba(255,255,255,.04) inset !important;
  overflow:hidden !important;
  transform:none;
}

/* si el JS lo coloca a la derecha, mantenemos esa UX pero más agradable */
#cfg_panel.open{
  transform:translateX(0) !important;
}

#cfg_panel .cfg_head,
.config-dialog .cfg-header{
  background:linear-gradient(180deg, rgba(47,79,135,.98), rgba(27,49,88,.98)) !important;
  color:#ffffff !important;
  border-bottom:1px solid var(--cfg-line) !important;
  padding:16px 20px !important;
}

#cfg_panel .cfg_head h3,
.config-dialog .cfg-header h3,
#cfg_panel .cfg_head .title{
  display:block !important;
  visibility:visible !important;
  margin:0 !important;
  font-size:1.2rem !important;
  line-height:1.2 !important;
  color:#fff !important;
}

#cfg_panel .cfg_body,
.config-dialog .cfg-form{
  background:linear-gradient(180deg, rgba(18,31,55,.96), rgba(12,22,40,.97)) !important;
  color:var(--cfg-text) !important;
  padding:18px 20px !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
}

#cfg_panel .foot,
.config-dialog .cfg-footer{
  background:linear-gradient(180deg, rgba(24,39,66,.98), rgba(14,24,42,.98)) !important;
  border-top:1px solid var(--cfg-line) !important;
  padding:14px 18px !important;
  display:flex !important;
  gap:10px !important;
  flex-wrap:wrap !important;
  justify-content:flex-end !important;
}

/* filas y bloques internos */
#cfg_panel .row,
#cfg_panel .field,
#cfg_panel .opt-card,
#cfg_panel .banner-picker,
#cfg_panel .cfg-color-group,
#cfg_panel .cc-swatch-row{
  background:rgba(255,255,255,.045) !important;
  border:1px solid rgba(198,216,255,.10) !important;
  border-radius:14px !important;
  padding:12px 14px !important;
  margin-bottom:12px !important;
}

#cfg_panel label,
.config-dialog label,
#cfg_panel .row > label,
#cfg_panel .field > span{
  display:block !important;
  font-size:.98rem !important;
  font-weight:700 !important;
  line-height:1.35 !important;
  margin-bottom:8px !important;
  color:var(--cfg-soft) !important;
}

/* selects e inputs: más grandes y legibles */
#cfg_panel select,
#cfg_panel input,
#cfg_panel textarea,
#cfg_panel .form-control,
.config-dialog select,
.config-dialog input,
.config-dialog textarea{
  width:100% !important;
  min-height:48px !important;
  padding:11px 14px !important;
  font-size:1rem !important;
  font-weight:700 !important;
  line-height:1.25 !important;
  color:var(--cfg-input-text) !important;
  background:var(--cfg-input-bg) !important;
  border:1px solid rgba(112,145,198,.55) !important;
  border-radius:12px !important;
  box-shadow:none !important;
}

#cfg_panel select:focus,
#cfg_panel input:focus,
#cfg_panel textarea:focus,
#cfg_panel .form-control:focus,
.config-dialog select:focus,
.config-dialog input:focus,
.config-dialog textarea:focus{
  outline:none !important;
  border-color:#8ab4ff !important;
  box-shadow:0 0 0 3px rgba(138,180,255,.24) !important;
}

/* el select de tiempo inyectado por JS */
#cfg_time_preset,
#cfg_time,
#cfg_inc,
#cfg_bot_level,
#sel_piezas{
  font-size:1rem !important;
  font-weight:700 !important;
}

/* radios de color */
#cfg_panel .radios{
  display:flex !important;
  gap:10px !important;
  flex-wrap:wrap !important;
}
#cfg_panel .radios label{
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  margin:0 !important;
  padding:10px 12px !important;
  background:rgba(255,255,255,.06) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  border-radius:12px !important;
  color:#f2f6ff !important;
}

/* swatches más proporcionados */
#cfg_panel .swatches{
  display:grid !important;
  grid-template-columns:repeat(5, minmax(0,1fr)) !important;
  gap:10px !important;
}
#cfg_panel .sw{
  height:42px !important;
  border-radius:10px !important;
  border:1px solid rgba(255,255,255,.18) !important;
}

/* botones del footer */
#cfg_panel .foot .btn,
#cfg_panel .foot button,
.config-dialog .cfg-footer .btn,
.config-dialog .cfg-footer button{
  min-height:46px !important;
  padding:11px 16px !important;
  font-size:15px !important;
  font-weight:700 !important;
  border-radius:12px !important;
}

#cfg_save,
#cfg_bot,
#cfg_panel .foot .btn-primary,
#cfg_panel .foot .btn-success{
  background:linear-gradient(180deg, #4c74c4, #2c4e8a) !important;
  border:1px solid #355b9d !important;
  color:#fff !important;
}
#cfg_cancel,
#cfg_panel .foot .btn-default{
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.06)) !important;
  border:1px solid rgba(198,216,255,.20) !important;
  color:#eef4ff !important;
}

/* móvil: ocupar casi todo el ancho sin hacerse diminuto */
@media (max-width: 768px){
  #cfg_panel,
  .config-dialog{
    top:10px !important;
    right:10px !important;
    left:10px !important;
    width:auto !important;
    min-width:0 !important;
    max-width:none !important;
    max-height:calc(100vh - 20px) !important;
    border-radius:16px !important;
  }

  #cfg_panel .cfg_head,
  .config-dialog .cfg-header{
    padding:14px 16px !important;
  }

  #cfg_panel .cfg_body,
  .config-dialog .cfg-form{
    padding:14px 16px !important;
  }

  #cfg_panel .foot,
  .config-dialog .cfg-footer{
    padding:12px 14px calc(12px + env(safe-area-inset-bottom)) 14px !important;
  }

  #cfg_panel .swatches{
    grid-template-columns:repeat(4, minmax(0,1fr)) !important;
  }
}

@media (max-width: 430px){
  #cfg_panel label,
  .config-dialog label{
    font-size:.92rem !important;
  }

  #cfg_panel select,
  #cfg_panel input,
  #cfg_panel textarea,
  #cfg_panel .form-control,
  .config-dialog select,
  .config-dialog input,
  .config-dialog textarea{
    min-height:44px !important;
    font-size:.96rem !important;
  }

  #cfg_panel .swatches{
    grid-template-columns:repeat(3, minmax(0,1fr)) !important;
  }
}

#cfg_panel label {
    color: #f8fbff !important;
    background: transparent !important;
    font-size: 1.15rem !important;
    line-height: 1.45 !important;
    font-weight: 600 !important;
    letter-spacing: 0.01em;
}

#cfg_panel select,
#cfg_panel input,
#cfg_panel textarea,
#cfg_panel .form-control {
    font-size: 1.08rem !important;
    line-height: 1.4 !important;
    min-height: 46px !important;
    padding: 0.7rem 0.9rem !important;
}

#cfg_panel .btn,
#cfg_panel button {
    font-size: 1.05rem !important;
    line-height: 1.25 !important;
    min-height: 46px !important;
    padding: 0.72rem 1rem !important;
}

#cfg_panel option {
    font-size: 1rem;
}

#cfg_panel .row {
    margin-bottom: 14px !important;
}

@media (max-width: 768px) {
    #cfg_panel label {
        font-size: 1.18rem !important;
        line-height: 1.45 !important;
    }

    #cfg_panel select,
    #cfg_panel input,
    #cfg_panel textarea,
    #cfg_panel .form-control,
    #cfg_panel .btn,
    #cfg_panel button {
        font-size: 1.1rem !important;
        min-height: 48px !important;
    }
}

@media (max-width: 480px) {
    #cfg_panel label {
        font-size: 1.2rem !important;
    }

    #cfg_panel select,
    #cfg_panel input,
    #cfg_panel textarea,
    #cfg_panel .form-control,
    #cfg_panel .btn,
    #cfg_panel button {
        font-size: 1.12rem !important;
        min-height: 50px !important;
        padding: 0.78rem 1rem !important;
    }
}

/* ===== ELO visual de alto contraste ===== */
.elo-delta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-left:6px;
  padding:3px 8px;
  border-radius:999px;
  font-weight:800;
  font-size:.84em;
  line-height:1;
  letter-spacing:.01em;
  vertical-align:middle;
}
.elo-delta.pos{
  background:#d1fae5 !important;
  color:#065f46 !important;
  border:1px solid #34d399 !important;
}
.elo-delta.neg{
  background:#fee2e2 !important;
  color:#991b1b !important;
  border:1px solid #f87171 !important;
}
.elo-delta.neu{
  background:#e5e7eb !important;
  color:#374151 !important;
  border:1px solid #cbd5e1 !important;
}
.cc-flag{
  display:inline-block;
  margin-right:6px;
  vertical-align:middle;
  border-radius:2px;
  box-shadow:0 0 0 1px rgba(255,255,255,.12);
}

/* =========================================================
   HOTFIX ROBUSTO FINAL · CONFIG SIEMPRE VISIBLE
   - solo actúa cuando el panel está abierto
   - layout real en 3 filas: cabecera / contenido / footer
   - el footer deja de invadir el área útil
   - compacto en alturas bajas y navegadores con barras visibles
   ========================================================= */

/* Mantener oculto por defecto si el JS lo usa cerrado */
#cfg_panel:not(.open):not(.is-open):not(.in):not([open]){
  display:none;
}

/* Estado abierto: layout estable */
#cfg_panel.open,
#cfg_panel.is-open,
#cfg_panel.in,
#cfg_panel[open],
body.cfg-open #cfg_panel,
.config-dialog[open]{
  display:grid !important;
  grid-template-rows:auto minmax(0,1fr) auto !important;
  align-content:stretch !important;
  overflow:hidden !important;
  max-height:calc(100dvh - 24px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)) !important;
  height:auto !important;
}

/* Safari/iOS y navegadores con barras dinámicas */
@supports (height: 100svh){
  #cfg_panel.open,
  #cfg_panel.is-open,
  #cfg_panel.in,
  #cfg_panel[open],
  body.cfg-open #cfg_panel,
  .config-dialog[open]{
    max-height:calc(100svh - 24px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)) !important;
  }
}

#cfg_panel.open .cfg_head,
#cfg_panel.is-open .cfg_head,
#cfg_panel.in .cfg_head,
#cfg_panel[open] .cfg_head,
body.cfg-open #cfg_panel .cfg_head,
.config-dialog[open] .cfg-header{
  position:relative !important;
  top:auto !important;
  bottom:auto !important;
  flex:0 0 auto !important;
}

#cfg_panel.open .cfg_body,
#cfg_panel.is-open .cfg_body,
#cfg_panel.in .cfg_body,
#cfg_panel[open] .cfg_body,
body.cfg-open #cfg_panel .cfg_body,
.config-dialog[open] .cfg-form{
  min-height:0 !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  overscroll-behavior:contain !important;
  -webkit-overflow-scrolling:touch !important;
  padding-bottom:clamp(24px, 4vh, 40px) !important;
  scroll-padding-bottom:140px !important;
}

#cfg_panel.open .foot,
#cfg_panel.is-open .foot,
#cfg_panel.in .foot,
#cfg_panel[open] .foot,
body.cfg-open #cfg_panel .foot,
.config-dialog[open] .cfg-footer{
  position:relative !important;
  bottom:auto !important;
  top:auto !important;
  flex:0 0 auto !important;
  z-index:1 !important;
  display:flex !important;
  gap:10px !important;
  flex-wrap:wrap !important;
  justify-content:flex-end !important;
}

/* Que los selects nunca queden pegados al footer */
#cfg_panel .row:last-child,
#cfg_panel .field:last-child,
#cfg_panel .opt-card:last-child,
#cfg_panel .banner-picker:last-child,
#cfg_panel .cfg-color-group:last-child,
#cfg_panel .cc-swatch-row:last-child{
  margin-bottom:24px !important;
}

/* Altura útil baja: compactar agresivamente */
@media (max-height: 900px){
  #cfg_panel.open,
  #cfg_panel.is-open,
  #cfg_panel.in,
  #cfg_panel[open],
  body.cfg-open #cfg_panel,
  .config-dialog[open]{
    max-height:calc(100dvh - 12px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)) !important;
  }

  #cfg_panel .cfg_body,
  .config-dialog .cfg-form{
    padding:14px 16px 40px !important;
    scroll-padding-bottom:156px !important;
  }

  #cfg_panel label,
  .config-dialog label{
    font-size:1rem !important;
    line-height:1.3 !important;
    margin-bottom:6px !important;
  }

  #cfg_panel select,
  #cfg_panel input,
  #cfg_panel textarea,
  #cfg_panel .form-control,
  .config-dialog select,
  .config-dialog input,
  .config-dialog textarea{
    min-height:42px !important;
    font-size:.98rem !important;
    padding:.58rem .78rem !important;
  }

  #cfg_panel .row,
  #cfg_panel .field,
  #cfg_panel .opt-card,
  #cfg_panel .banner-picker,
  #cfg_panel .cfg-color-group,
  #cfg_panel .cc-swatch-row{
    padding:10px 12px !important;
    margin-bottom:10px !important;
  }

  #cfg_panel .foot,
  .config-dialog .cfg-footer{
    gap:8px !important;
    padding:10px 12px calc(10px + env(safe-area-inset-bottom, 0px)) !important;
  }

  #cfg_panel .foot .btn,
  #cfg_panel .foot button,
  .config-dialog .cfg-footer .btn,
  .config-dialog .cfg-footer button{
    min-height:40px !important;
    font-size:.94rem !important;
    padding:.58rem .8rem !important;
  }
}

/* Caso crítico: portátiles con escalado alto o barras del navegador grandes */
@media (max-height: 760px){
  #cfg_panel.open,
  #cfg_panel.is-open,
  #cfg_panel.in,
  #cfg_panel[open],
  body.cfg-open #cfg_panel,
  .config-dialog[open]{
    width:min(500px, calc(100vw - 16px)) !important;
    max-height:calc(100dvh - 8px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)) !important;
    border-radius:14px !important;
  }

  #cfg_panel .cfg_head,
  .config-dialog .cfg-header{
    padding:10px 12px !important;
  }

  #cfg_panel .cfg_head h3,
  .config-dialog .cfg-header h3,
  #cfg_panel .cfg_head .title{
    font-size:1rem !important;
  }

  #cfg_panel .cfg_body,
  .config-dialog .cfg-form{
    padding:10px 12px 48px !important;
    scroll-padding-bottom:170px !important;
  }

  #cfg_panel label,
  .config-dialog label{
    font-size:.93rem !important;
    line-height:1.22 !important;
    margin-bottom:5px !important;
  }

  #cfg_panel select,
  #cfg_panel input,
  #cfg_panel textarea,
  #cfg_panel .form-control,
  .config-dialog select,
  .config-dialog input,
  .config-dialog textarea{
    min-height:38px !important;
    font-size:.93rem !important;
    padding:.5rem .7rem !important;
  }

  #cfg_panel .row,
  #cfg_panel .field,
  #cfg_panel .opt-card,
  #cfg_panel .banner-picker,
  #cfg_panel .cfg-color-group,
  #cfg_panel .cc-swatch-row{
    padding:8px 10px !important;
    margin-bottom:8px !important;
    border-radius:12px !important;
  }

  #cfg_panel .foot,
  .config-dialog .cfg-footer{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:6px !important;
    justify-content:stretch !important;
    padding:8px 10px calc(8px + env(safe-area-inset-bottom, 0px)) !important;
  }

  #cfg_panel .foot .btn,
  #cfg_panel .foot button,
  .config-dialog .cfg-footer .btn,
  .config-dialog .cfg-footer button{
    width:100% !important;
    min-height:36px !important;
    font-size:.9rem !important;
    padding:.5rem .7rem !important;
    margin:0 !important;
  }
}

/* En móviles estrechos, dejar aún más colchón para el select del bot */
@media (max-width: 480px){
  #cfg_panel .cfg_body,
  .config-dialog .cfg-form{
    padding-bottom:56px !important;
    scroll-padding-bottom:180px !important;
  }
}

/* ===== FIX FINAL · radios compactos de color/lado en iPhone y móvil ===== */
#cfg_panel input[type="radio"],
.config-dialog input[type="radio"]{
  -webkit-appearance:none !important;
  appearance:none !important;
  width:16px !important;
  min-width:16px !important;
  max-width:16px !important;
  height:16px !important;
  min-height:16px !important;
  max-height:16px !important;
  margin:0 !important;
  padding:0 !important;
  border:2px solid #9fb8ea !important;
  border-radius:50% !important;
  background:#ffffff !important;
  box-shadow:none !important;
  display:inline-block !important;
  vertical-align:middle !important;
  flex:0 0 16px !important;
  transform:none !important;
}

#cfg_panel input[type="radio"]:checked,
.config-dialog input[type="radio"]:checked{
  background:
    radial-gradient(circle at center, #2f4a7d 0 42%, #ffffff 43% 100%) !important;
  border-color:#c7d7f7 !important;
}

#cfg_panel input[type="radio"] + span,
.config-dialog input[type="radio"] + span{
  display:inline-block;
}

#cfg_panel .radios,
#cfg_panel .cfg-side-group,
#cfg_panel .cfg-color-side,
.config-dialog .radios{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:8px !important;
}

#cfg_panel .radios label,
#cfg_panel .cfg-side-group label,
#cfg_panel .cfg-color-side label,
.config-dialog .radios label{
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  min-height:40px !important;
  padding:8px 12px !important;
  margin:0 !important;
  border-radius:12px !important;
  background:rgba(255,255,255,.06) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  width:auto !important;
}

@media (max-width: 480px){
  #cfg_panel input[type="radio"],
  .config-dialog input[type="radio"]{
    width:14px !important;
    min-width:14px !important;
    max-width:14px !important;
    height:14px !important;
    min-height:14px !important;
    max-height:14px !important;
    flex:0 0 14px !important;
  }

  #cfg_panel .radios label,
  #cfg_panel .cfg-side-group label,
  #cfg_panel .cfg-color-side label,
  .config-dialog .radios label{
    min-height:36px !important;
    padding:7px 10px !important;
    font-size:.92rem !important;
  }
}
