/* ============================================================
   VOLCANO SM — Rediseño del sitio público (2026)
   Paleta original respetada: verde #7AB730. Sistema de diseño moderno.
   Se carga DESPUÉS de style.css y sobrescribe la capa visual del tema.
   ============================================================ */
:root{
  --green:#7AB730; --green-d:#5c9220; --green-dd:#3f6b14;
  --green-soft:#eef6e4; --green-tint:#f6faf0;
  --ink:#16231a; --body:#4b5650; --muted:#7c8a80;
  --bg:#f7f9f4; --card:#ffffff; --line:#e7ece1;
  --amber:#e0a526;
  --shadow-sm:0 4px 14px rgba(20,40,15,.07);
  --shadow:0 10px 30px rgba(20,40,15,.10);
  --shadow-lg:0 24px 50px rgba(20,40,15,.16);
  --r:18px; --r-sm:12px; --r-pill:999px;
}

/* ---------- Base ---------- */
body{ background:var(--bg)!important; color:var(--body); font-family:'Poppins',sans-serif; -webkit-font-smoothing:antialiased; line-height:1.65; }
h1,h2,h3,h4,h5,h6{ color:var(--ink); font-weight:700; letter-spacing:-.02em; line-height:1.18; }
a{ transition:color .2s ease; }
.text-primary{ color:var(--green)!important; }
.bg-primary{ background:var(--green)!important; }
img{ max-width:100%; }
.container{ max-width:1200px; }

/* ---------- Botones ---------- */
.btn{ border-radius:var(--r-pill); font-weight:600; padding:.7rem 1.6rem; transition:all .22s ease; border-width:2px; }
.btn-primary,.btn.btn-primary{ background:var(--green); border-color:var(--green); color:#fff; box-shadow:0 8px 20px rgba(122,183,48,.25); }
.btn-primary:hover,.btn-primary:focus{ background:var(--green-d); border-color:var(--green-d); transform:translateY(-2px); box-shadow:0 12px 26px rgba(122,183,48,.38); }
.btn-outline-primary{ color:var(--green-d); border-color:var(--green); background:transparent; }
.btn-outline-primary:hover{ background:var(--green); border-color:var(--green); color:#fff; transform:translateY(-2px); }
.btn-light{ border-radius:var(--r-pill); }
.btn-square{ border-radius:50%!important; }

/* ---------- Topbar ---------- */
.container-fluid.bg-light.pt-3{ background:var(--ink)!important; padding:.5rem 0!important; }
.container-fluid.bg-light.pt-3 p,.container-fluid.bg-light.pt-3 a{ color:#cfe0c4!important; font-size:.86rem; margin-bottom:0!important; }
.container-fluid.bg-light.pt-3 a:hover{ color:#fff!important; }
.container-fluid.bg-light.pt-3 .text-primary{ color:#a8d57f!important; }

/* ---------- Navbar ---------- */
.nav-bar{ position:sticky; top:0; z-index:1000; }
.nav-bar .navbar{ background:rgba(255,255,255,.92)!important; backdrop-filter:saturate(140%) blur(8px); border:0; border-radius:0; box-shadow:0 6px 24px rgba(20,40,15,.07)!important; padding:.6rem 0; }
.navbar-brand h1{ font-weight:800; font-size:1.7rem; letter-spacing:-.03em; }
.navbar-nav .nav-link{ font-weight:600; color:var(--ink)!important; padding:.55rem 1rem!important; border-radius:var(--r-pill); margin:0 .1rem; transition:all .2s; }
.navbar-nav .nav-link:hover{ color:var(--green-d)!important; background:var(--green-soft); }
.navbar-nav .nav-link.active{ color:#fff!important; background:var(--green); }

/* ---------- HERO (carrusel) ---------- */
#header-carousel{ border-radius:0 0 32px 32px; overflow:hidden; }
#header-carousel .carousel-item{ position:relative; }
#header-carousel .carousel-item img,#header-carousel .carousel-inner img{
  width:100%!important; height:88vh!important; min-height:460px; max-height:820px; object-fit:cover!important;
}
#header-carousel .carousel-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,25,8,.30) 0%,rgba(10,25,8,.20) 40%,rgba(10,25,8,.72) 100%); }
#header-carousel .carousel-caption{ z-index:3; bottom:auto; top:50%; transform:translateY(-50%); right:8%; left:8%; text-align:center; }
.carousel-caption h4,.carousel-caption .text-uppercase{ color:#bfe39a!important; font-weight:700; letter-spacing:4px; }
.carousel-caption h1,.carousel-caption .display-3{ color:#fff!important; font-weight:800; font-size:clamp(2rem,5vw,4rem); text-shadow:0 4px 30px rgba(0,0,0,.4); margin-bottom:1.5rem!important; }

/* ---------- Secciones / encabezados ---------- */
.container-fluid.py-5,.container-fluid.py-6{ padding:5rem 0; }
.section-eyebrow,.text-center h6.text-primary{ color:var(--green-d)!important; font-weight:700; text-transform:uppercase; letter-spacing:4px; font-size:.8rem!important; }
.text-center h1,.text-center h3{ position:relative; display:inline-block; padding-bottom:.85rem; margin-top:.4rem; font-size:clamp(1.6rem,3.2vw,2.5rem); }
.text-center h1::after,.text-center h3::after{ content:""; position:absolute; left:50%; bottom:0; transform:translateX(-50%); width:64px; height:4px; border-radius:4px; background:var(--green); }

/* ---------- Tarjetas de Tours (destination) ---------- */
.destination-item{ border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .3s ease,box-shadow .3s ease; background:var(--card); }
.destination-item:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.destination-item img{ width:100%; height:280px; object-fit:cover; display:block; transition:transform .55s ease; }
.destination-item:hover img{ transform:scale(1.08); }
.destination-overlay{ background:linear-gradient(transparent,rgba(12,28,8,.88))!important; }
.destination-overlay h5{ font-weight:700; }

/* ---------- Servicios (cards de íconos) ---------- */
.service-item{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:2.4rem 1.6rem!important; box-shadow:var(--shadow-sm); transition:transform .3s,box-shadow .3s,border-color .3s; }
.service-item:hover{ transform:translateY(-8px); box-shadow:var(--shadow); border-color:var(--green); }
.service-item i{ color:var(--green); }
.service-item img{ height:96px; width:auto; object-fit:contain; margin:0 auto .6rem; }

/* ---------- Equipo ---------- */
.team-item{ border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .3s,box-shadow .3s; background:var(--card); }
.team-item:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.team-img{ overflow:hidden; }
.team-img img{ height:340px; width:100%; object-fit:cover; transition:transform .55s ease; }
.team-item:hover .team-img img{ transform:scale(1.07); }

/* ---------- Tarjetas genéricas (cabañas/camping/listados internos) ---------- */
.card{ border:0; border-radius:var(--r); box-shadow:var(--shadow-sm); overflow:hidden; transition:transform .25s,box-shadow .25s; }
.card:hover{ box-shadow:var(--shadow); }
.card-img-top,.card img{ object-fit:cover; }

/* ---------- Footer ---------- */
.container-fluid.bg-dark{ background:#10180f!important; margin-top:0!important; }
.container-fluid.bg-dark h2,.container-fluid.bg-dark h5,.container-fluid.bg-dark h6{ color:#fff!important; }
.container-fluid.bg-dark a.text-white-50:hover{ color:var(--green)!important; padding-left:4px; }
.input-group .form-control{ border-radius:var(--r-pill) 0 0 var(--r-pill)!important; }
.input-group .btn,.input-group-append .btn{ border-radius:0 var(--r-pill) var(--r-pill) 0!important; }

/* ---------- Formularios ---------- */
.form-control{ border-radius:var(--r-sm); border:1.5px solid var(--line); padding:.7rem 1rem; }
.form-control:focus{ border-color:var(--green); box-shadow:0 0 0 .2rem rgba(122,183,48,.18); }

/* ---------- Back to top ---------- */
.back-to-top{ border-radius:14px!important; box-shadow:var(--shadow); }

/* ---------- Animación de entrada ---------- */
@keyframes vsmUp{ from{opacity:0; transform:translateY(18px);} to{opacity:1; transform:none;} }
.destination-item,.service-item,.team-item,.card{ animation:vsmUp .5s ease both; }

/* ---------- Responsive ---------- */
@media (max-width:991.98px){
  #header-carousel .carousel-item img{ height:64vh!important; }
  .container-fluid.py-5,.container-fluid.py-6{ padding:3rem 0; }
}
@media (max-width:575.98px){
  #header-carousel .carousel-item img{ height:56vh!important; min-height:340px; }
  .destination-item img{ height:230px; }
}

/* ============================================================
   COMPONENTES DEL REDISEÑO ESTRUCTURAL (markup nuevo .vsm-*)
   ============================================================ */
.vsm-section{ padding:5.5rem 0; }
.vsm-section--tint{ background:var(--green-tint); }
.vsm-wrap{ max-width:1200px; margin:0 auto; padding:0 1.25rem; }
.vsm-head{ max-width:700px; margin:0 auto 3rem; text-align:center; }
.vsm-eyebrow{ color:var(--green-d); font-weight:700; text-transform:uppercase; letter-spacing:4px; font-size:.78rem; display:block; }
.vsm-head h2{ font-size:clamp(1.8rem,3.6vw,2.7rem); margin:.5rem 0 .7rem; }
.vsm-head p{ color:var(--muted); font-size:1.05rem; }

/* Hero */
.vsm-hero{ position:relative; min-height:92vh; display:flex; align-items:center; color:#fff; overflow:hidden; border-radius:0 0 36px 36px; }
.vsm-hero .carousel,.vsm-hero .carousel-inner,.vsm-hero .carousel-item{ position:absolute; inset:0; height:100%; }
.vsm-hero .carousel-item img{ width:100%; height:100%; object-fit:cover; }
.vsm-hero__veil{ position:absolute; inset:0; z-index:2; background:linear-gradient(110deg,rgba(8,20,6,.82),rgba(8,20,6,.35) 60%,rgba(8,20,6,.15)); }
.vsm-hero__inner{ position:relative; z-index:3; max-width:1200px; margin:0 auto; padding:0 1.5rem; width:100%; }
.vsm-hero__content{ max-width:720px; }
.vsm-hero__badge{ display:inline-block; background:rgba(122,183,48,.2); border:1px solid rgba(122,183,48,.55); color:#d4efb2; padding:.4rem 1.1rem; border-radius:999px; font-weight:600; letter-spacing:1px; font-size:.85rem; }
.vsm-hero h1{ color:#fff; font-size:clamp(2.2rem,5.6vw,4.3rem); line-height:1.04; margin:1.2rem 0; }
.vsm-hero p{ font-size:1.18rem; color:#e9f1e1; max-width:580px; }
.vsm-hero__cta{ display:flex; gap:1rem; flex-wrap:wrap; margin-top:1.9rem; }
.vsm-hero__stats{ display:flex; gap:2.8rem; margin-top:2.8rem; flex-wrap:wrap; }
.vsm-hero__stats .n{ font-size:1.9rem; font-weight:800; color:#fff; }
.vsm-hero__stats .l{ font-size:.85rem; color:#cfe0c4; }

/* Features */
.vsm-features{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.vsm-feature{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:2.1rem 1.4rem; text-align:center; transition:transform .25s,box-shadow .25s,border-color .25s; }
.vsm-feature:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--green); }
.vsm-feature__ico{ width:66px; height:66px; border-radius:50%; background:var(--green-soft); color:var(--green-d); display:flex; align-items:center; justify-content:center; font-size:1.7rem; margin:0 auto 1.1rem; }
.vsm-feature h5{ font-size:1.05rem; margin-bottom:.4rem; }
.vsm-feature p{ color:var(--muted); font-size:.92rem; margin:0; }

/* Tours grid */
.vsm-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.7rem; }
.vsm-tour{ background:#fff; border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .3s,box-shadow .3s; display:flex; flex-direction:column; }
.vsm-tour:hover{ transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.vsm-tour__img{ position:relative; height:225px; overflow:hidden; }
.vsm-tour__img img{ width:100%; height:100%; object-fit:cover; transition:transform .55s; }
.vsm-tour:hover .vsm-tour__img img{ transform:scale(1.08); }
.vsm-tour__badge{ position:absolute; top:12px; left:12px; background:var(--green); color:#fff; font-weight:700; padding:.35rem .85rem; border-radius:999px; font-size:.85rem; z-index:2; box-shadow:0 4px 12px rgba(0,0,0,.2); }
.vsm-tour__off{ position:absolute; top:12px; right:12px; background:#c0392b; color:#fff; font-weight:600; padding:.3rem .7rem; border-radius:999px; font-size:.75rem; z-index:2; }
.vsm-tour__body{ padding:1.35rem; display:flex; flex-direction:column; gap:.55rem; flex:1; }
.vsm-tour__body h5{ font-size:1.12rem; margin:0; }
.vsm-tour__meta{ display:flex; gap:1.2rem; color:var(--muted); font-size:.86rem; }
.vsm-tour__body .btn{ margin-top:auto; }

/* CTA band */
.vsm-cta{ position:relative; background:linear-gradient(120deg,var(--green-dd),var(--green-d)); color:#fff; border-radius:30px; padding:3.4rem 2rem; text-align:center; box-shadow:var(--shadow-lg); }
.vsm-cta h2{ color:#fff; font-size:clamp(1.7rem,3.4vw,2.4rem); }
.vsm-cta p{ color:#e7f5d7; max-width:620px; margin:.6rem auto 1.6rem; }
.vsm-cta .btn-light{ color:var(--green-dd); font-weight:700; }

/* Team grid */
.vsm-team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.vsm-member{ background:#fff; border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .3s,box-shadow .3s; }
.vsm-member:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.vsm-member__img{ height:300px; overflow:hidden; }
.vsm-member__img img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.vsm-member:hover .vsm-member__img img{ transform:scale(1.06); }
.vsm-member__body{ padding:1.1rem; text-align:center; }
.vsm-member__body h5{ margin:0; font-size:1.05rem; }
.vsm-member__body p{ color:var(--green-d); font-size:.85rem; margin:.2rem 0 0; }

@media (max-width:991.98px){
  .vsm-features,.vsm-team-grid{ grid-template-columns:repeat(2,1fr); }
  .vsm-grid{ grid-template-columns:repeat(2,1fr); }
  .vsm-hero{ min-height:80vh; }
}
@media (max-width:575.98px){
  .vsm-features,.vsm-team-grid,.vsm-grid{ grid-template-columns:1fr; }
  .vsm-section{ padding:3.2rem 0; }
  .vsm-hero__stats{ gap:1.6rem; }
}

/* Full-bleed: rompe el .container del base para secciones a todo lo ancho */
body{ overflow-x:hidden; }
.vsm-bleed{ width:100vw; position:relative; left:50%; margin-left:-50vw; }

/* Topbar nuevo */
.vsm-topbar{ background:var(--ink); color:#cfe0c4; font-size:.86rem; padding:.55rem 0; }
.vsm-topbar a{ color:#cfe0c4; text-decoration:none; }
.vsm-topbar a:hover{ color:#fff; }
.vsm-topbar .fab,.vsm-topbar .fa{ }
.vsm-topbar i.text-primary{ color:var(--green)!important; }

/* Navbar CTA */
.navbar .vsm-navcta{ color:#fff!important; background:var(--green); padding:.55rem 1.4rem!important; }
.navbar .vsm-navcta:hover{ background:var(--green-d); color:#fff!important; }

/* Servicios: nueva sección con íconos */
.vsm-feature__ico img{ width:42px; height:42px; object-fit:contain; }

/* ===== Encabezado de página (páginas internas) ===== */
.vsm-pagehero{ position:relative; padding:5rem 0 3.6rem; color:#fff; text-align:center; overflow:hidden; background:linear-gradient(120deg,var(--green-dd),var(--green-d)); border-radius:0 0 32px 32px; }
.vsm-pagehero::after{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 82% 18%, rgba(255,255,255,.14), transparent 52%); }
.vsm-pagehero__in{ position:relative; z-index:2; max-width:780px; margin:0 auto; padding:0 1.25rem; }
.vsm-pagehero h1{ color:#fff; font-size:clamp(2rem,4.6vw,3.2rem); margin:.3rem 0 .4rem; }
.vsm-pagehero p{ color:#e9f5da; font-size:1.08rem; margin:0; }
.vsm-pagehero .vsm-eyebrow{ color:#cdeaa6; }
.vsm-crumbs{ color:#d6e8c9; font-size:.85rem; margin-top:.7rem; }
.vsm-crumbs a{ color:#fff; text-decoration:none; }
.vsm-crumbs a:hover{ text-decoration:underline; }

/* Variante de encabezado con imagen de fondo (estilo hero del inicio) */
.vsm-pagehero--img{ padding:7rem 0 5.5rem; background-size:cover; background-position:center; }
.vsm-pagehero--img::before{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(120deg,rgba(8,20,6,.84),rgba(8,20,6,.45) 60%,rgba(8,20,6,.30)); }
.vsm-pagehero--img .vsm-pagehero__in{ z-index:2; }
.vsm-pagehero__cta{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:1.6rem; }
.vsm-pagehero__stats{ display:flex; gap:2.8rem; justify-content:center; flex-wrap:wrap; margin-top:2rem; }
.vsm-pagehero__stats .n{ font-size:1.95rem; font-weight:800; color:#fff; line-height:1; }
.vsm-pagehero__stats .l{ font-size:.82rem; color:#cfe0c4; }

/* Pricing / planes */
.vsm-price{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:2rem 1.5rem; text-align:center; box-shadow:var(--shadow-sm); transition:transform .25s,box-shadow .25s,border-color .25s; height:100%; }
.vsm-price:hover{ transform:translateY(-8px); box-shadow:var(--shadow); border-color:var(--green); }
.vsm-price__amt{ font-size:2.4rem; font-weight:800; color:var(--green-d); }
.vsm-price__amt small{ font-size:.95rem; color:var(--muted); font-weight:600; }
.vsm-price ul{ list-style:none; padding:0; margin:1rem 0; text-align:left; }
.vsm-price li{ padding:.4rem 0; border-bottom:1px dashed var(--line); color:var(--body); }
.vsm-price li i{ color:var(--green); margin-right:.5rem; }

/* Form card (contacto/reserva) */
.vsm-formcard{ background:#fff; border-radius:var(--r); box-shadow:var(--shadow); padding:2.2rem; }
.vsm-detail-img{ border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow); }
.vsm-detail-img img{ width:100%; height:100%; object-fit:cover; }

/* ===== FIX íconos: el prefijo legacy 'fa' no renderiza en FontAwesome 5 ===== */
.fa{ font-family:"Font Awesome 5 Free"!important; font-weight:900!important; }

/* ===== Compatibilidad Bootstrap 5 -> sitio Bootstrap 4 (clases usadas en las internas) ===== */
.d-grid{ display:grid!important; }
.d-grid > .btn,.d-grid > *{ width:100%; }
.gap-1{ gap:.25rem!important; } .gap-2{ gap:.5rem!important; } .gap-3{ gap:1rem!important; } .gap-4{ gap:1.5rem!important; }
.me-1{ margin-right:.25rem!important; } .me-2{ margin-right:.5rem!important; } .me-3{ margin-right:1rem!important; }
.ms-1{ margin-left:.25rem!important; } .ms-2{ margin-left:.5rem!important; } .ms-3{ margin-left:1rem!important; } .ms-auto{ margin-left:auto!important; }
.ps-0{ padding-left:0!important; } .pe-0{ padding-right:0!important; }
/* gutters g-* (BS5) en filas BS4 */
.row.g-2{ margin:-.25rem; } .row.g-2 > [class*="col"]{ padding:.25rem; }
.row.g-3{ margin:-.5rem; } .row.g-3 > [class*="col"]{ padding:.5rem; }
.row.g-4{ margin:-.75rem; } .row.g-4 > [class*="col"]{ padding:.75rem; }
.row.g-5{ margin:-1.25rem; } .row.g-5 > [class*="col"]{ padding:1.25rem; }
