/* ============================================================
   COLUMEN — Design system del sitio público
   Minimalismo moderno sobre la marca existente:
   navy #1a2744 · dorado #8a6d2b · Lora (serif) + Inter (sans)
   Compartido por: landing, páginas de servicios y blog.
   ============================================================ */

:root{
  --navy:#1a2744;
  --navy-2:#233050;
  --gold:#8a6d2b;
  --gold-soft:#b8974a;
  --accent:#6aacd6;
  --paper:#fffdf9;          /* fondo principal, blanco cálido */
  --paper-2:#faf7ef;        /* banda alternativa, crema muy suave */
  --cream:#f4f0e4;
  --ink:#1c1c1c;
  --ink-70:rgba(28,28,28,.72);
  --ink-50:rgba(28,28,28,.52);
  --ink-30:rgba(28,28,28,.30);
  --hairline:#e9e4d4;       /* bordes finos */
  --hairline-2:#f0ecdf;
  --wa:#25d366;
  --wa-dark:#1da851;
  --r:16px;
  --r-sm:10px;
  --container:1080px;
  --ease:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;overflow-x:clip;scrollbar-gutter:stable}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);line-height:1.7;background:var(--paper);overflow-x:clip;min-width:320px;font-size:16px}
h1,h2,h3,h4{font-family:'Lora',Georgia,serif;font-weight:600;letter-spacing:-.015em;line-height:1.18;color:var(--navy);text-wrap:balance}
h1{font-size:clamp(38px,5.4vw,62px)}
h2{font-size:clamp(27px,3.4vw,40px)}
h3{font-size:20px}
p{text-wrap:pretty}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--navy);color:var(--cream)}
em.it{font-style:italic;color:var(--gold)}

.container{max-width:var(--container);margin:0 auto;padding:0 32px}
.label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:16px}

/* Accesibilidad */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--gold-soft);outline-offset:3px;border-radius:3px}
.skip-link{position:absolute;top:-100px;left:8px;background:var(--navy);color:var(--cream);padding:10px 16px;border-radius:8px;font-weight:600;font-size:14px;z-index:200;transition:top .2s}
.skip-link:focus{top:8px}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-size:15px;font-weight:500;padding:15px 30px;border-radius:999px;border:none;cursor:pointer;transition:background .2s,box-shadow .25s,color .2s,border-color .2s,transform .2s var(--ease);letter-spacing:.01em}
.btn:active{transform:scale(.97)}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 4px 14px -6px rgba(37,211,102,.35)}
.btn-wa:hover{background:var(--wa-dark);box-shadow:0 12px 28px -8px rgba(37,211,102,.5);transform:translateY(-2px)}
.btn-navy{background:var(--navy);color:var(--cream)}
.btn-navy:hover{background:var(--navy-2);box-shadow:0 12px 28px -8px rgba(26,39,68,.45);transform:translateY(-2px)}
.btn-line{background:transparent;border:1px solid var(--ink-30);color:var(--ink)}
.btn-line:hover{border-color:var(--navy);color:var(--navy);background:rgba(26,39,68,.04)}

/* ---------- Header claro con blur ---------- */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,253,249,.86);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--hairline)}
.nav{display:flex;align-items:center;gap:20px;height:86px}
.logo-wrap{display:flex;align-items:center;flex-shrink:0;min-width:0}
.logo-wrap svg{height:64px;width:auto;max-width:300px;display:block}
.logo-wrap .logo-m{display:none}

/* Marca nueva en el header: imagen 3D + wordmark */
.brand-mark{width:54px;height:54px;border-radius:50%;display:block;box-shadow:0 2px 10px -3px rgba(26,39,68,.3),0 0 0 1px rgba(184,151,74,.18);flex-shrink:0}
.brand-text{display:flex;flex-direction:column;gap:5px;margin-left:14px;padding-left:14px;border-left:1px solid rgba(26,39,68,.16);min-width:0}
.brand-name{font-family:'Lora',Georgia,serif;font-weight:700;font-size:21px;letter-spacing:.16em;color:var(--navy);line-height:1;white-space:nowrap}
.brand-sub{font-family:'Inter',sans-serif;font-weight:600;font-size:8.5px;letter-spacing:.34em;color:var(--gold);line-height:1;white-space:nowrap}

/* Intro: el logo llena la página y vuela al header.
   El fondo vive en .intro-bg y se desvanece SOLO con opacity (composición GPU):
   transicionar background/blend-mode repintaba todo el viewport y trababa el vuelo. */
.intro{position:fixed;inset:0;z-index:300;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:34px}
.intro-bg{position:absolute;inset:0;background:radial-gradient(ellipse 900px 700px at 78% 14%,rgba(184,151,74,.12),transparent 60%),radial-gradient(ellipse 700px 600px at 8% 92%,rgba(106,172,214,.09),transparent 65%),var(--paper);will-change:opacity}
.intro-bg::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");opacity:.04}
.intro.done{pointer-events:none}
.intro.done .intro-bg{opacity:0;transition:opacity .85s ease .25s}
.intro-stage{position:relative;z-index:1;display:flex;align-items:center;justify-content:center}
/* OJO: la animación de entrada NO lleva fill 'both'/'forwards' — un fill activo
   pisa el transform inline y el vuelo no corre (el logo quedaba clavado al centro). */
.intro-mark{width:min(280px,52vw);height:auto;aspect-ratio:1;border-radius:50%;display:block;position:relative;z-index:1;box-shadow:0 40px 80px -28px rgba(26,39,68,.32),0 14px 30px -14px rgba(26,39,68,.16),0 0 0 1px rgba(184,151,74,.12);will-change:transform;animation:introIn .9s var(--ease),markBreathe 3s ease-in-out .95s infinite}
.intro-ring{position:absolute;inset:-11%;border-radius:50%;border:1.5px dashed rgba(184,151,74,.6);animation:ringIn 1s var(--ease),spin 9s linear .9s infinite;transition:opacity .3s;will-change:transform,opacity}
.intro-ring::before{content:'';position:absolute;top:-4.5px;left:50%;width:9px;height:9px;border-radius:50%;background:var(--gold-soft);box-shadow:0 0 12px rgba(184,151,74,.9)}
@keyframes markBreathe{0%,100%{transform:scale(1)}50%{transform:scale(1.045)}}
.intro-word{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:9px;animation:wordIn .8s var(--ease) .4s both;transition:opacity .28s,transform .28s}
.intro-word .intro-name{font-family:'Lora',Georgia,serif;font-weight:700;font-size:clamp(26px,4vw,34px);letter-spacing:.22em;color:var(--navy);line-height:1;padding-left:.22em}
.intro-word .intro-sub{font-family:'Inter',sans-serif;font-weight:600;font-size:clamp(10px,1.3vw,12px);letter-spacing:.42em;color:var(--gold);line-height:1;padding-left:.42em}
.intro.fly .intro-ring{opacity:0;animation-play-state:paused,paused}
.intro.fly .intro-word{opacity:0;transform:translateY(10px)}
@keyframes introIn{from{opacity:0;transform:scale(.78)}60%{opacity:1}to{opacity:1;transform:scale(1)}}
@keyframes ringIn{from{opacity:0;transform:scale(.66) rotate(-40deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}
@keyframes wordIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
/* El wordmark del header aparece cuando el logo aterriza */
.brand-text.landing{opacity:0;transform:translateX(-10px)}
.brand-text.landed{opacity:1;transform:translateX(0);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.nav > nav{flex:1;display:flex;justify-content:center;min-width:0}
.nav nav ul{display:flex;gap:30px;list-style:none;white-space:nowrap}
.nav nav a{font-size:14px;color:var(--ink-70);transition:color .2s;position:relative;padding:4px 0}
.nav nav a::after{content:'';position:absolute;left:0;bottom:-2px;width:100%;height:1.5px;background:var(--gold-soft);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.nav nav a:hover{color:var(--navy)}
.nav nav a:hover::after,.nav nav a[aria-current=page]::after{transform:scaleX(1)}
.nav nav a[aria-current=page]{color:var(--navy);font-weight:500}
.nav-cta{background:var(--navy);color:var(--cream);font-size:13.5px;padding:11px 22px;border-radius:999px;font-weight:500;display:inline-flex;align-items:center;gap:8px;transition:background .2s,box-shadow .25s,transform .15s;border:none;cursor:pointer;white-space:nowrap}
.nav-cta:hover{background:var(--navy-2);box-shadow:0 8px 20px -6px rgba(26,39,68,.35)}
.nav-cta:active{transform:scale(.97)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--navy);padding:8px}

/* Menú mobile (overlay claro) */
.mobile-overlay{position:fixed;inset:0;z-index:100;background:var(--paper);display:flex;flex-direction:column;transform:translateY(-102%);transition:transform .4s var(--ease);pointer-events:none}
.mobile-overlay.open{transform:translateY(0);pointer-events:auto}
.mobile-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:0 18px;height:64px;border-bottom:1px solid var(--hairline)}
.mobile-overlay-header .logo-wrap svg{height:44px}
.mobile-close{background:none;border:none;cursor:pointer;color:var(--navy);padding:8px}
.mobile-overlay-body{flex:1;display:flex;flex-direction:column;justify-content:center;padding:0 32px}
.mobile-overlay-body ul{list-style:none}
.mobile-overlay-body a{display:block;padding:18px 0;font-size:22px;font-family:'Lora',Georgia,serif;font-weight:500;color:var(--navy);border-bottom:1px solid var(--hairline-2);transition:color .15s,padding-left .2s}
.mobile-overlay-body a:hover{color:var(--gold);padding-left:6px}
.mobile-overlay-body li:first-child a{border-top:1px solid var(--hairline-2)}
.mobile-overlay-footer{padding:22px 32px calc(22px + env(safe-area-inset-bottom))}
.mobile-overlay-footer .btn-wa{width:100%;}

/* ---------- Secciones ---------- */
section{padding:110px 0}
[id]{scroll-margin-top:104px}
.band{background:radial-gradient(900px 480px at 88% 0%,rgba(184,151,74,.06),transparent 60%),radial-gradient(700px 420px at 0% 100%,rgba(106,172,214,.05),transparent 65%),var(--paper-2);border-top:1px solid var(--hairline-2);border-bottom:1px solid var(--hairline-2)}
.sec-head{max-width:620px;margin-bottom:64px}
.sec-head h2{margin-bottom:16px}
.sec-head p{font-size:17px;line-height:1.7;color:var(--ink-50)}
.sec-center{text-align:center;margin-left:auto;margin-right:auto}

/* ---------- Hero ---------- */
.hero{padding:96px 0 100px;position:relative;overflow:hidden;isolation:isolate}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 800px 560px at 88% 8%,rgba(184,151,74,.10),transparent 62%),radial-gradient(ellipse 640px 480px at 2% 96%,rgba(106,172,214,.08),transparent 65%);pointer-events:none;z-index:-1}
.hero::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");opacity:.03;pointer-events:none;z-index:-1}
.hero{text-align:center}
.hero-text{max-width:780px;margin:0 auto}
.hero .label{margin-bottom:22px}
.hero h1{margin-bottom:26px}
.hero h1 em.it{background:linear-gradient(180deg,transparent 70%,rgba(184,151,74,.20) 70%);padding:0 4px;margin:0 -4px;border-radius:2px}
.hero-sub{font-size:18px;line-height:1.7;color:var(--ink-50);max-width:560px;margin:0 auto 10px}
.hero-line{font-size:16.5px;color:var(--ink-70);margin:0 auto 40px;max-width:560px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
@keyframes spin{to{transform:rotate(360deg)}}

/* Stats minimal en línea, sin banda */
.stats{display:flex;justify-content:center;gap:0;margin-top:88px}
.stat{padding:0 56px;text-align:center}
.stat + .stat{border-left:1px solid var(--hairline)}
.stat-num{font-family:'Lora',serif;font-size:34px;font-weight:600;color:var(--navy);line-height:1.1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.stat-label{font-size:13.5px;color:var(--ink-50);margin-top:6px}

/* ---------- Cards de servicios ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.svc-grid + .svc-grid{margin-top:16px}
.service{background:var(--paper);border:1px solid var(--hairline);border-radius:var(--r);padding:36px 30px;transition:transform .4s var(--ease),box-shadow .35s,border-color .25s;display:flex;flex-direction:column;box-shadow:0 1px 2px rgba(26,39,68,.03),0 12px 32px -22px rgba(26,39,68,.10)}
.service:hover{transform:translateY(-4px);border-color:#d9d2bc;box-shadow:0 2px 4px rgba(26,39,68,.04),0 24px 48px -20px rgba(26,39,68,.18)}
.service-ico{width:46px;height:46px;margin-bottom:22px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:rgba(138,109,43,.07);color:var(--gold);transition:background .3s,transform .4s var(--ease)}
.service-ico svg{width:23px;height:23px}
.service:hover .service-ico{background:rgba(138,109,43,.15);transform:rotate(-5deg) scale(1.08)}
.service h3{margin-bottom:10px}
.service ul{list-style:none;margin-top:6px}
.service ul li{font-size:14.5px;line-height:1.65;color:var(--ink-70);padding:4px 0 4px 18px;position:relative}
.service ul li::before{content:"";position:absolute;left:0;top:13px;width:5px;height:5px;border-radius:50%;border:1.5px solid var(--gold-soft)}
.svc-more{margin-top:auto;padding-top:18px;font-size:13.5px;font-weight:500;color:var(--gold);display:inline-flex;align-items:center;gap:6px;transition:gap .2s,color .2s}
.svc-more:hover{color:var(--navy);gap:10px}

/* ---------- Pasos del proceso ---------- */
.how-intro{max-width:720px;margin:0 auto 64px;font-size:16.5px;line-height:1.75;color:var(--ink-50);text-align:center}
.how-intro + .how-intro{margin-top:-48px}
.how-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid var(--hairline)}
.step{padding:36px 22px 8px;position:relative;text-align:left}
.step + .step{border-left:1px solid var(--hairline)}
.step-num{font-family:'Lora',serif;font-size:15px;font-weight:600;color:var(--gold);margin-bottom:14px;letter-spacing:.06em}
.step h3{font-size:16.5px;font-family:'Inter',sans-serif;font-weight:600;color:var(--navy);margin-bottom:8px;letter-spacing:-.005em}
.step p{font-size:14px;line-height:1.6;color:var(--ink-50)}
.how-note{margin:72px auto 0;font-size:13.5px;color:var(--ink-50);max-width:680px;text-align:center;line-height:1.7}

/* ---------- Quiénes somos ---------- */
.about-text{max-width:760px;margin:0 auto;text-align:center}
.about-text p{font-family:'Lora',Georgia,serif;font-size:clamp(21px,2.6vw,28px);line-height:1.55;color:var(--navy);font-weight:500}

/* ---------- Equipo ---------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.team-card{background:var(--paper);border:1px solid var(--hairline);border-radius:var(--r);padding:38px 30px;transition:transform .4s var(--ease),box-shadow .35s,border-color .25s;box-shadow:0 1px 2px rgba(26,39,68,.03),0 12px 32px -22px rgba(26,39,68,.10)}
.team-card:hover{transform:translateY(-4px);border-color:#d9d2bc;box-shadow:0 2px 4px rgba(26,39,68,.04),0 24px 48px -20px rgba(26,39,68,.18)}
.team-role{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:16px}
.team-card h3{font-size:20px;margin-bottom:12px}
.team-cred{font-size:13px;color:var(--ink-50);line-height:1.6;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--hairline-2)}
.team-card>p{font-size:14.5px;line-height:1.7;color:var(--ink-70)}
.team-note{margin-top:48px;font-size:14px;line-height:1.7;color:var(--ink-50);max-width:720px;margin-left:auto;margin-right:auto;text-align:center}

/* ---------- CTA (momento navy) ---------- */
.cta{padding:110px 0;text-align:center}
.cta-box{background:var(--navy);color:var(--cream);border-radius:24px;padding:90px 48px;max-width:900px;margin:0 auto;position:relative;isolation:isolate;overflow:hidden;box-shadow:0 30px 70px -24px rgba(26,39,68,.38),0 8px 24px -10px rgba(26,39,68,.2)}
.cta-box::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 700px 500px at 85% -10%,rgba(184,151,74,.16),transparent 60%),radial-gradient(ellipse 500px 400px at 0% 110%,rgba(106,172,214,.09),transparent 65%);pointer-events:none;z-index:-1}
.cta-box::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");opacity:.045;pointer-events:none;z-index:-1}
.cta-box .label{color:var(--gold-soft)}
.cta-box h2{color:var(--cream);margin-bottom:18px}
.cta-box h2 em.it{color:var(--gold-soft)}
.cta-box p{color:rgba(244,240,228,.55);font-size:17px;max-width:460px;margin:0 auto 36px;line-height:1.65}
.cta-box .btn-wa{font-size:16px;padding:17px 36px}
.cta-email{margin:26px auto 0;font-size:14px;color:rgba(244,240,228,.5)}
.cta-email a{color:var(--gold-soft);border-bottom:1px solid rgba(184,151,74,.35);transition:border-color .2s,color .2s}
.cta-email a:hover{color:var(--cream);border-color:var(--cream)}

/* ---------- Footer ---------- */
footer.site{background:var(--navy);color:rgba(244,240,228,.4);padding:56px 0 40px;overflow:hidden}
/* Brand nuevo en footer (variante sobre navy) */
.foot-brand .brand-mark{width:62px;height:62px;box-shadow:0 4px 16px -4px rgba(0,0,0,.5),0 0 0 1px rgba(184,151,74,.3)}
.foot-brand .brand-text{border-left-color:rgba(244,240,228,.18)}
.foot-brand .brand-name{color:var(--cream);font-size:23px}
.foot-brand .brand-sub{color:var(--gold-soft)}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px;font-size:13.5px;min-width:0;max-width:100%}
.foot .logo-wrap svg{height:88px;max-width:380px}
.foot-info{text-align:right;line-height:1.8}
.foot-legal a{color:rgba(244,240,228,.85);border-bottom:1px solid rgba(244,240,228,.25);transition:color .2s,border-color .2s}
.foot-legal a:hover{color:var(--cream);border-color:rgba(244,240,228,.6)}
.foot-addr{font-style:normal;display:block}
.foot-hours{margin-top:4px;color:rgba(244,240,228,.55);font-size:12.5px}
.foot-map{flex-basis:100%;margin-top:20px;max-width:520px;width:100%;min-width:0;overflow:hidden;border-radius:12px}
.foot-map iframe{filter:grayscale(.35) contrast(.95);max-width:100%;display:block;border:0}
@media(min-width:769px){.foot-map{margin-left:auto;flex-basis:auto;max-width:380px}}

/* ---------- WhatsApp flotante ---------- */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:60;width:56px;height:56px;border-radius:50%;background:var(--wa);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(37,211,102,.35);transition:background .2s,transform .2s}
.wa-float:hover{background:var(--wa-dark);transform:scale(1.06)}

/* ---------- Animación reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  *,*::before,*::after{animation:none!important;transition-duration:.01ms!important}
}

/* ============================================================
   Sub-páginas (servicios SEO + blog)
   ============================================================ */
.page-hero{padding:88px 0 64px;border-bottom:1px solid var(--hairline-2);position:relative;isolation:isolate;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 700px 420px at 92% 0%,rgba(184,151,74,.08),transparent 62%),radial-gradient(ellipse 540px 380px at 0% 100%,rgba(106,172,214,.06),transparent 65%);pointer-events:none;z-index:-1}
.breadcrumb{font-size:13px;color:var(--ink-50);margin-bottom:22px;display:flex;gap:8px;flex-wrap:wrap}
.breadcrumb a{color:var(--gold);transition:color .2s}
.breadcrumb a:hover{color:var(--navy)}
.breadcrumb .sep{color:var(--ink-30)}
.page-hero h1{font-size:clamp(32px,4.4vw,50px);margin-bottom:18px;max-width:820px}
.page-hero .lead{font-size:18px;line-height:1.7;color:var(--ink-50);max-width:680px}

.article{padding:72px 0 96px}
.prose{max-width:720px;margin:0 auto}
.prose h2{font-size:clamp(23px,2.8vw,30px);margin:56px 0 18px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:19px;margin:36px 0 12px}
.prose p{font-size:16.5px;line-height:1.85;color:var(--ink-70);margin-bottom:18px}
.prose ul,.prose ol{margin:0 0 22px 4px;list-style:none}
.prose ul li,.prose ol li{font-size:16px;line-height:1.75;color:var(--ink-70);padding:5px 0 5px 24px;position:relative}
.prose ul li::before{content:"";position:absolute;left:2px;top:17px;width:6px;height:6px;border-radius:50%;border:1.5px solid var(--gold-soft)}
.prose ol{counter-reset:item}
.prose ol li{counter-increment:item}
.prose ol li::before{content:counter(item) ".";position:absolute;left:0;top:5px;font-family:'Lora',serif;font-weight:600;color:var(--gold)}
.prose a{color:var(--gold);border-bottom:1px solid rgba(184,151,74,.35);transition:color .2s,border-color .2s}
.prose a:hover{color:var(--navy);border-color:var(--navy)}
.prose strong{color:var(--navy);font-weight:600}
.prose blockquote{border-left:2px solid var(--gold-soft);padding:6px 0 6px 24px;margin:28px 0;font-family:'Lora',serif;font-style:italic;font-size:18px;color:var(--navy)}

/* FAQ con details */
.faq{max-width:720px;margin:64px auto 0}
.faq h2{font-size:clamp(23px,2.8vw,30px);margin-bottom:26px}
.faq details{border-top:1px solid var(--hairline)}
.faq details:last-child{border-bottom:1px solid var(--hairline)}
.faq summary{cursor:pointer;padding:22px 36px 22px 2px;font-size:16.5px;font-weight:500;color:var(--navy);list-style:none;position:relative;transition:color .2s}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:22px;font-weight:300;color:var(--gold);transition:transform .25s var(--ease)}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq summary:hover{color:var(--gold)}
.faq .faq-body{padding:0 2px 24px;font-size:15.5px;line-height:1.8;color:var(--ink-70);max-width:660px}

/* CTA inline al final de artículos */
.article-cta{max-width:720px;margin:72px auto 0;background:var(--paper-2);border:1px solid var(--hairline);border-radius:var(--r);padding:44px 40px;text-align:center}
.article-cta h2{font-size:24px;margin-bottom:10px}
.article-cta p{font-size:15.5px;color:var(--ink-50);margin-bottom:26px;line-height:1.7}

/* ---------- Blog ---------- */
.post-list{max-width:760px;margin:0 auto;padding:0}
.post-item{display:block;padding:40px 0;border-bottom:1px solid var(--hairline)}
.post-item:first-child{border-top:1px solid var(--hairline)}
.post-item .post-date{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:10px}
.post-item h2{font-size:clamp(21px,2.6vw,28px);margin-bottom:10px;transition:color .25s}
.post-item:hover h2{color:var(--gold)}
.post-item p{font-size:15.5px;line-height:1.75;color:var(--ink-50);max-width:640px}
.post-item .read-more{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:13.5px;font-weight:500;color:var(--gold);transition:gap .2s}
.post-item:hover .read-more{gap:10px}
.post-meta{font-size:13px;color:var(--ink-50);margin-bottom:28px;display:flex;gap:10px;align-items:center}
.post-meta .post-date{color:var(--gold);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:12px}
.empty-blog{text-align:center;padding:80px 24px;color:var(--ink-50);font-size:16px}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .svc-grid{grid-template-columns:1fr 1fr}
  .how-steps{grid-template-columns:repeat(3,1fr)}
  .how-steps .step:nth-child(4){border-left:none}
  .how-steps .step:nth-child(n+4){border-top:1px solid var(--hairline)}
  .team-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}
  .stat{padding:0 32px}
}
@media(max-width:768px){
  .nav>nav{display:none}
  .menu-btn{display:block;margin-left:auto}
  .nav{height:66px;gap:10px}
  .logo-wrap .logo-d{display:none}
  .logo-wrap .logo-m{display:block;height:42px;max-width:210px}
  .brand-mark{width:42px;height:42px}
  .brand-text{gap:4px;margin-left:10px;padding-left:10px}
  .brand-name{font-size:16.5px;letter-spacing:.13em}
  .brand-sub{font-size:7px;letter-spacing:.26em}
  .nav-cta{font-size:12.5px;padding:9px 16px;gap:6px}
  .nav-cta svg{width:13px;height:13px}
  section{padding:64px 0}
  .hero{padding:64px 0 60px}
  .hero h1{font-size:clamp(30px,8vw,38px)}
  .hero-sub{font-size:15.5px}
  .hero-line{font-size:14.5px;margin-bottom:30px}
  .hero-cta{flex-direction:column;gap:10px}
  .hero-cta .btn{width:100%}
  .stats{margin-top:44px;flex-wrap:wrap;gap:20px 0}
  .stat{padding:0 12px;flex:1 1 30%}
  .stat-num{font-size:23px}
  .stat-label{font-size:10.5px;line-height:1.4;margin-top:5px}
  [id]{scroll-margin-top:80px}
  .sec-head{margin-bottom:36px}
  .svc-grid{grid-template-columns:1fr;gap:12px}
  .service{padding:28px 22px}
  .how-steps{grid-template-columns:1fr;border-top:none}
  .how-steps .step{border-left:none!important;border-top:1px solid var(--hairline)!important;padding:22px 4px 22px;display:grid;grid-template-columns:40px 1fr;grid-template-areas:"num title" "num desc";column-gap:14px;row-gap:3px}
  .step-num{grid-area:num;margin:2px 0 0;font-size:14px}
  .step h3{grid-area:title;margin:0;font-size:15.5px}
  .step p{grid-area:desc}
  .how-intro{font-size:14.5px;margin-bottom:36px}
  .how-intro + .how-intro{margin-top:-22px}
  .how-note{margin-top:40px;font-size:12.5px}
  .about-text p{font-size:19px}
  .team-card{padding:28px 22px}
  .team-note{font-size:13px;margin-top:32px}
  .cta{padding:64px 0}
  .cta-box{padding:52px 24px;border-radius:18px}
  .cta-box p{font-size:15px;margin-bottom:26px}
  .cta-box .btn-wa{width:100%;font-size:15px}
  .foot{flex-direction:column;text-align:center;gap:16px;align-items:stretch}
  .foot .logo-wrap{justify-content:center}
  .foot .logo-wrap svg{height:84px;max-width:280px}
  .foot-brand .brand-mark{width:52px;height:52px}
  .foot-brand .brand-name{font-size:19px}
  .foot-info{text-align:center;font-size:12px}
  .foot-addr .addr-sep{display:none}
  .foot-addr .addr-line{display:block}
  .foot-map{margin:18px auto 0}
  .foot-map iframe{height:180px}
  .container{padding:0 20px}
  .page-hero{padding:48px 0 40px}
  .page-hero .lead{font-size:15.5px}
  .article{padding:44px 0 64px}
  .prose p{font-size:15.5px}
  .article-cta{padding:32px 22px}
  .article-cta .btn{width:100%}
  .post-item{padding:28px 0}
  .faq{margin-top:44px}
}
@media(max-width:400px){
  .brand-mark{width:38px;height:38px}
  .brand-text{gap:3px;margin-left:8px;padding-left:8px}
  .brand-name{font-size:15px;letter-spacing:.11em}
  .brand-sub{font-size:6.5px;letter-spacing:.22em}
  .foot-brand .brand-mark{width:48px;height:48px}
  .foot-brand .brand-name{font-size:17px}
  .hero h1{font-size:27px}
  .sec-head h2{font-size:23px}
  .stat-num{font-size:20px}
  .logo-wrap .logo-m{height:38px;max-width:185px}
  .nav-cta{font-size:11.5px;padding:8px 12px}
  .container{padding:0 16px}
}
