/* ============================================================
   Villagrán Creative Consulting — One-Page styles
   Palette: ink #2E2A24 · amber #C2683C (accent <10%) · ivory #F5F1EA
            cream #FBF9F4 · sand #E6DECF · stone #8C857A
   Type: Hanken Grotesk (primary) · Spectral (editorial)
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face { font-family:'Hanken Grotesk'; font-weight:300; font-display:swap; src:url('../fonts/HankenGrotesk-Light.ttf') format('truetype'); }
@font-face { font-family:'Hanken Grotesk'; font-weight:400; font-display:swap; src:url('../fonts/HankenGrotesk-Regular.ttf') format('truetype'); }
@font-face { font-family:'Hanken Grotesk'; font-weight:500; font-display:swap; src:url('../fonts/HankenGrotesk-Medium.ttf') format('truetype'); }
@font-face { font-family:'Hanken Grotesk'; font-weight:600; font-display:swap; src:url('../fonts/HankenGrotesk-SemiBold.ttf') format('truetype'); }
@font-face { font-family:'Hanken Grotesk'; font-weight:700; font-display:swap; src:url('../fonts/HankenGrotesk-Bold.ttf') format('truetype'); }
@font-face { font-family:'Spectral'; font-weight:300; font-style:normal; font-display:swap; src:url('../fonts/Spectral-Light.ttf') format('truetype'); }
@font-face { font-family:'Spectral'; font-weight:400; font-style:normal; font-display:swap; src:url('../fonts/Spectral-Regular.ttf') format('truetype'); }
@font-face { font-family:'Spectral'; font-weight:500; font-style:normal; font-display:swap; src:url('../fonts/Spectral-Medium.ttf') format('truetype'); }
@font-face { font-family:'Spectral'; font-weight:400; font-style:italic; font-display:swap; src:url('../fonts/Spectral-Italic.ttf') format('truetype'); }

/* ---------- Tokens ---------- */
:root{
  --ink:#2E2A24;
  --amber:#C2683C;
  --ivory:#F5F1EA;
  --cream:#FBF9F4;
  --sand:#E6DECF;
  --stone:#8C857A;
  --ink-80:rgba(46,42,36,.80);
  --ink-60:rgba(46,42,36,.60);
  --line:rgba(46,42,36,.12);

  --sans:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --serif:'Spectral',Georgia,serif;

  --container:1140px;
  --pad:24px;
  --r:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  font-weight:400;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--amber);color:var(--ivory);}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--pad);}

/* ---------- Shared type ---------- */
.eyebrow{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.0625rem;
  color:var(--amber);
  letter-spacing:.01em;
  margin-bottom:1.1rem;
}
.serif-it{font-family:var(--serif);font-style:italic;font-weight:400;}

.section{padding:120px 0;}
.section__title{
  font-size:clamp(1.9rem,3.6vw,3rem);
  font-weight:600;
  line-height:1.12;
  letter-spacing:-0.015em;
  max-width:18ch;
  margin-bottom:1.6rem;
}
.section__intro{
  font-size:1.18rem;
  color:var(--ink-80);
  max-width:50ch;
  margin-bottom:3.5rem;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:600;font-size:1rem;
  padding:15px 30px;border-radius:999px;
  background:var(--ink);color:var(--ivory);
  border:1.5px solid var(--ink);
  transition:transform .35s var(--ease),background .35s var(--ease),color .35s var(--ease);
}
.btn:hover{background:var(--amber);border-color:var(--amber);transform:translateY(-2px);}
.btn--small{padding:10px 22px;font-size:.95rem;}
.btn--light{background:var(--ivory);color:var(--ink);border-color:var(--ivory);}
.btn--light:hover{background:var(--amber);border-color:var(--amber);color:var(--ivory);}

.link-arrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:500;color:var(--ink);
  border-bottom:1.5px solid transparent;padding-bottom:2px;
  transition:gap .3s var(--ease),border-color .3s var(--ease);
}
.link-arrow i{width:18px;height:18px;transition:transform .3s var(--ease);}
.link-arrow:hover{border-color:var(--amber);}
.link-arrow:hover i{transform:translateX(4px);}
.link-arrow--light{color:var(--ivory);}

/* ---------- Navigation ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
}
.nav.is-scrolled{
  background:rgba(251,249,244,.86);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 1px 0 var(--line);
  padding:12px 0;
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;}
.nav__logo img{height:26px;width:auto;}
.nav__links{display:flex;align-items:center;gap:34px;}
.nav__links a{font-weight:500;font-size:1rem;color:var(--ink-80);transition:color .3s var(--ease);}
.nav__links a:hover{color:var(--ink);}
.nav__links a.btn{color:var(--ivory);}
.nav__links a.btn:hover{color:var(--ivory);}
.nav__toggle{
  display:none;background:none;border:none;cursor:pointer;color:var(--ink);
}
.nav__toggle i{width:26px;height:26px;}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  padding:200px 0 140px;
}
.hero__inner{position:relative;z-index:2;max-width:60ch;}
.hero__title{
  font-size:clamp(2.6rem,6vw,4.6rem);
  font-weight:700;line-height:1.04;letter-spacing:-0.025em;
  margin-bottom:1.8rem;
}
.hero__sub{font-size:1.25rem;color:var(--ink-80);max-width:54ch;margin-bottom:2.6rem;}
.hero__actions{display:flex;align-items:center;gap:28px;flex-wrap:wrap;margin-bottom:2.4rem;}
.hero__lead{font-family:var(--serif);font-style:italic;color:var(--stone);font-size:1.05rem;}
.hero__mark{
  position:absolute;top:50%;right:-60px;transform:translateY(-50%);
  width:min(46vw,560px);opacity:.05;z-index:1;pointer-events:none;
}
.hero__mark img{width:100%;}

/* ---------- The difference ---------- */
.difference{background:var(--ivory);}
.difference__body{display:grid;grid-template-columns:1fr 1fr;gap:40px;max-width:900px;margin-bottom:4.5rem;}
.difference__body p{color:var(--ink-80);font-size:1.1rem;}

.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.card{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--r);
  padding:36px 32px;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(46,42,36,.35);}
.card__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:52px;height:52px;border-radius:12px;
  background:var(--sand);color:var(--amber);margin-bottom:22px;
}
.card__icon i{width:26px;height:26px;}
.card h3{font-size:1.22rem;font-weight:600;line-height:1.25;margin-bottom:.7rem;}
.card p{color:var(--ink-60);font-size:1.02rem;}

/* ---------- Services ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-bottom:56px;}
.pillar{position:relative;padding-top:18px;border-top:2px solid var(--ink);}
.pillar__num{
  font-family:var(--serif);font-size:1rem;color:var(--stone);
  position:absolute;top:18px;right:0;
}
.pillar__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:50%;
  border:1.5px solid var(--line);color:var(--amber);
  margin:26px 0 22px;
  transition:border-color .4s var(--ease),background .4s var(--ease);
}
.pillar__icon i{width:26px;height:26px;}
.pillar:hover .pillar__icon{background:var(--ink);border-color:var(--ink);color:var(--ivory);}
.pillar h3{font-size:1.35rem;font-weight:600;line-height:1.2;margin-bottom:.9rem;}
.pillar p{color:var(--ink-80);font-size:1.04rem;}

.services__support{
  display:flex;align-items:flex-start;gap:22px;
  background:var(--ivory);border-radius:var(--r);
  padding:34px 38px;max-width:820px;
}
.services__support-icon{
  flex:none;display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:12px;background:var(--sand);color:var(--amber);
}
.services__support-icon i{width:24px;height:24px;}
.services__support p{color:var(--ink-80);font-size:1.08rem;}

/* ---------- Process ---------- */
.process{background:var(--ink);color:var(--ivory);}
.process .eyebrow{color:var(--amber);}
.process .section__title{color:var(--ivory);}
.steps{
  list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:36px;
  margin:10px 0 56px;
}
.step{position:relative;padding-top:32px;border-top:1px solid rgba(245,241,234,.18);}
.step__num{
  font-family:var(--serif);font-size:2.6rem;font-weight:300;
  color:var(--amber);display:block;margin-bottom:.5rem;line-height:1;
}
.step h3{font-size:1.5rem;font-weight:600;margin-bottom:.8rem;}
.step p{color:rgba(245,241,234,.74);font-size:1.05rem;}
.process__cta{margin-top:8px;}
.process .btn{background:var(--ivory);color:var(--ink);border-color:var(--ivory);}
.process .btn:hover{background:var(--amber);border-color:var(--amber);color:var(--ivory);}

/* ---------- About ---------- */
.about__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center;}
.about__text p{color:var(--ink-80);font-size:1.1rem;margin-bottom:1.2rem;max-width:50ch;}
.signature{
  font-family:var(--serif);font-style:italic;color:var(--ink);
  font-size:1.18rem;margin-top:2rem;
}
.signature span{display:block;font-size:.95rem;color:var(--stone);font-style:normal;font-family:var(--sans);margin-top:.25rem;}
.about__quote{
  position:relative;background:var(--ivory);border-radius:var(--r);
  padding:54px 48px;
}
.about__quote blockquote{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1.6rem;line-height:1.4;color:var(--ink);
}
.quote-mark{
  font-family:var(--serif);font-size:4rem;color:var(--amber);
  display:block;line-height:.6;height:2.4rem;
}
.about__seal{position:absolute;bottom:34px;right:38px;width:64px;opacity:.9;}

/* ---------- Trusted ---------- */
.trusted{background:var(--ivory);}
.quote-card{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--r);
  padding:34px 32px;display:flex;flex-direction:column;justify-content:space-between;
}
.quote-card blockquote{
  font-family:var(--serif);font-size:1.18rem;line-height:1.45;color:var(--ink);
  margin-bottom:1.8rem;
}
.quote-card figcaption{font-weight:600;font-size:1rem;color:var(--ink);}
.quote-card figcaption span{display:block;font-weight:400;color:var(--stone);font-size:.95rem;}
.trusted__note{margin-top:2rem;font-size:.92rem;color:var(--stone);font-style:italic;font-family:var(--serif);}

/* ---------- CTA ---------- */
.cta{background:var(--ink);color:var(--ivory);text-align:center;}
.cta__inner{max-width:62ch;margin:0 auto;display:flex;flex-direction:column;align-items:center;}
.cta__title{
  font-size:clamp(2.1rem,4.4vw,3.4rem);font-weight:700;line-height:1.1;
  letter-spacing:-0.02em;margin-bottom:1.4rem;
}
.cta .serif-it{color:var(--ivory);}
.cta__body{font-size:1.2rem;color:rgba(245,241,234,.78);margin-bottom:2.6rem;}
.cta__actions{display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap;}

/* Animated brand seal */
.cta__seal{width:118px;height:118px;margin-bottom:38px;}
.seal{width:100%;height:100%;overflow:visible;}
.seal__ring{transform-origin:100px 100px;animation:seal-spin 26s linear infinite;}
.seal__disc{transform-origin:100px 100px;animation:seal-breathe 6s var(--ease) infinite;}
.seal__v{transform-box:fill-box;transform-origin:center;animation:seal-breathe 6s var(--ease) infinite;}
@keyframes seal-spin{to{transform:rotate(360deg);}}
@keyframes seal-breathe{0%,100%{transform:scale(1);}50%{transform:scale(1.04);}}

/* CTA contact line */
.cta__contact{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap;margin-top:30px;}
.cta__contact-link{
  display:inline-flex;align-items:center;gap:10px;
  color:rgba(245,241,234,.82);font-size:1.02rem;font-weight:500;
  border-bottom:1.5px solid transparent;padding-bottom:3px;
  transition:color .3s var(--ease),border-color .3s var(--ease);
}
.cta__contact-link i{width:18px;height:18px;color:var(--amber);}
.cta__contact-link:hover{color:var(--ivory);border-color:var(--amber);}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:var(--ivory);padding:72px 0 32px;border-top:1px solid rgba(245,241,234,.12);}
.footer__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;padding-bottom:48px;}
.footer__logo{height:56px;width:auto;border-radius:8px;margin-bottom:20px;}
.footer__tagline{font-family:var(--serif);font-style:italic;color:rgba(245,241,234,.74);font-size:1.1rem;max-width:34ch;}
.footer__contact{display:flex;flex-direction:column;gap:14px;}
.footer__contact p{display:flex;align-items:center;gap:12px;color:rgba(245,241,234,.86);font-size:1.02rem;}
.footer__contact i{width:18px;height:18px;color:var(--amber);flex:none;}
.footer__contact a{transition:color .3s var(--ease);}
.footer__contact a:hover{color:var(--amber);}
.footer__legal{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:28px;border-top:1px solid rgba(245,241,234,.12);
  font-size:.9rem;color:rgba(245,241,234,.6);
}
.footer__top{display:inline-flex;align-items:center;gap:.5rem;transition:color .3s var(--ease);}
.footer__top i{width:16px;height:16px;}
.footer__top:hover{color:var(--amber);}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.is-visible{opacity:1;transform:none;}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .nav__links{
    position:fixed;top:0;right:0;height:100vh;width:min(78vw,320px);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:26px;
    background:var(--cream);padding:0 38px;
    transform:translateX(100%);transition:transform .4s var(--ease);
    box-shadow:-20px 0 60px -30px rgba(46,42,36,.5);
  }
  .nav__links.is-open{transform:translateX(0);}
  .nav__toggle{display:inline-flex;z-index:101;}
  .section{padding:88px 0;}
  .hero{padding:160px 0 100px;}
  .difference__body{grid-template-columns:1fr;gap:18px;}
  .cards-3,.pillars,.steps{grid-template-columns:1fr;}
  .about__grid{grid-template-columns:1fr;gap:40px;}
  .footer__grid{grid-template-columns:1fr;gap:36px;}
}
@media (max-width:560px){
  body{font-size:16px;}
  .hero__actions{gap:18px;}
  .services__support{flex-direction:column;gap:18px;}
  .footer__legal{flex-direction:column;gap:14px;align-items:flex-start;}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;}
  .reveal{opacity:1;transform:none;transition:none;}
  .btn,.card,.link-arrow i{transition:none;}
  .seal__ring,.seal__disc,.seal__v{animation:none;}
}
