/* ============================================================
   PGS HUNTING — Portalent Global Search
   Sistema de diseño: navy profundo · cobre/dorado · crema
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Manrope:wght@300;400;500;600;700&display=swap');

:root{
  --ink:        #0b1a2b;   /* navy profundo del emblema */
  --ink-2:      #0f2236;
  --ink-3:      #173249;
  --paper:      #f5f2ea;   /* crema cálido */
  --paper-2:    #ece6da;
  --paper-3:    #e2dac9;
  --gold:       #c2a05a;   /* cobre/dorado del logo */
  --gold-2:     #d9bf86;
  --gold-deep:  #a07f3d;
  --sea:        #2f5363;   /* teal náutico sutil */
  --ink-text:   #15212e;   /* texto sobre claro */
  --muted:      #5d6c79;   /* texto secundario claro */
  --on-dark:    #e9e3d6;   /* texto sobre oscuro */
  --on-dark-mut:#9aaab8;
  --line-light: rgba(11,26,43,.12);
  --line-dark:  rgba(255,255,255,.13);

  --serif: 'Playfair Display', Georgia, serif;
  --sans:  'Manrope', system-ui, sans-serif;

  --maxw: 1240px;
  --pad: clamp(22px, 5vw, 88px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  color:var(--ink-text);
  background:var(--paper);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
html,body{ overflow-x:clip; }
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.04; letter-spacing:-.01em; }
.display{ font-size:clamp(2.6rem, 6.4vw, 5.6rem); font-weight:500; }
.h-sec{ font-size:clamp(2rem, 4.4vw, 3.5rem); }
.h-card{ font-family:var(--serif); font-size:clamp(1.4rem,2vw,1.85rem); font-weight:600; }
.lead{ font-size:clamp(1.05rem,1.5vw,1.3rem); line-height:1.62; color:var(--muted); font-weight:400; }
p{ text-wrap:pretty; }

/* eyebrow / kicker */
.eyebrow{
  font-family:var(--sans);
  font-size:.74rem; font-weight:600;
  letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex; align-items:center; gap:.85em;
}
.eyebrow::before{
  content:""; width:34px; height:1px; background:var(--gold); display:inline-block;
}
.eyebrow.center::after{
  content:""; width:34px; height:1px; background:var(--gold); display:inline-block;
}
.eyebrow.on-dark{ color:var(--gold-2); }

/* ---------- layout ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
section{ position:relative; }
.pad-y{ padding-block:clamp(64px, 9vw, 140px); }
.bg-ink{ background:var(--ink); color:var(--on-dark); }
.bg-ink .lead{ color:var(--on-dark-mut); }
.bg-paper-2{ background:var(--paper-2); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--sans); font-weight:600; font-size:.83rem;
  letter-spacing:.14em; text-transform:uppercase;
  padding:1.05em 1.9em; cursor:pointer; border:none;
  transition:all .4s var(--ease); position:relative;
}
.btn .arr{ transition:transform .4s var(--ease); }
.btn:hover .arr{ transform:translateX(5px); }
.btn-gold{ background:var(--gold); color:var(--ink); }
.btn-gold:hover{ background:var(--gold-2); }
.btn-ghost{ background:transparent; color:var(--on-dark); border:1px solid var(--line-dark); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold-2); }
.btn-ink{ background:var(--ink); color:var(--paper); }
.btn-ink:hover{ background:var(--ink-3); }

/* ============================================================
   HEADER  (claro, fijo)
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  background:rgba(245,242,234,.0);
  transition:background .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.solid{
  background:rgba(245,242,234,.94);
  -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
  box-shadow:0 1px 0 var(--line-light), 0 18px 40px -34px rgba(11,26,43,.6);
  border-bottom:1px solid var(--line-light);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  height:84px; max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad);
}
.brand{ display:flex; align-items:center; gap:.7em; }
.brand img{ height:54px; width:auto; transition:height .4s var(--ease); }
.site-header.solid .brand img{ height:46px; }
.nav-links{ display:flex; align-items:center; gap:clamp(18px,2.6vw,40px); list-style:none; }
.nav-links a{
  font-size:.82rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-text); position:relative; padding-block:6px;
  transition:color .3s var(--ease);
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1.5px; width:0;
  background:var(--gold); transition:width .35s var(--ease);
}
.nav-links a:hover{ color:var(--gold-deep); }
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }
.nav-links a.active{ color:var(--gold-deep); }
.nav-cta{ display:inline-flex; }

/* header sobre hero oscuro (homepage) — variante transparente clara */
.site-header.over-hero:not(.solid) .nav-links a{ color:var(--paper); }
.site-header.over-hero:not(.solid) .nav-links a:hover{ color:var(--gold-2); }
.site-header.over-hero:not(.solid) .nav-links a.active{ color:var(--gold-2); }
.site-header.over-hero:not(.solid) .burger span{ background:var(--paper); }

/* burger */
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; }
.burger span{ width:26px; height:2px; background:var(--ink-text); transition:.35s var(--ease); }
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; color:var(--paper); }
.hero-media{ position:absolute; inset:0; z-index:0; background:var(--ink); }
.hero-media video, .hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero-media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(11,26,43,.78) 0%, rgba(11,26,43,.34) 30%, rgba(11,26,43,.46) 56%, rgba(11,26,43,.86) 82%, rgba(11,26,43,.97) 100%);
}
.hero-inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(56px,8vw,110px); padding-top:140px; }
.hero h1{ font-size:clamp(2rem, 4.4vw, 3.6rem); max-width:18ch; margin:.32em 0 .5em; }
.hero .lead{ color:#e7ddca; max-width:54ch; }
.hero-cta{ margin-top:2.4rem; display:flex; gap:18px; flex-wrap:wrap; align-items:center; }
.hero-scroll{
  position:absolute; bottom:26px; right:var(--pad); z-index:2;
  writing-mode:vertical-rl; font-size:.68rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--on-dark-mut); display:flex; align-items:center; gap:14px;
}
.hero-scroll::after{ content:""; width:1px; height:54px; background:linear-gradient(var(--gold),transparent); }

/* coordenadas náuticas decorativas */
.coords{
  position:absolute; top:120px; right:var(--pad); z-index:2;
  font-family:var(--sans); font-size:.66rem; letter-spacing:.22em; color:rgba(233,227,214,.5);
  text-transform:uppercase; text-align:right; line-height:2;
}
.coords b{ color:var(--gold-2); font-weight:600; }

/* ============================================================
   PAGE HEADER (interior)
   ============================================================ */
.page-head{ background:var(--ink); color:var(--paper); padding-top:150px; padding-bottom:clamp(54px,7vw,92px); position:relative; overflow:hidden; }
.page-head::before{
  content:""; position:absolute; right:-6%; top:-30%; width:520px; height:520px;
  background:radial-gradient(circle, rgba(194,160,90,.16), transparent 62%); pointer-events:none;
}
.page-head h1{ font-size:clamp(2.4rem,5vw,4.4rem); margin-top:.32em; max-width:18ch; line-height:1.08; }
.page-head .lead{ color:var(--on-dark-mut); max-width:62ch; margin-top:1.8rem; }
.crumbs{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--on-dark-mut); }
.crumbs a:hover{ color:var(--gold-2); }

/* ============================================================
   bloque intro / texto + imagen
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,84px); align-items:center; }
.split.narrow-text .stack > * + *{ margin-top:1.15rem; }
.stack > h2{ margin-bottom:.2em; }
.media-frame{ position:relative; }
.media-frame img{ width:100%; height:100%; object-fit:cover; }
.media-frame.tall img{ aspect-ratio:4/5; }
.media-frame .tag{
  position:absolute; left:-1px; bottom:-1px; background:var(--ink); color:var(--paper);
  padding:14px 22px; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase;
}
.media-frame .tag b{ color:var(--gold-2); font-weight:600; }
.media-frame::before{
  content:""; position:absolute; inset:14px -14px -14px 14px; border:1px solid var(--gold); z-index:-1;
}

/* ============================================================
   STATS
   ============================================================ */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); }
.stat{ background:var(--ink); padding:clamp(30px,4vw,52px) clamp(24px,3vw,40px); }
.stat .num{ font-family:var(--serif); font-size:clamp(3rem,6vw,5rem); color:var(--gold-2); line-height:1; font-weight:500; }
.stat .lab{ margin-top:.8rem; font-size:.92rem; color:var(--on-dark-mut); letter-spacing:.01em; max-width:24ch; }

/* ============================================================
   SERVICIOS — cards
   ============================================================ */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,32px); }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(20px,2.6vw,40px); }
.s-card{
  background:var(--paper); border:1px solid var(--line-light);
  display:flex; flex-direction:column; overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.s-card .img{ aspect-ratio:16/11; overflow:hidden; }
.s-card .img img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.s-card:hover{ transform:translateY(-7px); box-shadow:0 36px 60px -40px rgba(11,26,43,.45); }
.s-card:hover .img img{ transform:scale(1.06); }
.s-card .body{ padding:clamp(24px,2.4vw,34px); display:flex; flex-direction:column; gap:.85rem; flex:1; }
.s-card .idx{ font-family:var(--serif); font-style:italic; color:var(--gold-deep); font-size:1.1rem; }
.s-card p{ color:var(--muted); font-size:.98rem; }
.bg-ink .s-card{ background:var(--ink-2); border-color:var(--line-dark); }
.bg-ink .s-card p{ color:var(--on-dark-mut); }

/* ============================================================
   DIFERENCIADORES
   ============================================================ */
.diff-list{ border-top:1px solid var(--line-light); }
.diff{
  display:grid; grid-template-columns:auto 1fr 1.3fr; gap:clamp(20px,4vw,60px);
  align-items:baseline; padding:clamp(26px,3.4vw,42px) 0; border-bottom:1px solid var(--line-light);
  transition:padding-left .45s var(--ease);
}
.diff:hover{ padding-left:14px; }
.diff .di{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--gold-deep); }
.diff h3{ font-size:clamp(1.35rem,2.1vw,1.9rem); }
.diff p{ color:var(--muted); }
.bg-ink .diff-list{ border-color:var(--line-dark); }
.bg-ink .diff{ border-color:var(--line-dark); }
.bg-ink .diff p{ color:var(--on-dark-mut); }

/* ============================================================
   SECTORES
   ============================================================ */
.sector{ position:relative; overflow:hidden; min-height:clamp(320px,38vw,440px); display:flex; align-items:flex-end; color:var(--paper); }
.sector img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; transition:transform 1.2s var(--ease); }
.sector::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(11,26,43,.22) 0%, rgba(11,26,43,.4) 42%, rgba(11,26,43,.72) 72%, rgba(11,26,43,.96) 100%); z-index:1; }
.sector:hover img{ transform:scale(1.06); }
.sector .s-in{ position:relative; z-index:2; padding:clamp(26px,3vw,40px); width:100%; }
.sector .s-num{ font-family:var(--serif); font-style:italic; color:var(--gold-2); font-size:1.05rem; }
.sector h3{ font-size:clamp(1.7rem,2.6vw,2.4rem); margin:.25em 0 .4em; text-shadow:0 2px 18px rgba(11,26,43,.5); }
.sector p{ color:#e7dfce; max-width:34ch; font-size:.98rem; text-shadow:0 1px 12px rgba(11,26,43,.55); }
.sector .line{ width:46px; height:2px; background:var(--gold); margin-bottom:1rem; }

/* ============================================================
   GALERÍA
   ============================================================ */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:14px; }
.gallery a{ overflow:hidden; }
.gallery img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.gallery a:hover img{ transform:scale(1.07); }
.g-wide{ grid-column:span 2; }
.g-tall{ grid-row:span 2; }

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{ background:var(--ink-2); color:var(--paper); position:relative; overflow:hidden; }
.cta-band::before{
  content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:760px; height:760px; background:radial-gradient(circle, rgba(194,160,90,.13), transparent 60%);
}
.cta-inner{ position:relative; z-index:2; text-align:center; max-width:720px; margin:0 auto; }
.cta-inner h2{ font-size:clamp(2rem,4vw,3.4rem); margin:.4em 0 .5em; }
.cta-inner .lead{ color:var(--on-dark-mut); margin-bottom:2rem; }

/* ============================================================
   CONTACTO
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(34px,5vw,80px); align-items:start; }
.contact-card{ background:var(--ink); color:var(--paper); padding:clamp(34px,4vw,56px); }
.contact-card .label{ font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-2); }
.contact-card .email{ font-family:var(--serif); font-size:clamp(1.5rem,3vw,2.4rem); margin-top:.3em; display:inline-block; transition:color .3s; }
.contact-card .email:hover{ color:var(--gold-2); }
.contact-card .row + .row{ margin-top:2rem; padding-top:2rem; border-top:1px solid var(--line-dark); }
.contact-card .val{ font-size:1.05rem; margin-top:.35em; }
.contact-meta{ margin-top:2.4rem; border-top:1px solid var(--line-light); }
.contact-meta > div{ display:flex; justify-content:space-between; gap:24px; padding:1rem 0; border-bottom:1px solid var(--line-light); flex-wrap:wrap; }
.contact-meta .cm-k{ font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; }
.contact-meta .cm-v{ color:var(--muted); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--ink); color:var(--on-dark); padding-top:clamp(56px,7vw,90px); }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:clamp(30px,4vw,64px); padding-bottom:clamp(40px,5vw,64px); border-bottom:1px solid var(--line-dark); }
.foot-brand .mark{ font-family:var(--serif); font-size:2rem; letter-spacing:.04em; color:var(--paper); }
.foot-brand .mark b{ color:var(--gold-2); font-weight:500; }
.foot-brand .sub{ font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold-deep); margin-top:.3em; }
.foot-brand p{ color:var(--on-dark-mut); margin-top:1.3rem; max-width:42ch; font-size:.96rem; }
.foot-col h4{ font-family:var(--sans); font-size:.74rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-2); margin-bottom:1.2rem; }
.foot-col ul{ list-style:none; display:flex; flex-direction:column; gap:.7rem; }
.foot-col a, .foot-col li{ color:var(--on-dark-mut); font-size:.96rem; transition:color .3s; }
.foot-col a:hover{ color:var(--gold-2); }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap; padding-block:28px; font-size:.82rem; color:var(--on-dark-mut); }
.foot-bottom .dot{ color:var(--gold); }

/* ============================================================
   PROCESO
   ============================================================ */
.proc{ display:flex; flex-direction:column; gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); }
.proc-step{
  display:grid; grid-template-columns:auto 1fr 280px; gap:clamp(20px,3.4vw,52px);
  align-items:center; background:var(--ink-2); padding:clamp(24px,3vw,40px) clamp(24px,3vw,44px);
}
.proc-step .ps-num{ font-family:var(--serif); font-style:italic; font-size:clamp(2.4rem,5vw,4rem); color:var(--gold); line-height:1; }
.proc-step .ps-body h3{ font-size:clamp(1.5rem,2.4vw,2.1rem); margin-bottom:.4em; }
.proc-step .ps-body p{ color:var(--on-dark-mut); max-width:54ch; }
.proc-step img{ width:100%; height:160px; object-fit:cover; }
@media (max-width:860px){
  .proc-step{ grid-template-columns:auto 1fr; }
  .proc-step img{ display:none; }
}

/* ============================================================
   MISIÓN / VISIÓN
   ============================================================ */
.mv{ background:var(--ink-2); border:1px solid var(--line-dark); padding:clamp(30px,3.6vw,52px); position:relative; }
.mv::before{ content:""; position:absolute; left:0; top:0; width:64px; height:3px; background:var(--gold); }
.mv-num{ font-family:var(--serif); font-size:clamp(1.7rem,2.6vw,2.4rem); color:var(--gold-2); margin-bottom:1rem; }
.mv p{ color:var(--on-dark-mut); }
.mv p + p{ margin-top:1rem; }

/* ============================================================
   reveal animation
   ============================================================ */
@media (prefers-reduced-motion:no-preference){
  .reveal{ opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
  .reveal.in{ opacity:1; transform:none; }
  .reveal.d1{ transition-delay:.09s; }
  .reveal.d2{ transition-delay:.18s; }
  .reveal.d3{ transition-delay:.27s; }
}

/* RESPONSIVE */
@media (max-width:980px){
  .split, .contact-grid{ grid-template-columns:1fr; }
  .media-frame::before{ inset:10px -10px -10px 10px; }
  .foot-top{ grid-template-columns:1fr 1fr; }
  .grid-3{ grid-template-columns:1fr 1fr; }
  .diff{ grid-template-columns:auto 1fr; }
  .diff .dp{ grid-column:1 / -1; }
}
@media (max-width:760px){
  .nav-cta{ display:none; }
  .burger{ display:flex; }
  .nav-links{
    position:fixed; inset:84px 0 auto 0; flex-direction:column; align-items:flex-start; gap:0;
    background:var(--paper); padding:8px var(--pad) 26px;
    box-shadow:0 24px 40px -28px rgba(11,26,43,.5); border-bottom:1px solid var(--line-light);
    transform:translateY(-12px); opacity:0; pointer-events:none; transition:.4s var(--ease);
  }
  .nav-links.open{ transform:none; opacity:1; pointer-events:auto; }
  .nav-links a{ width:100%; padding:16px 0; border-bottom:1px solid var(--line-light); color:var(--ink-text) !important; }
  .site-header.over-hero:not(.solid) .nav-links a{ color:var(--ink-text); }
  .stats{ grid-template-columns:1fr; }
  .grid-3, .grid-2{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:1fr 1fr; grid-auto-rows:160px; }
  .g-wide{ grid-column:span 2; }
  .coords{ display:none; }
}
@media (max-width:520px){
  .foot-top{ grid-template-columns:1fr; }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ justify-content:center; }
}
