/* ============================================================
   RecreSport · Crescere — Tema sobre Bootstrap 5.3
   Paleta y tipografías heredadas de www.crescere.es
   ============================================================ */

:root {
  --navy:        #1a2744;
  --navy-light:  #2c4a6e;
  --blue:        #3d7ec2;
  --blue-light:  #4fa8d1;
  --blue-pale:   #e8f4fb;
  --orange:      #e8923a;
  --orange-light:#f5a623;
  --orange-pale: #fff3e6;

  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-body:    'Inter', system-ui, sans-serif;

  /* Overrides de Bootstrap */
  --bs-primary: var(--blue);
  --bs-body-font-family: var(--font-body);
  --bs-body-color: #333b50;
  --bs-border-radius: 0.75rem;
  --bs-border-radius-lg: 1.25rem;
}

body {
  font-family: var(--font-body);
  color: #333b50;
  background: #f8f9fc;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6,
.navbar-brand, .display-1, .display-2, .display-3, .display-4 {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--navy);
}

/* ── Botones de marca ───────────────────────────────────── */
.btn-primary {
  --bs-btn-bg: var(--blue);
  --bs-btn-border-color: var(--blue);
  --bs-btn-hover-bg: var(--navy-light);
  --bs-btn-hover-border-color: var(--navy-light);
  --bs-btn-active-bg: var(--navy);
}
.btn-accent {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--orange);
  --bs-btn-border-color: var(--orange);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--orange-light);
  --bs-btn-hover-border-color: var(--orange-light);
  --bs-btn-active-bg: #d87e28;
  color: #fff;
}
.btn-outline-primary {
  --bs-btn-color: var(--blue);
  --bs-btn-border-color: var(--blue);
  --bs-btn-hover-bg: var(--blue);
  --bs-btn-hover-border-color: var(--blue);
}

.text-navy   { color: var(--navy) !important; }
.text-blue   { color: var(--blue) !important; }
.text-accent { color: var(--orange) !important; }
.bg-navy     { background: var(--navy) !important; }
.bg-blue-pale{ background: var(--blue-pale) !important; }
.bg-accent-pale { background: var(--orange-pale) !important; }
a { color: var(--blue); text-decoration: none; }
a:hover { color: var(--navy-light); }

/* ── Banner prototipo ──────────────────────────────────── */
.proto-banner {
  background: repeating-linear-gradient(45deg, var(--orange-pale), var(--orange-pale) 12px, #ffe9cf 12px, #ffe9cf 24px);
  color: #8a5a16;
  font-size: .8rem;
  font-weight: 600;
  text-align: center;
  padding: .35rem 1rem;
  letter-spacing: .02em;
}

/* ── Navbar pública ────────────────────────────────────── */
.navbar-public {
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--bs-border-color);
}
.navbar-public .nav-link { color: var(--navy); font-weight: 500; }
.navbar-public .nav-link.active,
.navbar-public .nav-link:hover { color: var(--blue); }
.brand-logo { font-family: var(--font-display); font-weight: 700; font-size: 1.35rem; color: var(--navy); }
.brand-logo span { color: var(--orange); }

/* ── Hero ──────────────────────────────────────────────── */
.hero {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 55%, var(--blue) 120%);
  color: #fff;
  border-radius: 0 0 2rem 2rem;
  position: relative;
  overflow: hidden;
}
.hero h1, .hero .h1 { color: #fff; }
.hero .hero-blob {
  position: absolute; border-radius: 50%; filter: blur(60px); opacity: .35;
}
.hero .blob-1 { width: 380px; height: 380px; background: var(--orange); top: -120px; right: -80px; }
.hero .blob-2 { width: 300px; height: 300px; background: var(--blue-light); bottom: -140px; left: -60px; }

/* ── Tarjetas ──────────────────────────────────────────── */
.card {
  border: 1px solid var(--bs-border-color);
  box-shadow: 0 1px 2px rgba(26,39,68,.04);
}
.card-hover { transition: transform .18s ease, box-shadow .18s ease; }
.card-hover:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(26,39,68,.12); }

.offer-icon, .feature-icon {
  width: 52px; height: 52px; border-radius: 14px;
  display: grid; place-items: center; font-size: 1.4rem;
  background: var(--blue-pale); color: var(--blue);
}
.feature-icon.accent { background: var(--orange-pale); color: var(--orange); }

.age-pill {
  display: inline-block; font-size: .72rem; font-weight: 700;
  padding: .15rem .55rem; border-radius: 999px;
  background: var(--orange-pale); color: #b06a18;
}

/* ── Wizard de pasos ───────────────────────────────────── */
.wizard { display: flex; gap: .25rem; flex-wrap: wrap; }
.wizard .step {
  flex: 1 1 0; min-width: 120px; text-align: center; position: relative;
  padding: .5rem; font-size: .8rem; color: var(--gray-500, #6b7489);
}
.wizard .step .dot {
  width: 30px; height: 30px; border-radius: 50%; margin: 0 auto .35rem;
  display: grid; place-items: center; font-weight: 700;
  background: #e2e5ee; color: #6b7489;
}
.wizard .step.active .dot { background: var(--blue); color: #fff; }
.wizard .step.done .dot { background: var(--orange); color: #fff; }
.wizard .step.active, .wizard .step.done { color: var(--navy); font-weight: 600; }

/* ── Métodos de pago ───────────────────────────────────── */
.pay-method {
  border: 2px solid var(--bs-border-color); border-radius: 1rem;
  padding: 1rem 1.25rem; cursor: pointer; transition: .15s;
}
.pay-method:hover { border-color: var(--blue-light); }
.pay-method.selected { border-color: var(--blue); background: var(--blue-pale); }

/* ── Sidebar admin ─────────────────────────────────────── */
.admin-shell { min-height: 100vh; }
.admin-sidebar {
  background: var(--navy); color: #cdd6e6; width: 248px; flex-shrink: 0;
}
.admin-sidebar .brand-logo { color: #fff; }
.admin-sidebar .nav-link {
  color: #aeb9d0; border-radius: .6rem; padding: .55rem .8rem; font-size: .92rem;
  display: flex; align-items: center; gap: .65rem; margin-bottom: .15rem;
}
.admin-sidebar .nav-link:hover { background: rgba(255,255,255,.06); color: #fff; }
.admin-sidebar .nav-link.active { background: var(--blue); color: #fff; }
.admin-sidebar .nav-section {
  font-size: .68rem; text-transform: uppercase; letter-spacing: .08em;
  color: #6b7aa0; margin: 1.1rem .8rem .35rem; font-weight: 700;
}
.admin-main { flex: 1; min-width: 0; background: #f8f9fc; }
.admin-topbar { background: #fff; border-bottom: 1px solid var(--bs-border-color); }

.stat-card .stat-icon {
  width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; font-size: 1.25rem;
}
.stat-value { font-family: var(--font-display); font-weight: 700; font-size: 1.7rem; color: var(--navy); }
.stat-label { color: #6b7489; font-size: .82rem; }

table.table-clean thead th {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .04em;
  color: #6b7489; border-bottom: 2px solid var(--bs-border-color);
}
.table-clean tbody tr { vertical-align: middle; }

/* ── Auth ──────────────────────────────────────────────── */
.auth-wrap {
  min-height: 100vh; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 60%, var(--blue) 130%);
  padding: 2rem 1rem;
}
.auth-card { max-width: 440px; width: 100%; }

/* ── Footer ────────────────────────────────────────────── */
.site-footer { background: var(--navy); color: #aeb9d0; }
.site-footer a { color: #cdd6e6; }
.site-footer a:hover { color: #fff; }

@media (max-width: 991.98px) {
  .admin-sidebar { position: fixed; z-index: 1040; height: 100%; left: -260px; transition: left .2s; }
  .admin-sidebar.open { left: 0; }
}
