/*
Theme Name: NomadPhoto Expedition
Theme URI: https://example.com/nomadphoto-expedition
Author: David Lorenzo + ChatGPT
Description: WordPress classic theme (Desktop 1280px) with Bootstrap 5. Figma-accurate Home with sections: Hero → Newsletter → Tours grid → Why (dark) → Testimonials (text+2 photos) → Contact (form) → Travel Carousel → Footer.
Version: 1.1
Text Domain: nomadphoto
*/
@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-Thin.woff2') format('woff2'),
       url('fonts/Larken-Thin.woff') format('woff');
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-ThinItalic.woff2') format('woff2'),
       url('fonts/Larken-ThinItalic.woff') format('woff');
  font-weight: 100;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-Light.woff2') format('woff2'),
       url('fonts/Larken-Light.woff') format('woff');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-LightItalic.woff2') format('woff2'),
       url('fonts/Larken-LightItalic.woff') format('woff');
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-Regular.woff2') format('woff2'),
       url('fonts/Larken-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-Italic.woff2') format('woff2'),
       url('fonts/Larken-Italic.woff') format('woff');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-Medium.woff2') format('woff2'),
       url('fonts/Larken-Medium.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-MediumItalic.woff2') format('woff2'),
       url('fonts/Larken-MediumItalic.woff') format('woff');
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-Bold.woff2') format('woff2'),
       url('fonts/Larken-Bold.woff') format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-BoldItalic.woff2') format('woff2'),
       url('fonts/Larken-BoldItalic.woff') format('woff');
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-ExtraBold.woff2') format('woff2'),
       url('fonts/Larken-ExtraBold.woff') format('woff');
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-ExtraBoldItalic.woff2') format('woff2'),
       url('fonts/Larken-ExtraBoldItalic.woff') format('woff');
  font-weight: 800;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-Black.woff2') format('woff2'),
       url('fonts/Larken-Black.woff') format('woff');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Larken';
  src: url('fonts/Larken-BlackItalic.woff2') format('woff2'),
       url('fonts/Larken-BlackItalic.woff') format('woff');
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'LarkenVariable';
  src: url('fonts/LarkenVariable.woff2') format('woff2'),
       url('fonts/LarkenVariable.woff') format('woff');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'LarkenVariable';
  src: url('fonts/LarkenVariableItalic.woff2') format('woff2'),
       url('fonts/LarkenVariableItalic.woff') format('woff');
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}


:root {
  /* Colores principales */
  --np-yellow:     #FCC014;  /* NE Yellow */
  --np-dark:       #242421;  /* Neutral-900 */
  --np-gray-800:   #343432;  /* Neutral-800 */
  --np-gray-400:   #BCBCBC;  /* Neutral-400 */
  --np-bg:         #F2F0E8;  /* Neutral-50 */
  --np-wh:         #ffffff;  /* Neutral-50 */
  /* Tipografías */
  --font-title:    'Larken', serif;
  --font-text:     'Inter', sans-serif;
  --font-size-title : 48px;
  --font-size-h5 : 24px;

  /* Espaciados */
  --section-padding: 60px;

  /* Otros */
  --radius:        8px;
  --transition:    all 0.3s ease;
}
.pe-13 {
    padding-right: 11rem !important;
}
html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-text);
  background: var(--np-bg);
  color: var(--np-dark);
  line-height: 1.6;
}
.wh {
  color:var(--np-wh);
}
.container,
.container-lg,
.container-xl,
.container-xxl {
  max-width: var(--np-container, 1280px);
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-title);
  line-height: 1.15;
  color: var(--np-dark);
}
h5 {
  font-size: var(--font-size-h5);
}
.section-title {
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--np-gray-400);
  font-weight: 600;
  font-size: .9rem;
  margin-bottom: .25rem;
}
.section-headline {
  font-family: var(--font-title);
  font-weight: 800;
  line-height: 1.1;
}

/* Navbar over hero */
#site-header.navbar {
  background: linear-gradient(180deg, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.0) 100%);
}
.navbar .nav-link {
    color: #F2F0E8;
    transition: var(--transition);
    font-size: 14px;
    font-family: 'Inter';
    font-weight: 600;
}
.navbar .nav-link:hover {
  color: var(--np-yellow);
}
.navbar-brand {
  color: #fff;
  font-family: var(--font-title);
  font-weight: 800;
  letter-spacing: .02em;
}

/* Sections */
.section {
  padding: var(--section-padding) 0;
}

.hero {
  min-height: 88vh;
  position: relative;
  display: grid;
  align-items: center;
  background-position: center;
  background-size: cover;
  color: #fff;
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.6));
}
.hero > .container {
  position: relative;
  z-index: 2;
  
}

.home .hero > .container {
  padding-top: 100px;
}
.hero .display-3 {
      font-size: 64px;
    color: #fff;
    font-family: 'Larken';
    font-weight: 100 !important;
}
.hero .lead {
  color: var(--np-gray-400);
}

/* Tarjetas de imagen */
.card-photo {
  border: 1px solid rgba(0,0,0,.08);
  background: var(--np-bg);
}

/* Botones */
.btn-accent {
   background: var(--np-yellow);
    color: var(--np-dark);
    border: 0;
    transition: var(--transition);
    font-size: 14px;
    font-weight: 700;
    font-family: 'Inter';
    padding: 18px 35px;
}
.btn-accent:hover {
  filter: brightness(1.05);
  color: var(--np-dark);
}
.btn-outline-dark {
  border-color: var(--np-dark);
  color: var(--np-dark);
}
.btn-outline-dark:hover {
  background: var(--np-dark);
  color: var(--np-bg);
}

/* Texto secundario */
.text-muted-2 {
  color: var(--np-gray-400) !important;
}

/* Ratios de imagen */
.ratio-3x4 { --bs-aspect-ratio: 133.333%; } /* 4/3 * 100 */
.ratio > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Reset imágenes */
figure { margin: 0; }
img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Bloque oscuro genérico */
.section-dark {
  background: var(--np-dark);
  color: var(--np-bg);
}
.section-dark h2 {
  color: var(--np-bg);
}

/* Testimonials layout */
.testi-text {
  max-width: 560px;
}

.np-testimonials {
  background: var(--np-bg);
}

.np-testimonials h2 {
    font-family: 'Larken';
    color: var(--np-fg);
    font-size: 48px;
};
.testimonial-row {
  scrollbar-width: none;         /* Firefox */
  -ms-overflow-style: none;      /* IE/Edge */
}
.testimonial-row::-webkit-scrollbar {
  display: none;                 /* Chrome/Safari */
}
.testimonial-card {
  flex: 0 0 300px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.05);
  border-radius: .5rem;
  padding: 1.5rem;
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.testimonial-row {
  scrollbar-width: none;         /* Firefox */
  -ms-overflow-style: none;      /* IE/Edge */
}
.testimonial-row::-webkit-scrollbar {
  display: none;                 /* Chrome/Safari */
}
.testimonial-card {
  flex: 0 0 300px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.05);
  border-radius: .5rem;
  padding: 1.5rem;
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

.testimonial-card h5 {
  font-family: 'Larken';
  font-size: 24px;
  font-weight: 300 !important;
  line-height: 28px;
}
.testimonial-card p {
  font-family: 'Inter';
  font-size: 14px;
  margin-bottom: 1rem;
  font-weight: 100;
}
.testimonial-card small {
  font-size: 12px;
  font-weight: 600;
  color: #595959 !important;
  letter-spacing: 1px;
}
.testimonial-track-wrapper {
  position: relative;
}

.testimonial-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.9);
  border: none;
  font-size: 1.5rem;
  font-weight: bold;
  padding: 0.5rem 0.75rem;
  cursor: pointer;
  z-index: 10;
  border-radius: 50%;
  box-shadow: 0 0 10px rgba(0,0,0,0.1);
}
.testimonial-nav:hover {
  background: #fff;
}

.testimonial-nav.prev {
  left: 0.25rem;
}
.testimonial-nav.next {
  right: 0.25rem;
}

/* Opcional: Ocultar botones en móvil si lo deseas */
@media (max-width: 767px) {
  .testimonial-nav {
    display: none;
  }
}
/* Fades laterales en los carruseles de testimonios */
.testimonial-track-wrapper {
  position: relative;
  overflow: hidden; /* asegura que el degradado tape los bordes */
}

.testimonial-track-wrapper::before,
.testimonial-track-wrapper::after {
  content: "";
  position: absolute;
  top: 0;
  width: 80px;              /* ancho del fade, ajustable */
  height: 100%;
  pointer-events: none;     /* no bloquea clics ni hover */
  z-index: 5;
}

.testimonial-track-wrapper::before {
  left: 0;
  background: linear-gradient(to right, var(--np-bg) 0%, transparent 100%);
}

.testimonial-track-wrapper::after {
  right: 0;
  background: linear-gradient(to left, var(--np-bg) 0%, transparent 100%);
}

/* Ajuste en temas oscuros */
.section-dark .testimonial-track-wrapper::before {
  background: linear-gradient(to right, #111 0%, transparent 100%);
}
.section-dark .testimonial-track-wrapper::after {
  background: linear-gradient(to left, #111 0%, transparent 100%);
}

/* 🎬 Sombras dinámicas en tarjetas de testimonios (motion effect) */
.testimonial-track {
  transition: filter 0.3s ease;
  will-change: transform, filter;
}

/* estado en movimiento: sutil difuminado direccional */
.testimonial-track[data-moving="forward"] {
  filter: drop-shadow(4px 0 10px rgba(0,0,0,0.15));
}
.testimonial-track[data-moving="backward"] {
  filter: drop-shadow(-4px 0 10px rgba(0,0,0,0.15));
}


/* Logo badge del header */
.np-logo-badge {
  display: inline-block;
  background: var(--np-yellow);
  color: var(--np-dark);
  padding: .45rem .65rem;
  font-family: var(--font-title);
  font-weight: 800;
  letter-spacing: .02em;
  line-height: 1.05;
}
#newsletter .container .row {
  gap: 65px;
      height: 103px;
}
/* Barra de newsletter */
.np-newsletter {
  background: var(--np-dark);
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  color: var(--np-gray-400);
}
.np-news-title {
    font-family: var(--font-title);
    font-weight: 200;
    color: var(--np-bg);
    font-size: 24px;
}
.np-input {
    background: transparent;
    border: 0;
    border-bottom: 1px solid rgba(255, 255, 255, .35);
    border-radius: 0;
    color: var(--np-bg);
    padding-left: 0;
    font-weight: 400;
    font-size: 14px;
}
.np-input::placeholder {
  color: var(--np-dark);
}

/* Sección Adventure Photo Tours */
.np-about {
  padding-top: var(--section-padding);
  padding-bottom: 0;
}
.np-about .np-copy p {
    color: var(--np-dark);
        font-weight: 200;
    margin-bottom: 2rem;
}

.np-btn {
    text-transform: uppercase;
    letter-spacing: .02em;
    font-weight: 700;
    border-color: var(--np-dark);
    padding: 1.1em 1.8rem;
    border-radius: .35rem;
    font-size: 14px;
}
.pe-10 {
    padding-right: 5rem !important;
}
.np-photo img {
      max-width: 450px;
    height: 564px;
    object-fit: cover;
    object-position: center;
}

/* Línea divisoria */
.np-section-divider {
  height: 1px;
  background: #D1D1D1;
  opacity: .25;
  margin-top: 56px;
}

/* Bloque: Why Choose Us */
.np-values {
  background: var(--np-dark);
  color: var(--np-bg);
}
.np-values h2 {
   font-family: var(--font-title);
    color: #fff;
    font-size: 48px;
    line-height: 52px;
    padding-bottom: 20px;
}
.np-values .card {
  border: none;
  border-radius: var(--radius);
  background-color: var(--np-gray-800) !important;
}

.np-values .card .card-body {
    padding: 2rem;
        padding-bottom: 5rem;
}
.np-values .card h5 {
  font-family: var(--font-title);
  font-size: 36px;
  color: #fff;
}
.np-values .card img {
      width: 76px;
    height: 76px;
    object-fit: none;
}

.np-values .card .test {
  font-size: 18px;
    line-height: 24px;
    font-weight: 400;
    color: #cacaca;
    min-height: 79px;
}


/*Meet the team*/

.np-team {
  background: var(--np-dark);
  color: var(--np-bg);
  padding-top: 141px;
 
  
}
.np-team h2 {
  font-family: var(--font-title);
  color: var(--np-bg);
   font-size: var(--font-size-title);
   margin-bottom: 4rem !important;
}
.np-team p {
    font-size: 14px;
    line-height: 1.7;
    font-weight: 200;
}
.np-team .btn-outline-light {
  border: 1px solid var(--np-yellow);
  color: var(--np-bg);
  letter-spacing: .03em;
  text-transform: uppercase;
  width: 100%;
  font-size: 14px;
  font-weight: 700;
}
.np-team .btn-outline-light:hover {
  background: var(--np-yellow);
  color: var(--np-dark);
}
.awards-row {
  scrollbar-width: none;
}
.awards-row::-webkit-scrollbar {
  display: none;
}
.award img {
  opacity: .9;
  filter: grayscale(100%);
  transition: opacity .3s ease;
}
.award:hover img {
  opacity: 1;
  filter: grayscale(0%);
}
.award div {
  color: var(--np-gray-400);
  line-height: 1.3;
}

/*Contact*/

.np-contact {
  background: var(--np-bg);
  color: var(--np-dark);
      padding-top: 82px;
}
.np-contact h2 {
  font-family: var(--font-title);
  color: var(--np-dark);
  font-size: var(--font-size-title);
}
.np-contact-info li {
    font-family: var(--font-text);
    margin-bottom: 1.5rem;
    font-size: 17px;
    font-weight: 300;
    font-size: 16px;
}
.np-contact-info i {
  color: var(--np-dark);
}
.np-contact-image img {
  border-radius: .25rem;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.np-contact .row {
  position: relative;
}

/* DIVISOR EXACTO FIGMA */
.np-divider-vertical {
  position: absolute;
    top: 0;
    bottom: 0;     /* no llega hasta el final */
  left: 50%;
  width: 1px;
  background-color: #9a9a9a;
  transform: translateX(-50%);
}

/* Oculto en móvil */
@media (max-width: 991px) {
  .np-divider-vertical {
    display: none;
  }
}


/* Formulario */
.np-form .form-control,
.np-form .form-select {
    background: transparent;
    border: 1px solid #BCBCBC;
    border-radius: .25rem;
    font-family: var(--font-text);
    color: var(--np-dark);
    font-size: 14px;
    padding: .95rem 1.5rem;
}
.np-form .form-control::placeholder {
  color: var(--np-dark);
}

newsletter
.np-form .form-control:focus,
.np-form .form-select:focus {
  border-color: var(--np-yellow);
  box-shadow: none;
}
.np-form textarea {
  resize: none;
}

/* Botón */
.np-form .btn-outline-dark {
     border-color: var(--np-dark);
    color: var(--np-dark);
    font-size: 14px;
    letter-spacing: .05em;
    padding: 78px;
}
.np-form .btn-outline-dark:hover {
  background: var(--np-dark);
  color: var(--np-bg);
}
/*Discover*/

.np-discover{ background:var(--np-bg); color:var(--np-dark);     padding-bottom: 127px;}
.np-discover .title-row h2{ font-family:var(--font-title); font-weight:400; font-size: var(--font-size-title);    margin-bottom: 2rem !important;
    color: #383234;}

/* Elimina el scroll horizontal del documento sin romper el efecto full-width */
html, body {
  overflow-x: hidden;
}

/* Ajuste del wrapper para evitar el desbordamiento por el scrollbar del viewport */
.discover-full-right {
  width: 100vw;
  position: relative;
  left: calc((100vw - min(100vw, var(--np-container, 1280px))) / 2);
  overflow: hidden;
  max-width: 100%;
}
.discover-row {
  scroll-behavior: smooth;
  transition: scroll-left 0.3s ease;
  will-change: scroll-position;
}

.discover-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.discover-card:hover {
  transform: scale(1.02);
  box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}


/* Paddings para que la primera tarjeta alinee con el padding del container */
.discover-row{
  padding-right: var(--bs-gutter-x, 1.5rem);
  scrollbar-width: none; -ms-overflow-style: none;
}
.discover-row::-webkit-scrollbar{ display:none; }

/* Tarjetas */
.discover-card{ flex:0 0 360px; cursor:pointer; }
.discover-card img{ object-fit:cover; border-radius:4px; }
.discover-card h5{ font-family:var(--font-title); font-size:var(--font-size-h5); margin-top:.75rem; }
.discover-card small {
    color: var(--np-gray-400);
    font-size: 12px;
}

/* Flechas */
.discover-btn{
  background:transparent; border:none; color:var(--np-dark);
  font-size:1.25rem; padding:.25rem .5rem; cursor:pointer; transition:color .2s ease;
}
.discover-btn:hover{ color:var(--np-yellow); }

/*footer*/

/* === FOOTER === */
.np-footer {
  background: #111;
  color: #ddd;
  font-family: var(--np-font-sans);
}

.np-footer-notice {
  font-size: .8rem;
  background: var(--np-bg);
  color: var(--np-fg);
}

.np-footer a {
  color: #ddd;
  transition: color .2s ease;
}
.np-footer a:hover {
  color: var(--np-accent);
}

.np-footer-news .form-control {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,.35);
  color: #fff;
  border-radius: 0;
}
.np-footer-news .form-control:focus {
  box-shadow: none;
  border-color: var(--np-accent);
}

.np-footer-news .btn {
  background: var(--np-accent);
  border: none;
  color: #111;
  font-weight: 600;
}
.np-footer-news .btn:hover {
  filter: brightness(1.1);
}

/* Social icons */
.np-footer .bi {
  font-size: 1.2rem;
}

/* Separadores */
.np-footer hr {
  opacity: .2;
  border-color: rgba(255,255,255,.2);
}

#tours h5 {
  font-size: 36px;
  text-align: left;
}

.mt-7 {
  margin-top: 5rem !important;
}

.np-team small {
  font-size: 12px;
    font-weight: 300;
}

.np-contact-image {
      max-width: 408px;
}

.np-contact-info {
      margin-top: 73px;
}

.l24 {
  font-size: var(--font-size-h5);
}



#newsletter .np-input::placeholder {
  color: var(--np-gray-400);
}

/*VIAJE INDIV*/

  .tour-hero {
    position: relative;
    background-size: cover;
    background-position: center;
    color: #fff;
    padding: 429px 0 100px;
  height: 910px;
  z-index: 1;
}

.tour-hero .overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.6), rgba(0,0,0,0));
  z-index: 1;
}

.tour-hero .container {
  position: relative;
  z-index: 2;
  text-align: center;
}

.tour-hero-content .tag {
    display: inline-block;
    background-color: #333333;
    color: #FCC014;
    font-size: 14px;
    font-weight: 600;
    padding: 6px 12px;
    margin-bottom: 20px;
    letter-spacing: 0.5px;
    box-shadow:11px 12px 30px 3px rgba(252,192,20,0.96);
    -webkit-box-shadow:11px 12px 30px 3px rgba(252,192,20,0.96);
}

.hero-title {
    font-family: 'Larken', serif;
    font-size: 64px;
    font-weight: 400;
    margin-bottom: 30px;
    line-height: 64px;
    color: #fff;
    width: 80%;
    margin: 0 auto;
}

.hero-buttons {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-bottom: 30px;
  flex-wrap: wrap;
  padding-top: 35px;
}
.hero-buttons .btn.dark {
  background: rgba(20, 20, 20, 0.45); /* fondo translúcido */
  backdrop-filter: blur(8px);        /* DIFUMINADO REAL */
  -webkit-backdrop-filter: blur(8px); 
  border: 1px solid rgba(255, 255, 255, 0.25); /* borde suave */
  color: #fff;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: 0.25s ease;
}

/* Hover */
.hero-buttons .btn.dark:hover {
  background: rgba(255, 255, 255, 0.25);
  border-color: rgba(255, 255, 255, 0.4);
  color: #fff;
}
.btn {
     display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    padding: 13px 49px;
    border-radius: 7px;
    text-decoration: none;
    font-size: 14px;
    transition: all 0.2s 
ease;
}

.btn.yellow {
  background-color: #FCC014;
  color: #000;
}

.btn.dark {
  background-color: #2a2a2a;
  color: #fff;
  gap: 10px;
}

.btn.dark img {
  height: 24px;
}

/* Contenedor general */
.hero-details {
  display: flex;
  align-items: center;
  gap: 26px;
      margin: 74px 0 0;
  padding: 0;
  list-style: none;
  justify-content: center;
    font-family: 'Larken';
}

/* Cada elemento */
.hero-details li {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #fff;
  font-size: 18px;
  font-weight: 400;
  white-space: nowrap;
  position: relative;
  padding-right: 26px;
}

/* Iconos */
.hero-details .icon {
  font-size: 1.2rem;
  opacity: 0.9;
  display: inline-flex;
  align-items: center;
}

/* Línea vertical separadora */
.hero-details li:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 22px;
    background: #6F6F6F;
}


    /* === Tour Subnavigation === */
.tour-subnav {
  background-color: #FCC014;
  padding: 20px 0;
}

.tour-subnav .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.tour-subnav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
}

/* Estado: 2 SPOTS LEFT */
.tour-status {
    background-color: #333333;
    color: #FCC014;
    font-size: 12px;
    font-weight: 400;
    padding: 3px 11px;
    border-radius: 0;
    text-transform: uppercase;
}

/* Menú de secciones */
.tour-nav {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
}

.tour-nav a {
    font-size: 12px;
    font-weight: 500;
    color: #000;
    padding: 8px 15px;
    border: 1px solid #666666;
    border-radius: 4px;
    text-decoration: none;
    transition: background 0.2s 
ease;
    text-transform: uppercase;
}

.tour-nav a:hover {
  background-color: #000;
  color: #fff;
}

/* Botón ENQUIRE */
.enquire-button {
    background-color: #000;
    color: #fff;
    padding: 10px 55px;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    transition: background-color 0.2s 
ease;
    font-size: 12px;
}

.enquire-button:hover {
  background-color: #333;
}
.tour-intro {
  background-color: #f7f5ef;
  padding: 100px 20px;
  text-align: center;
}

.tour-intro .container {
    max-width: 944px;
    margin: 0 auto;
}

.tour-intro-location {
  font-family: 'Larken', serif;
    font-size: 48px;
    line-height: 1;
    color: #1c1c1c;
    margin: 0;
    font-weight: 100;
}

.tour-intro-text {
  font-family: 'Larken', serif;
  font-size: 48px;
  line-height: 1;
  color: #1c1c1c;
  margin: 0;
      font-weight: 200;
}
.tour-intro-location {
       font-size: 14px;
    margin-bottom: 15px;
    font-weight: 600;
    color: #595959;
    font-family: 'Inter', serif;
    letter-spacing: 1px;
}



.tour-intro-text em {
  font-style: italic;
}
.tour-highlights {
  background-color: #f7f5ef;
  padding: 40px 0;
}

.tour-highlights .container {
    max-width: 1300px;
    margin: 0 auto;
    padding: 70px 64px;
    background: #fff;
}

.tour-highlights-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  align-items: flex-start;
}

.tour-highlights-text {
  flex:1 1 46%;
}

.tour-highlights-text h2 {
    font-family: 'Larken', serif;
    font-size: 40px;
    margin-bottom: 71px;
    font-weight: 200;
    margin-top: 58px;
}

.tour-highlights-text ul {
  list-style-type: disc;
  padding-left: 20px;
  margin-bottom: 30px;
  font-size: 1rem;
  line-height: 1.6;
  color: #1c1c1c;
}

.tour-highlights-text li {
    margin-bottom: 2px;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
}

.highlight-button {
display: inline-block;
    background-color: #FCC014;
    color: #000;
    padding: 14px 38px;
    font-weight: 600;
    border-radius: 4px;
    text-decoration: none;
    transition: background-color 0.2s 
ease;
    font-size: 14px;
}

.highlight-button:hover {
  background-color: #d99e00;
}

/* Imagenes */
.tour-highlights-images {
  flex: 1 1 40%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.tour-highlights-images img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0;
}

/* Responsive */
@media (max-width: 900px) {
  .tour-highlights-inner {
    flex-direction: column;
  }
}
.tour-summary {
  background-color: #f7f5ef;
  padding: 80px 0 40px;
  font-family: 'Inter', sans-serif;
}

.tour-summary-inner {
    display: flex;
    gap: 152px;
    max-width: 1325px;
    margin: 0 auto;
    padding: 0 20px;
    flex-wrap: wrap;
}

.tour-difference {
  flex: 1 1 60%;
  background-color: #1c1c1c;
  color: #fff;
  border-top: 40px solid #d4a735;
  padding: 30px;
  position: relative;
}

.tour-difference-header {
  position: absolute;
  top: -32px;
  left: 30px;
  background-color: #d4a735;
  color: #000;
  font-weight: 700;
  font-size: 1.1rem;
  letter-spacing: 1px;
  padding: 4px 8px;
}

.tour-difference-content {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 30px;
}

.tour-difference-content ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.9rem;
}

.left-list li {
  margin-bottom: 10px;
  color: #fff;
  font-weight: 500;
  text-transform: uppercase;
}

.right-list li {
  margin-bottom: 10px;
  color: #FCC014;
  font-weight: 400;
}

.right-list strong {
  color: #fff;
}

.tour-difference-footer ul {
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 0.85rem;
}

.tour-difference-footer li {
  margin-bottom: 6px;
  color: #c0c0c0;
}

.tour-summary-text {
  flex: 1 1 35%;
}

.summary-label {
font-size: 14px !important;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: #595959 !important;
    margin-bottom: 25px !important;
    font-weight: 600 !important;
}

.tour-summary-text p {
    font-size: 16px;
    line-height: 24px;
    color: #000;
    margin-bottom: 20px;
    font-family: 'Inter';
    font-weight: 300;
}

.pdf-button {
    display: inline-block;
    background-color: #FCC014;
    color: #000;
    padding: 14px 70px;
    font-weight: 600;
    border-radius: 7px;
    text-decoration: none;
    transition: background-color 0.2s 
ease;
    margin: 30px 0;
    font-size: 14px;
}

.pdf-button:hover {
  opacity: 0.7;
}

.tour-summary-footer {
  text-align: center;
  padding-top: 10px;
  font-size: 1rem;
  font-weight: 600;
}

.tour-summary-footer .arrow {
  font-size: 1.2rem;
}
.tour-itinerary {
  background-color: #f7f5ef;
  padding: 80px 0;
}

.tour-itinerary .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    border-top: 1px solid #D1D1D1;
    padding-top: 80px;
}

/* Títulos */
.itinerary-header {
  text-align: center;
  margin-bottom: 50px;
}

.itinerary-label {
font-size: 12px;
    text-transform: uppercase;
    color: #595959;
    letter-spacing: 1px;
    margin-bottom: 10px;
    font-weight: 600;
}

.itinerary-title {
  font-family: 'Larken', serif;
    font-size: 48px;
    font-weight: 200;
}

/* Grid */
.itinerary-grid {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
}

.itinerary-map {
  flex: 1 1 45%;
}

.itinerary-map img {
width: 100%;
    height: auto;
    display: block;
    border-radius: 0;
    border: 1px solid #a4a4a4;
}

/* Días */
.itinerary-days {
      flex: 1 1 50%;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.day-entry {
  border-top: 1px solid #D1D1D1;
  padding: 0;
  overflow: hidden;
  background-color: transparent;
}

.day-entry summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
 padding: 10px 0;
  position: relative;
}

.day-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  color: #888;
  letter-spacing: 1px;
  font-weight: 500;
}

.day-title {
  font-family: 'Larken', serif;
  font-size: 1.25rem;
  font-weight: 500;
  color: #1c1c1c;
}

/* Icono flecha desplegable */
.day-entry summary::after {
  content: "⌄";
  font-size: 1rem;
  position: absolute;
  right: 0;
  top: 26px;
  color: #888;
  transition: transform 0.3s ease;
}

.day-entry[open] summary::after {
  transform: rotate(180deg);
}

.day-entry summary::-webkit-details-marker {
  display: none;
}

/* Contenido del día desplegado */
.day-content {
  padding: 0 0 30px 0;
  margin-top: -10px;
  font-size: 0.95rem;
  line-height: 1.65;
  color: #333;
  font-family: 'Larken', serif;
}

.day-content p {
  margin-bottom: 16px;
}

/* Iconos emoji básicos (pueden sustituirse por SVG más adelante) */
.day-content p::before {
  display: none;
}

.tour-extensions {
  background-color: #f7f5ef;
  padding: 80px 0;
}

.tour-extensions .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Títulos */
.extensions-header {
  text-align: center;
  margin-bottom: 50px;
}

.extensions-label {
  font-size: 0.7rem;
  text-transform: uppercase;
  color: #888;
  letter-spacing: 1px;
  font-weight: 600;
  margin-bottom: 10px;
}

.extensions-title {
  font-family: 'Larken', serif;
  font-size: 2rem;
  font-weight: 400;
}

.extensions-title em {
  font-style: italic;
}

/* Grid */
.extensions-grid {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
}

.extensions-map {
  flex: 1 1 45%;
}

.extensions-map img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 4px;
}

.extensions-days {
  flex: 1 1 50%;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Reutiliza los estilos del acordeón */
.day-entry {
      border-top: 1px solid #B5B5B5;
    overflow: hidden;
}

.day-entry summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  flex-direction: column;
    padding: 15px 0;
  position: relative;
}

.day-label {
    font-size: 12px;
    text-transform: uppercase;
    color: #595959;
    letter-spacing: 1px;
    font-weight: 400;
}

.day-title {
     font-family: 'Larken', serif;
    font-size: 24px;
    font-weight: 200;
    color: #383234;
}

.day-entry summary::after {
  content: "⌄";
  font-size: 1rem;
  position: absolute;
  right: 0;
  top: 26px;
  color: #888;
  transition: transform 0.3s ease;
}

.day-entry[open] summary::after {
  transform: rotate(180deg);
}

.day-entry summary::-webkit-details-marker {
  display: none;
}

.day-content {
  padding-bottom: 30px;
  font-size: 0.95rem;
  line-height: 1.6;
  color: #444;
  font-family: 'Larken', serif;
}

/* Responsive */
@media (max-width: 900px) {
  .extensions-grid {
    flex-direction: column;
  }
}
.tour-included {
  background-color: #f7f5ef;
  padding: 80px 0;
}

.tour-included .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.tour-included-grid {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
}

.included-left {
  flex: 1 1 30%;
}

.included-label {
font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #595959;
    font-weight: 500;
    margin-bottom: 10px;
}

.included-title {
    font-family: 'Larken', serif;
    font-size: 48px;
    font-weight: 200;
}

.included-right {
  flex: 1 1 65%;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

/* Bloques */
.included-block h3 {
font-family: 'Larken', sans-serif;
    font-size: 24px;
    font-weight: 200;
    margin-bottom: 12px;
    border-bottom: 1px solid #ddd;
    padding-bottom: 11px;
    color: #383234;
}

.included-text {
      padding-top: 35px;
}

.included-text p{
     font-size: 16px;
    font-weight: 400;
    color: #000;
    font-family: 'Inter';
}
.included-text ul li {
    font-family: 'Inter';
    font-size: 16px;
    margin-bottom: 4px;
}

.included-block ul {
  list-style: disc;
  padding-left: 20px;
  color: #333;
  font-size: 0.95rem;
  line-height: 1.6;
}

.included-block p.included-text {
  margin-bottom: 16px;
  font-size: 0.95rem;
  color: #444;
  line-height: 1.6;
}

/* Precios */
.price-line {
    margin-top: 20px;
    max-width: 482px;
}

.price-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #595959;
    font-weight: 500;
    margin-bottom: 8px;
}

.price-row {
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid #B5B5B5;
    padding: 16px 0;
    font-size: 16px;
    font-weight: 400;
}

.price-row span:last-child {
  white-space: nowrap;
}

.tour-other-dates {
  background-color: #f7f5ef;
  padding: 80px 0;
}

.other-dates-box {
    background-color: #1c1c1c;
    display: flex;
    flex-wrap: wrap;
    border-radius: 11px;
    overflow: hidden;
    padding: 40px 75px;
}

.other-dates-image {
    flex: 1 1 50%;
}

.other-dates-image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.other-dates-content {
    flex: 1 1 50%;
    padding: 50px;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 30px;
    align-items: center;
}

.other-dates-title {
    font-family: 'Larken', serif;
    font-size: 48px;
    font-weight: 200;
    margin: 0;
    color: #F2F0E8;
}

.other-dates-divider {
border: none;
    height: 1px;
    width: 79%;
    background-color: #FCC014;
    margin: 0;
    opacity: 1;
}

.other-dates-tour {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.tour-info .tour-dates {
    font-size: 12px;
    color: #fff;
    margin: 0px 0 11px;
    text-transform: uppercase;
    letter-spacing: 0;
}

.tour-info .tour-name {
    font-family: 'Larken', serif;
    font-size: 32px;
    font-weight: 200;
    margin: 0;
    color: #fff;
}

.tour-arrow {
display: inline-block;
    width: 50px;
    height: 50px;
    border: 1px solid #fff;
    border-radius: 50%;
    color: #fff;
    font-size: 30px;
    text-align: center;
    line-height: 46px;
    text-decoration: none;
    transition: background-color 0.2s 
ease;
    font-weight: 100;
}

.tour-arrow:hover {
  background-color: #fff;
  color: #000;
}

/* Botón */
.join-button {
    background-color: #FCC014;
    color: #000;
    font-weight: 600;
    text-transform: uppercase;
    padding: 15px 47px;
    text-decoration: none;
    border-radius: 7px;
    display: inline-block;
    width: fit-content;
    font-size: 14px;
    margin-top: 23px;
}

.join-button:hover {
  background-color: #dba700;
}

/* Responsive */
@media (max-width: 900px) {
  .other-dates-box {
    flex-direction: column;
  }

  .other-dates-content {
    padding: 30px 20px;
  }
}


/* TITULAR */
.np-footer-title {
    font-size: 48px;
    line-height: 52px;
    font-weight: 100;
    color: #ffffff;
}
.text-muted {
    --bs-text-opacity: 1;
    color: #BCBCBC !important;
    width: 60%;
}
/* NEWSLETTER */
.np-newsletter-form {
  width: 100%;
  max-width: 420px;
  border: 1px solid #555;
  border-radius: 4px;
  overflow: hidden;
}

.np-newsletter-input {
background: transparent;
    border: none;
    padding: 14px 24px;
    width: 100%;
    color: #fff;
    font-size: 14px;
}

.np-newsletter-input::placeholder {
  color: rgba(255,255,255,0.6);
}

.np-newsletter-btn {
  background: transparent;
  border: none;
  padding: 10px 18px;
  color: #E0A80D;
  font-size: 20px;
}

/* ICONOS */
.np-social i {
  font-size: 20px;
  color: #fff;
  transition: 0.2s;
}
.np-social:hover i {
  color: #E0A80D;
}

/* HEADINGS LISTAS */
.np-footer-heading {
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  margin-bottom: 20px;
}

/* LISTAS */
.np-footer-list {
  list-style: none;
  padding: 0;
  margin: 0 0 22px 0;
}
.np-footer-list li {
  margin-bottom: 10px;
}
.np-footer-list a {
  color: #fff;
  text-decoration: none;
  font-size: 15px;
  transition: 0.2s;
}
.np-footer-list a:hover {
  color: #E0A80D;
}

/* CONTACT */
.np-contact-text {
  color: #fff;
  line-height: 1.6;
  font-size: 15px;
}
.np-contact-text a {
  color: #fff;
}
.np-contact-text a:hover {
  color: #E0A80D;
}

/* DIVISORES */
.np-footer-divider {
  border-color: rgba(255,255,255,0.1) !important;
  margin: 14px 0;
}
.np-footer-bottom-divider {
    border-color: #BCBCBC !important;
}

.np-footer-notice {
     color: #242421;
}
.np-footer .text-center.small {
    color: #969696 !important;
    width: 100%;
    font-size: 14px;
    line-height: 18px;
    font-weight: 300;
    padding: 0 200px;
    margin-bottom: 60px;
}
.np-footer a {
   color:#969696 !important;
}
/* Encabezados */
.np-footer-heading {
    font-size: 12px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #F2F0E8;
    margin-bottom: 18px;
    font-family: 'Inter';
}

/* Listas */
.np-footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.np-footer-list li {
  margin-bottom: 0;
}

.np-footer-list a {
  color: #F2F0E8 !important;
  text-decoration: none;
     font-size: 14px;
         font-weight: 300;
  transition: 0.2s ease;
}

.np-footer-list a:hover {
  color: #E0A80D;
}

/* Divider fino */
.np-footer-divider {
  border-top: 1px solid rgba(255,255,255,0.2);
  margin: 18px 0;
}

/* CONTACT */
.np-contact-text {
  color: #ffffff;
  font-size: 15px;
  line-height: 1.6;
}

.np-contact-text a {
     color: #F2F0E8 !important;
    text-decoration: none;
    font-size: 14px;
}

.np-contact-text a:hover {
  color: #E0A80D;
}
/* ===== AWARDS GRID FINAL ===== */

.np-awards-grid{
  --stagger-x: 90px;      /* desplazamiento fila inferior */
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: 140px;
  row-gap: 60px;
  justify-items: center;
  padding-right: var(--stagger-x);
      margin-top: 56px;
    margin-bottom: 75px;
}

/* Bloque premio */
.np-award{
  position: relative;
  width: 260px;          /* ancho real del conjunto */
  height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

/* Laurel izquierdo */
.np-award::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 70px;
  height: 90px;
             
  opacity: .55;
}

/* Laurel derecho (espejado) */
.np-award::after{
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 70px;
  height: 90px;
  transform: scaleX(-1);
  opacity: .55;
}

/* Texto dentro de los laureles */
.np-award span{
  max-width: 150px;
  font-size: 10px;
  line-height: 1.9;
  letter-spacing: 0;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}

/* Desplazamiento SOLO segunda fila */
.np-awards-grid .np-award:nth-child(n+5){
  transform: translateX(var(--stagger-x));
}

/* Responsive: sin escalonado */
@media (max-width: 991px){
  .np-awards-grid{
    grid-template-columns: repeat(2, 1fr);
    column-gap: 70px;
    padding-right: 0;
  }
  .np-awards-grid .np-award:nth-child(n+5){
    transform: none;
  }
}

@media (max-width: 575px){
  .np-awards-grid{
    grid-template-columns: 1fr;
  }
}
.np-award::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
     width: 257px;
  background: var(--laurel) no-repeat center / contain;
  opacity: .55;
}

/* Fila 1 (1–4): sin desplazamiento */
.np-award:nth-child(-n+4){
  transform: translateX(0);
}

/* Fila 2 (5–8): un poco a la izquierda */
.np-award:nth-child(n+5):nth-child(-n+8){
  transform: translateX(-60px);
}

/* Fila 3 (9–12): más a la izquierda (por si crece) */
.np-award:nth-child(n+9):nth-child(-n+12){
  transform: translateX(-120px);
}

/* Fila 4 (13–16): aún más */
.np-award:nth-child(n+13):nth-child(-n+16){
  transform: translateX(-180px);
}

.np-awards-title {
    color: var(--np-wh);
    font-size: 24px;
    font-weight: 100;
}

.border-yellow {
      border-color: #FCC014;
    font-size: 14px;
    font-weight: 700;
    padding: 15px 50px;
    width: 250px;
}

#about h2 p {
      font-size: 48px;
    font-weight: 100;
    line-height: 52px;
}

#tours h2 {
      font-size: 48px;
    font-weight: 100;
    font-family: 'Larken';
}
#tours .mb-5 {
margin-bottom: 59px !important;
}

#tours .gx-5 .mb-4{
 padding-right: 19px;
    padding-left: 19px;
}

#tours figure {
  margin-bottom: 1.5rem !important;
}

#tours {
      padding-bottom: 5rem;
}


/* HERO */
.destination-hero {
    position: relative;
    height: 80vh;
    min-height: 600px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    text-align: center;
    padding-bottom: 50px;
}

.destination-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}

.destination-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
}

.destination-hero-content {
    position: relative;
    z-index: 2;
    color: #fff;
}

.destination-hero-title {
       font-size: 64px;
    font-weight: 100;
    color: #fff;
}

/* INTRO */
.destination-intro {
    padding: 60px 0 40px;
    text-align: center;
}

.destination-intro-text {
       max-width: 80%;
    margin: 0 auto;
    font-size: 24px;
    line-height: 28px;
    color: #555;
    font-family: 'Larken';
    font-weight: 100;
}

/* TOURS LIST */
.tour-row {
     display: grid;
    grid-template-columns: 627px 1fr;
    gap: 40px;
    padding: 5px 5px;
    border: 1px solid #BCBCBC;
    align-items: center;
    margin-top: 38px;
}

.tour-row-image {
    position: relative;
}

.tour-row-image img {
    width: 100%;
    display: block;
}

.tour-row-label {
      position: absolute;
    top: 28px;
    left: 28px;
}

.tour-row-date {
    font-size: 12px;
    text-transform: uppercase;
    color: #242421;
    margin-bottom: 10px;
    font-family: 'Inter';
    font-weight: 100;
}

.tour-row-title {
    font-size: 1.8rem;
    font-weight: 500;
    margin-bottom: 15px;
}

.tour-row-title a {
color: #242421;
    text-decoration: none;
    font-size: 36px;
    font-weight: 100;
    line-height: 32px;
}

.tour-row-excerpt {
       font-size: 18px;
    line-height: 26px;
    color: #343432;
    max-width: 650px;
    margin-bottom: 25px;
    font-weight: 200;
    margin-top: 37px;
}

.tour-row-button {
    display: inline-block;
    background: #FCC014;
    color: #000;
    padding: 15px 70px;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    border-radius: 7px;
}

.tour-row-button:hover {
  opacity: 0.7;
}

@media (max-width: 900px) {
    .tour-row {
        grid-template-columns: 1fr;
    }
}

.tour-row-meta {
   display: flex;
    gap: 64px;
    align-items: center;
    margin: 28px 0 32px;
    font-size: 0.95rem;
    color: #242421;
}

.tour-row-meta-item {
    display: flex;
    align-items: center;
    gap: 16px;
}

.tour-row-icon {
    font-size: 1rem;
    opacity: 0.85;
}

.tour-row-meta-text {
       font-weight: 300;
    font-family: 'Larken';
    font-size: 18px;
    line-height: 32px;
    color: #242421;
}

/* BLOG PAGE BASE */
.blog-page {
    padding: 80px 0;
     background: #F2F0E8;;
}

/* POST DESTACADO */
.blog-featured {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    margin-bottom: 100px;
}

.blog-featured-image img {
    width: 100%;
    display: block;
}

.blog-featured-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.blog-date {
    font-size: 0.75rem;
    letter-spacing: 1px;
    margin-bottom: 15px;
    display: inline-block;
}
.blog-featured-date {
    font-size: 0.75rem;
    letter-spacing: 1px;
    margin-bottom: 15px;
    display: inline-block;
}
.blog-featured-title {
    font-size: 2rem;
    line-height: 1.3;
    margin-bottom: 15px;
}

.blog-author {
    font-size: 0.7rem;
    letter-spacing: 1px;
    margin-bottom: 33px;
}

.blog-featured-excerpt {
    font-size: 0.95rem;
    line-height: 1.7;
    margin-bottom: 30px;
}

.blog-read-more {
      border: 1px solid #727272;
    padding: 12px 39px;
    width: fit-content;
    text-decoration: none;
    font-size: 14px;
    letter-spacing: 0;
    border-radius: 7px;
    color: #000;
    font-family: 'Inter';
    font-weight: 700;
}

/* GRID EDITORIAL */
.blog-editorial-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 50px 33px;
}

.blog-editorial-image img {
    width: 100%;
    display: block;
    margin-bottom: 20px;
}

.blog-editorial-title {
    font-size: 1.1rem;
    line-height: 1.4;
}

/* RESPONSIVE */
@media (max-width: 900px) {
    .blog-featured {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .blog-editorial-grid {
        grid-template-columns: 1fr;
    }
}
.blog-hero {
    position: relative;
    height: 746px;
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;   /* 🔥 CENTRADO HORIZONTAL */
    overflow: hidden;
    padding-bottom: 100px;
}


.blog-hero-bg {
    position: absolute;
    inset: 0;
    background-size: contain;
    background-position: center;
}

.blog-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
}
.blog-hero-content {
    position: relative;
    z-index: 2;
    color: #fff;
    max-width: 900px;
    text-align: center;        /* 🔥 TEXTO CENTRADO */
}


.blog-hero-eyebrow {
    display: block;
    font-size: 20px;
    letter-spacing: 2px;
    margin-bottom: 13px;
    opacity: 1;
    font-family: 'Larken';
    font-weight: 100;
}


.blog-hero-title {
     font-size: 64px;
    font-weight: 100;
    line-height: 64px;
    color: #fff;
}

.blog-editorial-title a {
      font-family: 'Larken';
    text-decoration: none;
    color: #000;
    font-size: 32px;
    font-weight: 100
}

.blog-featured-image img {
    width: 100%;
    height: 514px;
    object-fit: cover;        /* 🔥 recorte correcto */
    object-position: center; /* 🔥 desde el centro */
    display: block;
}
.blog-editorial-image img {
    width: 100%;
    height: 449px;
    object-fit: cover;
    object-position: center;
    display: block;
}

.blog-featured {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 130px;
    margin-bottom: 100px;
}

.blog-featured-image {
    margin-left: -70px;
    margin-right: -25px;
}

.blog-featured-image img {
    width: 100%;
    height: 514px;
    object-fit: cover;
    object-position: center;
    display: block;
}
@media (max-width: 900px) {
    .blog-featured-image {
        margin-left: 0;
        margin-right: 0;
    }
}

.blog-date {
 display: inline-flex;
    align-items: center;
    color: #000;
    font-family: 'Inter';
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 0;
}

.blog-date::before {
    content: "";
    display: inline-block;
    width: 19px;          /* 🔥 longitud de la línea */
    height: 1px;          /* 🔥 grosor */
    background: currentColor;
    margin-right: 10px;   /* 🔥 separación línea-texto */
    transform: translateY(-1px); /* ajuste óptico fino */
}

.blog-author {
   margin-top: 16px;
    font-size: 12px;
    letter-spacing: 0;
    text-transform: uppercase;
    color: #000;
}

.blog-featured-title a{
      font-family: 'Larken';
    font-weight: 100;
    text-decoration: none;
    color: #000;
    font-size: 40px;
    line-height: 44px;

}


.blog-featured-date {
     display: inline-flex;
    align-items: center;
    width: auto;
    max-width: fit-content;
    background: #f2b705;
    color: #000;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    padding: 6px 15px;
    border-radius: 6px;
    margin-bottom: 18px;
    letter-spacing: 0;
}

.blog-author {
    margin-top: 6px;
    font-size: 0.7rem;
    text-transform: uppercase;
    color: #000;
    opacity: 0.85;
}


.blog-separator {
    width: 100vw;                     /* 🔥 ancho completo */
    height: 1px;
    background: #d8d8d8;              /* gris suave */
    margin: 91px 0;
    margin-left: calc(-50vw + 50%);   /* 🔥 rompe el container */
}


.blog-separator-bottom {
    width: 100vw;                     /* 🔥 ancho completo */
    height: 1px;
    background: #d8d8d8;              /* gris suave */
    margin: 0 0;
    margin-left: calc(-50vw + 50%);   /* 🔥 rompe el container */
    margin-top: 80px;
}



.blog .mt-5 {
     margin-top: 0rem !important;
}

.blog-load-more-wrapper {
    text-align: center;
    margin: 80px 0 0;
}

#blog-load-more {
      background: transparent;
    border: 1px solid #000;
    padding: 17px 71px;
    font-size: 14px;
    letter-spacing: 1px;
    cursor: pointer;
    font-weight: 600;
    border-radius: 7px;
}

#blog-load-more:hover {
      background: #000;
    color:#fff;
     transition: opacity 0.4s ease, transform 0.4s ease;
}
/* Estado inicial al insertar */
.blog-editorial-item.is-loading {
    opacity: 0;
    transform: translateY(30px);
}

/* Estado final */
.blog-editorial-item.is-visible {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

/* =========================
   SINGLE POST HERO
========================= */
.single-post-hero {
    position: relative;
    overflow: hidden;
}

.single-post-hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.single-post-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
}

.single-post-hero-content {
    position: absolute;
    inset: 0;
    z-index: 2;
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.single-post-title {
    font-size: clamp(2.5rem, 4vw, 3.5rem);
    max-width: 800px;
    line-height: 1.2;
    margin: 20px 0;
}
.tour-card-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.tour-card-link:hover {
  text-decoration: none;
}

/* =========================
   CONTENT
========================= */
.single-post-content {
    background: #F2F0E8;
    padding: 80px 0;
}

.single-post-entry {
    font-size: 1rem;
    line-height: 1.8;
}

.single-post-entry img {
    width: 100%;
    margin: 40px 0;
}

/* =========================
   SIDEBAR
========================= */
.single-post-sidebar .sidebar-box {
    margin-bottom: 40px;
}

.sidebar-box.highlight {
    background: #f2b705;
    padding: 30px;
}

.btn-cta {
      display: inline-block;
    background: #FCC014;
    color: #000;
    padding: 13px 50px;
    text-transform: uppercase;
    font-size: 14px;
    letter-spacing: 2px;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: 0;
    font-family: 'Inter';
    border-radius: 7px;
    margin-top: 32px;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 991px) {
    .single-post-hero {
        height: 400px;
    }

    .single-post-sidebar {
        margin-top: 60px;
    }
}
/* =========================
   SINGLE POST HERO
========================= */

.single-post-hero {
    width: 100%;
}

/* BLOQUE SUPERIOR OSCURO */
.single-post-hero-header {
background: #242421;
    padding: 187px 0 50px;
    color: #F2F0E8;
    margin-bottom: 0;
}

.single-post-title {
    font-size: 48px;
    line-height: 1.2;
    max-width: 900px;
    margin: 0 auto 24px;
    color: #F2F0E8;
    font-weight: 100;
    letter-spacing: 0;
    line-height: 48px;
}

.single-post-hero-image {
    margin: 0;
    padding: 0;
}


.single-post-meta {
     display: flex;
    justify-content: center;
    gap: 141px;
    margin-top: 43px;
    font-size: 16px;
    color: #F2F0E8;
    font-weight: 200;
}

.single-post-meta span {
display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 16px;
}

.meta-icon {
  width: 17px;
  height: auto;
  opacity: 0.9;
}


/* IMAGEN */
.single-post-hero-image img {
    display: block;      /* 🔴 elimina espacio inline */
    width: 100%;
    height: 654px;
    object-fit: cover;
    margin: 0;
    padding: 0;
}


.single-post-hero-image img {
    /*filter: grayscale(100%);*/
}

/* =========================
   POST EXCERPT (INTRO)
========================= */
.single-post-excerpt {
    font-size: 40px;
    line-height: 44px;
    color: #212121;
    margin-bottom: 40px;
    max-width: 680px;
    font-weight: 100;
    font-family: 'Larken';
    letter-spacing: 0;
}
.single-post-entry h3 {
    font-family: 'Larken', sans-serif;
    font-weight: 100;
    font-size: 24px;
    color: #212121;
    margin-top: 35px;
}

.single-post-entry p, .single-post-entry ul li {
    font-family: 'Libre Franklin', 'Larken';
    font-weight: 400;
    font-size: 16px;
    line-height: 28px;
    color: #212121;
}
  
/* === DISCOVER CAROUSEL FIX === */

.discover-row {
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
}

.discover-card {
    flex: 0 0 auto;        /* 🔴 CLAVE */
    width: 320px;          /* o el ancho exacto que uses en viajes */
}

/* ===============================
   DISCOVER CAROUSEL – FIX REAL
=============================== */

.discover-full-right {
    overflow:hidden;
}

.discover-row {
    display: flex;
    flex-wrap: nowrap;
    width: fit-content;       /* 🔴 CLAVE */
    min-width: 100%;          /* 🔴 CLAVE */
    overflow-x: auto;
    overflow-y: hidden;
}

.discover-card {
    flex: 0 0 auto;           /* 🔴 CLAVE */
    width: 414px;             /* ajusta a tu diseño */
}

/* =========================
   ABOUT HERO
========================= */

.about-hero {
    position: relative;
    width: 100%;
    height: 746px; /* ajustable */
    overflow: hidden;
}

/* Imagen */
.about-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* Overlay suave (como en la imagen) */
.about-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        rgba(0,0,0,0.35),
        rgba(0,0,0,0.35)
    );
}

/* Texto centrado */
.about-hero-content {
        position: relative;
    z-index: 2;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    color: #fff;
    text-align: center;
    padding-bottom: 95px;
}

/* About */
.about-hero-subtitle {
    font-size: 20px;
    margin-bottom: 10px;
    font-family: 'Larken';
}

/* Harry Fisch */
.about-hero-title {
       font-size: 64px;
    font-weight: 200;
    line-height: 64px;
    color: #fff;
}
/* =========================
   ABOUT – TEXT BLOCK
========================= */

.about-text-section {
    padding: 72px 0;
}

.about-text-content {
    max-width: 842px;       /* clave: ancho de lectura */
    margin: 0 auto;
    font-size: 0.95rem;
    line-height: 1.8;
    color: #111;
}

/* Espaciado entre párrafos */
.about-text-content p {
       margin-bottom: 1.6em;
    font-size: 16px;
    line-height: 24px;
    font-family: 'Inter';
    font-weight: 300;
}

/* Últimos bloques en negrita (galerías, contacto) */
.about-text-content strong {
    font-weight: 600;
}

/* =========================
   ABOUT – AWARDS
========================= */

.about-awards {
    padding: 0 0;
}

.about-awards-title {
    text-align: center;
    font-size: 24px;
    font-weight: 200;
    margin-bottom: 80px;
}

/* Grid */
.about-awards-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 70px 40px;
    justify-items: center;
}

/* Award item */
.award-item {
    text-align: center;
    max-width: 180px;
}

/* Icono */
.award-icon {
    position: relative;
    width: 191px;
    margin: 0 auto;
}

.award-icon img {
    width: 100%;
    height: auto;
    display: block;
    opacity: 0.9;
}

/* Texto dentro del laurel */
.award-text {
       position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 0 16px;
    font-size: 0.55rem;
    line-height: 1.3;
    text-transform: uppercase;
    color: #333;
}

/* Año */
.award-year {
    font-weight: 600;
    margin-bottom: 4px;
}

/* Texto */
.award-description {
    font-weight: 400;
    font-size: 11px;
}

/* Responsive */
@media (max-width: 1200px) {
    .about-awards-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 992px) {
    .about-awards-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 60px 30px;
    }
}

@media (max-width: 576px) {
    .about-awards-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* =========================
   ABOUT – FULL AWARDS LIST
========================= */

.about-full-awards {

    padding: 120px 0;
      padding-bottom: 0;
}

.about-full-awards-title {
    text-align: center;
    font-size: 1.6rem;
    font-weight: 200;
    margin-bottom: 39px;
}

/* Lista */
.about-full-awards-list {
  max-width: 473px;
    margin: 0 auto;
}

/* Fila por año */
.full-award-row {
      display: grid;
    grid-template-columns: 40px 1fr;
    column-gap: 40px;
    margin-bottom: 30px;
}

/* Año */
.full-award-year {
  font-weight: 700;
    font-size: 16px;
    font-family: 'Inter';
    letter-spacing: 0;
}

/* Awards */
.full-award-items p {
      margin-bottom: 0.3rem;
    font-size: 14px;
    line-height: 24px;
    font-weight: 200;
}

/* Responsive */
@media (max-width: 576px) {
    .full-award-row {
        grid-template-columns: 1fr;
        row-gap: 10px;
    }

    .full-award-year {
        font-weight: 700;
    }
}

/* =========================
   ABOUT – FULL WIDTH GALLERY
========================= */

.about-gallery-full {
    background: #F2F0E8;
    padding: 80px 0;
}

/* Grid */
.about-gallery-grid {
      display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 5px;
    width: 100%;
    max-width: none;
    padding: 0 24px;
}

/* Item */
.about-gallery-item {
    margin: 0;
    overflow: hidden;
}

/* Imagen */
.about-gallery-item img {
    width: 100%;
    height: 100%;
    aspect-ratio: 4 / 3;     /* look editorial como en la captura */
    object-fit: cover;
    display: block;
}

/* Responsive */
@media (max-width: 992px) {
    .about-gallery-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
}

@media (max-width: 576px) {
    .about-gallery-grid {
        grid-template-columns: 1fr;
        padding: 0 16px;
    }
}


.page-id-6931 .np-contact {
  padding-top: 50px;
  padding-bottom: 92px;
}

/* HARRY FISCH mega menu */
.nav-item.mega-harry-fisch {
  position: relative;
}

@media (min-width: 992px) {
  .nav-item.mega-harry-fisch:hover .photo-tours-dropdown,
  .nav-item.mega-harry-fisch .photo-tours-dropdown:hover {
    display: block !important;
  }
}
.tour-subnav {
  position: relative;
  transition: box-shadow 0.2s ease;
}

/* Estado sticky */
.tour-subnav.is-sticky {
  position: fixed;
  top: var(--header-height);
  left: 0;
  width: 100%;
  z-index: 999;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.tour-subnav-spacer {
  height: 0;
}

.tour-subnav.is-sticky + .tour-subnav-spacer {
  height: var(--tour-subnav-height);
}
#site-header {
  transition: background 0.25s ease;
}

#site-header.is-scrolled {
  background: linear-gradient(
    180deg,
    rgba(0,0,0,0.75) 0%,
    rgba(0,0,0,0.5) 100%
  );
}

.tour-subnav.is-sticky {
  position: fixed;
  top: var(--header-height);
  left: 0;
  right: 0;
  z-index: 998;
}
.nav-link:focus-visible{
  box-shadow: none;
}

.tours-filters.is-sticky {
  position: fixed;
  top: var(--header-height);
  left: 0;
  right: 0;
  z-index: 997;
  background: #1f1f1f; /* el negro/gris que ya usas */
}

/* Para evitar que el contenido “salte” */
body.has-sticky-filters {
  padding-top: var(--filters-height);
}
/* Estado base */
.tour-card-hero {
  transition:
    opacity 0.35s ease,
    transform 0.35s ease;
}

/* Oculto */
.tour-card-hero.is-hidden {
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
}

/* Para evitar huecos visuales */
.tour-card-hero.is-hidden {
  position: absolute;
  visibility: hidden;
}
.tours-grid.is-single {
  display: flex !important;
  justify-content: center;
}

.tours-grid.is-single .tour-card-hero {
  position: relative;
}
.newsletter-form {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}

.newsletter-form input {
  flex: 1;
  padding: 10px 14px;
  border-radius: 20px;
  border: 1px solid #ccc;
}

.newsletter-form button {
  width: 42px;
  border-radius: 50%;
  border: none;
  background: #2d2f4a;
  color: #fff;
  font-size: 18px;
  cursor: pointer;
}

.newsletter-success {
  margin-top: 10px;
  font-size: 14px;
  color: #2f7a3d;
}

.newsletter-message {
  margin-top: 10px;
  font-size: 14px;
}

.newsletter-message.success {
  color: #2f7a3d;
}

.newsletter-message.error {
  color: #b23b3b;
}

/* Página Contact */
.contact-page.contact-dark .np-contact {
  background: #1f1f1c;
  color: #F2F0E8;
      padding-bottom: 100px;
}
.contact-page.contact-dark .mt-5{
  margin-top: 0!important;
}
/* Títulos */
.contact-page.contact-dark h1,
.contact-page.contact-dark h2,
.contact-page.contact-dark h3,
.contact-page.contact-dark h4,
.contact-page.contact-dark h5 {
  color: #F2F0E8;
}

/* Texto */
.contact-page.contact-dark p,
.contact-page.contact-dark li,
.contact-page.contact-dark label {
    color: #F2F0E8;
    font-size: 14px;
    line-height: 28px;
    font-weight: 300;
}

/* Inputs */
.contact-page.contact-dark .np-input,
.contact-page.contact-dark select,
.contact-page.contact-dark textarea {
  background: transparent;
  border: 1px solid #CFCFCF;
  color: #fff;
}

.contact-page.contact-dark .np-input::placeholder {
  color: #fff;
  font-weight: 300;
}

/* Divider vertical */
.contact-page.contact-dark .np-divider-vertical {
  background: #767676;
}

.np-contact-info li {
  font-size: 15px;
  line-height: 1.6;
}

.np-contact-icon {
  display: inline-flex;
  width: 18px;
  min-width: 18px;
  margin-top: 2px;
}

.np-contact-icon img {
  width: 18px;
  height: auto;
  display: block;
}
/* === CUSTOM CHECKBOXES === */

.np-checkbox-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: 42px !important;
    padding-left: 13px;
}

.np-checkbox {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: #d0d0d0;
  cursor: pointer;
}

.np-checkbox input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.np-checkbox .checkmark {
width: 13px;
    height: 13px;
    border: 1px solid #C8C8C8;
    display: inline-block;
    position: relative;
    transition: all 0.2s 
ease;
}

.np-checkbox input:checked + .checkmark {
  background: #f5c400;
  border-color: #f5c400;
}

.np-checkbox input:checked + .checkmark::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 5px;
  height: 9px;
  border: solid #000;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
/* === YELLOW CTA BUTTON === */

.np-btn-yellow {
  background: #f5c400;
  color: #000;
  font-weight: 700;
  text-transform: uppercase;
  padding: 12px 36px;
  border-radius: 6px;
  border: none;
  transition: all 0.25s ease;
}

.np-btn-yellow:hover {
  background: #ffd633;
  color: #000;
}

.contact-hero-header {
  padding: 120px 0 80px;
}

.contact-hero-eyebrow {
    display: block;
    margin-bottom: 9px;
    font-size: 24px;
    color: #fff;
    font-family: 'Larken';
    font-weight: 200;
}

.contact-hero-title {
    font-family: 'Larken';
    font-size: 48px;
    font-weight: 200;
    color: #fff;
    margin: 0;
    margin-bottom: 100px;
}

.page-id-6939 #site-header {
  border-bottom: 1px solid #4B4B4B;
}

.contact-page .np-btn-yellow {
    background: #FCC014;
    color: #000;
    font-weight: 700;
    text-transform: uppercase;
    padding: 16px 78px;
    border-radius: 7px;
    border: none;
    transition: all 0.25s 
ease;
    font-size: 14px;
    margin-top: 28px;
}

.contact-page.contact-dark h5 {
    color: #F2F0E8;
    margin-bottom: 40px !important;
}
#site-header .nav-link.is-active {
  color: #FCC014;
}
.tour-gallery-badge {
  position: absolute;
    right: 76px;
    top: 300px;
  width: 199px;
  height: 199px;
  border-radius: 50%;
  border: 2px solid #FCC014;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  text-decoration: none;
  color: #fff;
  z-index: 50;
}

.tour-gallery-badge img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  z-index: 0;
}

.tour-gallery-badge span {
  position: relative;
  z-index: 1;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1px;
}


#site-header .col-4.text-center{
  padding-top: 6px;
}
.home #hero a {
padding :13px 29px;
}

.home #hero a:hover {
       background: #FCC014;
      opacity: 0.7;
}

h2.np-footer-title {
  margin-top: 4rem;
  margin-bottom: 3rem !important;
}

.pt-left-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
}
.pt-arrow{
    width: 6px;
    height: 10px;
    background: #E0A80D;
    clip-path: polygon(0 0, 0 100%, 100% 50%);
    flex-shrink: 0;
    transform: translateY(0px);
}


.pt-country-link.fw-bold {
  color: #F8F3EA;
}

.single-post-sidebar {
  padding-left: 40px;
}

.single-post .sidebar-box {
  margin-bottom: 80px;
}

.sidebar-box h4 {
     font-family: 'Larken';
    font-size: 24px;
    font-weight: 200;
    margin-bottom: 20px;
    color: #2B2D42;
}
.newsletter-box h4 {
    font-size: 24px;
    line-height: 32px;
    margin-bottom: 23px;
    font-family: 'Larken';
    font-weight: 200;
    color: #2B2D42;
}

.newsletter-form {
  display: flex;
  align-items: center;
  gap: 12px;
}

.newsletter-form input {
  flex: 1;
  height: 46px;
  padding: 0 18px;
  border-radius: 30px;
  border: 1px solid #2c2c2c;
  background: transparent;
  font-size: 14px;
}

.newsletter-form input::placeholder {
  color: #6f6f6f;
}

.newsletter-form button {
      width: 87px;
    height: 46px;
    border-radius: 40%;
    border: none;
    background: #2b2e45;
    color: #fff;
    font-size: 20px;
    cursor: pointer;
    transition: background .2s 
ease;
    padding: 25px 18px;
}
.newsletter-btn {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: none;
  background: #2b2e45;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.newsletter-btn img {
  width: 32px;
  height: auto;
  display: block;
}


.newsletter-form button:hover {
  background: #1e2035;
}
.sidebar-share {
  display: flex;
  gap: 14px;
}

.sidebar-share a {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1c1c1c;
  text-decoration: none;
  font-size: 18px;
}
.about-author p {
 font-size: 14px;
    line-height: 24px;
    color: #000;
    font-family: 'Inter';
    font-weight: 200;
}
.sidebar-cta {
  margin-top: 60px;
}

.sidebar-cta .btn-cta {
display: inline-block;
    background: #FCC014;
    color: #000;
    padding: 14px 43px;
    font-size: 14px;
    /* letter-spacing: 1px; */
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 7px;
    text-decoration: none;
        margin-top: 0;
    font-family: 'Inter';
}
.about-harry-text {
  font-size: 14px;
  line-height: 1.7;
  color: #4b4b4b;
}

.about-harry-text p {
  margin-bottom: 14px;
}

.about-harry-text a {
  color: #1c1c1c;
  text-decoration: underline;
}

.sidebar-share {
  display: flex;
  gap: 33px;
  align-items: center;
}

.share-icon {
  display: inline-flex;
  width: 28px;
  height: 28px;
  align-items: center;
  justify-content: center;
}

.share-icon img {
    width: 23px;
    height: auto;
    display: block;
      opacity: 0.9;
    transition: opacity .2s 
ease;
}

.share-icon:hover img {
  opacity: 1;
}

.single-post-sidebar {
  position: relative;
  padding-left: 48px;
}

.single-post-sidebar::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  bottom: 10px;
  width: 1px;
  background: #D1D1D1;
}

.single-post-content .col-lg-8  {
  padding-right: 50px;
}

.single-post #site-header {
  border-bottom: 1px solid #4B4B4B;
}


.tour-card-image {
  position: relative;
}

.tour-card-full-link {
  position: absolute;
  inset: 0;
  z-index: 5;
  text-indent: -9999px;
}
.tour-card-info {
  position: relative;
  z-index: 6;
}
.featured-tour-card {
  position: relative;
}

.featured-tour-link {
  position: absolute;
  inset: 0;
  z-index: 5;
  text-indent: -9999px;
}

.post-6947, .post-6950 , .post-6954 , .post-6958, .post-6960, .page-id-6976 {
      padding-top: 141px;
}

.post-6947 p, .post-6950 p , .post-6954  p, .post-6958 p, .post-6960 p,.page-id--6976 p{
        font-family: 'Inter';
    font-size: 14px;
    line-height: 24px;
}
.np-reviews-page {
  padding: 80px 0;
}

.review-card {
  background: #f7f7f7;
  padding: 50px 60px;
  position: relative;
  height: 100%;
}

.review-title {
 font-size: 24px;
    line-height: 24px;
    color: #3f3f3f;
    font-family: 'larken';
    font-weight: 300;
    margin-bottom: 25px;
}

.review-text {
    font-size: 14px;
    line-height: 24px;
    color: #3f3f3f;
    font-family: 'Inter';
}

.review-quote {
  position: absolute;
  font-size: 60px;
  color: #3f3f3f;
  font-family: serif;
  line-height: 1;
}

.review-quote-start {
  top: 25px;
  left: 25px;
}

.review-quote-end {
  bottom: 25px;
  right: 25px;
}

.review-footer {
  text-align: center;
  margin-top: 40px;
}

.review-name {
font-weight: 600;
    margin-bottom: 5px;
    color: #595959;
    letter-spacing: 1px !important;
    text-transform: uppercase;
    font-size: 12px;
}

.review-country {
  font-size: 13px;
  color: #595959;
  margin-bottom: 10px;
}

.review-stars {
  color: #f4b400;
  font-size: 23px;
}
.discover-link {
  text-decoration: none;
  color: inherit;
  display: block;
}

.discover-link:hover {
  text-decoration: none;
}
.discover-row {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
}

.discover-card {
  flex: 0 0 360px;
  max-width: 360px;
}
