:root{
  --green:#173d34;
  --green-2:#0f2b24;
  --green-3:#2f6b5d;
  --sand:#f7f3ec;
  --sand-2:#efe7dc;
  --ink:#171918;
  --text:#343b38;
  --muted:#68726d;
  --line:#ded6c9;
  --white:#fff;
  --shadow:0 18px 60px rgba(23,61,52,.10);
  --shadow-hover:0 26px 70px rgba(23,61,52,.16);
  --radius:28px;
  --radius-sm:18px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;text-rendering:optimizeLegibility}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  color:var(--text);
  background:var(--sand);
  line-height:1.68;
  -webkit-font-smoothing:antialiased;
}

.container{width:min(1140px,92vw);margin-inline:auto}
.skip-link{position:absolute;left:-999px;top:8px;background:#fff;padding:8px 12px;z-index:99;border-radius:8px}
.skip-link:focus{left:8px}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(247,243,236,.86);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(23,61,52,.09);
  transition:background .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
}
.site-header.is-scrolled{
  background:rgba(255,255,255,.90);
  border-bottom-color:rgba(23,61,52,.12);
  box-shadow:0 12px 34px rgba(23,61,52,.08);
}
.nav{height:74px;display:flex;align-items:center;justify-content:space-between;transition:height .35s var(--ease)}
.site-header.is-scrolled .nav{height:66px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--green);font-weight:800}
.brand-mark{
  display:grid;place-items:center;width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--green-3));color:#fff;
  box-shadow:0 10px 24px rgba(23,61,52,.22);
}
.brand-text{text-transform:uppercase;letter-spacing:.10em;font-size:.78rem}
.nav-menu{display:flex;align-items:center;gap:30px}
.nav-menu a{
  position:relative;
  color:var(--ink);
  text-decoration:none;
  font-size:.94rem;
  font-weight:600;
  transition:color .25s var(--ease);
}
.nav-menu a:not(.nav-cta)::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-7px;
  height:2px;
  background:var(--green);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .28s var(--ease);
}
.nav-menu a:hover,.nav-menu a.active{color:var(--green)}
.nav-menu a:hover::after,.nav-menu a.active::after{transform:scaleX(1)}
.nav-cta{background:var(--green);color:#fff!important;padding:12px 20px;border-radius:999px;box-shadow:0 10px 24px rgba(23,61,52,.16)}
.nav-cta:hover{background:var(--green-2);transform:translateY(-1px)}
.nav-toggle{display:none}

/* General */
.section{padding:80px 0}
.hero.section{padding:68px 0 82px}
.hero{min-height:calc(100vh - 74px);display:flex;align-items:center;background:
  radial-gradient(circle at 86% 12%,rgba(23,61,52,.14),transparent 34%),
  linear-gradient(180deg,#fbf8f2 0%,var(--sand) 100%);
}
.hero-grid,.split{display:grid;grid-template-columns:1.05fr .95fr;gap:68px;align-items:flex-start}
.hero-grid{padding-top:4px}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:12px;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--green);
  font-size:.76rem;
  font-weight:800;
  margin:0 0 16px;
}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--green);opacity:.55}
h1,h2,h3{line-height:1.08;margin:0;color:var(--green-2)}


h1{
  font-size:clamp(2rem,3.5vw,3.5rem);
  letter-spacing:-.06em;
  line-height:1.02;
  max-width:850px;
  font-weight:800;
}

h2{
  font-size:clamp(1.8rem,3vw,3rem);
  letter-spacing:-.045em;
  line-height:1.08;
  font-weight:800;
}

h3{
  font-size:1.5rem;
  letter-spacing:-.02em;
  line-height:1.15;
  font-weight:800;
}



.hero-lead{font-size:1.2rem;color:#2d3430;margin-top:24px}
.hero-copy p:not(.eyebrow){max-width:680px}
p{margin:0 0 18px}.section-copy p{font-size:1.08rem;color:#343b38}

/* Buttons */
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}.hero-actions.center{justify-content:center}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:52px;
  padding:15px 25px;
  border-radius:999px;
  text-decoration:none;
  font-weight:800;
  letter-spacing:-.01em;
  transition:transform .28s var(--ease),box-shadow .28s var(--ease),background .28s var(--ease),color .28s var(--ease),border-color .28s var(--ease);
  position:relative;
  overflow:hidden;
}
.btn::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.22) 48%,transparent 100%);
  transform:translateX(-120%);
  transition:transform .6s var(--ease);
}
.btn:hover::after{transform:translateX(120%)}
.btn.primary{background:var(--green);color:#fff;box-shadow:0 14px 34px rgba(23,61,52,.18)}
.btn.primary:hover{background:var(--green-2);transform:translateY(-2px);box-shadow:0 20px 42px rgba(23,61,52,.24)}
.btn.secondary{border:1px solid rgba(23,61,52,.35);color:var(--green);background:rgba(255,255,255,.48)}
.btn.secondary:hover{border-color:var(--green);background:#fff;transform:translateY(-2px);box-shadow:0 14px 34px rgba(23,61,52,.10)}
.btn:focus-visible,.nav-menu a:focus-visible,.nav-toggle:focus-visible{outline:3px solid rgba(47,107,93,.34);outline-offset:4px}

/* Hero visual */
.hero-visual{
  position:relative;min-height:540px;border-radius:var(--radius);
  background:linear-gradient(135deg,#315d52 0%,#173d34 52%,#0d211c 100%);
  box-shadow:var(--shadow);overflow:hidden;
  transition:transform .6s var(--ease),box-shadow .6s var(--ease);
}
.hero-visual:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.hero-visual:before{
  content:"";position:absolute;inset:38px;border:1px solid rgba(255,255,255,.16);border-radius:22px;
  background:
    linear-gradient(135deg,rgba(255,255,255,.10),transparent 42%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.075) 0 1px,transparent 1px 44px),
    repeating-linear-gradient(0deg,rgba(255,255,255,.055) 0 1px,transparent 1px 44px);
}
.hero-visual:after{content:"";position:absolute;inset:auto -18% -20% 20%;height:48%;background:radial-gradient(circle,rgba(255,255,255,.20),transparent 68%)}
.portrait-placeholder{position:absolute;right:40px;bottom:40px;width:58%;height:70%;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.28),rgba(255,255,255,.08));display:grid;place-items:end center;padding:26px;color:#fff;font-weight:800;letter-spacing:.02em;z-index:1}
.dashboard-card{position:absolute;background:rgba(255,255,255,.94);border:1px solid rgba(255,255,255,.55);border-radius:18px;padding:18px 20px;box-shadow:0 20px 50px rgba(0,0,0,.16);z-index:2;backdrop-filter:blur(10px)}
.dashboard-card span{display:block;color:var(--muted);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.dashboard-card strong{font-size:2rem;color:var(--green);letter-spacing:-.04em}.card-a{right:60px;bottom:40px}.card-b{left:40px;bottom:75px}

/* Sections */
.intro,.experience{background:#fff}.section-heading{max-width:840px}.section-heading h2{max-width:780px}.section-heading:after{content:"";display:block;width:74px;height:3px;background:var(--green);border-radius:999px;margin-top:28px;opacity:.75}
.services-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:48px}.service-card{background:rgba(255,255,255,.82);border:1px solid var(--line);border-radius:24px;padding:30px 28px;min-height:310px;transition:transform .28s var(--ease),box-shadow .28s var(--ease),border-color .28s var(--ease),background .28s var(--ease);position:relative;overflow:hidden}.service-card:before{content:"";position:absolute;left:28px;right:28px;top:0;height:3px;background:var(--green);transform:scaleX(.45);transform-origin:left;opacity:.55;transition:transform .28s var(--ease),opacity .28s var(--ease)}.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);border-color:rgba(23,61,52,.22);background:#fff}.service-card:hover:before{transform:scaleX(1);opacity:1}.icon{display:inline-flex;color:var(--green);font-weight:900;margin-bottom:28px;font-size:.9rem;letter-spacing:.10em}.service-card p{color:var(--muted);font-size:.96rem;margin-top:14px}

.hotels{background:var(--green);color:#fff;position:relative;overflow:hidden}.hotels:before{content:"";position:absolute;inset:-30% auto auto -20%;width:520px;height:520px;border-radius:50%;background:rgba(255,255,255,.07)}.hotels h2,.hotels .eyebrow{color:#fff}.hotels .eyebrow::before{background:#fff}.hotels p{color:rgba(255,255,255,.84)}.reverse{grid-template-columns:.9fr 1.1fr}.image-panel{min-height:520px;border-radius:var(--radius);background:linear-gradient(135deg,rgba(255,255,255,.24),rgba(255,255,255,.055));display:grid;place-items:center;border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.10)}.image-placeholder{font-weight:800;letter-spacing:.10em;text-transform:uppercase;color:rgba(255,255,255,.72)}

.timeline{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:48px}.timeline-item{border-left:3px solid var(--green);padding:10px 0 10px 24px;transition:transform .25s var(--ease),border-color .25s var(--ease)}.timeline-item:hover{transform:translateX(4px);border-left-color:var(--green-3)}.timeline-item p{color:#4d5551}.signature{margin-top:40px!important;color:var(--green);font-family:Georgia,"Times New Roman",serif;font-size:1.45rem}.signature span{font-family:Inter,Arial,sans-serif;font-size:.82rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}

.cta{background:var(--sand)}.cta-box{text-align:center;background:#fff;border:1px solid rgba(23,61,52,.08);border-radius:var(--radius);padding:76px 44px;box-shadow:var(--shadow);position:relative;overflow:hidden}.cta-box:before{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:120px;height:4px;background:var(--green);border-radius:0 0 999px 999px}.cta-box p{max-width:690px;margin-inline:auto;color:var(--muted)}
.footer{background:var(--green-2);color:#fff;padding:28px 0}.footer-inner{display:flex;justify-content:space-between;gap:20px}.footer a{color:#fff;text-underline-offset:4px}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}.reveal.visible{opacity:1;transform:none}

@media (max-width:980px){.nav-toggle{display:block;border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 14px;font-weight:700;color:var(--green)}.nav-menu{position:absolute;left:4vw;right:4vw;top:86px;display:none;flex-direction:column;align-items:flex-start;background:#fff;padding:24px;border-radius:22px;box-shadow:var(--shadow)}.nav-menu.open{display:flex}.hero-grid,.split,.reverse{grid-template-columns:1fr}.hero-visual{min-height:440px}.services-grid{grid-template-columns:repeat(2,1fr)}.timeline{grid-template-columns:1fr}.section{padding:78px 0}.hero{min-height:auto}.hero-copy{padding-top:12px}}
@media (max-width:620px){.brand-text{display:none}.services-grid{grid-template-columns:1fr}.hero-visual{min-height:380px}.portrait-placeholder{width:70%;right:22px;bottom:22px}.dashboard-card{padding:14px 16px}.dashboard-card strong{font-size:1.65rem}.section{padding:60px 0}h1{font-size:3.18rem}.footer-inner{flex-direction:column}.cta-box{padding:48px 24px}.hero-actions{width:100%}.hero-actions .btn{width:100%}}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}.reveal{opacity:1;transform:none}}


/* Microinteracciones y espaciado fino */
.brand-mark{transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.brand:hover .brand-mark{transform:translateY(-2px) scale(1.03);box-shadow:0 14px 30px rgba(23,61,52,.28)}
.dashboard-card{transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.hero-visual:hover .dashboard-card{box-shadow:0 24px 58px rgba(0,0,0,.18)}
.hero-visual:hover .card-a{transform:translate(4px,-4px)}
.hero-visual:hover .card-b{transform:translate(-3px,4px)}
.service-card,.timeline-item,.cta-box{will-change:transform}
.reveal{transition-delay:var(--reveal-delay,0ms)}
@keyframes softFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes softPulse{0%,100%{opacity:.65}50%{opacity:.95}}
.hero-visual:after{animation:softPulse 7s ease-in-out infinite}
.card-a{animation:softFloat 6.5s ease-in-out infinite}
.card-b{animation:softFloat 7.5s ease-in-out infinite reverse}

@media (max-width:980px){
  .site-header.is-scrolled .nav{height:64px}
  .hero.section{padding:46px 0 70px}
  .hero-grid{gap:44px;padding-top:0}
  .hero-lead{margin-top:20px}
  .hero-actions{margin-top:26px}
}
@media (max-width:620px){
  .hero.section{padding:34px 0 58px}
  .hero-grid{gap:34px}
  .nav{height:68px}
  .site-header.is-scrolled .nav{height:62px}
}

.logo{
  width:220px;
  height:auto;
  display:block;
}

.brand{
  flex-shrink:0;
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
}
.portrait-image{
  position:relative;
  border-radius:32px;
  overflow:hidden;
  height:640px;
  box-shadow:0 30px 60px rgba(0,0,0,0.18);
}

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

.dashboard-card{
  background: rgba(255,255,255,0.5);
color:#0b3a32;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  border:1px solid rgba(255,255,255,0.5);

  box-shadow:
    0 10px 30px rgba(0,0,0,0.08);

  border-radius:24px;
}
.dashboard-card span{
  color:#124d41;
  font-weight:600;
  letter-spacing:0.04em;
}

.image-real{
  border-radius:32px;
  overflow:hidden;
  box-shadow:0 30px 60px rgba(0,0,0,0.12);
}

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

.cta-box{
  padding:50px 50px !important;

  background:
  linear-gradient(
    180deg,
    #ffffff 0%,
    #faf9f6 100%
  );

  border-radius:36px;
}

.cta-box h3{
  margin-bottom:15px;
}

.cta-box p{
  margin-top:0;
}

.signature{
  margin-top:44px;
  font-size:2rem;
  color:#6f7572;
}

.signature span{
  display:block;
  margin-top:10px;

  font-size:1.1rem;
  letter-spacing:0.18em;

  color:#7b817e;
}
.hero-actions.center{
  margin-top:28px;
}
.cta-box{
  border:1px solid rgba(18,77,65,0.05);
}
.hero-lead{
  font-size:1.18rem;
  line-height:1.7;
}

.section-copy{
  max-width:620px;
}
.section-copy{
  max-width:560px;
}
.section-copy{
  padding-top:6px;
}
.footer-inner{
  display:flex;
  justify-content:center;
  align-items:center;
}

.footer-inner p{
  margin:0;
  text-align:center;
}

.contact-buttons{
  display:flex;
  gap:22px;
  justify-content:center;
  align-items:center;
  margin-top:40px;
}

.icon-btn{
  width:72px;
  height:72px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  transition:.25s ease;
  box-shadow:0 12px 30px rgba(0,0,0,.10);
}

.icon-btn i{
  font-size:1.7rem;
}

.icon-btn.dark{
  background:#123c34;
  color:#fff;
}

.icon-btn.light{
  background:#fff;
  color:#123c34;
  border:1px solid rgba(18,60,52,.18);
}

.icon-btn:hover{
  transform:translateY(-3px);
}
.linkedin-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 34px;
  border:1px solid #bfc5bf;
  border-radius:999px;
  color:#0f3b34;
  text-decoration:none;
  font-weight:700;
  font-size:1rem;
  transition:.25s ease;
}

.linkedin-btn:hover{
  background:#0f3b34;
  color:#fff;
}

.linkedin-btn i{
  font-size:1.1rem;
}
.linkedin-wrapper{
  width:100%;
  display:flex;
  justify-content:center;
  margin-top:40px;
}
.story-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:18px 42px;
  border:1px solid rgba(255,255,255,.55);
  border-radius:999px;
  color:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:1.05rem;
  transition:.25s ease;
  background:transparent;
}

.story-btn:hover{
  background:#fff;
  color:#0f3b34;
}

.story-btn i{
  font-size:1rem;
}
.story-btn-wrapper{
  width:100%;
  display:flex;
  justify-content:center;
  margin-top:50px;
}

.story-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:18px 42px;
  border:1px solid rgba(255,255,255,.55);
  border-radius:999px;
  color:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:1.05rem;
  transition:.25s ease;
  background:transparent;
}

.story-btn:hover{
  background:#fff;
  color:#0f3b34;
}