/* ============================================
   BRABUS BARBER — CSS principal
   ============================================ */

:root {
  --brabus-bg:      #111111;
  --brabus-bg2:     #1a1a1a;
  --brabus-bg3:     #222222;
  --brabus-neon:    #39FF14;
  --brabus-neon2:   #2DC40A;
  --brabus-white:   #ffffff;
  --brabus-gray:    #888888;
  --brabus-gray2:   #444444;
  --brabus-danger:  #E24B4A;
  --brabus-warning: #EF9F27;
  --brabus-info:    #1B8FD4;
  --brabus-bizum:   #9B35C5;
  --brabus-radius:  10px;
  --brabus-radius-sm: 6px;
}

/* === ADMIN WRAP === */
.brabus-admin-wrap {
  background: var(--brabus-bg);
  color: var(--brabus-white);
  min-height: 100vh;
  padding: 20px;
  font-family: 'Segoe UI', system-ui, sans-serif;
}

.brabus-page-title {
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--brabus-white) !important;
  margin-bottom: 20px !important;
}

/* === MÉTRICAS === */
.brabus-metrics-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 16px;
}
@media (min-width: 600px) {
  .brabus-metrics-grid { grid-template-columns: repeat(4, 1fr); }
}

.brabus-metric {
  background: var(--brabus-bg2);
  border: 1px solid #2a2a2a;
  border-radius: var(--brabus-radius);
  padding: 14px;
}
.brabus-metric-label {
  font-size: 11px;
  color: var(--brabus-gray);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}
.brabus-metric-value {
  font-size: 22px;
  font-weight: 700;
  color: var(--brabus-neon);
  line-height: 1;
}
.brabus-metric-sub {
  font-size: 11px;
  color: var(--brabus-gray2);
  margin-top: 4px;
}

/* === CARDS === */
.brabus-card {
  background: var(--brabus-bg2);
  border: 1px solid #2a2a2a;
  border-radius: var(--brabus-radius);
  padding: 16px;
  margin-bottom: 14px;
}
.brabus-card h3 {
  font-size: 13px;
  color: var(--brabus-gray);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
  font-weight: 600;
}

/* === DESGLOSE === */
.brabus-desglose {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid #2a2a2a;
  font-size: 14px;
}
.brabus-desglose:last-child { border-bottom: none; }
.brabus-ef { color: var(--brabus-neon); font-weight: 700; }
.brabus-bz { color: var(--brabus-bizum); font-weight: 700; }
.brabus-tj { color: var(--brabus-info); font-weight: 700; }

/* === INPUTS === */
.brabus-input,
.brabus-input-full,
.brabus-input-sm {
  background: var(--brabus-bg3);
  border: 1px solid #333;
  border-radius: var(--brabus-radius-sm);
  color: var(--brabus-white);
  padding: 10px 12px;
  font-size: 14px;
  outline: none;
  font-family: inherit;
  transition: border-color 0.2s;
  -webkit-appearance: none;
}
.brabus-input:focus,
.brabus-input-full:focus,
.brabus-input-sm:focus {
  border-color: var(--brabus-neon);
}
.brabus-input-full { width: 100%; }
.brabus-input-sm { padding: 8px 10px; font-size: 13px; }

select.brabus-input,
select.brabus-input-full,
select.brabus-input-sm {
  cursor: pointer;
}
select.brabus-input option,
select.brabus-input-full option,
select.brabus-input-sm option {
  background: var(--brabus-bg2);
}

.brabus-label {
  display: block;
  font-size: 11px;
  color: var(--brabus-gray);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
  margin-bottom: 6px;
}

.brabus-form-group { margin-bottom: 12px; }

/* === BOTONES === */
.brabus-btn {
  display: inline-block;
  background: var(--brabus-bg3);
  color: var(--brabus-gray);
  border: 1px solid #333;
  border-radius: var(--brabus-radius-sm);
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  margin-right: 6px;
  margin-bottom: 6px;
  transition: all 0.2s;
}
.brabus-btn:hover {
  border-color: var(--brabus-neon);
  color: var(--brabus-neon);
  text-decoration: none;
}
.brabus-btn-primary-full {
  width: 100%;
  background: var(--brabus-neon);
  color: #111;
  border: none;
  border-radius: var(--brabus-radius-sm);
  padding: 12px 16px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  display: block;
  text-align: center;
}
.brabus-btn-primary-full:hover { background: var(--brabus-neon2); }
.brabus-btn-cobrar {
  background: var(--brabus-neon);
  color: #111;
  border: none;
  border-radius: 4px;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.brabus-btn-edit {
  background: transparent;
  color: var(--brabus-warning);
  border: 1px solid var(--brabus-warning);
  border-radius: 4px;
  padding: 5px 8px;
  font-size: 11px;
  cursor: pointer;
}
.brabus-btn-danger {
  background: transparent;
  color: var(--brabus-danger);
  border: 1px solid var(--brabus-danger);
  border-radius: 4px;
  padding: 5px 8px;
  font-size: 11px;
  cursor: pointer;
}
.brabus-btn-back {
  background: transparent;
  border: none;
  color: var(--brabus-gray);
  font-size: 13px;
  cursor: pointer;
  padding: 6px 0;
  margin-top: 8px;
}

/* === TABS === */
.brabus-tabs {
  display: flex;
  border-bottom: 1px solid #2a2a2a;
  margin-bottom: 16px;
  overflow-x: auto;
  scrollbar-width: none;
}
.brabus-tabs::-webkit-scrollbar { display: none; }
.brabus-tab {
  flex: 1;
  min-width: 80px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--brabus-gray);
  padding: 10px 8px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  transition: all 0.2s;
}
.brabus-tab.active {
  color: var(--brabus-neon);
  border-bottom-color: var(--brabus-neon);
}
.brabus-tab-content { display: none; }
.brabus-tab-content.active { display: block; }

/* === FILTERS BAR === */
.brabus-filters-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 14px;
  align-items: flex-end;
}

/* === CITAS === */
.brabus-cita-item {
  background: var(--brabus-bg3);
  border-radius: var(--brabus-radius-sm);
  padding: 12px 14px;
  margin-bottom: 8px;
}
.brabus-cita-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 6px;
}
.brabus-cita-cliente {
  font-size: 14px;
  font-weight: 700;
}
.brabus-cita-meta {
  font-size: 12px;
  color: var(--brabus-gray);
  line-height: 1.7;
}
.brabus-cita-actions {
  display: flex;
  gap: 6px;
  margin-top: 10px;
  flex-wrap: wrap;
}

/* === BADGES === */
.brabus-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 10px;
  white-space: nowrap;
}
.brabus-badge-agenda {
  background: #071a2e;
  color: var(--brabus-info);
  border: 1px solid var(--brabus-info);
}
.brabus-badge-done {
  background: #0d2a08;
  color: var(--brabus-neon);
  border: 1px solid var(--brabus-neon);
}
.brabus-badge-cancel {
  background: #2a0808;
  color: var(--brabus-danger);
  border: 1px solid var(--brabus-danger);
}
.brabus-badge-pago {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
}
.badge-ef { background:#0d2a08; color:var(--brabus-neon); border:1px solid #1a4a10; }
.badge-bz { background:#1e0a2e; color:var(--brabus-bizum); border:1px solid #3d1460; }
.badge-tj { background:#071a2e; color:var(--brabus-info); border:1px solid #0e3060; }
.brabus-badge-pago.badge-ef { background:#0d2a08; color:var(--brabus-neon); border:1px solid #1a4a10; }
.brabus-badge-pago.badge-bz { background:#1e0a2e; color:var(--brabus-bizum); border:1px solid #3d1460; }
.brabus-badge-pago.badge-tj { background:#071a2e; color:var(--brabus-info); border:1px solid #0e3060; }

/* === SERVICIOS === */
.brabus-srv-item {
  background: var(--brabus-bg3);
  border-radius: var(--brabus-radius-sm);
  padding: 12px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.brabus-srv-item.inactivo { opacity: 0.4; }

/* === BARBEROS === */
.brabus-barbero-item {
  background: var(--brabus-bg3);
  border-radius: var(--brabus-radius-sm);
  padding: 12px 14px;
  margin-bottom: 8px;
}

/* === PAGO PILLS === */
.brabus-pago-pill {
  background: var(--brabus-bg3);
  border: 1.5px solid #333;
  border-radius: var(--brabus-radius-sm);
  padding: 10px 4px;
  text-align: center;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  color: var(--brabus-gray);
  transition: all 0.2s;
}
.brabus-pago-pill.ap-ef { border-color:var(--brabus-neon); background:#0d2a08; color:var(--brabus-neon); }
.brabus-pago-pill.ap-bz { border-color:var(--brabus-bizum); background:#1e0a2e; color:var(--brabus-bizum); }
.brabus-pago-pill.ap-tj { border-color:var(--brabus-info); background:#071a2e; color:var(--brabus-info); }

/* === EXTRAS PILLS === */
.brabus-extra-pill {
  background: var(--brabus-bg3);
  border: 1px solid #333;
  border-radius: var(--brabus-radius-sm);
  padding: 8px 10px;
  cursor: pointer;
  transition: all 0.2s;
}
.brabus-extra-pill.selected {
  border-color: var(--brabus-neon);
  background: #0d2a08;
}

/* === PERIODO BTNS === */
.brabus-periodo-btn {
  background: var(--brabus-bg3);
  border: 1px solid #333;
  border-radius: 20px;
  padding: 6px 12px;
  font-size: 12px;
  color: var(--brabus-gray);
  cursor: pointer;
  transition: all 0.2s;
}
.brabus-periodo-btn.active {
  border-color: var(--brabus-neon);
  color: var(--brabus-neon);
}

/* === PORTAL CLIENTE (shortcode) === */
.brabus-booking-wrap {
  font-family: 'Segoe UI', system-ui, sans-serif;
  max-width: 680px;
  margin: 0 auto;
  color: #fff;
}
.brabus-step { display: none; }
.brabus-step.active { display: block; }
.brabus-step-title {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 20px;
  color: #fff;
}
.brabus-services-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 16px;
}
@media (min-width: 600px) {
  .brabus-services-grid { grid-template-columns: repeat(3, 1fr); }
}
.brabus-service-card {
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  border-radius: 10px;
  padding: 16px;
  cursor: pointer;
  transition: all 0.2s;
}
.brabus-service-card:hover,
.brabus-service-card.selected {
  border-color: #39FF14;
}
.brabus-service-card.selected { background: #0d2a08; }
.brabus-service-name { font-size: 14px; font-weight: 700; margin-bottom: 4px; }
.brabus-service-duration { font-size: 12px; color: #888; }
.brabus-service-price { font-size: 18px; font-weight: 800; color: #39FF14; margin-top: 8px; }
.brabus-staff-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 16px;
}
.brabus-staff-card {
  background: #1a1a1a;
  border: 1.5px solid #2a2a2a;
  border-radius: 10px;
  padding: 16px 12px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
}
.brabus-staff-card:hover,
.brabus-staff-card.selected {
  border-color: #39FF14;
  background: #0d2a08;
}
.brabus-staff-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #222;
  border: 2px solid #333;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  margin: 0 auto 10px;
}
.brabus-staff-card.selected .brabus-staff-avatar { border-color: #39FF14; }
.brabus-staff-name { font-size: 14px; font-weight: 700; }
.brabus-slots-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 8px;
}
@media (min-width: 480px) {
  .brabus-slots-grid { grid-template-columns: repeat(5, 1fr); }
}
.brabus-slot {
  background: #222;
  border: 1px solid #333;
  border-radius: 6px;
  padding: 10px 4px;
  text-align: center;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  color: #fff;
}
.brabus-slot:hover,
.brabus-slot.selected {
  background: #0d2a08;
  border-color: #39FF14;
  color: #39FF14;
}
.brabus-resumen-box {
  background: #222;
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 16px;
}
.brabus-resumen-row {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  padding: 4px 0;
  color: #888;
}
.brabus-resumen-row span:last-child { color: #fff; }
.brabus-resumen-total {
  display: flex;
  justify-content: space-between;
  font-size: 16px;
  font-weight: 700;
  color: #39FF14;
  padding-top: 8px;
  border-top: 1px solid #333;
  margin-top: 6px;
}
.brabus-btn-primary {
  width: 100%;
  background: #39FF14;
  color: #111;
  border: none;
  border-radius: 6px;
  padding: 14px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  margin-top: 8px;
  display: block;
  text-align: center;
  transition: all 0.2s;
}
.brabus-btn-primary:hover { background: #2DC40A; }
.brabus-btn-primary:disabled { opacity: 0.6; cursor: not-allowed; }
.brabus-confirm-box {
  background: #0d2a08;
  border: 1px solid #39FF14;
  border-radius: 10px;
  padding: 32px 24px;
  text-align: center;
}
.brabus-confirm-icon { font-size: 48px; margin-bottom: 12px; }
.brabus-confirm-title {
  font-size: 22px;
  font-weight: 800;
  color: #39FF14;
  margin-bottom: 12px;
}
.brabus-confirm-text {
  font-size: 14px;
  color: #9FE1CB;
  line-height: 1.8;
}
.brabus-error {
  background: #2a0808;
  border: 1px solid #E24B4A;
  color: #E24B4A;
  border-radius: 6px;
  padding: 10px 14px;
  font-size: 13px;
  margin-top: 10px;
}
