/* Variables y ajustes generales */
:root {
 --app-header-height:96px;
 --app-header-gap-fix: 0px; /* ajuste fino para eliminar el pequeño espacio bajo el header */
 --app-header-bg: #dc3545; /* rojo del header */
 --app-header-title-main: #ffc107; /* amarillo */
 --app-header-title-sub: #ffffff;  /* blanco */
 --content-max-width:1200px; /* ancho base del contenedor */
 --news-offers-card-border: #ffc107;  /* amarillo */
 --news-offers-card-radius: 10px;     /* curvatura sutil */
}

html {
 font-size:14px;
}

@media (min-width:768px) {
 html {
 font-size:16px;
 }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
 box-shadow:0000.1rem white,0000.25rem #258cfb;
}

html {
 position: relative;
 min-height:100%;
}

body {
 margin-bottom:60px;
 padding-top:0; /* changed from 3vh to 0 to remove gap under fixed header */
 margin-top: 0; /* Ajuste: eliminar franja blanca superior sobre el header fijo */
}

@media (max-width:767.98px) {
 body { padding-top:0; }
}

/* Header fixed and content offset */
.app-header {
 position: fixed;
 top:0;
 left:0;
 right:0;
 height: var(--app-header-height);
 background: var(--app-header-bg);
 z-index:1040;
 display: flex;
 align-items: center;
 margin-top: 0; /* Ajuste: eliminar margen superior colapsado */
 border-top: 0; /* Ajuste: quitar borde superior */
}

/* Nuevo bloque de título del header (2 líneas) */
.app-header-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  line-height: 1.1;
}

.app-header-title-main {
  color: var(--app-header-title-main);
  font-weight: 800;
  letter-spacing: 0.5px;
  font-size: clamp(20px, 2.4vw + 8px, 34px);
}

.app-header-title-sub {
  color: var(--app-header-title-sub);
  font-weight: 600;
  font-size: clamp(12px, 0.85vw + 6px, 16px);
  opacity: 0.95;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* Mantener compatibilidad con el comportamiento existente en scroll */
.header-scrolled .app-header-title-main { font-size: clamp(18px, 2.0vw + 6px, 28px); }
.header-scrolled .app-header-title-sub { font-size: clamp(11px, 0.75vw + 6px, 14px); }

/* En móviles, permite que el subtítulo envuelva si es necesario */
@media (max-width: 575.98px) {
  .app-header-title-sub {
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
}

/* Ajuste visual: el título previo (si existiera en otras vistas) ahora debe verse bien sobre fondo rojo */
.page-title {
  color: #fff;
}

.page-title {
 font-size: clamp(18px,2.2vw +6px,26px);
 font-weight:600;
 margin:0;
 line-height:1.1;
 word-wrap: normal;
 overflow-wrap: normal;
 hyphens: none;
 text-align: center;
 padding:8px; /* small padding so text doesn't touch edges */
 white-space: nowrap;        /* keep title in one line */
 overflow: hidden;           /* hide overflow instead of wrapping */
 text-overflow: ellipsis;    /* show ellipsis if it doesn't fit */
 transition: font-size .22s ease, transform .22s ease;
}

/* box that contains the page title. ensures the title stays inside and can shrink on scroll */
.page-title-box {
  width: 60%; /* wider by default so title fits in one line on most screens */
  min-width: 260px; /* require enough space for single-line title */
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden; /* ensure long titles don't overflow container */
  padding-left: 8px;
  padding-right: 8px;
  transition: width .28s ease, transform .28s ease;
}

/* Cuando hay scroll se aplica esta clase al body para reducir el contenedor un20% */
.header-scrolled .page-title-box {
 width:48%; /* reduced but still wide enough */
 transform: scale(.96);
}

/* on scroll: reduce title font size to keep it in one line */
.header-scrolled .page-title {
 font-size: clamp(14px,1.6vw +3px,20px);
}

/* Prevent main carousel from being obscured by fixed header - nudge it down a bit */
.main-carousel {
  position: relative;
  /* make carousel span full browser width */
  width: 100vw;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  max-width: 100%;
  overflow: hidden;
  /* pull carousel up so it uses the space under the fixed header */
  margin-top: calc((var(--app-header-height) + var(--app-header-gap-fix)) * -1); /* align exactly under header */
  /* preserve click/accessible area under header */
  padding-top: calc(var(--app-header-height) + var(--app-header-gap-fix));

  /* height settings: use viewport height so carousel is prominent */
  height: calc(60vh);
  min-height: 320px;
  margin-bottom: 22px;

  /* Ensure the element uses border-box sizing so padding doesn't add to vw width */
  box-sizing: border-box;
  /* remove any unintended left/right padding that could shrink inner width */
  padding-left: 0;
  padding-right: 0;
  /* prevent horizontal gaps caused by scrollbars or parent padding */
  max-width: 100vw;
}

/* ensure carousel inner/items fill the height */
.main-carousel .carousel,
.main-carousel .carousel-inner,
.main-carousel .carousel-item {
  height: 100%;
  width: 100vw; /* force inner elements to span the viewport */
  max-width: 100vw;
  left: 0;
  right: 0;
  margin: 0 auto;
}

/* images should cover the area without distortion */
.main-carousel .carousel-inner img,
.main-carousel .carousel-item img {
  width: 100%;
  min-width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  /* New: ensure image fills the full item height and is aligned to the top so it reaches the bottom border */
  min-height: 100%;
  object-position: center top;
  align-self: stretch;
}

/* Make sure carousel items stretch their children (images) to avoid gaps */
.main-carousel .carousel-item {
  display: flex;
  align-items: stretch;
  justify-content: center;
}

/* slight adjustment for very small screens */
@media (max-width: 767.98px) {
  .main-carousel {
    height: calc(40vh);
    min-height: 200px;
    padding-top: calc(var(--app-header-height) + var(--app-header-gap-fix)); /* keep clickable area under header */
    margin-top: calc((var(--app-header-height) + var(--app-header-gap-fix)) * -1);
  }
}

/* If you prefer the carousel not to go behind the header, add the class `no-bleed-top` to `.main-carousel` in the view
   and the following rule will prevent the negative margin/padding behavior. */
.main-carousel.no-bleed-top {
  margin-top: 0;
  padding-top: 0;
}

/* Ensure header stays above carousel */
.app-header {
  z-index: 1060; /* higher than carousel to keep controls and title accessible */
}

/* separacion del contenido teniendo en cuenta el header */
.content-wrapper {
 padding-top: calc(var(--app-header-height) + var(--app-header-gap-fix)); /* offset exacto al header */
 margin-top: 0; /* evita microespacios por colapso de márgenes */
}

/* FIX: evita el micro-espacio visible justo debajo del header fijo causado por colapso de márgenes
   del primer elemento dentro del contenedor (p.ej. `.main-carousel` o `h*`).
   No altera el diseño; solo fuerza a que el primer hijo no empuje hacia arriba el contenedor. */
.content-wrapper::before {
  content: "";
  display: table;
}

/* Si el primer bloque es el carrusel a pantalla completa, no debe aportar margen superior */
.content-wrapper > .main-carousel:first-child {
  margin-top: calc((var(--app-header-height) + var(--app-header-gap-fix)) * -1);
}

/* Contenedor principal: centrado y responsive */
.content-wrapper .container {
 max-width: var(--content-max-width);
 margin-left: auto;
 margin-right: auto;
 padding-left:24px;
 padding-right:24px;
 width:100%;
}

/* Ajustes para pantallas muy grandes */
@media (min-width:1400px) {
 :root { --content-max-width:1300px; }
}

/* Ajustes para pantallas pequeñas */
@media (max-width:991.98px) {
 .content-wrapper .container { max-width:100%; padding-left:16px; padding-right:16px; }
 .page-title-box { width:100%; min-width:0; }
}

/* Thumbnail styles and animations */
.thumb-indicators {
 padding:6px0;
}
.thumb-btn {
 border: none;
 background: transparent;
 padding:2px;
 display: inline-block;
}
.thumb-img {
 display: block;
 width:100%;
 height: auto;
 border-radius:4px;
 box-shadow:01px2px rgba(0,0,0,0.15);
 transition: transform .18s ease, border .18s ease, box-shadow .18s ease, opacity .18s ease;
 opacity: .95;
}

/* Active border color changed to green and stronger box-shadow + slight scale */
.thumb-btn.active .thumb-img {
 border:3px solid #198754; /* active border color */
 padding:0;
 transform: scale(1.06);
 box-shadow:08px24px rgba(0,0,0,0.28);
 opacity:1;
}

/* Hover/tap feedback */
.thumb-btn:hover .thumb-img,
.thumb-btn:focus .thumb-img {
 transform: scale(1.03);
 box-shadow:06px18px rgba(0,0,0,0.2);
}

/* Small animation when clicking a thumbnail - uses a class toggled via JS for stronger feedback */
.thumb-img.anim-click {
 transition: transform .12s cubic-bezier(.2,.8,.2,1);
 transform: scale(0.98);
}

/* Floating menu styles (inside header) */
.floating-menu {
 z-index:1050;
}

.floating-menu .btn {
 border-radius:6px;
 width:48px;
 height:48px;
 padding:0;
 display: flex;
 align-items: center;
 justify-content: center;
}

/* Botón hamburguesa: rojo/amarillo (mantiene tamaño existente) */
#floatingMenuButton.btn {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: #ffc107 !important;
  box-shadow: 0 0 0 2px #ffc107; /* marco amarillo */
}

#floatingMenuButton.btn:hover,
#floatingMenuButton.btn:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
  box-shadow: 0 0 0 2px #dc3545; /* marco rojo al invertir */
}

/* Evita que el caret azul de bootstrap resalte diferente */
#floatingMenuButton.dropdown-toggle::after {
  border-top-color: currentColor;
}

/* Botones de sesión del header (login/logout): rojo/amarillo */
#headerActionsContainer .btn {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: #ffc107 !important;
  box-shadow: 0 0 0 2px #ffc107; /* marco amarillo */
}

#headerActionsContainer .btn i {
  color: #ffc107 !important;
}

#headerActionsContainer .btn:hover,
#headerActionsContainer .btn:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
  box-shadow: 0 0 0 2px #dc3545; /* marco rojo al invertir */
}

/* Page overlay when menu is open */
.page-overlay {
 position: fixed;
 top:0;
 left:0;
 right:0;
 bottom:0;
 background: rgba(0,0,0,0.35);
 z-index:1030;
}

body.overlay-open {
 overflow: hidden;
}

/* Row cards spacing */
.row-cards {
 align-items: flex-start;
 gap:8px; /* reduce gap to tighten layout */
 max-width: calc(var(--content-max-width) -80px); /* slightly narrower so it visually aligns with main carousel */
 margin-left: auto;
 margin-right: auto;
 justify-content: center; /* center the pair of columns */
}

/* Force the two columns to fixed widths so the right column aligns with the carousel edges */
.row-cards > .col-md-5 {
 flex:00360px;
 max-width:360px;
}
.row-cards > .col-md-6 {
 flex:00640px;
 max-width:640px;
}

/* Reduce top spacing of card-carousels so they sit closer under the main carousel */
.card-carousel {
 margin-top:8px;
}

/* Card carousel layout and sizing */
.card-carousel {
 background: #fff;
 border:1px solid #e6e6e6;
 padding:12px; /* slightly reduced padding to remove unnecessary white space */
 overflow: visible;
}

/* Ensure card content (buttons/links) is above indicators */
.card, .card-carousel .card {
 position: relative;
 z-index:4;
}
.card .btn {
 position: relative;
 z-index:10; /* make sure buttons are above any indicators */
}

/* Place card-carousel indicators below the card so they don't overlap buttons */
.card-carousel {
  padding-bottom: 28px; /* reserve space for indicators below the cards */
}
.card-carousel .carousel-indicators {
  bottom: -12px; /* move indicators below the visible card area */
  z-index:3;     /* ensure indicators sit below actionable buttons */
  pointer-events: auto; /* indicator buttons remain clickable */
}
.card-carousel .carousel-indicators button {
  pointer-events: auto;
  z-index:4;
}

/* Slightly increase card body min-height to avoid buttons being too close to edge */
#newsCarousel .card-body, #offersCarousel .card-body {
    min-height: 140px;
}

/* Specific adjustments for News and Offers card containers to remove extra whitespace */
#newsCarouselCard, #offersCarouselCard {
 padding-top:8px;
 padding-bottom:8px;
}

#newsCarouselCard h4, #offersCarouselCard h4 {
 margin-top:4px;
 margin-bottom:10px;
 font-weight:600;
}

/* Ensure cards inside news/offers fill their column and keep buttons visible without extra space */
#newsCarousel .card, #offersCarousel .card {
 margin-top:6px;
}

#newsCarousel .carousel-item, #offersCarousel .carousel-item {
 display: flex;
 align-items: flex-start; /* align cards to top to avoid vertical centering gaps */
}

/* Make offer cards use same tighter image size as news when images are present */
#offersCarousel .card-img-top {
 height: 150px;
 object-fit: cover;
}

/* Ensure when there are few items, content doesn't leave large empty area */
@media (min-width: 768px) {
    #newsCarousel .carousel-inner, #offersCarousel .carousel-inner {
        min-height: 140px;
    }
}

/* News carousel — moved from Views/Home/Index.cshtml */

/* News carousel sizing and visibility tweaks */
/* Reduce title and description font so button remains visible */
#newsCarousel .card-title {
    font-size: 0.88rem; /* smaller */
    line-height: 1.05;
    margin-bottom: 0.3rem;
}
#newsCarousel .card-text {
    font-size: 0.78rem;
    color: #666;
    margin-bottom: 0.4rem;
}

/* Ensure card body is vertical flex so button stays at bottom */
#newsCarousel .card-body {
    display: flex;
    flex-direction: column;
    padding: 0.75rem;
    min-height: 120px; /* allow space for button */
}

/* Ensure offers cards use the same sizing/layout as news cards */
#offersCarousel .card-title,
#offersCarouselCard .card-title {
    font-size: 0.88rem;
    line-height: 1.05;
    margin-bottom: 0.3rem;
}
#offersCarousel .card-text,
#offersCarouselCard .card-text {
    font-size: 0.78rem;
    color: #666;
    margin-bottom: 0.4rem;
}
#offersCarousel .card-body,
#offersCarouselCard .card-body {
    display: flex;
    flex-direction: column;
    padding: 0.75rem;
    min-height: 120px;
}

/* Image height adjustments (desktop and mobile) */
#newsCarousel .card-img-top {
    height: 150px; /* reduced image height */
    object-fit: cover;
}

@media (max-width: 991px) {
    #newsCarousel .card-img-top { height: 120px; }
    #newsCarousel .card-body { min-height: 110px; }
}
@media (max-width: 575px) {
    #newsCarousel .card-img-top { height: 100px; }
    #newsCarousel .card-body { min-height: 100px; }
}

/* --- OFFERS FOR YOU: match main offers card layout/typography --- */
#offersForYouCarousel .card-title,
#offersForYouCarousel .card-title span,
#offersForYouCarousel .card-title small {
  font-size: 0.88rem;
  line-height: 1.05;
}

#offersForYouCarousel .card-text {
  font-size: 0.78rem;
  color: #666;
  margin-bottom: 0.4rem;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

#offersForYouCarousel .card-body {
  display: flex;
  flex-direction: column;
  padding: 0.75rem;
  min-height: 120px;
}

#offersForYouCarousel .card-body .btn {
  margin-top: auto;
  width: 100%;
}

/* Prevent description from expanding: show max ~3 lines and stop flex-grow */
#newsCarousel .card-text,
#newsCarousel .card-text.flex-grow-1 {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex: 0 1 auto !important;
    margin-bottom: 0.35rem;
}

/* Ensure the button appears near the description (not pushed out) */
#newsCarousel .card-body .btn {
    margin-top: 0.4rem;
}

/* Fix: ensure news carousel shows only the active slide and prevents stacking of slides */
#newsCarousel .carousel-inner {
    overflow: hidden !important;
    position: relative;
}
#newsCarousel .carousel-item {
    display: none !important;
    position: relative;
    width: 100%;
    transition: transform .45s ease-in-out, opacity .3s ease-in-out;
}
#newsCarousel .carousel-item.active {
    display: block !important; /* only active slide visible */
    opacity: 1;
}
#newsCarousel .carousel-item:not(.active) {
    display: none !important;
}
#newsCarousel .carousel-item .col-12 { padding-left: 0.5rem; padding-right: 0.5rem; }
#newsCarousel .carousel-item .card { width: 100%; margin-top: 0; }

/* --- OFFERS: mirror news visibility and slide behavior --- */
#offersCarousel .carousel-inner {
    overflow: hidden !important;
    position: relative;
}
#offersCarousel .carousel-item {
    display: none !important;
    position: relative;
    width: 100%;
    transition: transform .45s ease-in-out, opacity .3s ease-in-out;
}
#offersCarousel .carousel-item.active {
    display: block !important; /* only active slide visible */
    opacity: 1;
}
#offersCarousel .carousel-item:not(.active) {
    display: none !important;
}
#offersCarousel .carousel-item .col-12 { padding-left: 0.5rem; padding-right: 0.5rem; }
#offersCarousel .carousel-item .card { width: 100%; margin-top: 0; }

/* Keep prev/next controls visible but not covering interactive elements for offers (mirror news controls) */
#offersCarousel .carousel-control-prev,
#offersCarousel .carousel-control-next {
    z-index: 50;
    width: 44px;
    height: 44px;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(255,255,255,0.95);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #333;
    box-shadow: 0 2px 6px rgba(0,0,0,0.12);
}
#offersCarousel .carousel-control-prev { left: 6px; }
#offersCarousel .carousel-control-next { right: 6px; }

/* Keep prev/next controls visible for news (mirror offers styles) */
#newsCarousel .carousel-control-prev,
#newsCarousel .carousel-control-next {
    z-index: 50; /* ensure above cards and indicators */
    width: 44px;
    height: 44px;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(255,255,255,0.95);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #333;
    box-shadow: 0 2px 6px rgba(0,0,0,0.12);
}
#newsCarousel .carousel-control-prev { left: 6px; }
#newsCarousel .carousel-control-next { right: 6px; }

/* Ensure controls remain clickable even if parent uses overflow rules */
#newsCarousel { position: relative; }
#newsCarousel .carousel-control-prev, #newsCarousel .carousel-control-next { pointer-events: auto; }

/* Reset: use Bootstrap grid for offers (match news card widths) */
#offersCarousel .carousel-item .row {
    display: block; /* allow Bootstrap .col-* to control layout */
    margin: 0; /* reset any forced negative margins */
    padding: 0; 
}

#offersCarousel .carousel-item .col-12,
#offersCarousel .carousel-item [class*="col-"] {
    float: left; /* follow bootstrap column flow */
    box-sizing: border-box;
    padding-left: 12px; /* match page container spacing */
    padding-right: 12px;
}

#offersCarousel .carousel-item .card {
    width: 100% !important; /* full width of the column like news */
    max-width: none !important;
    box-sizing: border-box;
    margin: 0 0 12px 0;
}

/* keep button at bottom of card body */
#offersCarousel .card-body { display: flex; flex-direction: column; }
#offersCarousel .card-body .btn { margin-top: auto; width: 100%; }

/* Ensure controls for offers remain visible and clickable */
#offersCarousel { position: relative; }
#offersCarousel .carousel-control-prev, #offersCarousel .carousel-control-next { pointer-events: auto; }

/* Responsive: no forced calc widths here, Bootstrap handles columns */
@media (max-width: 991.98px) {
    /* keep column stacking handled by Bootstrap grid */
}

/* --- MAIN CAROUSEL: keep Bootstrap default slide mechanics --- */
#mainCarousel .carousel-inner {
  overflow: hidden;
}

#mainCarousel .carousel-item {
  /* Override previous `.main-carousel .carousel-item { display:flex }` which breaks sliding */
  display: none;
  position: relative;
  float: left;
  width: 100%;
  margin-right: -100%;
  backface-visibility: hidden;
  transition: transform .6s ease-in-out;
}

#mainCarousel .carousel-item.active,
#mainCarousel .carousel-item-next,
#mainCarousel .carousel-item-prev {
  display: block;
}

#mainCarousel .carousel-item-next:not(.carousel-item-start),
#mainCarousel .active.carousel-item-end {
  transform: translateX(100%);
}

#mainCarousel .carousel-item-prev:not(.carousel-item-end),
#mainCarousel .active.carousel-item-start {
  transform: translateX(-100%);
}

/* allow image to fill slide without forcing flex layout */
#mainCarousel .carousel-item > img,
#mainCarousel .carousel-item > a > img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* --- Indicators below cards (News/Offers) ---
   Reserve vertical space at the bottom of each carousel so indicators never overlap cards.
   This does NOT change card content styles; it only adjusts carousel container layout.
*/
#newsCarousel,
#offersCarousel {
  padding-bottom: 34px; /* reserved space for indicators */
}

#newsCarousel .carousel-indicators,
#offersCarousel .carousel-indicators {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 8px; /* place inside the reserved padding area */
  margin: 0;
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  pointer-events: auto;
}

#newsCarousel .carousel-indicators [data-bs-target],
#offersCarousel .carousel-indicators [data-bs-target] {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin: 0;
  opacity: 1;
  background-color: #ffc107; /* amarillo (inactivo) */
}

#newsCarousel .carousel-indicators .active,
#offersCarousel .carousel-indicators .active {
  background-color: #dc3545; /* rojo (activo) */
  opacity: 1;
}

/* Ensure indicators are not clipped by parent containers */
#newsCarouselCard,
#offersCarouselCard {
  overflow: visible;
}

/* --- PERSONALIZED: mismos colores que News/Offers (contenedor) --- */
#newsForYouCol .card-carousel,
#offersForYouCol .card-carousel {
  border: 1px solid var(--news-offers-border) !important;
  background-color: var(--news-offers-bg) !important;
}
 /* --- NEWS/OFFERS: ajustes de color solicitados (sin cambiar estructura/layout) --- */
:root {
  --news-offers-border: #dc3545;       /* rojo */
  --news-offers-bg: #f8d7da;           /* rojo claro (tipo bg-danger-subtle) */
  --news-offers-card-grad-start: #fff3cd; /* amarillo claro */
  --news-offers-card-grad-end: #ffffff;   /* blanco */
  --news-offers-btn-bg: #dc3545;       /* rojo */
  --news-offers-btn-fg: #ffc107;       /* amarillo */
}

/* 1) bordes/márgenes visuales rojos + 2) fondo rojo claro en los contenedores principales */
#newsCarouselCard,
#offersCarouselCard {
  border-color: var(--news-offers-border) !important;
  background-color: var(--news-offers-bg) !important;
}

/* Si el borde real lo aplica `.card-carousel`, asegúralo ahí también */
#newsCarouselCard.card-carousel,
#offersCarouselCard.card-carousel {
  border-color: var(--news-offers-border) !important;
  background-color: var(--news-offers-bg) !important;
}

/* 3) fondo de los cards: degradado diagonal amarillo/blanco */
#newsCarousel .card,
#offersCarousel .card {
  background: linear-gradient(135deg, var(--news-offers-card-grad-start) 0%, var(--news-offers-card-grad-end) 60%) !important;
 	border-color: var(--news-offers-card-border) !important;
  border-width: 2px;
  border-style: solid;
  border-radius: var(--news-offers-card-radius);
  overflow: hidden; /* para que el degradado/imagen respeten bordes redondeados */
}

/* 4) botones: fondo rojo + letra amarilla; hover: fondo amarillo + letra roja */
#newsCarousel .btn,
#offersCarousel .btn {
  background-color: var(--news-offers-btn-bg) !important;
  border-color: var(--news-offers-btn-bg) !important;
  color: var(--news-offers-btn-fg) !important;
}

#newsCarousel .btn:hover,
#offersCarousel .btn:hover,
#newsCarousel .btn:focus,
#offersCarousel .btn:focus {
  background-color: var(--news-offers-btn-fg) !important;
  border-color: var(--news-offers-btn-fg) !important;
  color: var(--news-offers-btn-bg) !important;
}

#newsCarousel .btn:active,
#offersCarousel .btn:active {
  background-color: var(--news-offers-btn-fg) !important;
  border-color: var(--news-offers-btn-fg) !important;
  color: var(--news-offers-btn-bg) !important;
}

/* --- APP BACKGROUND (SmartiresApp): degradado diagonal rojo/blanco/amarillo --- */
html, body {
  background: linear-gradient(135deg, #dc3545 0%, #ffffff 45%, #ffc107 100%);
  background-attachment: fixed;
}

/* --- Floating menu dropdown: rojo (fondo) + amarillo (texto/iconos) --- */
.floating-menu .dropdown-menu {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
}

.floating-menu .dropdown-menu .dropdown-item,
.floating-menu .dropdown-menu .dropdown-header,
.floating-menu .dropdown-menu .dropdown-item i {
  color: #ffc107 !important;
}

/* Hover/focus: fondo amarillo + texto/iconos rojos */
.floating-menu .dropdown-menu .dropdown-item:hover,
.floating-menu .dropdown-menu .dropdown-item:focus {
  background-color: #ffc107 !important;
  color: #dc3545 !important;
}

.floating-menu .dropdown-menu .dropdown-item:hover i,
.floating-menu .dropdown-menu .dropdown-item:focus i {
  color: #dc3545 !important;
}

/* Divider visible on red background */
.floating-menu .dropdown-menu .dropdown-divider {
  border-top-color: rgba(255, 193, 7, 0.6) !important;
}

/* --- PERSONALIZED: mismas cards (degradado/borde/botones) que News/Offers --- */
#newsForYouCarousel .card,
#offersForYouCarousel .card {
  background: linear-gradient(135deg, var(--news-offers-card-grad-start) 0%, var(--news-offers-card-grad-end) 60%) !important;
  border-color: var(--news-offers-card-border) !important;
  border-width: 2px;
  border-style: solid;
  border-radius: var(--news-offers-card-radius);
  overflow: hidden;
}

#newsForYouCarousel .btn,
#offersForYouCarousel .btn {
  background-color: var(--news-offers-btn-bg) !important;
  border-color: var(--news-offers-btn-bg) !important;
  color: var(--news-offers-btn-fg) !important;
}

#newsForYouCarousel .btn:hover,
#offersForYouCarousel .btn:hover,
#newsForYouCarousel .btn:focus,
#offersForYouCarousel .btn:focus {
  background-color: var(--news-offers-btn-fg) !important;
  border-color: var(--news-offers-btn-fg) !important;
  color: var(--news-offers-btn-bg) !important;
}

#newsForYouCarousel .btn:active,
#offersForYouCarousel .btn:active {
  background-color: var(--news-offers-btn-fg) !important;
  border-color: var(--news-offers-btn-fg) !important;
  color: var(--news-offers-btn-bg) !important;
}

/* --- LOGIN: estilos solicitados --- */
.login-card {
  border: 2px solid #dc3545 !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #fff3cd 0%, #ffffff 60%) !important;
}

.login-card .login-submit-btn {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: #ffc107 !important;
}

.login-card .login-submit-btn:hover,
.login-card .login-submit-btn:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
}

.login-card .forgot-pwd-link {
  color: #dc3545 !important;
}

.login-card .forgot-pwd-link:hover,
.login-card .forgot-pwd-link:focus {
  color: #dc3545 !important;
  text-decoration: underline;
}

/* --- MODALS (SmartiresApp): borde rojo + degradado amarillo/blanco + botones rojo/amarillo --- */
.modal-content {
  border: 2px solid #dc3545 !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #fff3cd 0%, #ffffff 60%) !important;
}

.modal-content .btn.btn-primary {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: #ffc107 !important;
}

.modal-content .btn.btn-primary:hover,
.modal-content .btn.btn-primary:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
}

/* --- MODALS: outline-primary también en rojo/amarillo --- */
.modal-content .btn.btn-outline-primary {
  background-color: transparent !important;
  border-color: #dc3545 !important;
  color: #dc3545 !important;
}

.modal-content .btn.btn-outline-primary:hover,
.modal-content .btn.btn-outline-primary:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
}

/* --- EDIT PROFILE: contenedor y botón guardar con esquema rojo/amarillo --- */
.edit-profile-card {
  border: 2px solid #dc3545;
  border-radius: 12px;
  background: linear-gradient(135deg, #fff3cd 0%, #ffffff 60%);
  padding: 16px;
}

.edit-profile-card .edit-profile-save-btn {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: #ffc107 !important;
}

.edit-profile-card .edit-profile-save-btn:hover,
.edit-profile-card .edit-profile-save-btn:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
}

/* --- NUEVO USUARIO: contenedores/steps y botones con esquema rojo/amarillo --- */

/* Reusa el mismo look de `login-card` / `edit-profile-card` */
.nuevo-usuario-card,
#stepContainer .card {
  border: 2px solid #dc3545 !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #fff3cd 0%, #ffffff 60%) !important;
}

/* Botones del wizard (Siguiente/Finalizar) en rojo/amarillo + hover invertido */
.nuevo-usuario-btn-primary,
#btnNext {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: #ffc107 !important;
}

.nuevo-usuario-btn-primary:hover,
.nuevo-usuario-btn-primary:focus,
#btnNext:hover,
#btnNext:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
}

/* Botones primarios dentro de los steps (si en algún paso se usan) */
#stepContainer .btn.btn-primary {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: #ffc107 !important;
}

#stepContainer .btn.btn-primary:hover,
#stepContainer .btn.btn-primary:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
}

/* --- NEWS/OFFER DETAIL: contenedor con borde rojo + degradado, y botón rojo/amarillo --- */
.news-detail-card,
.offer-detail-card {
  border: 2px solid #dc3545 !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #fff3cd 0%, #ffffff 60%) !important;
}

.news-detail-card .btn.btn-primary,
.offer-detail-card .btn.btn-primary {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: #ffc107 !important;
}

.news-detail-card .btn.btn-primary:hover,
.news-detail-card .btn.btn-primary:focus,
.offer-detail-card .btn.btn-primary:hover,
.offer-detail-card .btn.btn-primary:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
}

/* --- AYUDA: contenedor con borde rojo + degradado, y botón rojo/amarillo --- */
.ayuda-card {
  border: 2px solid #dc3545 !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #fff3cd 0%, #ffffff 60%) !important;
}

.ayuda-card .btn.btn-primary {
  background-color: #dc3545 !important;
  border-color: #dc3545 !important;
  color: #ffc107 !important;
}

.ayuda-card .btn.btn-primary:hover,
.ayuda-card .btn.btn-primary:focus {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  color: #dc3545 !important;
}

/* --- CONTENEDORES (Noticias/Ofertas y "Para ti"): borde rojo + degradado amarillo/blanco ---
   Nota: se aplica SOLO al contenedor (wrapper), sin modificar cards internos ni mecánica del carrusel.
*/
#newsCarouselCard,
#offersCarouselCard,
#newsForYouCol .card-carousel,
#offersForYouCol .card-carousel {
  border: 2px solid #dc3545 !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #fff3cd 0%, #ffffff 60%) !important;
}

/* Respetar reglas previas que dependan de overflow/spacing del contenedor */
#newsCarouselCard,
#offersCarouselCard {
  overflow: visible;
}

/* --- PERSONALIZED carousels: indicators same style as News/Offers --- */
#newsForYouCarousel,
#offersForYouCarousel {
  padding-bottom: 34px;
}

#newsForYouCarousel .carousel-indicators,
#offersForYouCarousel .carousel-indicators {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 8px;
  margin: 0;
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  pointer-events: auto;
}

#newsForYouCarousel .carousel-indicators [data-bs-target],
#offersForYouCarousel .carousel-indicators [data-bs-target] {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin: 0;
  opacity: 1;
  background-color: #ffc107;
}

#newsForYouCarousel .carousel-indicators .active,
#offersForYouCarousel .carousel-indicators .active {
  background-color: #dc3545;
  opacity: 1;
}

/* --- NEWS FOR YOU: match main news card layout/typography --- */
#newsForYouCarousel .card-title {
  font-size: 0.88rem;
  line-height: 1.05;
  margin-bottom: 0.3rem;
}

#newsForYouCarousel .card-text {
  font-size: 0.78rem;
  color: #666;
  margin-bottom: 0.4rem;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 0 1 auto !important;
}

#newsForYouCarousel .card-body {
  display: flex;
  flex-direction: column;
  padding: 0.75rem;
  min-height: 120px;
}

#newsForYouCarousel .card-body .btn {
  margin-top: auto;
  width: 100%;
}