/* ================================================================
   TIERRAS DE LEYENDA — Design Tokens
   ================================================================ */
:root {
    --tdl-bg-page:       #3a0000;
    --tdl-bg-dark:       #400000;
    --tdl-bg-mid:        #5a1a1a;
    --tdl-bg-deep:       #280000;

    --tdl-gold:          #F9DD1C;
    --tdl-gold-dim:      #C0A820;
    --tdl-gold-glow:     rgba(249,221,28,0.18);
    --tdl-red-action:    #F90C1C;
    --tdl-cyan:          #3A9DBA;
    --tdl-green-ok:      #4adf6a;

    --tdl-panel-bg:      linear-gradient(160deg, #5a1a1a 0%, #480e0e 100%);
    --tdl-nav-bg:        linear-gradient(180deg, #550808 0%, #3e0000 100%);
    --tdl-action-bg:     linear-gradient(180deg, #4a0505 0%, #320000 100%);
    --tdl-card-border:   rgba(249,221,28,0.25);
    --tdl-card-shadow:   0 2px 8px rgba(0,0,0,0.55), 0 0 0 1px rgba(249,221,28,0.08);
    --tdl-glow-shadow:   0 0 12px rgba(249,221,28,0.12);

    --tdl-font-heading:  'Cinzel', 'Trajan Pro', serif;
    --tdl-font-body:     'Crimson Text', 'Georgia', serif;
    --tdl-font-ui:       'Tahoma', 'Segoe UI', sans-serif;

    --tdl-radius-sm:     4px;
    --tdl-radius-md:     6px;
    --tdl-radius-pill:   20px;
    --tdl-transition:    all 0.18s ease;
}

/* ================================================================
   BASE
   ================================================================ */
body {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    text-align: left;
    font-family: var(--tdl-font-ui);
    background-color: var(--tdl-bg-page);
    background-image:
        radial-gradient(ellipse at 50% 0%, rgba(120,10,10,0.4) 0%, transparent 60%),
        repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,0,0,0.06) 2px, rgba(0,0,0,0.06) 4px);
    background-attachment: fixed;
    margin: 0;
    padding: 0;
    min-height: 100vh;
}

a:link    { text-decoration: none; }
a:visited { text-decoration: none; }
img       { border: 0; }

/* ================================================================
   LAYOUT
   ================================================================ */
#player {
    width: 200px;
    min-width: 200px;
    flex-shrink: 0;
    text-align: right;
    padding-right: 6px;
    border-right: 1px solid rgba(249,221,28,0.08);
}

#central {
    flex: 1;
    min-width: 0;
    max-width: 1024px;
}

#bannersup {
    width: 100%;
    max-width: 1024px;
}

#social {
    width: 140px;
    flex-shrink: 0;
    padding: 4px;
    border-left: 1px solid rgba(249,221,28,0.08);
}

/* ================================================================
   PRIMARY NAVIGATION — menu1
   ================================================================ */
.tdl-nav-primary {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px;
    padding: 4px 2px;
    justify-content: center;
    align-items: center;
    margin-bottom: 4px;
}

.menu1_t {
    display: inline-block;
    flex: 0 0 auto;
    background: var(--tdl-nav-bg);
    font-family: var(--tdl-font-heading);
    font-size: 8pt;
    color: var(--tdl-gold);
    font-weight: 600;
    border: 1px solid rgba(249,221,28,0.22);
    border-bottom: 2px solid rgba(249,221,28,0.35);
    border-radius: var(--tdl-radius-sm) !important;
    box-shadow: var(--tdl-card-shadow);
    padding: 0 !important;
    height: auto !important;
    transition: var(--tdl-transition);
    letter-spacing: 0.03em;
    text-shadow: 0 1px 3px rgba(0,0,0,0.7);
    cursor: pointer;
    white-space: nowrap;
}

div.menu1_t:hover {
    background: linear-gradient(180deg, #7a1010 0%, #560000 100%);
    border-color: rgba(249,221,28,0.55);
    box-shadow: var(--tdl-glow-shadow), 0 2px 10px rgba(0,0,0,0.6);
    transform: translateY(-1px);
}

div.menu1_t:has(a[aria-current="page"]) {
    background: linear-gradient(180deg, #8a2020 0%, #600000 100%);
    border-color: rgba(249,221,28,0.60);
    box-shadow: 0 0 12px rgba(249,221,28,0.15), 0 2px 8px rgba(0,0,0,0.7);
    transform: translateY(-1px);
}

/* Standalone: renders as a small gold button */
a.menu1,
a:link.menu1,
a:visited.menu1 {
    display: inline-block;
    text-decoration: none;
    font-family: var(--tdl-font-heading);
    color: var(--tdl-gold);
    font-size: 8pt;
    font-weight: 600;
    letter-spacing: 0.03em;
    background: var(--tdl-nav-bg);
    border: 1px solid rgba(249,221,28,0.22);
    border-bottom: 2px solid rgba(249,221,28,0.35);
    border-radius: var(--tdl-radius-sm);
    padding: 4px 10px;
    box-shadow: var(--tdl-card-shadow);
    transition: var(--tdl-transition);
    cursor: pointer;
}

a:hover.menu1 {
    text-decoration: none;
    color: #fff;
    background: linear-gradient(180deg, #7a1010 0%, #560000 100%);
    border-color: rgba(249,221,28,0.55);
    box-shadow: var(--tdl-glow-shadow), 0 2px 10px rgba(0,0,0,0.6);
    transform: translateY(-1px);
    text-shadow: 0 0 8px var(--tdl-gold-glow);
}

a[aria-current="page"].menu1,
a[aria-current="page"]:hover.menu1 {
    color: #ffffff;
    text-shadow: 0 0 12px rgba(249,221,28,0.8), 0 0 4px rgba(249,221,28,0.4);
}

/* Inside .menu1_t wrapper: link fills the full button area */
.menu1_t a.menu1,
.menu1_t a:link.menu1,
.menu1_t a:visited.menu1 {
    display: block;
    background: none;
    border: none;
    border-radius: 0;
    padding: 5px 10px;
    box-shadow: none;
    transform: none;
}
.menu1_t a:hover.menu1 {
    background: none;
    border: none;
    box-shadow: none;
    transform: none;
}

/* legacy .navigation-menu/.menu-item (kept for compatibility) */
.navigation-menu { background-color: var(--tdl-bg-dark); border: 1px solid rgba(249,221,28,0.2); padding: 5px; }
.menu-item { background: var(--tdl-nav-bg); font-family: var(--tdl-font-heading); font-size: 8pt; color: var(--tdl-gold); font-weight: 600; border: 1px solid rgba(249,221,28,0.22); padding: 5px 10px; text-align: center; border-radius: var(--tdl-radius-sm); }
.menu-item a { color: var(--tdl-gold); text-decoration: none; }
.menu-item a:hover { color: #fff; text-decoration: none; }

/* ================================================================
   ACTION BUTTONS — menu2
   ================================================================ */
.tdl-nav-actions {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px;
    padding: 3px 5px;
    justify-content: center;
    align-items: center;
    margin-bottom: 2px;
}

.tdl-nav-actions--zone {
    border-bottom: 1px solid rgba(249,12,28,0.12);
    padding-bottom: 5px;
    margin-bottom: 2px;
}

.tdl-nav-actions--core {
    background: linear-gradient(to bottom, rgba(50,0,0,0.5) 0%, rgba(30,0,0,0.3) 100%);
    border: 1px solid rgba(249,12,28,0.18);
    border-radius: var(--tdl-radius-md);
    padding: 5px 8px;
}

.menu2_t {
    display: inline-block;
    flex: 0 0 auto;
    background: var(--tdl-action-bg);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    color: var(--tdl-red-action);
    font-weight: bold;
    border: 1px solid rgba(249,12,28,0.30);
    border-bottom: 2px solid rgba(249,12,28,0.50);
    border-radius: var(--tdl-radius-pill) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 2px 6px rgba(0,0,0,0.5);
    padding: 0 !important;
    height: auto !important;
    transition: var(--tdl-transition);
    letter-spacing: 0.02em;
    cursor: pointer;
    white-space: nowrap;
}

div.menu2_t:hover {
    background: linear-gradient(180deg, #5e0808 0%, #3a0000 100%);
    border-color: rgba(249,12,28,0.65);
    color: #ff5566;
    box-shadow: 0 0 10px rgba(249,12,28,0.20), 0 2px 8px rgba(0,0,0,0.6);
    transform: translateY(-1px);
}

.tdl-nav-actions .menu2_t { padding: 0 !important; }
.tdl-nav-actions .menu2_t a.menu2,
.tdl-nav-actions .menu2_t a:link.menu2,
.tdl-nav-actions .menu2_t a:visited.menu2 { padding: 5px 14px; }

/* Standalone: renders as a small red pill button */
a.menu2,
a:link.menu2,
a:visited.menu2 {
    display: inline-block;
    text-decoration: none;
    font-family: var(--tdl-font-ui);
    color: var(--tdl-red-action);
    font-size: 9pt;
    font-weight: bold;
    background: var(--tdl-action-bg);
    border: 1px solid rgba(249,12,28,0.30);
    border-bottom: 2px solid rgba(249,12,28,0.50);
    border-radius: var(--tdl-radius-pill);
    padding: 3px 10px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.5);
    transition: var(--tdl-transition);
    cursor: pointer;
}

a:hover.menu2 {
    text-decoration: none;
    color: #ff6070;
    background: linear-gradient(180deg, #5e0808 0%, #3a0000 100%);
    border-color: rgba(249,12,28,0.65);
    box-shadow: 0 0 10px rgba(249,12,28,0.20), 0 2px 8px rgba(0,0,0,0.6);
    transform: translateY(-1px);
    text-shadow: 0 0 6px rgba(249,12,28,0.4);
}

/* Inside .menu2_t wrapper: link fills the full button area */
.menu2_t a.menu2,
.menu2_t a:link.menu2,
.menu2_t a:visited.menu2 {
    display: block;
    background: none;
    border: none;
    border-radius: 0;
    padding: 4px 12px;
    box-shadow: none;
    transform: none;
}
.menu2_t a:hover.menu2 {
    background: none;
    border: none;
    box-shadow: none;
    transform: none;
}

.menu2 {
    font-family: var(--tdl-font-ui);
    color: var(--tdl-red-action);
    font-size: 11pt;
    font-weight: bold;
}

a.menu3 {
    text-decoration: none;
    font-family: var(--tdl-font-ui);
    color: #C0B555;
    font-size: 9pt;
    font-weight: bold;
}

a.desab {
    color: #600000;
    font-size: 1pt;
}

/* ================================================================
   CONTENT PANELS
   ================================================================ */
.menu2_t2 {
    background: var(--tdl-panel-bg);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    color: var(--tdl-gold);
    font-weight: bold;
    border: 1px solid var(--tdl-card-border);
    border-top: 2px solid rgba(249,221,28,0.30);
    border-radius: var(--tdl-radius-sm);
    box-shadow: var(--tdl-card-shadow);
    padding: 4px 6px;
}

.menu2_t2red {
    background: var(--tdl-panel-bg);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    color: #ef4444;
    font-weight: bold;
    border: 1px solid rgba(239,68,68,0.25);
    border-radius: var(--tdl-radius-sm);
}

.menu2_t2green {
    background: var(--tdl-panel-bg);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    color: var(--tdl-green-ok);
    font-weight: bold;
    border: 1px solid rgba(74,223,106,0.25);
    border-radius: var(--tdl-radius-sm);
}

.menu2_t3 {
    background: var(--tdl-panel-bg);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    color: var(--tdl-red-action);
    font-weight: bold;
    border: 1px solid rgba(249,12,28,0.20);
    border-radius: var(--tdl-radius-sm);
}

.menu2_t4 {
    background: var(--tdl-panel-bg);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    color: var(--tdl-cyan);
    font-weight: bold;
    border: 1px solid rgba(58,157,186,0.25);
    border-radius: var(--tdl-radius-sm);
}

/* table-cell compatibility for panels
   !important overrides needed to neutralize the div-oriented rules above */
tr.menu1_t > td, td.menu1_t {
    display: table-cell !important;   /* override display:inline-block from .menu1_t */
    flex: unset !important;
    white-space: normal !important;
    background: var(--tdl-nav-bg);
    color: var(--tdl-gold);
    font-family: var(--tdl-font-heading);
    font-size: 8pt;
    font-weight: 600;
    padding: 5px 10px !important;
    border-bottom: 1px solid rgba(249,221,28,0.20);
    letter-spacing: 0.03em;
    text-shadow: 0 1px 3px rgba(0,0,0,0.7);
    /* neutralize div-only effects */
    border-radius: 0 !important;
    box-shadow: none !important;
    transform: none !important;
    transition: background 0.18s ease !important;
}

tr.menu1_t > td:hover, td.menu1_t:hover {
    background: linear-gradient(180deg, #7a1010 0%, #560000 100%);
    transform: none !important;
}

tr.menu2_t > td, td.menu2_t {
    display: table-cell !important;
    flex: unset !important;
    white-space: normal !important;
    background: var(--tdl-action-bg);
    color: var(--tdl-red-action);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    font-weight: bold;
    padding: 4px 12px !important;
    border-bottom: 1px solid rgba(249,12,28,0.20);
    /* neutralize div-only effects */
    border-radius: 0 !important;
    box-shadow: none !important;
    transform: none !important;
    transition: background 0.18s ease !important;
}

tr.menu2_t > td:hover, td.menu2_t:hover {
    background: linear-gradient(180deg, #5e0808 0%, #3a0000 100%);
    color: #ff5566;
    transform: none !important;
}

tr.menu2_t2 > td, td.menu2_t2 {
    background: var(--tdl-panel-bg);
    color: var(--tdl-gold);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    font-weight: bold;
    padding: 4px 6px;
    border-radius: 0 !important;
    box-shadow: none !important;
}

/* ================================================================
   DATA TABLES
   ================================================================ */
.tabla {
    background-color: rgba(48,5,4,0.85);
    font-family: var(--tdl-font-ui);
    color: var(--tdl-gold);
    font-size: 12pt;
    font-weight: bold;
}

.dtab {
    background-color: rgba(50,0,0,0.6);
    font-family: var(--tdl-font-ui);
    color: #dddddd;
    font-size: 8pt;
    font-weight: bold;
    border: 1px solid rgba(255,255,255,0.04);
    border-radius: var(--tdl-radius-sm);
}

.dtab2 {
    background-color: rgba(80,0,0,0.7);
    font-family: var(--tdl-font-ui);
    color: var(--tdl-red-action);
    font-size: 8pt;
    font-weight: bold;
    border: 1px solid rgba(249,12,28,0.30);
    border-radius: var(--tdl-radius-sm);
    animation: dtab2-pulse 2.2s ease-in-out infinite;
}

@keyframes dtab2-pulse {
    0%, 100% { box-shadow: 0 0 4px rgba(249,12,28,0.3); }
    50%       { box-shadow: 0 0 10px rgba(249,12,28,0.6); }
}

.dtab_menu {
    background-color: var(--tdl-bg-dark);
    font-family: var(--tdl-font-heading);
    color: var(--tdl-gold);
    font-size: 12pt;
    font-weight: bold;
    letter-spacing: 0.04em;
}

.fila1 {
    background: rgba(112,32,32,0.55);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    color: var(--tdl-gold);
    font-weight: bold;
    text-align: center;
    border-bottom: 1px solid rgba(249,221,28,0.08);
    transition: background var(--tdl-transition);
}

.fila2 {
    background: rgba(80,0,0,0.25);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    color: var(--tdl-gold);
    font-weight: bold;
    text-align: center;
    border-bottom: 1px solid rgba(249,221,28,0.05);
    transition: background var(--tdl-transition);
}

.fila1:hover, .fila2:hover { background: rgba(140,40,40,0.45); }

/* ================================================================
   TYPOGRAPHY
   ================================================================ */
.perso {
    font-family: var(--tdl-font-heading);
    color: var(--tdl-gold);
    font-size: 12pt;
    font-weight: bold;
    letter-spacing: 0.05em;
    text-shadow: 0 1px 4px rgba(0,0,0,0.8);
}

.perso_peq {
    font-family: var(--tdl-font-heading);
    color: var(--tdl-gold);
    font-size: 10pt;
    font-weight: bold;
    letter-spacing: 0.04em;
}

.cualid {
    font-family: var(--tdl-font-ui);
    color: var(--tdl-gold);
    font-size: 8pt;
    font-weight: bold;
    border-left: 2px solid rgba(249,221,28,0.25);
    padding-left: 4px;
}

.texto {
    font-family: var(--tdl-font-body);
    color: var(--tdl-gold);
    font-size: 11pt;
    font-weight: 600;
    line-height: 1.45;
}

.textor {
    font-family: var(--tdl-font-body);
    color: var(--tdl-red-action);
    font-size: 11pt;
    font-weight: 600;
    line-height: 1.45;
}

.texto_m {
    font-family: var(--tdl-font-heading);
    color: var(--tdl-gold);
    font-size: 12pt;
    font-weight: bold;
    letter-spacing: 0.04em;
}

.texto_g {
    font-family: var(--tdl-font-heading);
    color: var(--tdl-gold);
    font-size: 14pt;
    font-weight: bold;
    letter-spacing: 0.05em;
    text-shadow: 0 1px 6px rgba(0,0,0,0.7);
}

.texto_peq {
    font-family: var(--tdl-font-ui);
    color: var(--tdl-gold);
    font-size: 8pt;
    font-weight: bold;
}

.texto_peq2 {
    font-family: var(--tdl-font-ui);
    color: var(--tdl-gold-dim);
    font-size: 6pt;
    font-weight: bold;
}

/* ================================================================
   FORM ELEMENTS
   ================================================================ */
.tbox, .desple {
    font-size: 12px;
    background-color: var(--tdl-bg-deep);
    color: var(--tdl-gold);
    border: 1px solid rgba(249,221,28,0.35);
    border-radius: var(--tdl-radius-sm);
    padding: 4px 6px;
    font-family: var(--tdl-font-ui);
    transition: border-color var(--tdl-transition), box-shadow var(--tdl-transition);
    outline: none;
}

.tbox:focus, .desple:focus {
    border-color: rgba(249,221,28,0.7);
    box-shadow: 0 0 6px rgba(249,221,28,0.18);
}

input.btn {
    color: var(--tdl-gold);
    background: var(--tdl-nav-bg);
    border: 1px solid rgba(249,221,28,0.35);
    border-radius: var(--tdl-radius-sm);
    font-family: var(--tdl-font-ui);
    font-size: 84%;
    font-weight: bold;
    padding: 5px 12px;
    cursor: pointer;
    transition: var(--tdl-transition);
}

input.btn:hover {
    background: linear-gradient(180deg, #7a1010 0%, #560000 100%);
    border-color: rgba(249,221,28,0.60);
    box-shadow: 0 0 8px rgba(249,221,28,0.12);
}

/* ================================================================
   SEPARATORS
   ================================================================ */
.td_hor_p {
    height: 2px;
    background: linear-gradient(to right, transparent 0%, rgba(249,221,28,0.12) 10%, rgba(249,221,28,0.45) 40%, rgba(249,221,28,0.45) 60%, rgba(249,221,28,0.12) 90%, transparent 100%);
    color: transparent;
    border: none;
    margin: 4px 0;
    font-size: 1px;
}

.td_hor_p2 {
    height: 1px;
    background: linear-gradient(to right, transparent 0%, rgba(249,12,28,0.15) 10%, rgba(249,12,28,0.35) 40%, rgba(249,12,28,0.35) 60%, rgba(249,12,28,0.15) 90%, transparent 100%);
    color: transparent;
    border: none;
    margin: 3px 0;
    font-size: 1px;
}

.td_hor {
    font-size: 3pt;
    color: transparent;
    height: 10px;
}

.td_hor_der {
    font-size: 3pt;
    color: transparent;
    height: 10px;
}

.td_ver {
    width: 11px;
    background: linear-gradient(to bottom, transparent 0%, rgba(249,221,28,0.08) 15%, rgba(249,221,28,0.18) 50%, rgba(249,221,28,0.08) 85%, transparent 100%);
    color: transparent;
}

/* ================================================================
   XP BAR
   ================================================================ */
#CasilleroExp {
    position: relative;
    height: 12px;
    width: 100%;
    max-width: 180px;
    background-color: rgba(30,0,0,0.7);
    border: 1px solid rgba(249,221,28,0.40);
    border-radius: var(--tdl-radius-pill);
    overflow: hidden;
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.5), 0 0 4px rgba(249,221,28,0.08);
}

#PorcentajeExp {
    height: 100%;
    width: 0;
    background: linear-gradient(to right, #b89010 0%, var(--tdl-gold) 60%, #fff8a0 100%);
    background-size: 200% 100%;
    border-radius: var(--tdl-radius-pill);
    transition: width 0.6s ease;
    box-shadow: 0 0 8px rgba(249,221,28,0.5);
    animation: xp-shimmer 2.5s linear infinite;
}

@keyframes xp-shimmer {
    0%   { background-position: 200% center; }
    100% { background-position: -200% center; }
}

/* ================================================================
   UTILITY CLASSES (new — additive)
   ================================================================ */
.tdl-card {
    background: var(--tdl-panel-bg);
    border: 1px solid var(--tdl-card-border);
    border-top: 2px solid rgba(249,221,28,0.35);
    border-radius: var(--tdl-radius-md);
    box-shadow: var(--tdl-card-shadow);
    padding: 8px;
}

/* Equipment card */
.arma-card {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 4px 8px;
}
.arma-card-img {
    width: 80px;
    flex-shrink: 0;
}
.arma-card-img img {
    max-width: 100%;
    height: auto;
}
.arma-card-stats {
    flex: 1;
    min-width: 0;
    text-align: left;
}
.arma-stat-row {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    padding: 1px 0;
}

.tdl-section-head {
    font-family: var(--tdl-font-heading);
    font-size: 8.5pt;
    font-weight: 600;
    color: var(--tdl-gold);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 3px 8px;
    background: linear-gradient(to right, rgba(249,221,28,0.08) 0%, transparent 100%);
    border-left: 3px solid var(--tdl-gold);
    border-bottom: 1px solid rgba(249,221,28,0.15);
    margin-bottom: 4px;
}

.tdl-avatar-frame {
    display: inline-block;
    border: 1px solid rgba(249,221,28,0.25);
    border-radius: var(--tdl-radius-md);
    box-shadow: 0 4px 16px rgba(0,0,0,0.6), 0 0 0 1px rgba(249,221,28,0.10);
    overflow: hidden;
    background: rgba(50,0,0,0.4);
}

/* ================================================================
   LOGIN
   ================================================================ */
.login-container {
    max-width: 400px;
    margin: 20px auto;
    padding: 20px;
    background: var(--tdl-panel-bg);
    border: 2px solid rgba(249,221,28,0.45);
    border-radius: 8px;
    font-family: var(--tdl-font-ui);
    box-shadow: 0 8px 32px rgba(0,0,0,0.6), 0 0 0 1px rgba(249,221,28,0.08);
}

.login-header    { text-align: center; margin-bottom: 20px; }
.login-title     { color: var(--tdl-gold); font-family: var(--tdl-font-heading); font-size: 18pt; font-weight: bold; margin: 0 0 10px 0; letter-spacing: 0.05em; text-shadow: 0 2px 8px rgba(0,0,0,0.8); }
.mundo-link      { color: var(--tdl-gold-dim); font-size: 10pt; }
.login-form      { display: flex; flex-direction: column; }
.form-group      { margin-bottom: 15px; }
.form-label      { display: block; color: var(--tdl-gold); font-size: 9pt; font-weight: bold; margin-bottom: 5px; }

.form-input {
    width: 100%;
    padding: 8px;
    border: 1px solid rgba(249,221,28,0.35);
    background-color: var(--tdl-bg-deep);
    color: var(--tdl-gold);
    font-family: var(--tdl-font-ui);
    font-size: 9pt;
    border-radius: var(--tdl-radius-sm);
    box-sizing: border-box;
    transition: border-color var(--tdl-transition), box-shadow var(--tdl-transition);
    outline: none;
}

.form-input:focus {
    border-color: rgba(249,221,28,0.7);
    box-shadow: 0 0 6px rgba(249,221,28,0.18);
}

.login-message   { background-color: rgba(60,0,0,0.8); color: var(--tdl-red-action); padding: 10px; margin-bottom: 15px; border: 1px solid rgba(249,12,28,0.5); border-radius: var(--tdl-radius-sm); text-align: center; font-weight: bold; }
.form-actions    { text-align: center; margin: 20px 0; }

.login-btn {
    background: var(--tdl-nav-bg);
    color: var(--tdl-gold);
    border: 1px solid rgba(249,221,28,0.40);
    padding: 10px 24px;
    border-radius: var(--tdl-radius-sm);
    cursor: pointer;
    font-family: var(--tdl-font-heading);
    font-size: 10pt;
    font-weight: bold;
    letter-spacing: 0.04em;
    transition: var(--tdl-transition);
}

.login-btn:hover {
    background: linear-gradient(180deg, #7a1010 0%, #560000 100%);
    color: #fff;
    border-color: rgba(249,221,28,0.65);
    box-shadow: 0 0 10px rgba(249,221,28,0.15);
}

.form-links      { margin-top: 10px; }
.terms-link      { color: var(--tdl-gold); text-decoration: none; font-size: 8pt; }
.terms-link:hover { color: #fff; text-decoration: underline; }
.register-link   { text-align: center; margin-top: 15px; }
.register-btn    { color: var(--tdl-gold); text-decoration: none; font-size: 9pt; line-height: 1.4; }
.register-btn:hover { color: #fff; text-decoration: underline; }
.forgot-password { text-align: center; margin: 20px 0; }
.forgot-link     { color: var(--tdl-gold); text-decoration: none; font-size: 9pt; }
.forgot-link:hover { color: #fff; text-decoration: underline; }

.google-login-btn {
    display: inline-flex;
    align-items: center;
    background: #fff;
    color: #444;
    border: 1px solid #ccc;
    border-radius: 3px;
    padding: 5px 12px;
    font-family: Arial, sans-serif;
    font-size: 9pt;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: box-shadow 0.15s;
}
.google-login-btn:hover {
    box-shadow: 0 2px 6px rgba(0,0,0,0.35);
    color: #222;
    text-decoration: none;
}

/* ================================================================
   LOGIN SIDEBAR (columna derecha)
   ================================================================ */
.login-sidebar {
    padding: 6px 4px 4px;
    border: 1px solid rgba(249,221,28,0.20);
    border-radius: var(--tdl-radius-sm);
    background: var(--tdl-panel-bg);
    margin-bottom: 4px;
}

.login-sidebar-msg {
    color: var(--tdl-red-action);
    font-size: 7pt;
    font-family: var(--tdl-font-ui);
    text-align: center;
    margin-bottom: 4px;
    border: 1px solid rgba(249,12,28,0.4);
    border-radius: var(--tdl-radius-sm);
    padding: 3px;
    background: rgba(80,0,0,0.4);
}

.login-sidebar-row {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 4px;
}

.login-sidebar-label {
    font-family: var(--tdl-font-ui);
    font-size: 7pt;
    color: var(--tdl-gold-dim);
    font-weight: bold;
    width: 28px;
    flex-shrink: 0;
    text-align: right;
}

.login-sidebar-input {
    flex: 1;
    min-width: 0;
    width: 100%;
    padding: 3px 4px;
    font-size: 8pt;
    box-sizing: border-box;
}

/* ================================================================
   MISC
   ================================================================ */
.publi {
    border: rgba(0,0,0,0.5) 1px solid;
    margin: 0;
    padding: 0;
    width: 770px;
    height: 150px;
}

.bannerlink { color: var(--tdl-bg-dark); }

/* ================================================================
   RESPONSIVE — Mobile (≤767px)
   ================================================================ */
@media (max-width: 767px) {
    body        { flex-direction: column; align-items: stretch; }
    #player     { display: none; }
    #social     { display: none; }
    #central    { max-width: 100%; }
    .td_ver     { display: none; }
    .publi      { width: 100%; max-width: 100%; height: auto; }
    .sidebar-r  { display: none; }
    img         { max-width: 100%; height: auto; }

    .resp-cols              { grid-template-columns: 1fr !important; }
    .resp-cols .col-left    { min-width: 0 !important; }

    .menu1_t    { padding: 0 !important; font-size: 9pt; }
    .menu1_t a.menu1,
    .menu1_t a:link.menu1,
    .menu1_t a:visited.menu1 { padding: 8px 14px; }
    .menu2_t    { padding: 0 !important; font-size: 9pt; }
    .menu2_t a.menu2,
    .menu2_t a:link.menu2,
    .menu2_t a:visited.menu2 { padding: 8px 16px; }
    a.menu1     { font-size: 9pt; }

    .tdl-nav-primary,
    .tdl-nav-actions { gap: 4px; }

    #CasilleroExp { max-width: 100%; width: 80%; }

    /* Disable hover transforms on touch devices */
    div.menu1_t:hover,
    div.menu2_t:hover { transform: none; }
}
