/* =========================
   TOKENS
========================= */
:root{
  --bg:#0b0b09; --ink:#f6f4ea; --ink-2:#cfc8b4; --gold:#fff1ac; --bronze:#7a4602; --line:#282316;

  --r-2xl:1.4rem; --r-xl:1rem; --r-lg:.8rem;
  --sh-sm:0 10px 22px rgba(0,0,0,.25);
  --sh-md:0 20px 50px rgba(0,0,0,.35);

  --maxw:1120px;
  --gutter: 2rem;

  --fs-h1:clamp(2.35rem, 4.2vw, 3.15rem);
  --fs-h2:clamp(1.7rem, 2.6vw, 2.2rem);
  --fs-lead:clamp(1.06rem, 1.8vw, 1.22rem);
  --fs-base:clamp(1rem, 1.3vw, 1.08rem);

  --ease:cubic-bezier(.2,.8,.2,1);

  --header-h-mobile:64px;
  --header-h-desktop:80px;
  --anchor-offset: var(--header-h-mobile);
}
@media (max-width:480px){ :root{ --gutter: 2.6rem; } }
@media (min-width:901px){ :root{ --anchor-offset: var(--header-h-desktop); } }

/* =========================
   BASE
========================= */
*{box-sizing:border-box}
html,body{height:100%}
html,body{overflow-x:hidden}
html{ scroll-behavior:smooth; scroll-padding-top: var(--anchor-offset); }
body{
  margin:0;
  font-family:'Poppins', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial;
  font-size:var(--fs-base); line-height:1.6;
  color:var(--ink); background:var(--bg);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  padding-left:max(0px, env(safe-area-inset-left));
  padding-right:max(0px, env(safe-area-inset-right));
}
h1,h2,h3,h4,h5{font-family:'Antonio','Poppins',sans-serif;font-weight:400;letter-spacing:.5px;margin:0;color:var(--ink)}
h1{font-weight:700} h2{font-weight:600} h3{font-weight:500}
img{max-width:100%;display:block;height:auto}
.container{width:min(100% - var(--gutter), var(--maxw));margin-inline:auto}
a{text-underline-offset:.18em}
html.nav-open, body.nav-open{ overflow:hidden; height:100%; }

/* Accesibilidad */
.sr-only{position:absolute;width:1px;height:1px;clip:rect(0,0,0,0);overflow:hidden;white-space:nowrap}
.skip-link{position:absolute;left:0;top:-40px;background:var(--gold);color:#3a2a0a;padding:.5rem .8rem;border-radius:0 .5rem .5rem 0;font-weight:600}
.skip-link:focus{top:0}

/* =========================
   HEADER
========================= */
.site-header{
  position:sticky;top:0;z-index:100;
  background:color-mix(in oklab, #000 70%, var(--bg) 30%);
  backdrop-filter:saturate(1.2) blur(6px);
  border-bottom:1px solid var(--line);
  transition: box-shadow .25s var(--ease), background .25s var(--ease);
}
.site-header[data-scrolled="true"]{box-shadow:0 10px 28px rgba(0,0,0,.35)}
.header-inner{display:flex;align-items:center;gap:.8rem;padding:.65rem 0}
@media (min-width:901px){ .header-inner{ padding:1.05rem 0; } }

.brand{
  display:flex;align-items:center;gap:.6rem;
  text-decoration:none;color:var(--ink);font-weight:750
}
/* Logo real (PNG/SVG) */
.brand-logo{
  width:32px;height:32px;object-fit:contain;display:block;
  border-radius:6px; /* opcional: suaviza bordes del favicon cuadrado */
}
.brand-name{letter-spacing:.2px}

/* NAV común */
.site-nav a{
  position:relative;
  padding:.55rem .8rem;border-radius:.65rem;text-decoration:none;
  color:var(--ink-2);
  transition: background .2s var(--ease), color .2s var(--ease);
  font-family:'Antonio','Poppins',sans-serif;
  letter-spacing:.02em;
}
.site-nav a::after{
  content:""; position:absolute; left:.8rem; right:.8rem; bottom:.38rem; height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  transform:scaleX(0); transform-origin:center;
  transition:transform .22s var(--ease);
}
.site-nav a:hover{background:#17140e;color:var(--ink)}
.site-nav a:hover::after{ transform:scaleX(1); }

/* CTA header (desktop: hover negro/blanco) */
.cta-link{
  color:#0b0b09 !important;
  background:linear-gradient(180deg, var(--gold), #e9d479);
  border-radius:.75rem;border:1px solid rgba(0,0,0,.25);font-weight:700;
  transition: background .2s var(--ease), color .2s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease);
}
@media (min-width:901px){
  #site-nav .cta-link:hover{
    background:#000; color:#fff !important; border-color:#3a2f18; box-shadow:0 8px 22px rgba(0,0,0,.35);
  }
}

/* Toggle (hamburger → X animada + halo dorado) */
.nav-toggle{
  display:none;border:0;background:transparent;inline-size:2.75rem;block-size:2.75rem;margin-left:auto;
  position:relative; z-index:2100; border-radius:999px;
  transition: transform .25s var(--ease);
}
.nav-toggle::before{
  content:""; position:absolute; inset:0; border-radius:999px;
  background: radial-gradient(24px 24px at 50% 50%, rgba(255,241,172,.22), transparent 60%);
  opacity:0; transform:scale(.8);
  transition: opacity .22s var(--ease), transform .22s var(--ease);
}
.nav-toggle:hover::before,
.nav-toggle:active::before,
.nav-toggle.active::before{ opacity:1; transform:scale(1); }
.nav-toggle:hover{ transform: rotate(2deg); }
.nav-toggle.active{ transform: rotate(90deg); }
.nav-toggle-bar{
  display:block; width:1.6rem; height:2px; background:var(--ink); position:relative; transition: background .2s var(--ease);
}
.nav-toggle-bar::before,.nav-toggle-bar::after{
  content:""; position:absolute; left:0; right:0; height:2px; background:var(--ink);
  transition: transform .25s var(--ease), top .25s var(--ease), opacity .2s var(--ease);
}
.nav-toggle-bar::before{ top:-6px } .nav-toggle-bar::after { top: 6px }
.nav-toggle.active .nav-toggle-bar{ background:transparent }
.nav-toggle.active .nav-toggle-bar::before{ top:0; transform:rotate(45deg) }
.nav-toggle.active .nav-toggle-bar::after { top:0; transform:rotate(-45deg) }

/* =========================
   HERO
========================= */
.hero{position:relative;border-bottom:1px solid var(--line);background:#0d0d0b; overflow:hidden;}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.08fr .92fr;gap:2rem;align-items:center;padding:clamp(2.2rem, 6vw, 4.8rem) 0}
@media (max-width: 900px){.hero-grid{grid-template-columns:1fr}}
.eyebrow{font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;color:color-mix(in oklab, var(--gold), #fff 20%);font-family:'Poppins',sans-serif}
.hero h1{font-size:var(--fs-h1);line-height:1.08;margin:.35rem 0 .75rem}
.lead{font-size:var(--fs-lead);max-width:52ch;margin:0 0 1.2rem;color:var(--ink-2);font-family:'Poppins',sans-serif}
.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-text{background:#11100d;border:1px solid #2a2416;border-radius:var(--r-2xl);padding:clamp(1rem, 2.6vw, 1.4rem);box-shadow:var(--sh-sm)}
.hero-media{border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--sh-md);position:relative}
.hero-media img{display:block;width:100%;height:100%;object-fit:cover}
.hero-gradient{position:absolute;inset:-10% -10% 0 -10%;z-index:0;background:radial-gradient(60rem 60rem at -10% -20%, rgba(255,241,172,.18) 10%, transparent 60%),radial-gradient(50rem 50rem at 110% 10%, rgba(255,241,172,.14) 10%, transparent 60%),linear-gradient(180deg, #0d0d0b 0%, #0b0b09 100%)}
.hero-ornament{position:absolute;border-radius:999px;filter:blur(28px);opacity:.4}
.hero-ornament.a{width:320px;height:320px;left:4%;top:-6%;background:rgba(122,70,2,.2)}
.hero-ornament.b{width:260px;height:260px;right:2%;top:12%;background:rgba(255,241,172,.16)}
.has-hero-image .hero::before{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.25) 35%, rgba(0,0,0,.2) 60%, rgba(0,0,0,.18))}
.has-hero-image .hero-text{background:rgba(15,14,11,.6);border-color:#2a2416;backdrop-filter:blur(6px) saturate(1.05)}

/* =========================
   SECTIONS
========================= */
.section{padding:clamp(2.4rem, 6vw, 5.2rem) 0; scroll-margin-top: var(--anchor-offset);}
.section-ink{background:#0e0e0c}
.section-void{background:#0b0b09}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:1rem;margin-bottom:1.25rem}
.section-head h2{margin:0;font-size:var(--fs-h2);line-height:1.12}
.muted{color:var(--ink-2);margin:0;font-family:'Poppins',sans-serif}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.9rem;align-items:start}
@media (max-width:900px){.grid-2{grid-template-columns:1fr}}
.stack{display:grid;gap:1rem}

/* Lists & Cards */
.list-check{list-style:none;padding:0;margin:.25rem 0 0}
.list-check li{padding-left:1.5rem;position:relative;margin:.4rem 0;font-family:'Poppins',sans-serif}
.list-check li::before{content:"✚";position:absolute;left:0;top:.05rem;color:var(--gold)}
.quote-card{background:#12110d;border:1px solid #2a2416;border-radius:var(--r-2xl);padding:1.2rem;box-shadow:var(--sh-sm);position:relative}
.quote-mark{width:36px;height:36px;fill:var(--gold);opacity:.35;position:absolute;top:.9rem;right:.9rem}
.media-card{border-radius:var(--r-2xl);overflow:hidden;border:1px solid #2a2416;box-shadow:var(--sh-sm)}

/* Valores */
.values-grid{display:grid;gap:1rem;grid-template-columns: repeat(5, 1fr)}
@media (max-width:1100px){.values-grid{grid-template-columns: repeat(3, 1fr)}}
@media (max-width:700px){.values-grid{grid-template-columns: 1fr}}
.value{background:#12110d;border:1px solid #2a2416;border-radius:var(--r-xl);padding:1rem;box-shadow:var(--sh-sm);display:grid;gap:.45rem;transition: transform .15s var(--ease), box-shadow .2s var(--ease)}
.value:hover{transform:translateY(-2px);box-shadow:0 16px 38px rgba(0,0,0,.4)}
.value h3{margin:.15rem 0 .2rem;color:var(--gold);font-size:1.05rem}
.ic{width:28px;height:28px}
.ic svg{fill:var(--gold)}
.value p{color:var(--ink-2);font-family:'Poppins',sans-serif}

/* Pills */
.pill-row{display:flex;flex-wrap:wrap;gap:.5rem}
.pill{display:inline-block;padding:.38rem .75rem;border-radius:999px;border:1px solid #2a2416;background:#15130f;color:var(--ink-2);font-family:'Poppins',sans-serif}

/* Timeline */
.timeline{display:grid;gap:.9rem}
.timecard{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.95rem;background:#12110d;border:1px solid #2a2416;border-radius:var(--r-xl);padding:.95rem;box-shadow:var(--sh-sm)}
.time-badge{display:inline-block;white-space:nowrap;font-size:.93rem;padding:.38rem .7rem;border-radius:.8rem;color:#2c1e06;background:linear-gradient(180deg, var(--gold), #e9d479);border:1px solid rgba(0,0,0,.25);font-family:'Poppins',sans-serif}
.timebody h3{margin:.1rem 0 .2rem}
.timebody p{margin:0;color:var(--ink-2);font-family:'Poppins',sans-serif}

/* CTA */
.cta-wrap{border:1px solid #2a2416;border-radius:var(--r-2xl);padding:clamp(1.2rem, 3vw, 1.8rem);box-shadow:var(--sh-sm);text-align:center;background:radial-gradient(30rem 30rem at 90% -10%, rgba(255,241,172,.14) 18%, transparent 60%), #100f0c}

/* Formulario */
.form{display:grid;gap:1rem;margin-top:.5rem}
.form-row{display:grid;gap:.45rem}
label{color:var(--ink);font-family:'Poppins',sans-serif}
input,textarea{width:100%;padding:.9rem 1rem;border-radius:.9rem;border:1px solid #2a2416;background:#15130f;outline:none;color:var(--ink);font-family:'Poppins',sans-serif}
input::placeholder,textarea::placeholder{color:#80765e}
input:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,241,172,.18)}
.form-hint{font-size:.9rem;color:var(--ink-2);margin:.2rem 0 0;font-family:'Poppins',sans-serif}
.contact-card{border:1px solid #2a2416;border-radius:var(--r-2xl);padding:1.2rem;background:#12110d;box-shadow:var(--sh-sm);display:grid;gap:1rem}
.contact-block h3{margin:.2rem 0;color:var(--gold)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.88rem 1.15rem;border-radius:.95rem;border:1px solid transparent;text-decoration:none;transition:transform .06s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);font-family:'Poppins',sans-serif}
.btn:hover{transform:translateY(-1px)} .btn:active{transform:translateY(0)}
.btn-primary{color:#2c1e06;background:linear-gradient(180deg, var(--gold), #e9d479);box-shadow:0 10px 26px rgba(0,0,0,.35);font-weight:700}
.btn-primary:hover{box-shadow:0 12px 32px rgba(0,0,0,.45)}
.btn-ghost{background:#15130f;border:1px solid #3a2f18;color:var(--gold);font-weight:600}
.btn-ghost:hover{background:#19160f}

/* Footer */
.site-footer{border-top:1px solid var(--line);background:#0b0b09}
.footer-grid{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;padding:1.2rem 0}
.footer-brand{display:flex;align-items:center;gap:.55rem;font-weight:700}
.footer-nav{display:flex;gap:.5rem;flex-wrap:wrap}
.footer-nav a{color:var(--ink-2);text-decoration:none;padding:.35rem .6rem;border-radius:.6rem;font-family:'Poppins',sans-serif}
.footer-nav a:hover{background:#17140e;color:var(--ink)}
.legal{margin:0;color:#9e9378;font-family:'Poppins',sans-serif}
@media (max-width:800px){.footer-grid{grid-template-columns:1fr;justify-items:center;text-align:center}}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(12px);transition:opacity .6s var(--ease), transform .6s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* =========================
   MENÚ MÓVIL — overlay minimal premium
========================= */
@keyframes menuLinkIn{ from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:none} }

@media (max-width:900px){
  .nav-toggle{display:block}

  .js #site-nav{
    position:fixed; inset:0; z-index:2000;
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    gap:1rem; text-align:center; background:#000;
    transform:translateY(100%); opacity:0; visibility:hidden; pointer-events:none;
    transition:transform .35s var(--ease), opacity .25s var(--ease);
    padding: max(4rem, env(safe-area-inset-top) + 3.5rem) 1.25rem 2rem;
    min-height: 100svh;
  }
  .js #site-nav.open{ transform:translateY(0); opacity:1; visibility:visible; pointer-events:auto; }

  .js #site-nav a{
    color:var(--ink); text-decoration:none;
    font-family:'Antonio','Poppins',sans-serif;
    font-size:1.22rem; font-weight:400; letter-spacing:.02em;
    padding:.5rem .9rem; border-radius:.55rem;
    transition:color .2s var(--ease), background .2s var(--ease);
    opacity:0; animation:menuLinkIn .34s var(--ease) forwards;
    position:relative;
  }
  .js #site-nav a::after{
    content:""; position:absolute; left:.9rem; right:.9rem; bottom:.35rem; height:2px;
    background:linear-gradient(90deg, transparent, var(--gold), transparent);
    transform:scaleX(0); transform-origin:center;
    transition:transform .22s var(--ease);
  }
  .js #site-nav a:hover::after, .js #site-nav a:focus-visible::after{ transform:scaleX(1); }

  .js #site-nav.open a:nth-of-type(1){animation-delay:.02s}
  .js #site-nav.open a:nth-of-type(2){animation-delay:.06s}
  .js #site-nav.open a:nth-of-type(3){animation-delay:.10s}
  .js #site-nav.open a:nth-of-type(4){animation-delay:.14s}
  .js #site-nav.open a:nth-of-type(5){animation-delay:.18s}
  .js #site-nav.open a:nth-of-type(6){animation-delay:.22s}
  .js #site-nav.open a:nth-of-type(7){animation-delay:.26s}
}

/* =========================
   NAV DESKTOP — top-right minimal
========================= */
@media (min-width:901px){
  #site-nav{
    position:fixed; top:0; right:max((100vw - var(--maxw))/2, 1rem); z-index:120;
    transform:none !important; opacity:1 !important; visibility:visible !important; pointer-events:auto !important;
    background:transparent; border:0; padding:.65rem 0;
    display:flex; gap:.25rem; align-items:center;
  }
  .nav-toggle{display:none}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}
