/* ─── Reset & Base ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --ht-green:   #0d9e6e;
  --ht-dark:    #050810;
  --ht-surface: #0d0d1f;
  --ht-border:  rgba(255,255,255,0.08);
  --text:       #f0f4ff;
  --text-muted: #8892b0;
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
}

body { background: var(--ht-dark); overflow: hidden; }

/* ─── Entry Modal ───────────────────────────────────────────────────────────── */
#entry-modal {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #020510 0%, #050d20 100%);
}

#entry-card {
  background: var(--ht-surface);
  border: 1px solid var(--ht-border);
  border-radius: 16px;
  padding: 40px;
  width: min(480px, 94vw);
  box-shadow: 0 32px 80px rgba(0,0,0,0.6);
}

.ht-logo { color: var(--ht-green); font-weight: 700; font-size: 14px; letter-spacing: 1px; margin-bottom: 12px; }

#entry-card h2 { color: var(--text); font-size: 26px; line-height: 1.3; margin-bottom: 8px; }
#entry-card h2 span { color: var(--ht-green); }
#entry-card > p { color: var(--text-muted); font-size: 14px; line-height: 1.6; margin-bottom: 24px; }

.entry-form-group { margin-bottom: 16px; }
.entry-form-group label { display: block; color: var(--text-muted); font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 6px; }
.entry-input {
  width: 100%; padding: 12px 14px;
  background: rgba(255,255,255,0.05); border: 1px solid var(--ht-border);
  border-radius: 8px; color: var(--text); font-size: 15px; outline: none;
  transition: border-color .2s;
}
.entry-input:focus { border-color: var(--ht-green); }
.entry-input::placeholder { color: var(--text-muted); }

/* Entry modal tab switcher */
.entry-tabs {
  display: flex; gap: 4px; margin-bottom: 20px;
  background: rgba(255,255,255,.04); border-radius: 8px; padding: 4px;
}
.entry-tab {
  flex: 1; padding: 8px 12px; border: none; border-radius: 6px; cursor: pointer;
  background: transparent; color: var(--text-muted); font-size: 13px; font-weight: 500;
  transition: background .15s, color .15s;
}
.entry-tab.active { background: var(--ht-green); color: #fff; }
.entry-tab-panel { display: none; }
.entry-tab-panel.active { display: block; }

#btn-entrar-guest, #btn-entrar-login {
  width: 100%; padding: 14px;
  background: var(--ht-green); border: none; border-radius: 8px;
  color: #fff; font-size: 15px; font-weight: 600; cursor: pointer;
  transition: opacity .2s; margin-top: 8px;
}
#btn-entrar-guest:hover, #btn-entrar-login:hover { opacity: .88; }
#btn-entrar-login:disabled { opacity: .55; cursor: default; }

.entry-stats {
  display: flex; gap: 24px; justify-content: center;
  margin-top: 28px; padding-top: 24px;
  border-top: 1px solid var(--ht-border);
}
.entry-stat { text-align: center; }
.entry-stat span { display: block; color: var(--ht-green); font-size: 22px; font-weight: 700; }
.entry-stat p { color: var(--text-muted); font-size: 12px; margin-top: 2px; }

/* ─── HUD wrapper ───────────────────────────────────────────────────────────── */
#hud { position: fixed; inset: 0; pointer-events: none; z-index: 10; display: none; }
#hud > * { pointer-events: auto; }

/* ─── Top Bar ───────────────────────────────────────────────────────────────── */
#top-bar {
  position: absolute; top: 0; left: 0; right: 0;
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 20px;
  background: linear-gradient(to bottom, rgba(5,8,16,.9), transparent);
}
#top-bar-left { display: flex; align-items: center; gap: 14px; }
.logo-ht { color: var(--ht-green); font-weight: 700; font-size: 13px; letter-spacing: .5px; }
#feria-name { color: var(--text); font-size: 13px; opacity: .7; }
#top-bar-right { display: flex; align-items: center; gap: 12px; }

.live-badge {
  display: flex; align-items: center; gap: 6px;
  background: rgba(220,38,38,.15); border: 1px solid rgba(220,38,38,.3);
  border-radius: 20px; padding: 4px 10px;
  color: #f87171; font-size: 11px; font-weight: 700; letter-spacing: 1px;
}
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: #ef4444; animation: pulse 1.5s infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .4; } }

#user-count { color: var(--text-muted); font-size: 13px; }
#user-count span { color: var(--text); font-weight: 600; }

/* ─── Booth Panel (right) ───────────────────────────────────────────────────── */
#booth-panel {
  position: absolute; top: 60px; right: 20px; bottom: 80px;
  width: 320px; max-height: calc(100vh - 140px); overflow-y: auto;
  background: var(--ht-surface); border: 1px solid var(--ht-border);
  border-radius: 12px; padding: 20px;
  transform: translateX(360px); transition: transform .3s cubic-bezier(.4,0,.2,1);
}
#booth-panel.open { transform: translateX(0); }

#btn-close-booth {
  position: absolute; top: 12px; right: 12px;
  background: rgba(255,255,255,.06); border: none; border-radius: 6px;
  color: var(--text-muted); font-size: 16px; width: 28px; height: 28px; cursor: pointer;
}

#booth-panel-header { display: flex; gap: 14px; align-items: center; margin-bottom: 16px; }
#booth-logo-circle {
  width: 48px; height: 48px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; color: #fff; font-size: 16px; flex-shrink: 0;
}
#booth-company-name { color: var(--text); font-weight: 600; font-size: 16px; }
#booth-company-location { color: var(--text-muted); font-size: 13px; margin-top: 2px; }

#booth-panel-body p { color: var(--text-muted); font-size: 13px; line-height: 1.6; margin-bottom: 14px; }
.booth-stat { color: var(--text); font-size: 13px; font-weight: 600; margin-bottom: 12px; }

/* Booth panel 3-tab nav */
.booth-tabs {
  display: flex; gap: 2px;
  border-bottom: 1px solid var(--ht-border); margin-bottom: 14px;
}
.booth-tab-btn {
  flex: 1; padding: 9px 4px; border: none; background: transparent;
  color: var(--text-muted); font-size: 12px; font-weight: 600; cursor: pointer;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color .15s, border-color .15s;
}
.booth-tab-btn.active { color: var(--ht-green); border-bottom-color: var(--ht-green); }
.booth-tab-content { display: none; }

/* Chat tab content */
#booth-chat-messages {
  height: 180px; overflow-y: auto;
  display: flex; flex-direction: column; gap: 6px;
  padding: 4px 0; margin-bottom: 10px;
}
#booth-chat-input-row {
  display: flex; gap: 6px;
}
#booth-chat-input {
  flex: 1; background: rgba(255,255,255,.05); border: 1px solid var(--ht-border);
  border-radius: 8px; color: var(--text); font-size: 13px; padding: 8px 10px; outline: none;
}
#booth-chat-input::placeholder { color: var(--text-muted); }
#btn-booth-send {
  background: var(--ht-green); border: none; border-radius: 8px;
  color: #fff; font-size: 16px; width: 34px; cursor: pointer; flex-shrink: 0;
}

/* Vacantes tab content */
#booth-cargos { list-style: none; margin-bottom: 12px; max-height: 200px; overflow-y: auto; }
#booth-cargos li {
  padding: 10px 12px; margin-bottom: 6px;
  background: rgba(255,255,255,.04); border-radius: 8px;
  font-size: 13px; color: var(--text);
  display: flex; justify-content: space-between; align-items: center;
}
#booth-cargos li .cargo-salario { color: var(--ht-green); font-size: 12px; }

.booth-btn {
  width: 100%; padding: 11px; border-radius: 8px; border: none;
  font-size: 14px; font-weight: 600; cursor: pointer; margin-bottom: 8px;
  transition: opacity .2s;
}
.booth-btn:hover { opacity: .85; }
.booth-btn-primary   { background: var(--ht-green); color: #fff; }
.booth-btn-secondary { background: rgba(255,255,255,.06); color: var(--text); border: 1px solid var(--ht-border); }
.booth-btn-video     { background: #1a56db; color: #fff; }

/* Calendly embed container */
#calendly-container { min-height: 180px; }

/* ─── Chat (inside booth panel tab) ────────────────────────────────────────── */
#chat-messages {
  height: 200px; overflow-y: auto;
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 10px;
}

.chat-msg { max-width: 85%; }
.chat-msg.own { align-self: flex-end; }
.chat-msg-name { font-size: 11px; color: var(--text-muted); margin-bottom: 3px; }
.chat-msg-bubble {
  padding: 8px 12px; border-radius: 10px; font-size: 13px; line-height: 1.5;
  background: rgba(255,255,255,.06); color: var(--text);
}
.chat-msg.own .chat-msg-bubble { background: var(--ht-green); color: #fff; }

#chat-input-row {
  display: flex; gap: 8px;
  border-top: 1px solid var(--ht-border); padding-top: 10px;
}
#chat-input {
  flex: 1; background: rgba(255,255,255,.05); border: 1px solid var(--ht-border);
  border-radius: 8px; color: var(--text); font-size: 13px; padding: 8px 10px; outline: none;
}
#chat-input::placeholder { color: var(--text-muted); }
#btn-send {
  background: var(--ht-green); border: none; border-radius: 8px;
  color: #fff; font-size: 16px; width: 34px; cursor: pointer;
}

/* ─── Minimap ───────────────────────────────────────────────────────────────── */
#minimap {
  position: absolute; bottom: 20px; left: 20px;
  width: 120px; height: 120px; border-radius: 8px;
  background: rgba(13,13,31,.85); border: 1px solid var(--ht-border);
  overflow: hidden;
}
#minimap-title {
  position: absolute; top: 6px; left: 8px;
  font-size: 9px; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted);
}
#minimap-player {
  position: absolute; width: 8px; height: 8px; border-radius: 50%;
  background: var(--ht-green); transform: translate(-50%, -50%);
  box-shadow: 0 0 6px var(--ht-green);
}
.minimap-booth {
  position: absolute; width: 6px; height: 6px; border-radius: 1px;
  transform: translate(-50%, -50%);
}

/* ─── Controls hint ─────────────────────────────────────────────────────────── */
#controls-hint {
  position: absolute; bottom: 20px; right: 20px;
  display: flex; gap: 12px; align-items: center;
  background: rgba(13,13,31,.7); border: 1px solid var(--ht-border);
  border-radius: 8px; padding: 8px 14px;
  font-size: 12px; color: var(--text-muted);
  pointer-events: none;
}
kbd {
  background: rgba(255,255,255,.1); border: 1px solid var(--ht-border);
  border-radius: 4px; padding: 1px 5px; font-family: inherit;
  font-size: 11px; color: var(--text);
}

/* ─── Notification ──────────────────────────────────────────────────────────── */
#notification {
  position: absolute; top: 60px; left: 50%; transform: translateX(-50%);
  background: var(--ht-surface); border: 1px solid var(--ht-green);
  border-radius: 8px; padding: 10px 20px;
  color: var(--text); font-size: 14px;
  opacity: 0; transition: opacity .3s; pointer-events: none;
  white-space: nowrap; max-width: 90vw;
}
#notification.show { opacity: 1; }

/* ─── Vacantes Modal ────────────────────────────────────────────────────────── */
#vacantes-modal {
  position: fixed; inset: 0; z-index: 100;
  display: none; align-items: center; justify-content: center;
  background: rgba(0,0,0,.7);
}
#vacantes-modal.open { display: flex; }

#vacantes-card {
  background: var(--ht-surface); border: 1px solid var(--ht-border);
  border-radius: 16px; padding: 28px; width: min(540px, 94vw);
  max-height: 80vh; overflow-y: auto; position: relative;
}
#btn-close-vacantes {
  position: absolute; top: 16px; right: 16px;
  background: rgba(255,255,255,.06); border: none; border-radius: 6px;
  color: var(--text-muted); font-size: 18px; width: 30px; height: 30px; cursor: pointer;
}
#vacantes-title { color: var(--text); font-size: 20px; font-weight: 700; margin-bottom: 4px; }
#vacantes-company-sub { color: var(--text-muted); font-size: 14px; margin-bottom: 20px; }

.vacante-card {
  padding: 16px; margin-bottom: 10px;
  background: rgba(255,255,255,.04); border: 1px solid var(--ht-border);
  border-radius: 10px;
}
.vacante-card h4 { color: var(--text); font-size: 15px; font-weight: 600; }
.vacante-card p { color: var(--text-muted); font-size: 13px; margin-top: 4px; }
.vacante-card .v-salario { color: var(--ht-green); font-weight: 600; margin-top: 8px; display: block; }
.btn-postular {
  margin-top: 10px; padding: 8px 16px;
  background: var(--ht-green); color: #fff; border: none; border-radius: 6px;
  font-size: 13px; font-weight: 600; cursor: pointer;
}
.btn-postular:disabled { background: #3d3d5c; color: var(--text-muted); cursor: default; }

/* ─── Video Panel ───────────────────────────────────────────────────────────── */
#video-panel {
  position: absolute; top: 60px; left: 50%; transform: translateX(-50%);
  width: min(640px, 92vw); height: min(480px, 55vh);
  background: #000; border: 1px solid var(--ht-border); border-radius: 12px;
  display: none; overflow: hidden; z-index: 20;
}

/* ─── Touch Joystick ────────────────────────────────────────────────────────── */
#touch-joystick {
  position: absolute; bottom: 90px; left: 50%;
  transform: translateX(-50%);
  width: 100px; height: 100px; border-radius: 50%;
  background: rgba(13,13,31,.6); border: 2px solid rgba(255,255,255,.15);
  display: none; align-items: center; justify-content: center;
  touch-action: none;
}
#joystick-knob {
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--ht-green); opacity: .85;
  pointer-events: none;
}

/* Show joystick on touch devices */
@media (pointer: coarse) {
  #touch-joystick { display: flex; }
  #controls-hint { display: none; }
}

/* ─── Scrollbar ─────────────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 4px; }
