/* ================================================================
   DURRES.PL — MAIN STYLESHEET
   Stack: Vanilla HTML/CSS/JS · Font: Poppins · Accent: #2D6A8F
   ================================================================ */

/* ── 1. TOKENS ── */
:root {
  --white:       #ffffff;
  --off-white:   #F8F8F6;
  --black:       #111111;
  --gray:        #6B7280;
  --gray-light:  #E5E7EB;
  --gray-mid:    #9CA3AF;
  --blue:        #2D6A8F;
  --blue-d:      #1E4D6B;
  --blue-l:      #4A8DB5;
  --blue-ghost:  rgba(45,106,143,.10);
  --gold:        #E8C98A;
  --gold-d:      #C9A85C;
  --footer-bg:   #0F1923;

  --font:        'Poppins', sans-serif;
  --nav-h:       72px;
  --r-sm:        4px;
  --r-md:        8px;
  --r-lg:        12px;
  --r-xl:        18px;
  --r-full:      9999px;

  --sh-sm:  0 1px 3px rgba(0,0,0,.07);
  --sh-md:  0 4px 18px rgba(0,0,0,.10);
  --sh-lg:  0 8px 32px rgba(0,0,0,.13);
  --sh-xl:  0 16px 48px rgba(0,0,0,.16);

  --ease:   350ms ease;
  --ease-f: 200ms ease;
  --ease-s: 600ms ease;

  --max-w:  1200px;
  --px:     1.5rem;
}

/* ── 2. RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--font); color:var(--black); background:var(--white); line-height:1.6; overflow-x:hidden; }
img  { max-width:100%; height:auto; display:block; }
a    { color:inherit; text-decoration:none; }
ul   { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

/* ── 3. BASE TYPOGRAPHY ── */
h1 { font-size:clamp(2.25rem,5.5vw,4.5rem); font-weight:700; line-height:1.1; }
h2 { font-size:clamp(1.75rem,3.5vw,2.75rem); font-weight:700; line-height:1.2; }
h3 { font-size:clamp(1.1rem,2vw,1.5rem);     font-weight:700; line-height:1.3; }

/* ── 4. LAYOUT HELPERS ── */
.container { max-width:var(--max-w); margin:0 auto; padding:0 var(--px); }
.section   { padding:5rem 0; }
.section--alt { background:var(--off-white); }

.section__header { text-align:center; margin-bottom:4rem; }
.section__tag {
  display:inline-block;
  font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.12em;
  color:var(--blue); background:var(--blue-ghost);
  padding:.3em 1em; border-radius:var(--r-full); margin-bottom:1rem;
}
.section__title  { margin-bottom:.75rem; }
.section__subtitle { font-size:1.1rem; color:var(--gray); max-width:580px; margin:0 auto; }

/* ── 5. BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--font); font-size:.875rem; font-weight:600;
  padding:.75em 1.7em; border-radius:var(--r-full);
  border:2px solid transparent; transition:all var(--ease-f); cursor:pointer;
}
.btn--primary { background:var(--blue); color:var(--white); border-color:var(--blue); }
.btn--primary:hover { background:var(--blue-d); border-color:var(--blue-d); transform:translateY(-1px); box-shadow:var(--sh-md); }
.btn--outline { background:transparent; color:var(--blue); border-color:var(--blue); }
.btn--outline:hover { background:var(--blue); color:var(--white); }
.btn--white { background:var(--white); color:var(--blue); border-color:var(--white); }
.btn--white:hover { background:transparent; color:var(--white); }
.btn--dark { background:var(--black); color:var(--white); border-color:var(--black); }
.btn--dark:hover { background:#333; border-color:#333; }
.btn__arr { display:inline-block; transition:transform var(--ease-f); }
.btn:hover .btn__arr { transform:translateX(4px); }

.btn--nav {
  font-size:.82rem; font-weight:600; padding:.55em 1.3em;
  background:var(--blue); color:var(--white) !important; border-color:var(--blue);
}
.btn--nav:hover { background:var(--blue-d); border-color:var(--blue-d); transform:translateY(-1px); }

/* Skip link */
.skip-link {
  position:absolute; top:-100%; left:1rem;
  background:var(--blue); color:#fff; padding:.75rem 1.5rem;
  border-radius:var(--r-md); z-index:9999; font-weight:600;
}
.skip-link:focus { top:1rem; }

/* ── 6. NAVBAR ── */
.navbar {
  position:fixed; inset:0 0 auto; height:var(--nav-h); z-index:900;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(10px);
  box-shadow:0 2px 20px rgba(0,0,0,.08);
}
.navbar .container {
  height:100%; display:flex; align-items:center;
  justify-content:space-between; gap:2rem;
}
.navbar__logo {
  font-size:1.4rem; font-weight:700; color:var(--black);
  letter-spacing:-.02em; flex-shrink:0;
}
.navbar__logo span { color:var(--gold); }

.navbar__links { display:flex; align-items:center; gap:2rem; }
.navbar__links a {
  font-size:.875rem; font-weight:500; color:var(--gray);
  transition:color var(--ease-f); position:relative;
}
.navbar__links a::after {
  content:''; position:absolute; bottom:-4px; left:0;
  width:0; height:2px; background:var(--gold); transition:width var(--ease-f);
}
.navbar__links a:hover::after, .navbar__links a.active::after { width:100%; }
.navbar__links a:hover { color:var(--blue); }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  width:28px; padding:4px 0; cursor:pointer;
}
.hamburger span {
  display:block; height:2px; background:var(--black);
  border-radius:2px; transition:all var(--ease-f);
}
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile Drawer */
.mobile-drawer {
  position:fixed; top:0; right:-100%;
  width:min(320px,85vw); height:100dvh;
  background:var(--white); z-index:950;
  padding:5rem 2rem 2rem; transition:right var(--ease);
  box-shadow:var(--sh-xl); overflow-y:auto;
}
.mobile-drawer.open { right:0; }
.mobile-drawer ul { display:flex; flex-direction:column; gap:.5rem; }
.mobile-drawer a {
  display:block; font-size:1.25rem; font-weight:600; color:var(--black);
  padding:.65rem 1rem; border-radius:var(--r-md); transition:all var(--ease-f);
}
.mobile-drawer a:hover { background:var(--off-white); color:var(--blue); padding-left:1.5rem; }
.mobile-drawer .drawer-contact {
  margin-top:2rem; padding-top:2rem;
  border-top:1px solid var(--gray-light);
  font-size:.875rem; color:var(--gray);
  display:flex; flex-direction:column; gap:.75rem;
}
.mobile-drawer .drawer-contact a { font-size:.875rem; font-weight:400; color:var(--gray); }

.drawer-close {
  position:absolute; top:1.25rem; right:1.25rem;
  width:36px; height:36px; border-radius:var(--r-full);
  background:var(--off-white); display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; cursor:pointer; color:var(--black); border:none;
}

.drawer-backdrop {
  position:fixed; inset:0; background:rgba(0,0,0,.5);
  z-index:940; opacity:0; pointer-events:none;
  transition:opacity var(--ease); backdrop-filter:blur(4px);
}
.drawer-backdrop.visible { opacity:1; pointer-events:all; }

/* ── 7. HERO SLIDER ── */
.hero {
  position:relative; height:100svh;
  min-height:560px; max-height:900px; overflow:hidden;
}
.hero-swiper { width:100%; height:100%; }
.hero-swiper .swiper-slide { position:relative; overflow:hidden; }
.hero-slide__img {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
}
.hero-slide__overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,.08) 0%, rgba(0,0,0,.18) 45%, rgba(0,0,0,.58) 100%);
}
.hero__ellipse {
  position:absolute; right:-8%; top:8%; width:50%; max-width:620px;
  opacity:.05; pointer-events:none; z-index:1;
}
.hero-slide__content {
  position:absolute; bottom:14%; left:50%; transform:translateX(-50%);
  width:100%; max-width:820px; text-align:center;
  color:#fff; padding:0 var(--px); z-index:2;
}
.hero-slide__tag {
  display:inline-block; font-size:.72rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.14em;
  background:rgba(255,255,255,.18); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.28); color:#fff;
  padding:.4em 1.2em; border-radius:var(--r-full); margin-bottom:1.2rem;
}
.hero-slide__title {
  font-size:clamp(1.9rem,5.5vw,4.25rem); font-weight:700; line-height:1.1;
  margin-bottom:1.1rem; text-shadow:0 2px 20px rgba(0,0,0,.3);
}
.hero-slide__sub {
  font-size:clamp(.95rem,1.8vw,1.2rem); opacity:.9;
  margin-bottom:2rem; max-width:560px; margin-left:auto; margin-right:auto;
}
.hero__nav {
  position:absolute; top:50%; transform:translateY(-50%); z-index:10;
  width:48px; height:48px; border-radius:var(--r-full);
  background:rgba(255,255,255,.15); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.28); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; cursor:pointer; transition:all var(--ease-f);
}
.hero__nav:hover { background:rgba(255,255,255,.3); }
.hero__nav--prev { left:1.5rem; }
.hero__nav--next { right:1.5rem; }
.hero-pagination {
  position:absolute; bottom:2rem; left:50%;
  transform:translateX(-50%); z-index:10;
}
.hero-pagination .swiper-pagination-bullet {
  width:8px; height:8px; background:rgba(255,255,255,.45);
  border-radius:var(--r-full); opacity:1;
  transition:all var(--ease-f); cursor:pointer;
}
.hero-pagination .swiper-pagination-bullet-active {
  background:#fff; width:26px;
}

/* ── 8. MARQUEE STRIP ── */
.marquee-section {
  padding:1.5rem 0; overflow:hidden;
  background:var(--off-white);
  border-top:1px solid var(--gray-light);
  border-bottom:1px solid var(--gray-light);
}
.marquee-track {
  display:flex; gap:1rem; width:max-content;
  animation:marqueeScroll 38s linear infinite;
}
.marquee-section:hover .marquee-track { animation-play-state:paused; }
.marquee-item {
  flex-shrink:0; width:160px; height:100px;
  border-radius:var(--r-lg); overflow:hidden;
}
.marquee-item img { width:100%; height:100%; object-fit:cover; transition:transform var(--ease-s); }
.marquee-item:hover img { transform:scale(1.08); }
@keyframes marqueeScroll {
  from { transform:translateX(0); }
  to   { transform:translateX(-33.333%); }
}

/* ── 9. ABOUT SECTION ── */
.about-section { padding:6rem 0; }
.about__grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:4rem; align-items:center;
}
.about__img-wrap {
  position:relative; border-radius:var(--r-xl); overflow:hidden; aspect-ratio:4/3;
}
.about__img-wrap img { width:100%; height:100%; object-fit:cover; }
.about__badge {
  position:absolute; bottom:1.5rem; left:1.5rem;
  background:#fff; border-radius:var(--r-lg); padding:.75rem 1.2rem;
  box-shadow:var(--sh-md); display:flex; align-items:center; gap:.75rem;
}
.about__badge-icon { font-size:1.4rem; }
.about__badge-label { font-size:.8rem; font-weight:700; color:var(--black); }
.about__badge-sub   { font-size:.72rem; color:var(--gray); }
.about__features { margin:1.75rem 0; display:flex; flex-direction:column; gap:1rem; }
.about__feat {
  display:flex; gap:1rem; align-items:flex-start;
}
.about__feat-icon {
  flex-shrink:0; width:42px; height:42px; background:var(--blue-ghost);
  border-radius:var(--r-md); display:flex; align-items:center;
  justify-content:center; font-size:1.1rem; color:var(--blue);
}
.about__feat-text h4 { font-size:.95rem; font-weight:600; margin-bottom:2px; }
.about__feat-text p  { font-size:.85rem; color:var(--gray); line-height:1.5; }

/* ── 10. OFFER CAROUSEL ── */
.offer-section { padding:5rem 0; }
.offer-swiper-wrap { overflow:hidden; padding:0 var(--px); margin:0 calc(-1 * var(--px)); }
.offer-swiper  { overflow:visible; padding:1rem .25rem 3.5rem; }
.offer-card {
  background:var(--white); border-radius:var(--r-xl);
  overflow:hidden; box-shadow:var(--sh-md); border:1px solid var(--gray-light);
  transition:all var(--ease);
}
.offer-card:hover { transform:translateY(-8px); box-shadow:var(--sh-xl); }
.offer-card__img { aspect-ratio:16/9; overflow:hidden; }
.offer-card__img img { width:100%; height:100%; object-fit:cover; transition:transform var(--ease-s); }
.offer-card:hover .offer-card__img img { transform:scale(1.06); }
.offer-card__body { padding:1.5rem; }
.offer-card__badge {
  display:inline-flex; align-items:center; gap:.4em;
  font-size:.7rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em;
  color:var(--blue); background:var(--blue-ghost);
  padding:.25em .85em; border-radius:var(--r-full); margin-bottom:.75rem;
}
.offer-card__title { font-size:1.15rem; font-weight:700; margin-bottom:.6rem; }
.offer-card__desc  { font-size:.85rem; color:var(--gray); line-height:1.6; margin-bottom:1.2rem; }
.offer-card__footer {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:1rem; border-top:1px solid var(--gray-light);
}
.offer-card__price { font-size:.82rem; color:var(--gray); }
.offer-card__price strong { display:block; font-size:1.1rem; font-weight:700; color:var(--blue); }

/* Swiper shared nav */
.swiper-nav-row {
  display:flex; align-items:center; gap:.75rem;
  justify-content:center; margin-top:1.5rem;
}
.snav-btn {
  width:44px; height:44px; border-radius:var(--r-full);
  border:2px solid var(--gray-light); background:#fff;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all var(--ease-f); color:var(--gray);
}
.snav-btn:hover { border-color:var(--blue); background:var(--blue); color:#fff; }
.snav-btn svg { width:18px; height:18px; }

/* ── 11. ACTIVITY GRID ── */
.activity-section { padding:5rem 0; background:var(--off-white); }
.activity-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem;
}
.activity-card {
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  aspect-ratio:3/4; cursor:pointer;
}
.activity-card img { width:100%; height:100%; object-fit:cover; transition:transform var(--ease-s); }
.activity-card:hover img { transform:scale(1.08); }
.activity-card__ov {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 55%);
}
.activity-card__content { position:absolute; bottom:0; left:0; right:0; padding:1.25rem; color:#fff; }
.activity-card__tag {
  display:inline-block; font-size:.68rem; font-weight:600;
  background:rgba(255,255,255,.2); padding:.15em .7em;
  border-radius:var(--r-sm); margin-bottom:.4rem;
}
.activity-card__title { font-size:.95rem; font-weight:600; line-height:1.3; }

/* ── 12. SEASON GRID ── */
.season-section { padding:5rem 0; }
.season-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.season-card {
  background:#fff; border-radius:var(--r-xl); overflow:hidden;
  border:1px solid var(--gray-light); transition:all var(--ease);
}
.season-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); border-color:var(--blue); }
.season-card__img { aspect-ratio:16/9; overflow:hidden; }
.season-card__img img { width:100%; height:100%; object-fit:cover; transition:transform var(--ease-s); }
.season-card:hover .season-card__img img { transform:scale(1.05); }
.season-card__body { padding:1.25rem; }
.season-card__period {
  font-size:.7rem; font-weight:600; text-transform:uppercase;
  letter-spacing:.1em; color:var(--blue); margin-bottom:.4rem;
}
.season-card__title { font-size:1.1rem; font-weight:700; margin-bottom:.4rem; }
.season-card__desc  { font-size:.85rem; color:var(--gray); line-height:1.55; }

/* ── 13. DESTINATIONS TABS ── */
.destinations-section { padding:5rem 0; background:var(--off-white); }
.tabs { display:flex; gap:.75rem; margin-bottom:2.5rem; flex-wrap:wrap; justify-content:center; }
.tab-btn {
  font-family:var(--font); font-size:.85rem; font-weight:600;
  padding:.6em 1.6em; border-radius:var(--r-full);
  border:2px solid var(--gray-light); background:#fff;
  color:var(--gray); cursor:pointer; transition:all var(--ease-f);
}
.tab-btn:hover { border-color:var(--blue); color:var(--blue); }
.tab-btn.active { background:var(--blue); border-color:var(--blue); color:#fff; }
.tab-panel { display:none; }
.tab-panel.active {
  display:grid; grid-template-columns:1.3fr 1fr;
  gap:3.5rem; align-items:center;
  animation:fadeSlideIn .4s ease forwards;
}
@keyframes fadeSlideIn {
  from { opacity:0; transform:translateY(14px); }
  to   { opacity:1; transform:translateY(0); }
}
.tab-img { border-radius:var(--r-xl); overflow:hidden; aspect-ratio:16/10; }
.tab-img img { width:100%; height:100%; object-fit:cover; }
.tab-info__dist {
  display:inline-flex; align-items:center; gap:.4em;
  font-size:.82rem; color:var(--blue); font-weight:600;
  background:var(--blue-ghost); padding:.3em .9em;
  border-radius:var(--r-full); margin-bottom:1rem;
}
.tab-info__title { margin-bottom:1rem; }
.tab-info__text { font-size:.95rem; color:var(--gray); line-height:1.75; margin-bottom:1.5rem; }

/* ── 14. GALLERY ── */
.gallery-section { padding:5rem 0; }
.gallery-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:1rem;
}
.gallery-item {
  border-radius:var(--r-lg); overflow:hidden; cursor:pointer; position:relative;
}
.gallery-item:nth-child(1) { grid-column:span 2; aspect-ratio:16/9; }
.gallery-item:nth-child(2),
.gallery-item:nth-child(3),
.gallery-item:nth-child(4),
.gallery-item:nth-child(5) { aspect-ratio:4/3; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform var(--ease-s); }
.gallery-item:hover img { transform:scale(1.06); }
.gallery-item__ov {
  position:absolute; inset:0;
  background:rgba(0,0,0,0); display:flex; align-items:center; justify-content:center;
  transition:background var(--ease);
}
.gallery-item:hover .gallery-item__ov { background:rgba(0,0,0,.28); }
.gallery-item__ov svg { opacity:0; transform:scale(.8); transition:all var(--ease); color:#fff; width:36px; height:36px; }
.gallery-item:hover .gallery-item__ov svg { opacity:1; transform:scale(1); }

/* Lightbox */
.lightbox {
  position:fixed; inset:0; background:rgba(0,0,0,.95);
  z-index:9999; display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity var(--ease);
}
.lightbox.open { opacity:1; pointer-events:all; }
.lightbox__img { max-width:92vw; max-height:88vh; border-radius:var(--r-lg); object-fit:contain; }
.lightbox__close {
  position:absolute; top:1.5rem; right:1.5rem; width:44px; height:44px;
  border-radius:var(--r-full); background:rgba(255,255,255,.1); color:#fff;
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  font-size:1.4rem; border:none; transition:background var(--ease-f);
}
.lightbox__close:hover { background:rgba(255,255,255,.2); }

/* ── 15. BLOG GRID ── */
.blog-section { padding:5rem 0; background:var(--off-white); }
.blog-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.blog-card {
  background:#fff; border-radius:var(--r-xl); overflow:hidden;
  border:1px solid var(--gray-light); transition:all var(--ease);
}
.blog-card:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); }
.blog-card__img { aspect-ratio:16/10; overflow:hidden; }
.blog-card__img img { width:100%; height:100%; object-fit:cover; transition:transform var(--ease-s); }
.blog-card:hover .blog-card__img img { transform:scale(1.07); }
.blog-card__body { padding:1.25rem; }
.blog-card__meta { display:flex; align-items:center; gap:.75rem; margin-bottom:.6rem; }
.blog-card__date  { font-size:.72rem; color:var(--gray); font-weight:500; }
.blog-card__time  { font-size:.72rem; color:var(--blue); font-weight:500; }
.blog-card__cat {
  display:inline-block; font-size:.68rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.07em;
  color:var(--blue); background:var(--blue-ghost);
  padding:.2em .7em; border-radius:var(--r-full); margin-bottom:.5rem;
}
.blog-card__title { font-size:.95rem; font-weight:700; margin-bottom:.9rem; line-height:1.4; }
.blog-card__link {
  display:inline-flex; align-items:center; gap:.4em;
  font-size:.82rem; font-weight:600; color:var(--blue);
  transition:gap var(--ease-f);
}
.blog-card__link:hover { gap:.8em; }

/* ── 16. CTA SECTION ── */
.cta-section {
  padding:6rem 0; background:var(--blue); color:#fff;
  text-align:center; position:relative; overflow:hidden;
}
.cta-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.06) 0%,transparent 50%),
             radial-gradient(circle at 80% 50%,rgba(255,255,255,.06) 0%,transparent 50%);
}
.cta-section .container { position:relative; z-index:1; }
.cta__title { font-size:clamp(1.6rem,3.5vw,2.8rem); font-weight:700; margin-bottom:1rem; }
.cta__sub { font-size:1.05rem; opacity:.85; margin-bottom:2.5rem; max-width:520px; margin-left:auto; margin-right:auto; }
.cta__form { display:flex; gap:.75rem; max-width:480px; margin:0 auto; flex-wrap:wrap; justify-content:center; }
.cta__input {
  flex:1; min-width:220px; padding:.75em 1.25em;
  border-radius:var(--r-full); border:2px solid rgba(255,255,255,.3);
  background:rgba(255,255,255,.14); color:#fff;
  font-family:var(--font); font-size:.875rem; outline:none;
  transition:border-color var(--ease-f);
}
.cta__input::placeholder { color:rgba(255,255,255,.6); }
.cta__input:focus { border-color:rgba(255,255,255,.7); background:rgba(255,255,255,.2); }

/* ── 17. FOOTER ── */
.footer { background:var(--footer-bg); color:rgba(255,255,255,.65); padding:4.5rem 0 2rem; }
.footer__grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr;
  gap:3rem; margin-bottom:3.5rem;
}
.footer__logo { font-size:1.35rem; font-weight:700; color:#fff; margin-bottom:.9rem; display:block; }
.footer__logo span { color:var(--gold); }
.footer__tagline { font-size:.85rem; line-height:1.65; margin-bottom:1.5rem; max-width:270px; }
.footer__social { display:flex; gap:.75rem; }
.footer__soc-link {
  width:38px; height:38px; border-radius:var(--r-full);
  background:rgba(255,255,255,.08); display:flex; align-items:center;
  justify-content:center; color:#fff; font-size:.85rem;
  transition:background var(--ease-f);
}
.footer__soc-link:hover { background:var(--blue); }
.footer__col h4 {
  font-size:.75rem; font-weight:600; color:#fff;
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:1.25rem;
}
.footer__links { display:flex; flex-direction:column; gap:.75rem; }
.footer__links a { font-size:.85rem; color:rgba(255,255,255,.55); transition:color var(--ease-f); }
.footer__links a:hover { color:#fff; }
.footer__contact-item {
  display:flex; gap:.75rem; align-items:flex-start;
  margin-bottom:1rem; font-size:.85rem;
}
.footer__ci-icon { color:var(--gold); flex-shrink:0; margin-top:2px; }
.footer__ci-val a { color:rgba(255,255,255,.65); transition:color var(--ease-f); }
.footer__ci-val a:hover { color:#fff; }
.footer__hr { border:none; border-top:1px solid rgba(255,255,255,.08); margin-bottom:1.5rem; }
.footer__bottom {
  display:flex; align-items:center; justify-content:space-between;
  font-size:.75rem; color:rgba(255,255,255,.35); flex-wrap:wrap; gap:1rem;
}
.footer__bot-links { display:flex; gap:1.25rem; }
.footer__bot-links a { color:rgba(255,255,255,.35); transition:color var(--ease-f); }
.footer__bot-links a:hover { color:rgba(255,255,255,.75); }
.footer__credit { color:rgba(255,255,255,.4); font-size:.72rem; letter-spacing:.02em; }
.footer__credit a {
  color:rgba(255,255,255,.78); font-weight:600;
  border-bottom:1px solid rgba(232,201,138,.35);
  padding-bottom:1px; transition:all var(--ease-f);
}
.footer__credit a:hover { color:var(--gold); border-bottom-color:var(--gold); }

/* ── 18. PAGE HERO (inner pages) ── */
.page-hero {
  padding:calc(var(--nav-h) + 4.5rem) 0 4rem;
  background:var(--off-white); text-align:center; position:relative; overflow:hidden;
}
.page-hero::after {
  content:''; position:absolute; top:-40%; right:-15%;
  width:550px; height:550px;
  background:radial-gradient(circle,rgba(45,106,143,.07) 0%,transparent 70%);
  pointer-events:none;
}
.page-hero .container { position:relative; z-index:1; }
.page-hero__title { margin-bottom:.75rem; }
.page-hero__sub { font-size:1.05rem; color:var(--gray); max-width:540px; margin:0 auto; }

.breadcrumb {
  display:flex; align-items:center; justify-content:center;
  gap:.5rem; font-size:.82rem; color:var(--gray); margin-bottom:1.25rem;
}
.breadcrumb a { color:var(--blue); }
.breadcrumb__sep { color:var(--gray-light); }

/* ── 19. STATS ROW ── */
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; padding:3rem 0; }
.stat-item { text-align:center; }
.stat-item__num { display:block; font-size:clamp(1.6rem,3.5vw,2.5rem); font-weight:700; color:var(--blue); }
.stat-item__label { font-size:.82rem; color:var(--gray); margin-top:.2rem; }

/* ── 20. CONTACT PAGE ── */
.contact-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:4rem; align-items:start; }
.contact-info__item { display:flex; gap:1rem; align-items:flex-start; margin-bottom:1.5rem; }
.ci-icon {
  width:48px; height:48px; background:var(--blue-ghost); border-radius:var(--r-lg);
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; color:var(--blue); flex-shrink:0;
}
.ci-label { font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--gray); font-weight:600; margin-bottom:3px; }
.ci-value { font-weight:600; color:var(--black); }
.ci-value a { color:var(--black); transition:color var(--ease-f); }
.ci-value a:hover { color:var(--blue); }
.contact-social { display:flex; gap:.75rem; margin-top:2rem; }
.cs-link {
  width:44px; height:44px; border-radius:var(--r-full);
  border:2px solid var(--gray-light); display:flex; align-items:center;
  justify-content:center; color:var(--gray); font-size:1rem;
  transition:all var(--ease-f);
}
.cs-link:hover { border-color:var(--blue); background:var(--blue); color:#fff; }

.contact-form {
  background:#fff; border-radius:var(--r-xl); padding:2.5rem;
  box-shadow:var(--sh-lg); border:1px solid var(--gray-light);
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.form-group { margin-bottom:1.25rem; }
.form-label { display:block; font-size:.82rem; font-weight:600; color:var(--black); margin-bottom:.4rem; }
.form-control {
  width:100%; padding:.72em 1em;
  border:2px solid var(--gray-light); border-radius:var(--r-md);
  font-family:var(--font); font-size:.875rem; color:var(--black);
  outline:none; background:#fff; transition:border-color var(--ease-f);
}
.form-control:focus { border-color:var(--blue); box-shadow:0 0 0 3px rgba(45,106,143,.1); }
textarea.form-control { resize:vertical; min-height:120px; }
.form-check { display:flex; align-items:flex-start; gap:.75rem; margin-bottom:1.5rem; }
.form-check input[type="checkbox"] { margin-top:3px; flex-shrink:0; accent-color:var(--blue); width:16px; height:16px; }
.form-check label { font-size:.78rem; color:var(--gray); line-height:1.5; }
.form-msg {
  display:none; padding:1rem 1.25rem; border-radius:var(--r-md);
  margin-top:1rem; font-weight:600; text-align:center; font-size:.875rem;
}
.form-msg.success { display:block; background:#D1FAE5; color:#065F46; }
.form-msg.error   { display:block; background:#FEE2E2; color:#991B1B; }

/* Map embed */
.map-wrap { border-radius:var(--r-xl); overflow:hidden; height:320px; margin-top:2rem; }
.map-wrap iframe { width:100%; height:100%; border:0; }

/* ── 21. BLOG PAGE ── */
.blog-list { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.blog-list-card {
  background:#fff; border-radius:var(--r-xl); overflow:hidden;
  border:1px solid var(--gray-light); transition:all var(--ease);
}
.blog-list-card:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); }
.blog-list-card__img { aspect-ratio:16/9; overflow:hidden; }
.blog-list-card__img img { width:100%; height:100%; object-fit:cover; transition:transform var(--ease-s); }
.blog-list-card:hover .blog-list-card__img img { transform:scale(1.07); }
.blog-list-card__body { padding:1.5rem; }
.blog-list-card__meta { display:flex; gap:.75rem; margin-bottom:.75rem; font-size:.72rem; color:var(--gray); }
.blog-list-card__title { font-size:1.15rem; font-weight:700; margin-bottom:.75rem; line-height:1.35; }
.blog-list-card__lead { font-size:.875rem; color:var(--gray); line-height:1.6; margin-bottom:1.25rem; }

/* ── 22. ARTICLE ── */
.article-wrap { max-width:760px; margin:0 auto; padding:0 var(--px); }
.article-header { padding:calc(var(--nav-h) + 3rem) 0 2.5rem; }
.article-header .section__tag { margin-bottom:.75rem; }
.article-hero-img { width:100%; aspect-ratio:16/7; object-fit:cover; border-radius:var(--r-xl); margin-bottom:3rem; }
.article-meta { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; font-size:.82rem; color:var(--gray); margin-bottom:1.5rem; }
.article-body h2 { font-size:1.45rem; font-weight:700; margin:2.5rem 0 1rem; color:var(--black); }
.article-body h3 { font-size:1.15rem; font-weight:600; margin:2rem 0 .75rem; }
.article-body p  { font-size:.975rem; line-height:1.82; color:#374151; margin-bottom:1.25rem; }
.article-body ul,
.article-body ol { margin:1.25rem 0; padding-left:1.5rem; }
.article-body li { font-size:.975rem; line-height:1.7; color:#374151; margin-bottom:.4rem; list-style:disc; }
.article-body ol li { list-style:decimal; }
.article-cta {
  margin:3rem 0; padding:2rem;
  background:var(--blue-ghost); border-radius:var(--r-xl);
  border-left:4px solid var(--blue); text-align:center;
}
.article-cta p { font-weight:600; color:var(--black); margin-bottom:1rem; }
.article-nav {
  display:flex; justify-content:space-between; align-items:center;
  padding:2rem 0; border-top:1px solid var(--gray-light);
  margin-top:3rem; gap:1rem; flex-wrap:wrap;
}
.article-nav a { font-size:.875rem; font-weight:600; color:var(--blue); }

/* ── 23. OFERTA PAGE ── */
.oferta-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-bottom:3rem; }
.oferta-card {
  background:#fff; border-radius:var(--r-xl); overflow:hidden;
  border:1px solid var(--gray-light); transition:all var(--ease);
}
.oferta-card:hover { box-shadow:var(--sh-lg); border-color:var(--blue); }
.oferta-card--feat { border-color:var(--blue); box-shadow:var(--sh-md); }
.oferta-card__img { aspect-ratio:16/9; overflow:hidden; }
.oferta-card__img img { width:100%; height:100%; object-fit:cover; transition:transform var(--ease-s); }
.oferta-card:hover .oferta-card__img img { transform:scale(1.05); }
.oferta-card__head { background:var(--blue); color:#fff; padding:1.75rem; }
.oferta-card--feat .oferta-card__head { background:var(--blue-d); }
.oferta-card__type { font-size:.7rem; font-weight:600; text-transform:uppercase; letter-spacing:.12em; opacity:.75; margin-bottom:.4rem; }
.oferta-card__h2   { font-size:1.5rem; font-weight:700; margin-bottom:.3rem; }
.oferta-card__min  { font-size:.85rem; opacity:.8; }
.oferta-card__body { padding:1.75rem; }
.oferta-card__feats { margin-bottom:1.5rem; }
.oferta-card__feats li {
  display:flex; align-items:flex-start; gap:.75rem; padding:.65rem 0;
  font-size:.875rem; border-bottom:1px solid var(--gray-light); color:var(--gray);
}
.oferta-card__feats li:last-child { border-bottom:none; }
.oferta-card__feats li span:first-child { color:var(--blue); font-weight:700; flex-shrink:0; }

/* ── 24. GALLERY PAGE ── */
.gallery-page-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.gp-item { border-radius:var(--r-lg); overflow:hidden; aspect-ratio:4/3; cursor:pointer; position:relative; }
.gp-item:nth-child(5n+1) { grid-column:span 2; aspect-ratio:16/9; }
.gp-item img { width:100%; height:100%; object-fit:cover; transition:transform var(--ease-s); }
.gp-item:hover img { transform:scale(1.06); }
.gp-item__ov {
  position:absolute; inset:0; background:rgba(0,0,0,0);
  display:flex; align-items:center; justify-content:center;
  transition:background var(--ease);
}
.gp-item:hover .gp-item__ov { background:rgba(0,0,0,.28); }
.gp-item__ov svg { opacity:0; transform:scale(.8); transition:all var(--ease); color:#fff; width:36px; height:36px; }
.gp-item:hover .gp-item__ov svg { opacity:1; transform:scale(1); }
.gallery-placeholder {
  margin-top:3rem; padding:2.5rem; text-align:center;
  background:var(--off-white); border-radius:var(--r-xl);
  border:2px dashed var(--gray-light);
}
.gallery-placeholder p { font-size:.95rem; color:var(--gray); }

/* ── 25. O NAS PAGE ── */
.owner-grid { display:grid; grid-template-columns:1fr 2.2fr; gap:3.5rem; align-items:start; }
.owner-photo { border-radius:var(--r-xl); aspect-ratio:3/4; overflow:hidden; }
.owner-photo img { width:100%; height:100%; object-fit:cover; }
.owner-story h3 { font-size:1.4rem; font-weight:700; margin-bottom:1.25rem; }
.owner-story p  { font-size:.95rem; color:var(--gray); line-height:1.8; margin-bottom:1.1rem; }

.timeline { position:relative; padding-left:2.5rem; margin-top:2.5rem; }
.timeline::before {
  content:''; position:absolute; left:10px; top:0; bottom:0;
  width:2px; background:var(--gray-light);
}
.tl-item { position:relative; margin-bottom:2rem; }
.tl-item::before {
  content:''; position:absolute; left:calc(-2.5rem + 6px); top:5px;
  width:12px; height:12px; border-radius:var(--r-full);
  background:var(--blue); border:3px solid #fff;
  box-shadow:0 0 0 2px var(--blue);
}
.tl-date  { font-size:.72rem; font-weight:600; color:var(--blue); text-transform:uppercase; letter-spacing:.1em; margin-bottom:.3rem; }
.tl-title { font-size:1rem; font-weight:700; margin-bottom:.2rem; }
.tl-desc  { font-size:.85rem; color:var(--gray); }

/* ── 26. COOKIE BANNER ── */
.cookie-banner {
  position:fixed; bottom:1.25rem; left:50%;
  transform:translateX(-50%); width:min(680px,calc(100vw - 2rem));
  background:#fff; border-radius:var(--r-xl); box-shadow:var(--sh-xl);
  padding:1.25rem 1.75rem; z-index:800;
  border:1px solid var(--gray-light);
  display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap;
}
.cookie-banner p { font-size:.82rem; color:var(--gray); flex:1; min-width:200px; }
.cookie-banner p a { color:var(--blue); text-decoration:underline; }
.cookie-btns { display:flex; gap:.6rem; flex-shrink:0; }
.cookie-banner.hidden { display:none; }

/* ── 27. SCROLL REVEAL ── */
.reveal { opacity:0; transform:translateY(36px); transition:opacity .75s ease, transform .75s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-d1 { transition-delay:.1s; }
.reveal-d2 { transition-delay:.2s; }
.reveal-d3 { transition-delay:.3s; }
.reveal-d4 { transition-delay:.4s; }

/* ── 28. ACCESSIBILITY ── */
:focus-visible { outline:3px solid var(--blue); outline-offset:3px; border-radius:2px; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border-width:0; }

/* ── 29. REDUCED MOTION ── */
@media (prefers-reduced-motion:reduce) {
  *, *::before, *::after { animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  .marquee-track { animation-play-state:paused !important; }
  .reveal, .reveal.visible { opacity:1; transform:none; transition:none; }
}

/* ── 30. RESPONSIVE ── */
@media (max-width:1100px) {
  .blog-grid         { grid-template-columns:repeat(2,1fr); }
  .activity-grid     { grid-template-columns:repeat(3,1fr); }
  .footer__grid      { grid-template-columns:1fr 1fr; gap:2rem; }
  .stats-row         { grid-template-columns:repeat(2,1fr); }
  .gallery-grid      { grid-template-columns:1fr 1fr; }
  .gallery-item:nth-child(1) { grid-column:span 2; }
  .gallery-item:nth-child(4),
  .gallery-item:nth-child(5) { aspect-ratio:16/9; }
}
@media (max-width:900px) {
  .about__grid       { grid-template-columns:1fr; }
  .about__img-wrap   { order:-1; max-height:360px; }
  .tab-panel.active  { grid-template-columns:1fr; gap:2rem; }
  .contact-grid      { grid-template-columns:1fr; }
  .form-row          { grid-template-columns:1fr; }
  .owner-grid        { grid-template-columns:1fr; }
  .owner-photo       { max-height:320px; aspect-ratio:3/2; }
  .oferta-grid       { grid-template-columns:1fr; }
  .season-grid       { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px) {
  .navbar__links { display:none; }
  .hamburger     { display:flex; }
  .hero          { max-height:680px; }
  .hero-slide__content { bottom:11%; }
  .activity-grid { grid-template-columns:repeat(2,1fr); }
  .blog-grid     { grid-template-columns:1fr; }
  .blog-list     { grid-template-columns:1fr; }
  .gallery-page-grid  { grid-template-columns:1fr 1fr; }
  .gp-item:nth-child(5n+1) { grid-column:span 2; }
  .footer__grid  { grid-template-columns:1fr 1fr; }
  .footer__bottom { flex-direction:column; align-items:flex-start; }
  .section       { padding:3.5rem 0; }
  .season-grid   { grid-template-columns:1fr; }
  .gallery-grid  { grid-template-columns:1fr; }
  .gallery-item:nth-child(1) { grid-column:span 1; aspect-ratio:4/3; }
}
@media (max-width:480px) {
  :root { --px:1rem; }
  .activity-grid { gap:.75rem; }
  .hero__nav     { display:none; }
  .stats-row     { grid-template-columns:repeat(2,1fr); gap:1rem; }
  .footer__grid  { grid-template-columns:1fr; }
  .contact-form  { padding:1.5rem; }
  .cta__form     { flex-direction:column; }
  .cta__input    { min-width:unset; width:100%; }
  .tabs          { gap:.5rem; }
  .tab-btn       { font-size:.78rem; padding:.5em 1em; }
  .gallery-page-grid { grid-template-columns:1fr; }
  .gp-item:nth-child(5n+1) { grid-column:span 1; aspect-ratio:4/3; }
  .blog-grid { grid-template-columns:1fr; }
}
