/* =========================================================
   Aeronique Travels — stylesheet
   Navy + gold premium palette. Mobile-first responsive.
   ========================================================= */

:root{
  --ink:        #0b2742;
  --ink-soft:   #14385d;
  --ink-deep:   #071a2e;
  --accent:     #e85d2f;
  --accent-hi:  #ff7a4d;
  --cream:      #fbf7f0;
  --paper:      #ffffff;
  --soft:       #f4f6fa;
  --text:       #1a2b3a;
  --muted:      #5b6b7d;
  --line:       #e3e8ef;
  --whatsapp:   #25d366;
  --whatsapp-d: #1ebe5b;

  --radius:     14px;
  --radius-sm:  10px;
  --shadow-sm:  0 1px 2px rgba(11,39,66,.06), 0 2px 6px rgba(11,39,66,.04);
  --shadow:     0 8px 24px rgba(11,39,66,.08), 0 2px 6px rgba(11,39,66,.05);
  --shadow-lg:  0 24px 60px rgba(11,39,66,.18);

  --font-sans:  'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-serif: 'Playfair Display', Georgia, serif;

  --container:  1160px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:96px; }
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--text);
  background:var(--paper);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:0; background:transparent; color:inherit; }

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 24px;
}

h1,h2,h3,h4{
  font-family:var(--font-serif);
  color:var(--ink);
  line-height:1.15;
  margin:0 0 .5em;
  font-weight:700;
  letter-spacing:-.01em;
}
h1{ font-size:clamp(2.25rem, 4.2vw + 1rem, 4rem); }
h2{ font-size:clamp(1.75rem, 2vw + 1rem, 2.5rem); }
h3{ font-size:1.25rem; }
p{ margin:0 0 1em; }

.eyebrow{
  display:inline-block;
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  margin:0 0 .75rem;
}
.eyebrow--light{ color:var(--accent-hi); }
.accent{ color:var(--accent); font-style:italic; font-family:var(--font-serif); }
.link{
  display:inline-block;
  color:var(--ink);
  font-weight:600;
  border-bottom:1px solid transparent;
  transition:border-color .2s, color .2s;
}
.link:hover{ color:var(--accent); border-color:var(--accent); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  padding:.9rem 1.4rem;
  border-radius:999px;
  font-weight:600;
  font-size:.95rem;
  letter-spacing:.01em;
  transition:transform .15s ease, background .2s, color .2s, box-shadow .2s;
  white-space:nowrap;
  cursor:pointer;
}
.btn:hover{ transform:translateY(-1px); }
.btn--primary{
  background:var(--ink);
  color:#fff;
  box-shadow:var(--shadow-sm);
}
.btn--primary:hover{ background:var(--ink-soft); box-shadow:var(--shadow); }
.btn--ghost{
  background:transparent;
  color:#fff;
  border:1.5px solid rgba(255,255,255,.5);
}
.btn--ghost:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.btn--whatsapp{
  background:var(--whatsapp);
  color:#fff;
  box-shadow:var(--shadow-sm);
}
.btn--whatsapp:hover{ background:var(--whatsapp-d); }
.btn--full{ width:100%; }

/* ---------- Top bar ---------- */
.topbar{
  background:var(--ink-deep);
  color:#cfd6df;
  font-size:.82rem;
}
.topbar__inner{
  display:flex;
  align-items:center;
  gap:.6rem;
  padding:.55rem 24px;
  justify-content:center;
}
.topbar__item{ color:#cfd6df; }
.topbar__item:hover{ color:var(--accent-hi); }
.topbar__dot{ opacity:.5; }
@media (max-width: 540px){
  .topbar__dot--hide,.topbar__item--hide{ display:none; }
}

/* ---------- Nav ---------- */
.nav{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .2s, box-shadow .2s, background .2s;
}
.nav.is-scrolled{
  background:rgba(255,255,255,.96);
  border-color:var(--line);
  box-shadow:var(--shadow-sm);
}
.nav__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.25rem;
  padding:1rem 24px;
}

.brand{
  display:inline-flex;
  align-items:center;
  gap:.65rem;
  color:var(--ink);
  text-decoration:none;
  line-height:1;
}
.brand__logo{
  display:block;
  height:34px;
  width:auto;
  color:inherit;
}
.brand__tag{
  font-family:var(--font-serif);
  font-style:italic;
  font-size:.95rem;
  color:var(--accent);
  font-weight:600;
  letter-spacing:.01em;
  margin-left:.1rem;
}
@media (max-width: 480px){
  .brand__logo{ height:28px; }
  .brand__tag{ font-size:.82rem; }
}

.nav__links{
  display:flex;
  gap:1.75rem;
  font-size:.95rem;
  font-weight:500;
}
.nav__links a{ color:var(--text); padding:.25rem 0; position:relative; }
.nav__links a:hover,
.nav__links a.is-active{ color:var(--ink); }
.nav__links a::after{
  content:"";
  position:absolute;
  left:0; bottom:-4px;
  width:0; height:2px;
  background:var(--accent);
  transition:width .2s;
}
.nav__links a:hover::after,
.nav__links a.is-active::after{ width:100%; }

.nav__cta{ padding:.7rem 1.2rem; font-size:.9rem; }

.nav__toggle{
  display:none;
  flex-direction:column;
  gap:4px;
  padding:8px;
}
.nav__toggle span{
  width:24px; height:2px;
  background:var(--ink);
  border-radius:2px;
  transition:transform .2s, opacity .2s;
}
.nav__toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

@media (max-width: 900px){
  .nav__links{
    position:absolute;
    top:100%; left:0; right:0;
    background:#fff;
    flex-direction:column;
    gap:0;
    padding:.5rem 24px 1rem;
    border-bottom:1px solid var(--line);
    box-shadow:var(--shadow-sm);
    transform:translateY(-8px);
    opacity:0;
    pointer-events:none;
    transition:transform .2s, opacity .2s;
  }
  .nav__links.is-open{
    transform:translateY(0);
    opacity:1;
    pointer-events:auto;
  }
  .nav__links a{ padding:.85rem 0; border-bottom:1px solid var(--line); }
  .nav__links a:last-child{ border-bottom:0; }
  .nav__links a::after{ display:none; }
  .nav__cta{ display:none; }
  .nav__toggle{ display:flex; }
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  isolation:isolate;
  min-height:min(92vh, 820px);
  color:#fff;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding:6rem 0 5rem;
}
.hero__slides{
  position:absolute; inset:0;
  z-index:-2;
  overflow:hidden;
}
.hero__slide{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  opacity:0;
  transform:scale(1.06);
  transition:opacity 1.6s ease-in-out;
  will-change:opacity, transform;
}
.hero__slide.is-active{
  opacity:1;
  animation:kenburns 9s ease-out forwards;
}
@keyframes kenburns{
  from { transform:scale(1.06); }
  to   { transform:scale(1.14); }
}
.hero__overlay{
  position:absolute; inset:0;
  z-index:-1;
  background:
    linear-gradient(135deg, rgba(7,26,46,.88) 0%, rgba(11,39,66,.72) 45%, rgba(11,39,66,.55) 100%),
    linear-gradient(180deg, rgba(0,0,0,0) 55%, rgba(0,0,0,.25) 100%);
}
.hero__inner{ position:relative; }

.hero__rating{
  display:inline-flex;
  align-items:center;
  gap:.65rem;
  padding:.45rem 1rem .45rem .75rem;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter:blur(10px);
  backdrop-filter:blur(10px);
  border-radius:999px;
  font-size:.85rem;
  color:#e7edf4;
  margin-bottom:1.5rem;
}
.hero__stars{
  color:var(--accent-hi);
  letter-spacing:.1em;
  font-size:.85rem;
  line-height:1;
}
.hero__rating-text strong{ color:#fff; font-weight:700; }

.hero__title{
  color:#fff;
  margin:0 0 1rem;
  max-width:20ch;
}
.hero__lead{
  font-size:clamp(1rem, .4vw + .9rem, 1.2rem);
  color:#e7edf4;
  max-width:62ch;
  margin:0 0 2rem;
}
.hero__lead strong{ color:#fff; font-weight:600; }

.hero__cta{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
  align-items:center;
  margin-bottom:3rem;
}
.hero__reply{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-size:.82rem;
  color:#cfd6df;
  padding-left:.25rem;
}
.hero__reply-dot{
  width:8px; height:8px;
  border-radius:50%;
  background:var(--whatsapp);
  box-shadow:0 0 0 3px rgba(37,211,102,.25);
  animation:pulseDot 1.8s ease-in-out infinite;
}
@keyframes pulseDot{
  0%,100%{ box-shadow:0 0 0 3px rgba(37,211,102,.25); }
  50%   { box-shadow:0 0 0 6px rgba(37,211,102,.12); }
}

.hero__stats{
  list-style:none;
  padding:0; margin:0;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1rem;
  max-width:760px;
  border-top:1px solid rgba(255,255,255,.15);
  padding-top:1.5rem;
}
.hero__stats li{ display:flex; flex-direction:column; }
.hero__stats strong{
  font-family:var(--font-serif);
  font-size:clamp(1.5rem, 1.5vw + 1rem, 1.95rem);
  color:var(--accent-hi);
  line-height:1;
}
.hero__stats span{
  font-size:.8rem;
  color:#cfd6df;
  margin-top:.35rem;
  letter-spacing:.02em;
}
@media (max-width: 720px){
  .hero{
    min-height:auto;
    padding:3.5rem 0 3rem;
  }
  .hero__title{
    font-size:clamp(2rem, 9vw + .5rem, 2.75rem);
    max-width:100%;
  }
  .hero__lead{
    font-size:1rem;
    margin-bottom:1.5rem;
  }
  .hero__rating{
    font-size:.78rem;
    padding:.4rem .85rem .4rem .65rem;
    margin-bottom:1rem;
  }
  .hero__cta{
    flex-direction:column;
    align-items:stretch;
    gap:.7rem;
    margin-bottom:2rem;
  }
  .hero__cta .btn{
    width:100%;
    padding:.95rem 1rem;
  }
  .hero__reply{
    justify-content:center;
    padding-left:0;
    padding-top:.25rem;
  }
  .hero__stats{ grid-template-columns:repeat(2, 1fr); gap:1rem 1.25rem; padding-top:1.25rem; }
  .hero__stats strong{ font-size:1.5rem; }
  .hero__stats span{ font-size:.72rem; }
}
@media (max-width: 420px){
  .hero{ padding:3rem 0 2.5rem; }
  .hero__title{ font-size:1.85rem; line-height:1.2; }
  .hero__rating-text{ font-size:.78rem; }
}

/* ---------- Page hero (inner pages) ---------- */
.pagehero{
  background:linear-gradient(135deg, var(--ink-deep) 0%, var(--ink) 60%, var(--ink-soft) 100%);
  color:#fff;
  padding:4.5rem 0 4rem;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
.pagehero::before{
  content:"";
  position:absolute;
  right:-120px; top:-60px;
  width:360px; height:360px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(201,162,75,.22), transparent 70%);
  z-index:-1;
}
.pagehero__inner h1{
  color:#fff;
  margin-top:.5rem;
  max-width:22ch;
}
.pagehero__lead{
  font-size:1.1rem;
  color:#d3dbe5;
  max-width:60ch;
  margin:.5rem 0 0;
}

.crumbs{
  font-size:.82rem;
  color:#a4b1c2;
  letter-spacing:.04em;
}
.crumbs a{ color:#d3dbe5; border-bottom:1px solid transparent; }
.crumbs a:hover{ border-color:var(--accent-hi); color:#fff; }
.crumbs span{ margin:0 .5em; }

/* ---------- Trust bar ---------- */
.trustbar{
  background:
    linear-gradient(180deg, #fff 0%, var(--soft) 100%);
  border-bottom:1px solid var(--line);
  padding:2.75rem 0;
  position:relative;
}
.trustbar::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:3px;
  background:linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity:.4;
}
.trustbar__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1.5rem;
  flex-wrap:wrap;
  margin-bottom:1.5rem;
  padding-bottom:1.25rem;
  border-bottom:1px dashed var(--line);
}
.trustbar__label{
  margin:0;
  font-size:.78rem;
  color:var(--muted);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:600;
}
.trustbar__reviews{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  font-size:.88rem;
  color:var(--muted);
  white-space:nowrap;
}
.trustbar__reviews strong{ color:var(--ink); font-weight:700; font-size:.95rem; }
.trustbar__stars{
  color:var(--accent);
  letter-spacing:.08em;
  font-size:.95rem;
  line-height:1;
}
.trustbar__list{
  list-style:none;
  margin:0; padding:0;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:.55rem;
}
.trustbar__pill{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:.5rem 1rem .5rem .55rem;
  background:#fff;
  border:1px solid var(--line);
  border-radius:999px;
  font-family:var(--font-serif);
  font-weight:600;
  color:var(--ink);
  font-size:.92rem;
  box-shadow:var(--shadow-sm);
  transition:transform .2s, border-color .2s, box-shadow .2s;
  cursor:default;
}
.trustbar__pill:hover{
  transform:translateY(-2px);
  border-color:var(--accent);
  box-shadow:var(--shadow);
}
.trustbar__pill .fi{
  width:22px;
  height:16px;
  border-radius:2px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.08);
  flex-shrink:0;
}
@media (max-width: 560px){
  .trustbar__head{ justify-content:center; text-align:center; }
  .trustbar__pill{ font-size:.86rem; padding:.45rem .85rem .45rem .5rem; }
  .trustbar__pill .fi{ width:20px; height:14px; }
}

/* ---------- Jump nav (sub-page nav) ---------- */
.jumpnav{
  background:var(--soft);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:sticky;
  top:64px;
  z-index:30;
}
.jumpnav__inner{
  display:flex;
  gap:1.5rem;
  overflow-x:auto;
  padding:.9rem 24px;
  font-size:.9rem;
  font-weight:600;
  color:var(--muted);
  scrollbar-width:none;
}
.jumpnav__inner::-webkit-scrollbar{ display:none; }
.jumpnav__inner a{
  white-space:nowrap;
  padding:.25rem 0;
  border-bottom:2px solid transparent;
  transition:color .2s, border-color .2s;
}
.jumpnav__inner a:hover{ color:var(--ink); border-color:var(--accent); }

/* ---------- Sections ---------- */
.section{ padding:clamp(4rem, 7vw, 6.5rem) 0; }
.section--alt{ background:var(--soft); }
.section--dark{
  background:var(--ink);
  color:#e7edf4;
}
.section--dark h2,
.section--dark h3{ color:#fff; }

.section__head{
  text-align:center;
  max-width:640px;
  margin:0 auto 3rem;
}
.section__sub{
  color:var(--muted);
  font-size:1.05rem;
  margin:0;
}
.section--dark .section__sub{ color:#b8c4d2; }
.section__foot{ text-align:center; margin-top:2.5rem; }

/* ---------- Services (home grid) ---------- */
.services{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:1.25rem;
}
.service{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.75rem;
  transition:transform .2s, box-shadow .2s, border-color .2s;
}
.service:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
  border-color:transparent;
}
.service__icon{
  width:54px; height:54px;
  display:grid; place-items:center;
  border-radius:12px;
  background:linear-gradient(135deg, var(--ink) 0%, var(--ink-soft) 100%);
  color:var(--accent);
  margin-bottom:1.1rem;
}
.service h3{ margin:0 0 .5rem; }
.service p{ color:var(--muted); margin:0 0 1rem; font-size:.95rem; }

/* ---------- Process ---------- */
.process{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1.25rem;
  counter-reset:step;
}
.process__step{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.75rem;
  position:relative;
  transition:transform .2s, box-shadow .2s;
}
.process__step:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.process__num{
  font-family:var(--font-serif);
  font-size:2.25rem;
  color:var(--accent);
  line-height:1;
  display:block;
  margin-bottom:.75rem;
  opacity:.9;
}
.process__step h3{ margin:0 0 .5rem; }
.process__step p{ margin:0; color:var(--muted); font-size:.95rem; }
.section--alt .process__step{ background:#fff; }

/* ---------- About ---------- */
.about{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:3rem;
  align-items:center;
}
@media (max-width: 880px){
  .about{ grid-template-columns:1fr; gap:2rem; }
}
.about__text p{ color:var(--muted); max-width:55ch; }

.features{
  list-style:none;
  padding:0;
  margin:1.5rem 0 2rem;
  display:grid;
  gap:.9rem;
}
.features li{
  display:flex;
  gap:.85rem;
  align-items:flex-start;
  color:var(--text);
}
.features__tick{
  flex:0 0 24px;
  width:24px; height:24px;
  display:grid; place-items:center;
  background:var(--ink);
  color:var(--accent);
  border-radius:50%;
  font-size:.75rem;
  font-weight:700;
  margin-top:2px;
}

.about__visual{ position:relative; }
.about__visual img{
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  aspect-ratio: 4/5;
  object-fit:cover;
  width:100%;
}
.about__badge{
  position:absolute;
  left:-16px;
  bottom:24px;
  background:#fff;
  border-radius:var(--radius-sm);
  padding:1rem 1.1rem;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  min-width:150px;
}
.about__badge strong{
  font-family:var(--font-serif);
  font-size:1.5rem;
  color:var(--ink);
  line-height:1;
}
.about__badge span{
  font-size:.8rem;
  color:var(--muted);
  margin-top:.35rem;
}

/* ---------- Story (about page) ---------- */
.story{
  display:grid;
  grid-template-columns:1.15fr 1fr;
  gap:3rem;
  align-items:center;
}
@media (max-width: 880px){ .story{ grid-template-columns:1fr; gap:2rem; } }
.story__text p{ color:var(--muted); max-width:62ch; }
.story__visual img{
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  aspect-ratio:4/3;
  object-fit:cover;
  width:100%;
}

/* ---------- Stats strip ---------- */
.stats{
  background:var(--ink);
  color:#fff;
  padding:3rem 0;
}
.stats__list{
  list-style:none;
  padding:0; margin:0;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1.5rem;
  text-align:center;
}
@media (max-width: 640px){ .stats__list{ grid-template-columns:repeat(2, 1fr); } }
.stats__list li{ display:flex; flex-direction:column; gap:.35rem; }
.stats__list strong{
  font-family:var(--font-serif);
  font-size:clamp(2rem, 3vw + 1rem, 2.75rem);
  color:var(--accent-hi);
  line-height:1;
}
.stats__list span{ color:#cfd6df; font-size:.85rem; letter-spacing:.04em; }

/* ---------- Mission / Vision ---------- */
.mv{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.25rem;
}
@media (max-width: 780px){ .mv{ grid-template-columns:1fr; } }
.mv__card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:2rem;
}
.mv__card p{ color:var(--muted); margin:0; max-width:45ch; }

/* ---------- Values ---------- */
.values{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1.25rem;
}
.value{
  background:var(--soft);
  border-radius:var(--radius);
  padding:1.75rem;
  position:relative;
  overflow:hidden;
  transition:transform .2s, box-shadow .2s;
}
.value:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.value__num{
  position:absolute;
  right:1rem; top:.75rem;
  font-family:var(--font-serif);
  font-size:2.25rem;
  color:var(--accent);
  opacity:.5;
  line-height:1;
}
.value h3{ margin:0 0 .5rem; max-width:14ch; }
.value p{ margin:0; color:var(--muted); font-size:.95rem; }

/* ---------- Team ---------- */
.team{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:1.5rem;
}
.member{
  background:#fff;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  transition:transform .2s, box-shadow .2s;
}
.member:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.member__photo{
  aspect-ratio:4/3;
  background-size:cover;
  background-position:center;
}
.member h3{ margin:1.25rem 1.5rem .25rem; }
.member p{ margin:0 1.5rem 1rem; color:var(--muted); font-size:.95rem; }
.member__role{ color:var(--accent); font-weight:600; font-size:.85rem; letter-spacing:.04em; }
.team__note{
  text-align:center;
  color:var(--muted);
  font-size:.82rem;
  margin-top:2rem;
  font-style:italic;
}

/* ---------- Service row (services page) ---------- */
.servicerow{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:3rem;
  align-items:center;
}
.servicerow--reverse .servicerow__visual{ order:2; }
@media (max-width: 880px){
  .servicerow,
  .servicerow--reverse{ grid-template-columns:1fr; gap:1.5rem; }
  .servicerow--reverse .servicerow__visual{ order:0; }
}
.servicerow__visual img{
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  aspect-ratio:4/3;
  object-fit:cover;
  width:100%;
}
.servicerow__text p{ color:var(--muted); max-width:55ch; }

.checklist{
  list-style:none;
  padding:0;
  margin:1.25rem 0 1.5rem;
  display:grid;
  gap:.55rem;
}
.checklist li{
  padding-left:1.75rem;
  position:relative;
  color:var(--text);
  font-size:.97rem;
}
.checklist li::before{
  content:"";
  position:absolute;
  left:0; top:.45em;
  width:14px; height:14px;
  background:var(--accent);
  clip-path:polygon(14% 45%, 0 60%, 40% 100%, 100% 20%, 85% 6%, 38% 68%);
}

.metarow{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  margin-bottom:1.5rem;
  padding:1rem 1.25rem;
  background:var(--soft);
  border-radius:var(--radius-sm);
  border:1px solid var(--line);
}
.section--alt .metarow{ background:#fff; }
.metarow div{ display:flex; flex-direction:column; gap:.15rem; }
.metarow span{ font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.metarow strong{ color:var(--ink); font-family:var(--font-serif); font-weight:600; font-size:1.05rem; }

.servicerow__cta{ display:flex; gap:1.25rem; align-items:center; flex-wrap:wrap; }

/* ---------- Region head (destinations) ---------- */
.region__head{
  max-width:640px;
  margin:0 0 2rem;
}
.region__head p{ color:var(--muted); margin:0; }

/* ---------- Destinations ---------- */
.destinations{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1rem;
}
.destinations--dense{
  grid-template-columns:repeat(4, 1fr);
}
@media (max-width: 1024px){
  .destinations,
  .destinations--dense{ grid-template-columns:repeat(3, 1fr); }
}
@media (max-width: 760px){
  .destinations,
  .destinations--dense{ grid-template-columns:repeat(2, 1fr); }
}
@media (max-width: 500px){
  .destinations,
  .destinations--dense{ grid-template-columns:1fr; }
}

.dest{
  position:relative;
  min-height:220px;
  border-radius:var(--radius);
  overflow:hidden;
  color:#fff;
  background-size:cover;
  background-position:center;
  isolation:isolate;
  display:flex;
  align-items:flex-end;
  padding:1.25rem;
  transition:transform .25s;
}
.dest::after{
  content:"";
  position:absolute; inset:0;
  z-index:-1;
  background:linear-gradient(to top, rgba(7,26,46,.85) 0%, rgba(7,26,46,.25) 55%, transparent 100%);
  transition:background .25s;
}
.dest:hover{ transform:translateY(-3px); }
.dest:hover::after{ background:linear-gradient(to top, rgba(7,26,46,.9) 0%, rgba(7,26,46,.4) 55%, rgba(7,26,46,.1) 100%); }
.dest__content h3{ color:#fff; margin:0 0 .15rem; font-size:1.25rem; }
.dest__content span{ font-size:.85rem; color:#e7edf4; opacity:.9; }

/* ---------- Testimonials ---------- */
.testimonials{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.25rem;
}
@media (max-width: 900px){ .testimonials{ grid-template-columns:repeat(2, 1fr); } }
@media (max-width: 580px){ .testimonials{ grid-template-columns:1fr; } }

.tmn{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.75rem;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:1.25rem;
  transition:transform .2s, box-shadow .2s;
}
.tmn:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.tmn blockquote{
  margin:0;
  font-family:var(--font-serif);
  font-size:1.05rem;
  color:var(--ink);
  line-height:1.5;
  font-style:italic;
  position:relative;
  padding-top:1.5rem;
}
.tmn blockquote::before{
  content:"“";
  position:absolute;
  top:-.35rem; left:-.1rem;
  font-size:3.5rem;
  color:var(--accent);
  line-height:1;
  font-family:var(--font-serif);
  opacity:.85;
}
.tmn figcaption{
  display:flex;
  align-items:center;
  gap:.85rem;
  font-size:.88rem;
  color:var(--muted);
  margin-top:auto;
}
.tmn figcaption strong{ color:var(--ink); display:block; font-weight:600; }
.tmn figcaption span{ font-size:.8rem; color:var(--muted); }
.tmn__avatar{
  width:44px; height:44px;
  border-radius:50%;
  display:grid; place-items:center;
  background:var(--a, var(--ink));
  color:#fff;
  font-weight:700;
  font-size:.9rem;
  flex-shrink:0;
}

/* ---------- Callback form ---------- */
.cb{
  display:grid;
  grid-template-columns:1fr 1.15fr;
  gap:3rem;
  align-items:start;
}
@media (max-width: 880px){ .cb{ grid-template-columns:1fr; gap:2rem; } }
.cb__text p{ color:#b8c4d2; max-width:46ch; }
.cb__points{
  list-style:none;
  padding:0;
  margin:1.5rem 0;
  display:grid;
  gap:.6rem;
}
.cb__points li{
  padding-left:1.75rem;
  position:relative;
  color:#e7edf4;
}
.cb__points li::before{
  content:"✓";
  position:absolute; left:0; top:0;
  color:var(--accent-hi);
  font-weight:700;
}
.cb__direct{
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,.1);
}
.cb__direct p{ margin:0 0 .75rem; color:#b8c4d2; font-size:.9rem; }

.cb__form{
  background:#fff;
  color:var(--text);
  padding:2rem;
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  position:relative;
}
@media (max-width: 520px){ .cb__form{ grid-template-columns:1fr; padding:1.5rem; } }

.field{ display:flex; flex-direction:column; gap:.4rem; }
.field--full{ grid-column:1 / -1; }
.field label{
  font-size:.82rem;
  font-weight:600;
  color:var(--ink);
  letter-spacing:.01em;
}
.field__opt{ color:var(--muted); font-weight:400; }
.field input,
.field select,
.field textarea{
  font:inherit;
  padding:.75rem .9rem;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  color:var(--text);
  transition:border-color .2s, box-shadow .2s;
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:0;
  border-color:var(--ink);
  box-shadow:0 0 0 3px rgba(11,39,66,.12);
}
.field textarea{ resize:vertical; min-height:110px; }
.cb__form .btn{ grid-column:1 / -1; margin-top:.5rem; }
.cb__note{
  grid-column:1 / -1;
  margin:0;
  font-size:.8rem;
  color:var(--muted);
  text-align:center;
}

.cb__success{
  grid-column:1 / -1;
  background:#e9f7ee;
  color:#0f6b3a;
  border-radius:var(--radius);
  padding:1.5rem;
  text-align:center;
}
.cb__success h3{ color:#0f6b3a; margin:.5rem 0; }
.cb__success p{ margin:0; color:#1a5a35; }

/* ---------- Contact cards ---------- */
.contact{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1rem;
}
.contact__card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.5rem;
  transition:transform .2s, box-shadow .2s, border-color .2s;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  color:var(--text);
}
.contact__card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
  border-color:transparent;
}
.contact__card h3{ margin:0 0 .25rem; }
.contact__card p{ margin:0 0 .75rem; color:var(--muted); font-size:.95rem; }
.contact__card--static{ cursor:default; }
.contact__card--static:hover{ transform:none; box-shadow:none; border-color:var(--line); }
.contact__icon{
  width:44px; height:44px;
  display:grid; place-items:center;
  border-radius:10px;
  background:var(--soft);
  color:var(--ink);
  margin-bottom:1rem;
}
.contact__icon--whatsapp{ background:#e7fbef; color:var(--whatsapp-d); }
.contact__muted{ font-size:.85rem; color:var(--muted); }

/* ---------- Office / map (contact page) ---------- */
.office{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:3rem;
  align-items:stretch;
}
@media (max-width: 880px){ .office{ grid-template-columns:1fr; } }
.office__text p{ color:var(--muted); max-width:48ch; }
.office__meta{
  list-style:none;
  padding:0;
  margin:1.5rem 0 0;
  display:grid;
  gap:.6rem;
}
.office__meta li{
  display:grid;
  grid-template-columns:130px 1fr;
  padding:.5rem 0;
  border-bottom:1px dashed var(--line);
}
.office__meta strong{ color:var(--ink); font-weight:600; font-size:.9rem; }
.office__meta span{ color:var(--muted); font-size:.95rem; }
.office__map{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  min-height:360px;
  border:1px solid var(--line);
}
.office__map iframe{
  border:0;
  width:100%;
  height:100%;
  min-height:360px;
}

/* ---------- FAQ ---------- */
.faqwrap{ max-width:820px; margin:0 auto; }
.faq{ display:grid; gap:.75rem; }
.faq__item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:1.1rem 1.35rem;
  transition:box-shadow .2s, border-color .2s;
}
.faq__item[open]{
  box-shadow:var(--shadow);
  border-color:transparent;
}
.faq__item summary{
  cursor:pointer;
  font-weight:600;
  color:var(--ink);
  font-size:1rem;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{
  content:"+";
  width:24px; height:24px;
  display:grid; place-items:center;
  background:var(--soft);
  color:var(--ink);
  border-radius:50%;
  font-weight:600;
  font-size:1.1rem;
  transition:transform .2s, background .2s, color .2s;
  flex-shrink:0;
}
.faq__item[open] summary::after{
  transform:rotate(45deg);
  background:var(--ink);
  color:var(--accent);
}
.faq__item p{
  margin:.9rem 0 0;
  color:var(--muted);
  font-size:.97rem;
}

/* ---------- CTA band ---------- */
.cta{
  background:
    linear-gradient(135deg, var(--ink-deep) 0%, var(--ink) 70%, var(--ink-soft) 100%);
  color:#fff;
  padding:3.5rem 0;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
.cta::before{
  content:"";
  position:absolute;
  left:-80px; bottom:-80px;
  width:300px; height:300px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(201,162,75,.15), transparent 70%);
  z-index:-1;
}
.cta__inner{
  display:grid;
  grid-template-columns:1.25fr auto;
  gap:2rem;
  align-items:center;
}
@media (max-width: 780px){ .cta__inner{ grid-template-columns:1fr; } }
.cta h2{ color:#fff; margin:0 0 .5rem; }
.cta p{ color:#d3dbe5; margin:0; max-width:54ch; }
.cta__actions{ display:flex; gap:.75rem; flex-wrap:wrap; }

/* ---------- Footer ---------- */
.footer{
  background:var(--ink-deep);
  color:#b8c4d2;
  font-size:.9rem;
}
.footer__inner{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:2rem;
  padding:3.5rem 24px 2rem;
}
@media (max-width: 780px){ .footer__inner{ grid-template-columns:1fr 1fr; } }
@media (max-width: 480px){ .footer__inner{ grid-template-columns:1fr; } }
.footer__brand p{ color:#8a97a8; max-width:32ch; margin-top:1rem; }
.brand--footer{ color:#fff; }
.brand--footer .brand__tag{ color:var(--accent-hi); }
.footer__col h4{
  color:#fff;
  font-family:var(--font-sans);
  font-size:.95rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  margin:0 0 1rem;
}
.footer__col ul{ list-style:none; padding:0; margin:0; display:grid; gap:.5rem; }
.footer__col a:hover{ color:var(--accent-hi); }
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.07);
  padding:1.25rem 0;
  font-size:.82rem;
  color:#7a8697;
}

/* ---------- Floating WhatsApp ---------- */
.fab{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:60;
  width:56px; height:56px;
  border-radius:50%;
  background:var(--whatsapp);
  color:#fff;
  display:grid;
  place-items:center;
  box-shadow:0 10px 30px rgba(37,211,102,.45), 0 4px 10px rgba(0,0,0,.12);
  transition:transform .2s, background .2s;
}
.fab:hover{ transform:scale(1.06); background:var(--whatsapp-d); }
.fab::before{
  content:"";
  position:absolute; inset:-6px;
  border-radius:50%;
  background:var(--whatsapp);
  opacity:.35;
  z-index:-1;
  animation:pulse 2.2s ease-out infinite;
}
@keyframes pulse{
  0%   { transform:scale(.9); opacity:.45; }
  80%  { transform:scale(1.4); opacity:0; }
  100% { transform:scale(1.4); opacity:0; }
}

/* ---------- Scroll reveal ---------- */
.reveal{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .6s ease, transform .6s ease;
  will-change:opacity, transform;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

/* ---------- CEO showcase (about page) ---------- */
.ceo{
  display:grid;
  grid-template-columns:1fr 1.15fr;
  gap:3rem;
  align-items:center;
  max-width:980px;
  margin:0 auto;
}
@media (max-width: 820px){
  .ceo{ grid-template-columns:1fr; gap:1.75rem; max-width:520px; }
}
.ceo__visual{ position:relative; }
.ceo__photo{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  background:var(--soft);
}
.ceo__badge{
  position:absolute;
  left:-14px;
  bottom:24px;
  background:var(--accent);
  color:#fff;
  border-radius:999px;
  padding:.55rem 1.1rem;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  box-shadow:var(--shadow);
}
.ceo__role{
  color:var(--accent);
  font-weight:600;
  font-size:.82rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin:0 0 .5rem;
}
.ceo__name{
  font-family:var(--font-serif);
  color:var(--ink);
  font-size:clamp(1.75rem, 2.2vw + 1rem, 2.4rem);
  margin:0 0 1rem;
  line-height:1.15;
}
.ceo__bio{ color:var(--muted); max-width:52ch; }
.ceo__sig{
  margin-top:1.25rem;
  padding-top:1.25rem;
  border-top:1px solid var(--line);
  font-size:.88rem;
  color:var(--muted);
  font-style:italic;
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; animation:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}