/**
 * Lenguaje visual inspirado en Template/css/skin.css (site-btn, form-group, acentos).
 * Pensado para modo oscuro: no importa skin.css completo (evita conflictos y fuentes rotas).
 */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap");

:root {
  /* Template skin.css — referencia */
  --st-blue-deep: #0f2e5f;
  --st-blue-mid: #2e5299;
  --st-blue-enquiry: #0f235f;
  --st-orange: #f09708;
  --st-coral: #f9703e;
  --st-accent-red: #f04405;
  --st-yellow-soft: #ffda48;

  --st-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --st-shadow-btn: 0 4px 14px rgba(15, 46, 95, 0.35);
  --st-shadow-btn-hover: 0 8px 24px rgba(15, 46, 95, 0.45);
  --st-focus-ring: 0 0 0 3px rgba(240, 151, 8, 0.22);
}

/* Tipografía alineada al template (Inter) sin romper variables existentes del host */
body {
  font-family: "Inter", var(--font-body, system-ui, sans-serif);
}

h1, h2, h3, h4, h5, h6,
.panel h2,
.panel h3,
.chooser-title h2 {
  font-family: "Inter", var(--font-title, system-ui, sans-serif);
}

/* Acento tipo .section-heading span del template */
.panel h2 {
  color: var(--st-yellow-soft);
  text-shadow: 0 0 24px rgba(255, 218, 72, 0.12);
}

/* Paneles: borde sutil + brillo superior (sin mover layout) */
.panel {
  position: relative;
  border-radius: 12px;
  border-color: rgba(46, 82, 153, 0.35) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.04) inset,
    0 8px 32px rgba(0, 0, 0, 0.28);
  transition: border-color 0.25s var(--st-ease), box-shadow 0.25s var(--st-ease);
}

.panel::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 3px;
  border-radius: 12px 12px 0 0;
  background: linear-gradient(90deg, var(--st-coral), var(--st-orange), var(--st-blue-mid));
  opacity: 0.85;
  pointer-events: none;
}

.panel:hover {
  border-color: rgba(249, 112, 62, 0.35) !important;
}

/* Botones estilo .site-btn */
button.primary {
  position: relative;
  overflow: hidden;
  font-weight: 600;
  letter-spacing: 0.01em;
  border-radius: 999px !important;
  padding: 0.55rem 1.15rem !important;
  transition:
    transform 0.25s var(--st-ease),
    box-shadow 0.25s var(--st-ease),
    filter 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease !important;
  box-shadow: var(--st-shadow-btn);
}

button.primary:not(.secondary) {
  background: linear-gradient(180deg, #1a3d78 0%, var(--st-blue-deep) 55%, #0a1f42 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(46, 82, 153, 0.55) !important;
}

button.primary:not(.secondary):hover {
  filter: brightness(1.06);
  transform: translateY(-2px);
  box-shadow: var(--st-shadow-btn-hover);
}

button.primary:not(.secondary):active {
  transform: translateY(0);
  box-shadow: var(--st-shadow-btn);
}

/* Secundarios: borde + fondo tenue */
button.primary.secondary {
  background: rgba(15, 46, 95, 0.25) !important;
  color: #e7ecf3 !important;
  border: 1px solid rgba(46, 82, 153, 0.65) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

button.primary.secondary:hover {
  border-color: rgba(249, 112, 62, 0.55) !important;
  background: rgba(249, 112, 62, 0.12) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}

/* CTA éxito (clase .ok en botones) */
button.primary.ok,
button.primary.secondary.ok {
  background: linear-gradient(180deg, #2a5a2e 0%, #1e4622 100%) !important;
  border-color: rgba(63, 185, 80, 0.45) !important;
  color: #fff !important;
}

button.primary.ok:hover,
button.primary.secondary.ok:hover {
  filter: brightness(1.08);
  transform: translateY(-2px);
}

/* Inputs: foco tipo form-group (borde ámbar) */
input[type="text"],
input[type="password"],
input[type="number"],
input[type="email"],
input[type="tel"],
select,
textarea {
  border-radius: 10px !important;
  transition:
    border-color 0.2s var(--st-ease),
    box-shadow 0.2s var(--st-ease),
    background 0.2s ease !important;
}

input[type="text"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
select:focus,
textarea:focus {
  outline: none !important;
  border-color: var(--st-orange) !important;
  box-shadow: var(--st-focus-ring) !important;
}

input[type="file"] {
  padding: 0.4rem 0 !important;
  font-size: 0.85rem !important;
}

/* Barra modo / disclosure */
.mode-bar {
  border-radius: 12px !important;
  border: 1px solid rgba(46, 82, 153, 0.35) !important;
  background: linear-gradient(135deg, rgba(15, 46, 95, 0.35) 0%, rgba(22, 27, 34, 0.9) 100%) !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

details.panel-disclosure {
  border-radius: 10px !important;
  border-color: rgba(46, 82, 153, 0.3) !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

details.panel-disclosure[open] {
  border-color: rgba(240, 151, 8, 0.25) !important;
  box-shadow: 0 0 0 1px rgba(240, 151, 8, 0.08);
}

details.panel-disclosure > summary:hover {
  color: var(--st-coral) !important;
}

/* Tarjetas chooser */
.chooser-card {
  border-radius: 14px !important;
  border: 1px solid rgba(46, 82, 153, 0.4) !important;
  transition:
    transform 0.25s var(--st-ease),
    border-color 0.25s var(--st-ease),
    box-shadow 0.25s var(--st-ease) !important;
}

.chooser-card:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(249, 112, 62, 0.55) !important;
  box-shadow:
    0 12px 40px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(249, 112, 62, 0.15) !important;
}

.chooser-card h3 {
  color: #f0f3f8 !important;
}

/* Salida / badges */
pre.out {
  border-radius: 10px !important;
  border: 1px solid rgba(46, 82, 153, 0.35) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.busy-card {
  border-radius: 14px !important;
  border: 1px solid rgba(46, 82, 153, 0.45) !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.45) !important;
}

.cert-badge-ok {
  background: rgba(63, 185, 80, 0.2) !important;
}

.cert-badge-warn {
  background: rgba(240, 151, 8, 0.18) !important;
  color: var(--st-orange) !important;
}

/* Home: cards */
a.card {
  border-radius: 14px !important;
  border: 1px solid rgba(46, 82, 153, 0.35) !important;
  transition:
    transform 0.25s var(--st-ease),
    border-color 0.25s var(--st-ease),
    box-shadow 0.25s var(--st-ease) !important;
}

a.card:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(249, 112, 62, 0.45) !important;
}

a.card .go {
  color: var(--st-coral) !important;
  font-weight: 700 !important;
}

/* ——— Admin (clases admin-*) ——— */
button.admin-btn-primary {
  border-radius: 999px !important;
  background: linear-gradient(180deg, #1a3d78 0%, var(--st-blue-deep) 55%, #0a1f42 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(46, 82, 153, 0.55) !important;
  box-shadow: var(--st-shadow-btn);
  transition: transform 0.2s var(--st-ease), box-shadow 0.2s var(--st-ease), filter 0.2s ease !important;
}

button.admin-btn-primary:hover {
  filter: brightness(1.08);
  transform: translateY(-2px);
  box-shadow: var(--st-shadow-btn-hover);
}

button.admin-btn-secondary {
  border-radius: 999px !important;
  border-color: rgba(46, 82, 153, 0.55) !important;
  background: rgba(15, 46, 95, 0.2) !important;
  transition: transform 0.2s var(--st-ease), border-color 0.2s ease, background 0.2s ease !important;
}

button.admin-btn-secondary:hover {
  border-color: rgba(249, 112, 62, 0.45) !important;
  background: rgba(249, 112, 62, 0.1) !important;
  transform: translateY(-1px);
}

button.admin-btn-danger {
  border-radius: 999px !important;
  transition: transform 0.2s var(--st-ease), background 0.2s ease !important;
}

button.admin-btn-danger:hover {
  transform: translateY(-1px);
}

input.admin-input,
textarea.admin-input,
select.admin-input {
  border-radius: 10px !important;
  transition: border-color 0.2s var(--st-ease), box-shadow 0.2s var(--st-ease) !important;
}

input.admin-input:focus,
textarea.admin-input:focus,
select.admin-input:focus {
  border-color: var(--st-orange) !important;
  box-shadow: var(--st-focus-ring) !important;
}

nav a {
  transition: background 0.2s var(--st-ease), color 0.2s ease, border-color 0.2s ease !important;
}

nav a:hover {
  border-left-color: rgba(249, 112, 62, 0.5) !important;
}

a.card .num {
  color: var(--st-coral) !important;
}

/* Certificación v1: botones fantasma */
button.btn-ghost {
  border-radius: 999px !important;
  transition:
    transform 0.2s var(--st-ease),
    border-color 0.2s ease,
    background 0.2s ease,
    color 0.2s ease !important;
}

button.btn-ghost:hover:not(:disabled) {
  transform: translateY(-1px);
  border-color: rgba(249, 112, 62, 0.45) !important;
}

button.primary.btn-ghost {
  background: linear-gradient(180deg, #1a3d78 0%, var(--st-blue-deep) 55%, #0a1f42 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(46, 82, 153, 0.55) !important;
  box-shadow: var(--st-shadow-btn);
}

button.primary.btn-ghost:hover:not(:disabled) {
  filter: brightness(1.06);
  transform: translateY(-2px);
  box-shadow: var(--st-shadow-btn-hover);
}
