/* ============================================================
   EL CONSULTORIO DE BOBBY — styles.css
   Complementa Bootstrap 5. Tema oscuro con identidad de marca.
   ============================================================ */

/* ----------------------------------------------------------
   TOKENS DE COLOR Y TIPOGRAFÍA
   ---------------------------------------------------------- */
:root {
  --color-bg:         #050505;
  --color-bg-soft:    #101010;
  --color-bg-card:    #161616;
  --color-white:      #F5F5F5;
  --color-muted:      #B8B8B8;
  --color-yellow:     #FFC400;
  --color-yellow-dark:#C99300;
  --color-pink:       #FF1F7A;
  --color-pink-dark:  #B8004B;
  --color-orange:     #FF9B21;
  --color-border:     #2A2A2A;
  --color-danger:     #FF3B3B;
  --color-success:    #38D996;

  --font-display: 'Anton', 'Bebas Neue', Impact, sans-serif;
  --font-body:    'Inter', system-ui, -apple-system, sans-serif;

  --radius-card:   24px;
  --radius-btn:    999px;
  --transition:    .22s ease;
}

/* ----------------------------------------------------------
   BASE
   ---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  background-color: var(--color-bg);
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

::selection {
  background: var(--color-yellow);
  color: #000;
}

a { color: var(--color-yellow); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-yellow-dark); }

img { max-width: 100%; height: auto; }

/* Bootstrap overrides */
.container, .container-fluid { --bs-gutter-x: 1.5rem; }

/* ----------------------------------------------------------
   TIPOGRAFÍA
   ---------------------------------------------------------- */
h1 {
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 7vw, 6.5rem);
  line-height: .92;
  text-transform: uppercase;
  letter-spacing: -.02em;
  color: var(--color-white);
}
h2 {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 3.5rem);
  line-height: 1;
  text-transform: uppercase;
  color: var(--color-white);
}
h3 {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 2.5vw, 2.2rem);
  line-height: 1.05;
  text-transform: uppercase;
  color: var(--color-white);
}
h4 {
  font-family: var(--font-body);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-white);
}

.text-yellow  { color: var(--color-yellow) !important; }
.text-pink    { color: var(--color-pink)   !important; }
.text-orange  { color: var(--color-orange) !important; }
.text-muted   { color: var(--color-muted)  !important; }
.text-success { color: var(--color-success)!important; }

/* ----------------------------------------------------------
   NAVBAR / HEADER
   ---------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(5,5,5,.88);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--color-border);
}

.navbar-brand {
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--color-white) !important;
  letter-spacing: .02em;
  line-height: 1.1;
}
.navbar-brand span { color: var(--color-yellow); }

.navbar-nav .nav-link {
  color: var(--color-muted) !important;
  font-weight: 600;
  font-size: .88rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: .5rem .75rem !important;
  transition: color var(--transition);
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active {
  color: var(--color-yellow) !important;
}

.navbar-toggler {
  border-color: var(--color-border);
  color: var(--color-white);
}
.navbar-toggler-icon {
  filter: invert(1);
}

/* ----------------------------------------------------------
   BOTONES
   ---------------------------------------------------------- */
.btn-bobby-primary {
  background: var(--color-pink);
  color: #fff !important;
  border: none;
  border-radius: var(--radius-btn);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .85rem;
  padding: .7rem 1.6rem;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.btn-bobby-primary:hover {
  background: var(--color-pink-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(255,31,122,.35);
  color: #fff !important;
}

.btn-bobby-secondary {
  background: var(--color-yellow);
  color: #050505 !important;
  border: none;
  border-radius: var(--radius-btn);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .85rem;
  padding: .7rem 1.6rem;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}
.btn-bobby-secondary:hover {
  background: var(--color-yellow-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(255,196,0,.3);
}

.btn-bobby-ghost {
  background: transparent;
  color: var(--color-white) !important;
  border: 1.5px solid rgba(255,255,255,.25);
  border-radius: var(--radius-btn);
  font-weight: 700;
  font-size: .85rem;
  padding: .7rem 1.6rem;
  transition: border-color var(--transition), color var(--transition);
}
.btn-bobby-ghost:hover {
  border-color: var(--color-yellow);
  color: var(--color-yellow) !important;
}

/* ----------------------------------------------------------
   HERO SECTION
   ---------------------------------------------------------- */
.hero {
  position: relative;
  background: var(--color-bg);
  padding: 80px 0 60px;
  overflow: hidden;
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 70% 40%, rgba(255,196,0,.07) 0%, transparent 60%),
              radial-gradient(ellipse 50% 50% at 20% 80%, rgba(255,31,122,.06) 0%, transparent 55%);
  pointer-events: none;
}

.hero__eyebrow {
  font-family: var(--font-body);
  font-weight: 800;
  font-size: .75rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--color-pink);
  margin-bottom: 1rem;
}

.hero__title span.highlight-yellow { color: var(--color-yellow); }
.hero__title span.highlight-pink   { color: var(--color-pink); }

.hero__subtitle {
  font-size: 1.15rem;
  color: var(--color-muted);
  max-width: 540px;
  margin-bottom: 2rem;
}

.hero__microdisclaimer {
  font-size: .78rem;
  color: rgba(184,184,184,.65);
  margin-top: 1rem;
}

.hero__visual {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.hero__bobby-placeholder {
  width: 100%;
  max-width: 480px;
  aspect-ratio: 4/5;
  background: linear-gradient(160deg, #1a1a1a 0%, #0a0a0a 100%);
  border: 1px solid var(--color-border);
  border-radius: 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  color: var(--color-muted);
  font-size: .85rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.hero__bobby-placeholder::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 34px;
  background: linear-gradient(135deg, rgba(255,196,0,.2), transparent 50%, rgba(255,31,122,.15));
  z-index: -1;
}

.hero__bobby-emoji {
  font-size: 5rem;
  line-height: 1;
}

/* Floating tags around Bobby */
.floating-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: 1.5rem;
}

.floating-tag {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  color: var(--color-muted);
  font-size: .75rem;
  font-weight: 600;
  padding: .35rem .8rem;
  border-radius: 999px;
  transition: border-color var(--transition), color var(--transition);
  cursor: default;
}
.floating-tag:hover {
  border-color: var(--color-yellow);
  color: var(--color-yellow);
}

/* ----------------------------------------------------------
   SECCIONES GENERALES
   ---------------------------------------------------------- */
.section {
  padding: 80px 0;
  position: relative;
}
.section--soft {
  background: var(--color-bg-soft);
}
.section--dark {
  background: var(--color-bg);
}

.section-eyebrow {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--color-pink);
  margin-bottom: .5rem;
  display: block;
}
.section-title {
  margin-bottom: 1rem;
}
.section-title .accent { color: var(--color-yellow); }

/* Separador decorativo */
.section-divider {
  width: 48px;
  height: 4px;
  background: var(--color-pink);
  border-radius: 999px;
  margin-bottom: 2.5rem;
}

/* ----------------------------------------------------------
   CARDS DE ARTÍCULO
   ---------------------------------------------------------- */
.article-card {
  background: linear-gradient(180deg, #181818 0%, #0e0e0e 100%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 24px;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
  text-decoration: none;
  color: inherit;
}
.article-card:hover {
  transform: translateY(-5px);
  border-color: var(--color-pink);
  box-shadow: 0 16px 40px rgba(255,31,122,.15);
  color: inherit;
}

.article-card__cat {
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: .75rem;
}

.article-card__title {
  font-family: var(--font-display);
  font-size: clamp(1rem, 2vw, 1.3rem);
  text-transform: uppercase;
  line-height: 1.1;
  color: var(--color-white);
  margin-bottom: .75rem;
  flex: 1;
}

.article-card__desc {
  font-size: .88rem;
  color: var(--color-muted);
  margin-bottom: 1rem;
  line-height: 1.55;
}

.article-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: 1.25rem;
  align-items: center;
}

.article-card__cta {
  font-size: .8rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--color-pink);
  display: flex;
  align-items: center;
  gap: .4rem;
  margin-top: auto;
  transition: gap var(--transition);
}
.article-card:hover .article-card__cta { gap: .7rem; }

/* ----------------------------------------------------------
   CARDS DE CATEGORÍA
   ---------------------------------------------------------- */
.category-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 28px 24px;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition), border-color var(--transition);
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
}
.category-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--cat-color, var(--color-yellow));
  border-radius: var(--radius-card) var(--radius-card) 0 0;
}
.category-card:hover {
  transform: translateY(-4px);
  border-color: var(--cat-color, var(--color-yellow));
  color: inherit;
}

.category-card__icon {
  font-size: 2rem;
  margin-bottom: 1rem;
  color: var(--cat-color, var(--color-yellow));
}
.category-card__name {
  font-family: var(--font-display);
  font-size: 1.3rem;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: .5rem;
}
.category-card__desc {
  font-size: .85rem;
  color: var(--color-muted);
  line-height: 1.55;
  flex: 1;
}
.category-card__arrow {
  color: var(--cat-color, var(--color-yellow));
  margin-top: 1rem;
  font-size: 1.1rem;
  transition: transform var(--transition);
}
.category-card:hover .category-card__arrow { transform: translateX(5px); }

/* ----------------------------------------------------------
   CARDS DE VIDEO
   ---------------------------------------------------------- */
.video-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform var(--transition), border-color var(--transition);
  text-decoration: none;
  color: inherit;
}
.video-card:hover {
  transform: translateY(-4px);
  border-color: var(--color-orange);
  color: inherit;
}

.video-card__thumb {
  width: 100%;
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, #1a1a1a, #080808);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-orange);
  font-size: 2.5rem;
  position: relative;
  overflow: hidden;
}
.video-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}
.video-card__play {
  position: relative;
  z-index: 1;
  background: rgba(5,5,5,.7);
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  transition: background var(--transition), transform var(--transition);
}
.video-card:hover .video-card__play {
  background: var(--color-orange);
  transform: scale(1.08);
}
.video-card__duration {
  position: absolute;
  bottom: 10px; right: 10px;
  background: rgba(5,5,5,.85);
  font-size: .72rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 4px;
  color: var(--color-white);
}
.video-card__body {
  padding: 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.video-card__cat {
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-orange);
  margin-bottom: .5rem;
}
.video-card__title {
  font-family: var(--font-display);
  font-size: 1.1rem;
  text-transform: uppercase;
  line-height: 1.15;
  color: var(--color-white);
  margin-bottom: .5rem;
  flex: 1;
}
.video-card__desc {
  font-size: .83rem;
  color: var(--color-muted);
  margin-bottom: 1rem;
}

/* ----------------------------------------------------------
   BLOQUE ELEGIR PROBLEMA (Home)
   ---------------------------------------------------------- */
.problema-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1rem;
}
.problema-item {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: 16px;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 600;
  font-size: .92rem;
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), transform var(--transition);
  text-decoration: none;
  color: var(--color-white);
}
.problema-item:hover {
  background: #1e1e1e;
  border-color: var(--color-yellow);
  transform: translateY(-2px);
  color: var(--color-white);
}
.problema-item i {
  font-size: 1.3rem;
  color: var(--color-yellow);
  flex-shrink: 0;
}

/* ----------------------------------------------------------
   VIDEO DESTACADO
   ---------------------------------------------------------- */
.featured-video {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
}
.featured-video__thumb {
  width: 100%;
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, #1c1c1c, #080808);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 4rem;
  color: var(--color-orange);
  position: relative;
}
.featured-video__play-btn {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.featured-video__play-btn span {
  background: var(--color-orange);
  color: #000;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  transition: transform var(--transition), background var(--transition);
}
.featured-video:hover .featured-video__play-btn span {
  transform: scale(1.1);
  background: var(--color-yellow);
}
.featured-video__body { padding: 28px; }
.featured-video__label {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--color-orange);
  margin-bottom: .75rem;
  display: block;
}
.featured-video__title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 3vw, 2rem);
  text-transform: uppercase;
  line-height: 1.05;
  color: var(--color-white);
  margin-bottom: .75rem;
}
.featured-video__desc {
  color: var(--color-muted);
  font-size: .95rem;
  margin-bottom: 1.5rem;
}

/* ----------------------------------------------------------
   NEWSLETTER BLOCK
   ---------------------------------------------------------- */
.newsletter-block {
  background: linear-gradient(135deg, #111 0%, #0a0a0a 100%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 48px 40px;
  position: relative;
  overflow: hidden;
}
.newsletter-block::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 220px; height: 220px;
  background: radial-gradient(circle, rgba(255,196,0,.12) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.newsletter-block__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  text-transform: uppercase;
  line-height: 1.05;
  color: var(--color-white);
  margin-bottom: .75rem;
}
.newsletter-block__title span { color: var(--color-yellow); }
.newsletter-block__desc {
  color: var(--color-muted);
  font-size: .95rem;
  margin-bottom: 1.5rem;
  max-width: 460px;
}
.newsletter-form { display: flex; gap: .75rem; flex-wrap: wrap; }
.newsletter-form input[type="email"] {
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-btn);
  color: var(--color-white);
  padding: .7rem 1.4rem;
  font-size: .9rem;
  flex: 1;
  min-width: 220px;
  transition: border-color var(--transition);
  outline: none;
}
.newsletter-form input[type="email"]:focus {
  border-color: var(--color-yellow);
}
.newsletter-form input[type="email"]::placeholder { color: var(--color-muted); }

/* ----------------------------------------------------------
   FORMULARIOS
   ---------------------------------------------------------- */
.form-control-bobby {
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  color: var(--color-white);
  padding: .75rem 1rem;
  font-size: .92rem;
  width: 100%;
  transition: border-color var(--transition);
  outline: none;
  font-family: var(--font-body);
}
.form-control-bobby:focus {
  border-color: var(--color-yellow);
  background: var(--color-bg-soft);
  color: var(--color-white);
  box-shadow: 0 0 0 3px rgba(255,196,0,.12);
}
.form-control-bobby::placeholder { color: var(--color-muted); }

.form-label-bobby {
  font-size: .83rem;
  font-weight: 700;
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: .4rem;
  display: block;
}

.form-select-bobby {
  background: var(--color-bg-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23B8B8B8' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E") no-repeat right 1rem center;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  color: var(--color-white);
  padding: .75rem 2.5rem .75rem 1rem;
  font-size: .92rem;
  width: 100%;
  appearance: none;
  cursor: pointer;
  transition: border-color var(--transition);
  outline: none;
  font-family: var(--font-body);
}
.form-select-bobby:focus {
  border-color: var(--color-yellow);
  box-shadow: 0 0 0 3px rgba(255,196,0,.12);
}
.form-select-bobby option { background: #1a1a1a; color: var(--color-white); }

.form-check-bobby {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  cursor: pointer;
}
.form-check-bobby input[type="checkbox"] {
  flex-shrink: 0;
  width: 18px; height: 18px;
  border: 1.5px solid var(--color-border);
  border-radius: 4px;
  background: var(--color-bg-soft);
  appearance: none;
  cursor: pointer;
  margin-top: 3px;
  transition: background var(--transition), border-color var(--transition);
}
.form-check-bobby input[type="checkbox"]:checked {
  background: var(--color-yellow);
  border-color: var(--color-yellow);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%23050505' d='M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px;
}
.form-check-bobby span {
  font-size: .88rem;
  color: var(--color-muted);
  line-height: 1.5;
}
.form-check-bobby span a { color: var(--color-yellow); }

.form-group-bobby { margin-bottom: 1.25rem; }
.form-error { color: var(--color-danger); font-size: .8rem; margin-top: .3rem; display: none; }
.form-error.visible { display: block; }

/* Alert de sensibles */
.sensible-warning {
  display: none;
  background: rgba(255,59,59,.08);
  border: 1px solid rgba(255,59,59,.3);
  border-radius: 12px;
  padding: 12px 16px;
  font-size: .83rem;
  color: var(--color-danger);
  margin-top: .5rem;
}
.sensible-warning.visible { display: flex; align-items: center; gap: .5rem; }

/* ----------------------------------------------------------
   BADGES
   ---------------------------------------------------------- */
.badge-nivel, .badge-riesgo {
  display: inline-block;
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 3px 10px;
  border-radius: 999px;
  line-height: 1.6;
}
.badge-nivel-basico     { background: rgba(56,217,150,.12); color: var(--color-success); border: 1px solid rgba(56,217,150,.3); }
.badge-nivel-intermedio { background: rgba(255,155,33,.12); color: var(--color-orange);  border: 1px solid rgba(255,155,33,.3); }
.badge-nivel-ojo        { background: rgba(255,59,59,.12);  color: var(--color-danger);  border: 1px solid rgba(255,59,59,.3); }

.badge-riesgo-bajo  { background: rgba(56,217,150,.1);  color: var(--color-success); border: 1px solid rgba(56,217,150,.25); }
.badge-riesgo-medio { background: rgba(255,155,33,.1);  color: var(--color-orange);  border: 1px solid rgba(255,155,33,.25); }
.badge-riesgo-alto  { background: rgba(255,59,59,.1);   color: var(--color-danger);  border: 1px solid rgba(255,59,59,.25); }

.badge-cat {
  display: inline-block;
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(255,196,0,.1);
  color: var(--color-yellow);
  border: 1px solid rgba(255,196,0,.25);
}

/* ----------------------------------------------------------
   COMPONENTES DE MARCA
   ---------------------------------------------------------- */
.bobby-quote {
  background: var(--color-bg-card);
  border-left: 4px solid var(--color-yellow);
  border-radius: 0 16px 16px 0;
  padding: 20px 24px;
  margin: 2rem 0;
}
.bobby-quote__label {
  display: block;
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--color-yellow);
  margin-bottom: .5rem;
}
.bobby-quote__text {
  font-size: 1.05rem;
  color: var(--color-white);
  font-style: italic;
  margin: 0;
  line-height: 1.6;
}

.ojo-caja {
  background: rgba(255,59,59,.06);
  border: 1px solid rgba(255,59,59,.25);
  border-radius: 16px;
  padding: 18px 22px;
  margin: 1.5rem 0;
}
.ojo-caja__label {
  display: block;
  font-weight: 800;
  color: var(--color-danger);
  font-size: .85rem;
  margin-bottom: .5rem;
}
.ojo-caja p {
  margin: 0;
  color: var(--color-muted);
  font-size: .92rem;
}

.en-corto {
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: 16px;
  padding: 22px 26px;
  margin: 1.5rem 0;
}
.en-corto__label {
  display: block;
  font-family: var(--font-display);
  font-size: 1rem;
  text-transform: uppercase;
  color: var(--color-yellow);
  margin-bottom: .75rem;
}
.en-corto ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.en-corto ul li {
  padding: .3rem 0 .3rem 1.4rem;
  position: relative;
  font-size: .92rem;
  color: var(--color-white);
}
.en-corto ul li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--color-yellow);
  font-weight: 700;
}

.disclaimer-box {
  background: rgba(184,184,184,.05);
  border: 1px solid rgba(184,184,184,.15);
  border-radius: 12px;
  padding: 14px 18px;
  font-size: .8rem;
  color: var(--color-muted);
  margin: 1.5rem 0;
}

.alerta-riesgo {
  background: rgba(255,155,33,.07);
  border: 1px solid rgba(255,155,33,.3);
  border-radius: 14px;
  padding: 16px 20px;
  font-size: .88rem;
  color: var(--color-orange);
  margin: 1.5rem 0;
}

/* Definition box (diccionario) */
.definition-box {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
  transition: border-color var(--transition), transform var(--transition);
  text-decoration: none;
  color: inherit;
  display: block;
}
.definition-box:hover {
  border-color: var(--color-yellow);
  transform: translateY(-3px);
  color: inherit;
}
.definition-box__header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--color-border);
  background: rgba(255,255,255,.02);
}
.definition-box__term {
  font-family: var(--font-display);
  font-size: 1.5rem;
  text-transform: uppercase;
  color: var(--color-yellow);
  margin: 0;
}
.definition-box__body { padding: 20px; }
.definition-box__def {
  font-weight: 600;
  color: var(--color-white);
  margin-bottom: .75rem;
  font-size: .95rem;
}
.definition-box__bobby {
  font-size: .88rem;
  color: var(--color-muted);
  line-height: 1.6;
}

/* ----------------------------------------------------------
   BREADCRUMB
   ---------------------------------------------------------- */
.breadcrumb-bobby {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem;
  font-size: .8rem;
}
.breadcrumb-bobby li { display: flex; align-items: center; gap: .35rem; }
.breadcrumb-bobby li + li::before {
  content: '/';
  color: var(--color-border);
}
.breadcrumb-bobby a { color: var(--color-muted); }
.breadcrumb-bobby a:hover { color: var(--color-yellow); }
.breadcrumb-bobby .active { color: var(--color-muted); }

/* ----------------------------------------------------------
   ARTICLE CONTENT
   ---------------------------------------------------------- */
.article-content {
  max-width: 720px;
}
.article-content h2 {
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  margin: 2.5rem 0 1rem;
}
.article-content h3 { margin: 2rem 0 .75rem; }
.article-content p { margin-bottom: 1.25rem; color: rgba(245,245,245,.88); }
.article-content ul, .article-content ol {
  padding-left: 1.5rem;
  margin-bottom: 1.25rem;
  color: rgba(245,245,245,.85);
}
.article-content li { margin-bottom: .4rem; }
.article-content strong { color: var(--color-white); }

/* ----------------------------------------------------------
   B2B BLOCK
   ---------------------------------------------------------- */
.b2b-block {
  background: linear-gradient(135deg, #0f0f0f 0%, #0a0a0a 100%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 48px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.b2b-block::after {
  content: '';
  position: absolute;
  bottom: -40px; left: -40px;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(255,31,122,.1) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}

/* ----------------------------------------------------------
   FOOTER
   ---------------------------------------------------------- */
.site-footer {
  background: var(--color-bg-soft);
  border-top: 1px solid var(--color-border);
  padding: 64px 0 32px;
}
.footer-brand {
  font-family: var(--font-display);
  font-size: 1.4rem;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: .5rem;
}
.footer-brand span { color: var(--color-yellow); }
.footer-tagline {
  font-size: .85rem;
  color: var(--color-muted);
  margin-bottom: 1.5rem;
}
.footer-heading {
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--color-muted);
  margin-bottom: 1rem;
}
.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-links li { margin-bottom: .5rem; }
.footer-links a {
  color: rgba(245,245,245,.6);
  font-size: .88rem;
  text-decoration: none;
  transition: color var(--transition);
}
.footer-links a:hover { color: var(--color-yellow); }

.footer-social {
  display: flex;
  gap: .75rem;
  margin-top: .5rem;
}
.footer-social a {
  width: 38px; height: 38px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--color-muted);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.footer-social a:hover {
  background: var(--color-yellow);
  color: #000;
  border-color: var(--color-yellow);
}

.footer-disclaimer {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 16px 20px;
  font-size: .78rem;
  color: rgba(184,184,184,.6);
  margin-top: 2.5rem;
  text-align: center;
}
.footer-bottom {
  border-top: 1px solid var(--color-border);
  padding-top: 1.5rem;
  margin-top: 2.5rem;
  font-size: .78rem;
  color: rgba(184,184,184,.4);
}

/* ----------------------------------------------------------
   ALERTS Y MENSAJES
   ---------------------------------------------------------- */
.alert-bobby-success {
  background: rgba(56,217,150,.08);
  border: 1px solid rgba(56,217,150,.3);
  border-radius: 14px;
  padding: 16px 20px;
  color: var(--color-success);
  font-size: .9rem;
  display: flex;
  align-items: flex-start;
  gap: .75rem;
}
.alert-bobby-error {
  background: rgba(255,59,59,.08);
  border: 1px solid rgba(255,59,59,.3);
  border-radius: 14px;
  padding: 16px 20px;
  color: var(--color-danger);
  font-size: .9rem;
  display: flex;
  align-items: flex-start;
  gap: .75rem;
}
.alert-bobby-info {
  background: rgba(255,196,0,.06);
  border: 1px solid rgba(255,196,0,.2);
  border-radius: 14px;
  padding: 16px 20px;
  color: var(--color-yellow);
  font-size: .9rem;
}

/* ----------------------------------------------------------
   FILTER BAR
   ---------------------------------------------------------- */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  padding: 16px 0;
}
.filter-btn {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  color: var(--color-muted);
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: .4rem .9rem;
  border-radius: 999px;
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
  appearance: none;
  outline: none;
  font-family: var(--font-body);
}
.filter-btn:hover,
.filter-btn.active {
  background: var(--color-yellow);
  border-color: var(--color-yellow);
  color: #000;
}

/* Search bar */
.search-bar {
  position: relative;
}
.search-bar input {
  width: 100%;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  color: var(--color-white);
  padding: .75rem 1.25rem .75rem 3rem;
  font-size: .92rem;
  outline: none;
  transition: border-color var(--transition);
  font-family: var(--font-body);
}
.search-bar input:focus { border-color: var(--color-yellow); }
.search-bar input::placeholder { color: var(--color-muted); }
.search-bar__icon {
  position: absolute;
  left: 1.1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-muted);
  font-size: 1rem;
  pointer-events: none;
}

/* ----------------------------------------------------------
   PAGINA 404
   ---------------------------------------------------------- */
.page-404 {
  min-height: 70vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px 20px;
}
.page-404__num {
  font-family: var(--font-display);
  font-size: clamp(6rem, 18vw, 14rem);
  line-height: .85;
  color: transparent;
  -webkit-text-stroke: 3px var(--color-border);
  text-stroke: 3px var(--color-border);
  background: linear-gradient(135deg, var(--color-yellow), var(--color-pink));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 1rem;
}

/* ----------------------------------------------------------
   HERO DE SECCIÓN (internas)
   ---------------------------------------------------------- */
.section-hero {
  background: var(--color-bg-soft);
  border-bottom: 1px solid var(--color-border);
  padding: 60px 0 48px;
}
.section-hero__eyebrow {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--color-pink);
  margin-bottom: .75rem;
  display: block;
}

/* ----------------------------------------------------------
   PÁGINA PARA ENTIDADES
   ---------------------------------------------------------- */
.entidad-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 28px 24px;
  height: 100%;
  transition: border-color var(--transition), transform var(--transition);
}
.entidad-card:hover {
  border-color: var(--color-pink);
  transform: translateY(-4px);
}
.entidad-card__icon {
  font-size: 2.2rem;
  color: var(--color-pink);
  margin-bottom: 1rem;
}
.entidad-card__title {
  font-family: var(--font-display);
  font-size: 1.2rem;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: .5rem;
}
.entidad-card__desc {
  font-size: .88rem;
  color: var(--color-muted);
}

/* ----------------------------------------------------------
   PÁGINA /PREGUNTA-A-BOBBY
   ---------------------------------------------------------- */
.question-form-wrapper {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 40px 36px;
}

/* ----------------------------------------------------------
   MISC UTILITIES
   ---------------------------------------------------------- */
.glow-yellow { box-shadow: 0 0 60px rgba(255,196,0,.2); }
.glow-pink   { box-shadow: 0 0 60px rgba(255,31,122,.18); }

.divider-line {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: 2.5rem 0;
}

.reading-time {
  font-size: .78rem;
  color: var(--color-muted);
  display: flex;
  align-items: center;
  gap: .4rem;
}
.reading-time i { font-size: .85rem; }

/* Sticky CTA mobile */
.sticky-cta-mobile {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  padding: 12px 16px;
  background: rgba(5,5,5,.95);
  border-top: 1px solid var(--color-border);
  z-index: 900;
  gap: .75rem;
}

/* ----------------------------------------------------------
   RESPONSIVE
   ---------------------------------------------------------- */
@media (max-width: 991.98px) {
  .hero { padding: 48px 0 40px; }
  .section { padding: 56px 0; }
  .newsletter-block { padding: 32px 24px; }
  .b2b-block { padding: 36px 24px; }
  .question-form-wrapper { padding: 28px 20px; }
}

@media (max-width: 767.98px) {
  h1 { font-size: clamp(2.2rem, 9vw, 3.5rem); }
  h2 { font-size: clamp(1.5rem, 6vw, 2.2rem); }

  .section { padding: 40px 0; }

  .hero__visual { margin-top: 2rem; }
  .hero__bobby-placeholder { max-width: 100%; aspect-ratio: 3/2; }

  .problema-grid { grid-template-columns: 1fr 1fr; }

  .newsletter-form { flex-direction: column; }
  .newsletter-form input[type="email"] { min-width: 100%; }

  .floating-tags { justify-content: center; }

  .sticky-cta-mobile { display: flex; }

  /* Añadir padding-bottom para que el sticky CTA no tape contenido */
  body { padding-bottom: 72px; }
  .site-footer { padding-bottom: 80px; }
}

@media (max-width: 575.98px) {
  .problema-grid { grid-template-columns: 1fr; }
  .article-card { border-radius: 16px; padding: 18px; }
  .category-card { border-radius: 16px; }
  .footer-social { justify-content: flex-start; }
}

/* Focus visible accesibilidad */
:focus-visible {
  outline: 2px solid var(--color-yellow);
  outline-offset: 3px;
  border-radius: 4px;
}
