*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}

:root{
  /* Smart JRC Brand Tokens */
  --navy:#3549A0;--navy-dk:#2A3C8E;--navy-lt:#4A5DB8;
  --teal:#2E7A6A;--teal-lt:#3A9A86;
  --forest:#2E6B3A;--forest-lt:#3A8A4E;
  --silver:#9AAAB4;--silver-lt:#C4D0DC;
  --gold:#9A7B4F;--gold-lt:#C4A97D;

  --ink:#0E1530;--ink-2:#1F2748;--smoke:#5A6177;
  --paper:#FAFAF7;--paper-2:#F2F1EC;--white:#FFFFFF;
  --bdr:#E2E5EE;--bdr-dk:#C9CDDB;

  --r:14px;--r-sm:8px;--r-pill:999px;
  --shd-sm:0 1px 3px rgba(14,21,48,.06),0 1px 2px rgba(14,21,48,.04);
  --shd:0 8px 24px rgba(14,21,48,.08),0 2px 6px rgba(14,21,48,.05);
  --shd-lg:0 24px 60px rgba(14,21,48,.14),0 6px 16px rgba(14,21,48,.06);
  --ez:cubic-bezier(.4,.2,.2,1);
}

html,body{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  background:var(--paper);color:var(--ink);
  line-height:1.6;font-size:16px;
  background-image:
    radial-gradient(ellipse 70% 50% at 90% 0%,rgba(53,73,160,.05) 0%,transparent 60%),
    radial-gradient(ellipse 60% 40% at 0% 80%,rgba(46,122,106,.04) 0%,transparent 55%);
  background-attachment:fixed;
  overflow-x:hidden;
}

.serif{font-family:'Cormorant Garamond',serif}
h1,h2,h3,h4,.display{font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:-.01em}
h1{font-size:clamp(38px,5.5vw,68px);line-height:1.05}
h2{font-size:clamp(28px,3.8vw,46px);line-height:1.15}
h3{font-size:clamp(20px,2vw,28px);line-height:1.25}
h4{font-size:clamp(18px,1.5vw,22px);line-height:1.3}
em{font-style:italic;color:var(--teal-lt);font-weight:400}
p{color:var(--ink-2)}

.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.wrap-sm{max-width:820px;margin:0 auto;padding:0 24px}

/* ─── NAV ──────────────────── */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(250,250,247,.85);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bdr);
}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:88px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
.brand-logo{display:block;width:auto;height:72px;max-width:340px;object-fit:contain}
.brand-mark{
  width:40px;height:40px;border-radius:9px;
  background:linear-gradient(135deg,var(--navy),var(--teal),var(--silver));
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;
  box-shadow:0 2px 8px rgba(53,73,160,.25);
  letter-spacing:.5px;
}
.brand-name{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;letter-spacing:-.01em}
.brand-name span{color:var(--teal);font-style:italic;font-weight:400}

.nav-links{display:flex;align-items:center;gap:32px}
.nav-link{
  color:var(--ink-2);text-decoration:none;font-size:14px;font-weight:500;
  transition:color .15s var(--ez);position:relative;
}
.nav-link:hover{color:var(--navy)}
.nav-link::after{
  content:'';position:absolute;left:0;right:0;bottom:-6px;height:1px;
  background:var(--teal);transform:scaleX(0);transition:transform .25s var(--ez);
}
.nav-link:hover::after{transform:scaleX(1)}
.nav-cta{
  background:linear-gradient(135deg,var(--navy),var(--navy-dk));
  color:#fff;border:none;padding:11px 22px;border-radius:var(--r-sm);
  font-family:'Inter',sans-serif;font-size:14px;font-weight:600;
  cursor:pointer;text-decoration:none;display:inline-block;
  transition:transform .15s var(--ez),box-shadow .15s var(--ez);
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(53,73,160,.32)}

.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--ink)}

/* ─── HERO ──────────────────── */
.hero{
  position:relative;padding:96px 0 88px;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(ellipse 50% 70% at 80% 30%,rgba(46,122,106,.08),transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 60%,rgba(53,73,160,.06),transparent 60%);
  pointer-events:none;
}
.hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:start;
  position:relative;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px;border:1px solid var(--bdr-dk);border-radius:var(--r-pill);
  font-size:12px;font-weight:600;color:var(--smoke);
  text-transform:uppercase;letter-spacing:.12em;
  background:rgba(255,255,255,.6);backdrop-filter:blur(8px);
  margin-bottom:28px;
}
.hero-eyebrow::before{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 3px rgba(46,122,106,.2);
}
.hero h1{margin-bottom:24px}
.hero h1 .accent{color:var(--teal);font-style:italic;font-weight:400}
.hero-sub{
  font-size:clamp(17px,1.4vw,20px);color:var(--ink-2);
  max-width:560px;margin-bottom:36px;line-height:1.55;
}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 28px;border-radius:var(--r-sm);
  font-family:'Inter',sans-serif;font-size:15px;font-weight:600;
  text-decoration:none;cursor:pointer;border:none;
  transition:transform .15s var(--ez),box-shadow .15s var(--ez),background .2s var(--ez);
}
.btn-primary{
  background:linear-gradient(135deg,var(--navy),var(--navy-dk));
  color:#fff;box-shadow:0 6px 20px rgba(53,73,160,.28);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(53,73,160,.4)}
.btn-primary .arrow{transition:transform .25s var(--ez)}
.btn-primary:hover .arrow{transform:translateX(4px)}
.btn-ghost{
  background:transparent;color:var(--ink);
  border:1px solid var(--bdr-dk);
}
.btn-ghost:hover{border-color:var(--ink);background:rgba(14,21,48,.03)}

.hero-trust{
  display:flex;gap:32px;margin-top:48px;padding-top:32px;
  border-top:1px solid var(--bdr);
  flex-wrap:wrap;
}
.trust-item{display:flex;flex-direction:column;gap:4px}
.trust-num{
  font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:600;
  color:var(--navy);line-height:1;
}
.trust-num em{color:var(--teal);font-weight:500}
.trust-lbl{font-size:13px;color:var(--smoke);font-weight:500}

/* Hero visual (right column) */
.hero-visual{
  position:relative;
  margin-top:52px;
  aspect-ratio:4/5;
  border-radius:20px;
  overflow:hidden;
  background:
    linear-gradient(135deg,#1F2748 0%,#2A3C8E 50%,#2E7A6A 100%);
  box-shadow:var(--shd-lg);
}
.hero-visual::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 30% 20%,rgba(255,255,255,.15),transparent 50%),
    radial-gradient(circle at 80% 80%,rgba(154,123,79,.25),transparent 55%);
}
.hero-visual::after{
  content:'';position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg,transparent,transparent 30px,rgba(255,255,255,.03) 30px,rgba(255,255,255,.03) 31px);
  pointer-events:none;
}
.hero-video-slider{position:absolute;inset:16px;z-index:1;border-radius:16px;overflow:hidden;background:rgba(14,21,48,.42)}
.hero-video-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .45s var(--ez),visibility .45s var(--ez)}
.hero-video-slide.is-active{opacity:1;visibility:visible}
.hero-video-slide video{width:100%;height:100%;object-fit:contain;display:block;background:var(--ink)}
.hero-video-controls{
  position:absolute;left:50%;right:auto;bottom:26px;z-index:3;
  transform:translateX(-50%);
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:max-content;max-width:calc(100% - 40px);
  padding:9px 12px;border-radius:var(--r-pill);
  background:rgba(14,21,48,.52);border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}
.hero-video-btn{
  width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.12);color:#fff;cursor:pointer;
  font-size:22px;line-height:1;display:grid;place-items:center;
  transition:background .2s var(--ez),transform .2s var(--ez);
}
.hero-video-btn:hover{background:rgba(255,255,255,.24);transform:translateY(-1px)}
.hero-video-dots{
  display:flex;align-items:center;justify-content:center;gap:7px;
  flex-wrap:wrap;max-width:210px;
}
.hero-video-dot{
  width:7px;height:7px;border-radius:50%;border:0;padding:0;
  background:rgba(255,255,255,.36);
  cursor:pointer;
  transition:width .2s var(--ez),background .2s var(--ez);
}
.hero-video-dot.is-active{width:20px;border-radius:10px;background:#fff}
.hero-video-sound{
  min-height:34px;border-radius:var(--r-pill);border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.12);color:#fff;cursor:pointer;
  padding:0 12px;font-family:'Inter',sans-serif;font-size:12px;font-weight:700;
  transition:background .2s var(--ez),transform .2s var(--ez);
}
.hero-video-sound:hover,.hero-video-sound.is-on{background:rgba(255,255,255,.24)}

/* ─── FILTRO (PARA TI SI) ──────────────────── */
.filtro{
  padding:96px 0;background:var(--white);
  border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);
}
.filtro-head{text-align:center;margin-bottom:56px}
.sec-eyebrow{
  display:inline-block;font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--teal);margin-bottom:16px;
}
.filtro-head h2{max-width:760px;margin:0 auto}
.filtro-head h2 em{color:var(--teal);font-style:italic}

.filtro-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:20px;
  max-width:920px;margin:0 auto;
}
.filtro-card{
  background:var(--paper);
  border:1px solid var(--bdr);
  border-radius:var(--r);padding:28px 28px 28px 76px;
  position:relative;
  transition:transform .25s var(--ez),box-shadow .25s var(--ez),border-color .2s var(--ez);
}
.filtro-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shd);
  border-color:var(--bdr-dk);
}
.filtro-icon{
  position:absolute;left:24px;top:28px;
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  display:grid;place-items:center;color:#fff;
  box-shadow:0 4px 12px rgba(53,73,160,.25);
}
.filtro-card h4{
  font-family:'Inter',sans-serif;font-size:16px;font-weight:600;
  letter-spacing:0;color:var(--ink);margin-bottom:6px;
}
.filtro-card p{font-size:14px;color:var(--smoke);line-height:1.5;margin:0}

/* ─── PROPUESTA ──────────────────── */
.propuesta{
  padding:120px 0;position:relative;
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
}
.propuesta-in{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:80px;align-items:center;
}
.propuesta-text h2{margin-bottom:24px}
.propuesta-text h2 em{color:var(--teal);font-style:italic}
.propuesta-lead{
  font-size:18px;color:var(--ink-2);line-height:1.6;margin-bottom:24px;
}
.propuesta-quote{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:22px;color:var(--navy);line-height:1.4;
  padding-left:20px;border-left:2px solid var(--teal);
}

.value-list{display:grid;gap:14px}
.value-item{
  background:var(--white);
  border:1px solid var(--bdr);
  border-radius:var(--r);padding:24px 28px;
  display:flex;gap:20px;align-items:flex-start;
  transition:transform .2s var(--ez),box-shadow .2s var(--ez);
  position:relative;overflow:hidden;
}
.value-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--navy),var(--teal));
  transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ez);
}
.value-item:hover{transform:translateX(4px);box-shadow:var(--shd)}
.value-item:hover::before{transform:scaleY(1)}
.value-num{
  font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:500;
  color:var(--teal);line-height:1;flex-shrink:0;width:48px;
}
.value-content h4{
  font-family:'Inter',sans-serif;font-size:16px;font-weight:600;
  margin-bottom:6px;color:var(--ink);
}
.value-content p{font-size:14px;color:var(--smoke);margin:0;line-height:1.5}

/* ─── CTA INTERMEDIO ──────────────────── */
.cta-band{
  padding:80px 0;
  background:linear-gradient(135deg,var(--ink) 0%,var(--navy-dk) 100%);
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 50%,rgba(46,122,106,.18),transparent 50%),
    radial-gradient(circle at 80% 30%,rgba(154,123,79,.12),transparent 55%);
}
.cta-band-in{
  position:relative;text-align:center;color:#fff;
}
.cta-band h2{color:#fff;margin-bottom:18px;max-width:780px;margin-left:auto;margin-right:auto}
.cta-band h2 em{color:var(--teal-lt);font-style:italic}
.cta-band p{
  color:rgba(255,255,255,.78);font-size:18px;
  max-width:620px;margin:0 auto 36px;
}
.cta-band .btn-primary{
  background:linear-gradient(135deg,var(--teal),var(--teal-lt));
  box-shadow:0 8px 28px rgba(46,122,106,.45);
}
.cta-band .btn-primary:hover{box-shadow:0 14px 40px rgba(46,122,106,.6)}

/* ─── SERVICIOS ──────────────────── */
.servicios{padding:120px 0;background:var(--white)}
.servicios-head{text-align:center;margin-bottom:72px}
.servicios-head h2{max-width:760px;margin:0 auto 16px}
.servicios-head h2 em{color:var(--teal);font-style:italic}
.servicios-head p{
  color:var(--smoke);font-size:17px;max-width:580px;margin:0 auto;
}
.servicios-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
}
.serv-card{
  background:var(--paper);
  border:1px solid var(--bdr);
  border-radius:var(--r);padding:40px;
  position:relative;overflow:hidden;
  transition:transform .3s var(--ez),box-shadow .3s var(--ez);
}
.serv-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--navy),var(--teal));
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ez);
}
.serv-card:hover{transform:translateY(-4px);box-shadow:var(--shd-lg)}
.serv-card:hover::before{transform:scaleX(1)}
.serv-num{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:14px;color:var(--teal);font-weight:500;
  margin-bottom:14px;display:block;
  text-transform:uppercase;letter-spacing:.15em;
  font-style:normal;
}
.serv-card h3{margin-bottom:14px;color:var(--ink)}
.serv-tagline{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  color:var(--teal);font-size:17px;margin-bottom:18px;
}
.serv-card p{
  color:var(--ink-2);font-size:15px;line-height:1.6;margin-bottom:20px;
}
.serv-card ul{list-style:none;margin:0;padding:0}
.serv-card ul li{
  font-size:14px;color:var(--smoke);padding:6px 0 6px 22px;
  position:relative;line-height:1.45;
}
.serv-card ul li::before{
  content:'';position:absolute;left:0;top:14px;width:10px;height:1px;
  background:var(--teal);
}

/* ─── DIFERENCIADOR ──────────────────── */
.diferencia{
  padding:120px 0;
  background:
    linear-gradient(180deg,var(--paper-2) 0%,var(--paper) 100%);
  position:relative;
}
.dif-in{max-width:920px;margin:0 auto;text-align:center}
.dif-grid{
  display:grid;grid-template-columns:1fr auto 1fr;gap:48px;
  margin-top:64px;align-items:stretch;
}
.dif-col{
  background:var(--white);border:1px solid var(--bdr);
  border-radius:var(--r);padding:40px 32px;text-align:left;
}
.dif-col-mayoria{opacity:.85}
.dif-eyebrow{
  font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:.18em;margin-bottom:16px;display:block;
}
.dif-col-mayoria .dif-eyebrow{color:var(--smoke)}
.dif-col-tu .dif-eyebrow{color:var(--teal)}
.dif-col h3{
  font-size:24px;margin-bottom:20px;
}
.dif-col-mayoria h3{color:var(--smoke);text-decoration:line-through;text-decoration-color:rgba(154,42,42,.35);text-decoration-thickness:1px}
.dif-col-tu h3{color:var(--navy)}
.dif-col p{font-size:15px;line-height:1.55;color:var(--ink-2)}
.dif-col-tu{
  border:2px solid var(--navy);
  background:linear-gradient(180deg,var(--white) 0%,rgba(53,73,160,.03) 100%);
  box-shadow:var(--shd);
}
.dif-vs{
  display:grid;place-items:center;
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:24px;color:var(--smoke);
}

/* ─── ABOUT ──────────────────── */
.about{
  padding:120px 0;background:var(--white);
  border-top:1px solid var(--bdr);
}
.about-in{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.about-visual{
  aspect-ratio:1/1.1;border-radius:20px;
  background:linear-gradient(135deg,var(--navy),var(--navy-dk),var(--teal));
  position:relative;overflow:hidden;
  box-shadow:var(--shd-lg);
}
.about-visual::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 70% 30%,rgba(255,255,255,.18),transparent 50%),
    radial-gradient(circle at 20% 80%,rgba(154,123,79,.25),transparent 55%);
}
.about-visual::after{
  content:'SJ';
  position:absolute;inset:0;display:grid;place-items:center;
  font-family:'Cormorant Garamond',serif;
  font-size:200px;font-weight:300;color:rgba(255,255,255,.08);
  letter-spacing:-.05em;
}
.about-badges{
  position:absolute;bottom:32px;left:32px;right:32px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
}
.about-badge{
  background:rgba(255,255,255,.14);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:10px;padding:14px 16px;color:#fff;
}
.about-badge-num{
  font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;line-height:1;
}
.about-badge-lbl{font-size:11px;opacity:.85;margin-top:4px;text-transform:uppercase;letter-spacing:.1em}

.about-text h2{margin-bottom:24px}
.about-text h2 em{color:var(--teal);font-style:italic}
.about-text p{
  font-size:17px;line-height:1.65;color:var(--ink-2);margin-bottom:20px;
}
.about-text .pull{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:22px;color:var(--navy);line-height:1.4;
  padding:20px 0 20px 24px;border-left:3px solid var(--teal);
  margin:24px 0;
}

/* ─── BROCHURE CTA ──────────────────── */
.brochure-cta{
  padding:72px 0;
  background:var(--white);
  border-top:1px solid var(--bdr);
}
.brochure-cta-in{
  display:flex;align-items:center;justify-content:space-between;gap:28px;
  background:linear-gradient(135deg,var(--paper) 0%,var(--paper-2) 100%);
  border:1px solid var(--bdr);
  border-radius:var(--r);
  padding:34px 38px;
  box-shadow:var(--shd-sm);
}
.brochure-cta-in .sec-eyebrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 14px;
  margin-bottom:12px;
  color:#fff;
  text-align:center;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  border-radius:var(--r-pill);
  box-shadow:0 8px 22px rgba(53,73,160,.22);
}
.brochure-cta h2{
  max-width:680px;
  font-size:clamp(26px,3vw,38px);
}
.brochure-cta .btn{flex-shrink:0}

/* ─── BLOG (AUTORIDAD) ──────────────────── */
.blog{padding:120px 0;background:var(--paper-2)}
.blog-head{text-align:center;margin-bottom:64px}
.blog-head h2{max-width:680px;margin:0 auto 16px}
.blog-head h2 em{color:var(--teal);font-style:italic}
.blog-head p{color:var(--smoke);font-size:17px;max-width:560px;margin:0 auto}

.blog-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.blog-card{
  background:var(--white);border:1px solid var(--bdr);
  border-radius:var(--r);overflow:hidden;
  transition:transform .25s var(--ez),box-shadow .25s var(--ez);
  cursor:pointer;display:flex;flex-direction:column;
  color:inherit;text-decoration:none;
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shd-lg)}
.blog-card:focus-visible{outline:3px solid rgba(46,122,106,.35);outline-offset:4px}
.blog-cover{
  aspect-ratio:16/10;position:relative;overflow:hidden;
}
.blog-cover-1{background:linear-gradient(135deg,#3549A0,#2E7A6A)}
.blog-cover-2{background:linear-gradient(135deg,#2E6B3A,#3549A0)}
.blog-cover-3{background:linear-gradient(135deg,#9A7B4F,#3549A0)}
.blog-cover-4{background:linear-gradient(135deg,#2A3C8E,#3A9A86)}
.blog-cover-5{background:linear-gradient(135deg,#3A8A4E,#2A3C8E)}
.blog-cover::after{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 70% 30%,rgba(255,255,255,.18),transparent 55%);
}
.blog-num{
  position:absolute;top:16px;left:20px;
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:48px;font-weight:300;color:rgba(255,255,255,.5);line-height:1;
}
.blog-tag{
  position:absolute;bottom:16px;left:20px;
  font-size:10px;font-weight:600;text-transform:uppercase;
  letter-spacing:.15em;color:#fff;
  background:rgba(255,255,255,.18);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:5px 10px;border-radius:var(--r-pill);
  border:1px solid rgba(255,255,255,.25);
}
.blog-body{padding:24px 26px 28px;flex:1;display:flex;flex-direction:column}
.blog-card h4{
  font-family:'Cormorant Garamond',serif;font-size:21px;
  font-weight:500;line-height:1.3;margin-bottom:12px;color:var(--ink);
  letter-spacing:-.005em;
}
.blog-card p{
  font-size:14px;color:var(--smoke);line-height:1.55;margin-bottom:16px;flex:1;
}
.blog-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:var(--smoke);
  padding-top:14px;border-top:1px solid var(--bdr);
}
.blog-read{color:var(--navy);font-weight:600;display:flex;align-items:center;gap:4px}

/* ─── ARTICLE PLACEHOLDER ──────────────────── */
.article-page{background:var(--paper)}
.article-hero{padding:88px 0 72px;background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(242,241,236,.6));border-bottom:1px solid var(--bdr)}
.article-back{display:inline-flex;margin-bottom:34px;color:var(--navy);font-size:14px;font-weight:600;text-decoration:none}
.article-back:hover{text-decoration:underline}
.article-kicker{display:inline-flex;margin-bottom:18px;padding:7px 12px;border-radius:var(--r-pill);background:rgba(46,122,106,.1);color:var(--teal);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.article-hero h1{max-width:760px;margin-bottom:22px}
.article-hero p{max-width:680px;color:var(--smoke);font-size:19px;line-height:1.7}
.article-meta{display:flex;gap:16px;flex-wrap:wrap;margin-top:28px;color:var(--smoke);font-size:13px;font-weight:600}
.article-meta span{padding-right:16px;border-right:1px solid var(--bdr-dk)}
.article-meta span:last-child{border-right:none}
.article-body-section{padding:72px 0 110px}
.article-cover{position:relative;aspect-ratio:16/7;border-radius:var(--r);margin-bottom:48px;overflow:hidden;box-shadow:var(--shd)}
.article-cover::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 74% 24%,rgba(255,255,255,.22),transparent 48%)}
.article-cover span{position:absolute;left:28px;bottom:22px;z-index:1;font-family:'Cormorant Garamond',serif;font-size:76px;font-style:italic;color:rgba(255,255,255,.58);line-height:1}
.article-content{background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);padding:48px;box-shadow:var(--shd-sm)}
.article-content h2{font-size:32px;margin:34px 0 14px;color:var(--ink)}
.article-content p,.article-content li{color:var(--ink-2);font-size:17px;line-height:1.78}
.article-lead{font-size:20px!important;color:var(--ink)!important}
.article-content ul{padding-left:22px;margin:14px 0 0}
.article-note{margin-top:34px;padding:20px 22px;border:1px solid rgba(154,123,79,.28);border-radius:var(--r-sm);background:rgba(154,123,79,.08);color:var(--ink-2);font-size:14px;line-height:1.65}
.article-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}

/* ─── INSTAGRAM FEED ──────────────────── */
.instagram-feed{
  padding:110px 0;background:var(--white);
  border-top:1px solid var(--bdr);
}
.instagram-wrap{
  max-width:none;
  padding-left:0;
  padding-right:0;
}
.instagram-head{text-align:center;margin-bottom:48px;padding:0 24px}
.instagram-head h2{max-width:680px;margin:0 auto}
.instagram-head h2 em{color:var(--teal);font-style:italic}
.instagram-widget{
  width:100vw;
  max-width:100vw;
  margin-left:50%;
  transform:translateX(-50%);
  background:var(--paper);
  border-top:1px solid var(--bdr);
  border-bottom:1px solid var(--bdr);
  padding:24px 0;
  box-shadow:none;
}
.instagram-iframe{
  display:block;
  width:100% !important;
  max-width:100%;
  min-height:760px;
  border:none !important;
  overflow:hidden;
}

/* ─── FINAL CTA ──────────────────── */
.final-cta{
  padding:120px 0;
  background:
    linear-gradient(135deg,var(--ink) 0%,#16204A 50%,var(--navy-dk) 100%);
  position:relative;overflow:hidden;
}
.final-cta::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(ellipse 60% 80% at 80% 20%,rgba(46,122,106,.22),transparent 60%),
    radial-gradient(ellipse 50% 60% at 10% 90%,rgba(154,123,79,.16),transparent 60%);
  pointer-events:none;
}
.final-cta::after{
  content:'';position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(135deg,transparent 0,transparent 60px,rgba(255,255,255,.018) 60px,rgba(255,255,255,.018) 61px);
  pointer-events:none;
}
.final-in{position:relative;z-index:1;text-align:center;color:#fff;max-width:840px;margin:0 auto}
.final-eyebrow{
  display:inline-block;font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:.2em;
  color:var(--teal-lt);margin-bottom:24px;
  padding:7px 18px;border:1px solid rgba(58,154,134,.4);
  border-radius:var(--r-pill);
  background:rgba(46,122,106,.1);
}
.final-cta h2{
  color:#fff;font-size:clamp(34px,4.5vw,54px);
  margin-bottom:24px;line-height:1.1;
}
.final-cta h2 em{color:var(--teal-lt);font-style:italic}
.final-cta p{
  color:rgba(255,255,255,.8);font-size:19px;
  max-width:620px;margin:0 auto 40px;line-height:1.55;
}
.final-cta .btn-primary{
  background:linear-gradient(135deg,var(--teal),var(--teal-lt));
  font-size:16px;padding:18px 36px;
  box-shadow:0 12px 36px rgba(46,122,106,.5);
}
.final-cta .btn-primary:hover{
  box-shadow:0 18px 48px rgba(46,122,106,.65);
  transform:translateY(-2px);
}
.final-disclaimer{
  margin-top:24px;font-size:13px;color:rgba(255,255,255,.55);
}

/* ─── FOOTER ──────────────────── */
.footer{
  background:var(--ink);color:rgba(255,255,255,.7);
  padding:48px 0 28px;
}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;margin-bottom:32px}
.foot h5{color:#fff;font-size:13px;font-weight:700;margin-bottom:14px;letter-spacing:.05em}
.foot a{color:rgba(255,255,255,.7);text-decoration:none;font-size:13px;display:block;padding:4px 0;transition:color .15s}
.foot a:hover{color:var(--teal-lt)}
.foot p{font-size:13px;line-height:1.7;color:rgba(255,255,255,.65)}
.foot-bottom{
  border-top:1px solid rgba(255,255,255,.1);padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  font-size:12px;color:rgba(255,255,255,.5);
}
.foot-soc{display:flex;gap:10px;margin-top:14px}
.foot-soc a{
  width:34px;height:34px;border-radius:8px;
  background:rgba(255,255,255,.08);
  display:grid;place-items:center;padding:0;
}
.foot-soc a:hover{background:rgba(46,122,106,.3)}
.foot-brand-logo{margin-bottom:14px}

/* ─── 404 ──────────────────── */
.not-found-page{
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
.not-found{
  flex:1;
  position:relative;
  padding:96px 0 88px;
  overflow:hidden;
}
.not-found::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(90deg,rgba(53,73,160,.05) 1px,transparent 1px),
    linear-gradient(180deg,rgba(46,122,106,.05) 1px,transparent 1px);
  background-size:72px 72px;
  -webkit-mask-image:linear-gradient(90deg,transparent,black 20%,black 80%,transparent);
  mask-image:linear-gradient(90deg,transparent,black 20%,black 80%,transparent);
  pointer-events:none;
}
.not-found-grid{
  position:relative;
  display:grid;
  grid-template-columns:1fr 420px;
  gap:72px;
  align-items:center;
}
.not-found-copy h1{
  max-width:720px;
  margin-bottom:24px;
}
.not-found-copy h1 .accent{
  color:var(--teal);
  font-style:italic;
  font-weight:400;
}
.not-found-panel{
  position:relative;
  min-height:520px;
  border-radius:20px;
  padding:30px;
  background:
    radial-gradient(circle at 80% 12%,rgba(196,169,125,.34),transparent 32%),
    linear-gradient(145deg,var(--ink),var(--navy-dk) 56%,var(--teal));
  color:#fff;
  box-shadow:var(--shd-lg);
  overflow:hidden;
}
.not-found-panel::before{
  content:'';
  position:absolute;inset:18px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  pointer-events:none;
}
.not-found-code{
  position:absolute;
  top:20px;right:28px;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(86px,10vw,138px);
  font-weight:300;
  line-height:.82;
  color:rgba(255,255,255,.14);
}
.not-found-card{
  position:absolute;
  left:30px;right:30px;bottom:30px;
  padding:28px;
  border-radius:14px;
  background:rgba(255,255,255,.94);
  color:var(--ink);
  box-shadow:0 18px 50px rgba(14,21,48,.26);
}
.not-found-card span{
  display:block;
  margin-bottom:10px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--teal);
}
.not-found-card h2{
  margin-bottom:10px;
  font-size:30px;
}
.not-found-card p{
  margin-bottom:22px;
  color:var(--smoke);
  font-size:14px;
}
.not-found-links{
  position:relative;
  z-index:1;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.not-found-links a{
  color:rgba(255,255,255,.82);
  text-decoration:none;
  font-size:13px;
  font-weight:600;
  padding:9px 12px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r-sm);
  background:rgba(255,255,255,.08);
  transition:background .2s var(--ez),color .2s var(--ez);
}
.not-found-links a:hover{
  background:rgba(255,255,255,.16);
  color:#fff;
}
.not-found-footer{
  padding-top:32px;
}

/* ─── SOLUCIONES (PRODUCTOS) ──────────────────── */
.soluciones{
  padding:120px 0;background:var(--white);
  border-top:1px solid var(--bdr);
  position:relative;
}
.sol-head{text-align:center;margin-bottom:48px}
.sol-head h2{max-width:820px;margin:0 auto 16px}
.sol-head h2 em{color:var(--teal);font-style:italic}
.sol-head .sub{
  color:var(--smoke);font-size:17px;max-width:620px;margin:0 auto;line-height:1.55;
}

/* Selector de caso */
.sol-selector{
  max-width:980px;margin:0 auto 56px;
  background:var(--paper);border:1px solid var(--bdr);
  border-radius:18px;padding:8px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:6px;
  box-shadow:var(--shd-sm);
}
.sol-tab{
  background:transparent;border:none;cursor:pointer;
  padding:18px 16px;border-radius:12px;
  font-family:'Inter',sans-serif;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  transition:background .25s var(--ez),transform .15s var(--ez);
  color:var(--ink-2);
}
.sol-tab:hover{background:rgba(53,73,160,.05)}
.sol-tab.active{
  background:linear-gradient(135deg,var(--navy),var(--navy-dk));
  color:#fff;box-shadow:0 6px 18px rgba(53,73,160,.3);
}
.sol-tab-icon{
  width:42px;height:42px;border-radius:12px;
  display:grid;place-items:center;
  background:rgba(53,73,160,.08);
  color:var(--navy);
  transition:background .25s var(--ez),color .25s var(--ez);
}
.sol-tab.active .sol-tab-icon{
  background:rgba(255,255,255,.18);color:#fff;
}
.sol-tab-label{
  font-size:13px;font-weight:600;text-align:center;line-height:1.3;
}
.sol-tab-sub{
  font-size:11px;opacity:.7;font-weight:500;text-align:center;
}

/* Panel del caso */
.sol-panel{
  display:none;
  background:var(--paper);
  border:1px solid var(--bdr);
  border-radius:20px;overflow:hidden;
  box-shadow:var(--shd);
}
.sol-panel.active{display:block;animation:panelFade .4s var(--ez)}
@keyframes panelFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.sol-panel-head{
  padding:36px 40px 28px;
  border-bottom:1px solid var(--bdr);
  background:linear-gradient(135deg,rgba(53,73,160,.04),rgba(46,122,106,.04));
}
.sol-panel-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;color:var(--teal);
  text-transform:uppercase;letter-spacing:.15em;margin-bottom:12px;
}
.sol-panel-eyebrow::before{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--teal);
}
.sol-panel-head h3{
  font-family:'Cormorant Garamond',serif;font-size:32px;
  color:var(--ink);margin-bottom:10px;letter-spacing:-.01em;
}
.sol-panel-head h3 em{color:var(--teal);font-style:italic}
.sol-panel-head p{
  color:var(--ink-2);font-size:16px;line-height:1.55;
  max-width:720px;
}

.sol-panel-body{
  padding:40px;
  display:grid;grid-template-columns:1fr 1fr;gap:28px;
}

/* Tarjeta de solución */
.sol-card{
  background:var(--white);
  border:1px solid var(--bdr);
  border-radius:14px;padding:30px;
  position:relative;
  display:flex;flex-direction:column;
  transition:transform .25s var(--ez),box-shadow .25s var(--ez),border-color .2s var(--ez);
}
.sol-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shd);
  border-color:var(--bdr-dk);
}
.sol-card.featured{
  border:2px solid var(--navy);
  background:linear-gradient(180deg,var(--white) 0%,rgba(53,73,160,.02) 100%);
}
.sol-card-badge{
  position:absolute;top:-12px;right:24px;
  background:linear-gradient(135deg,var(--teal),var(--teal-lt));
  color:#fff;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;
  padding:6px 14px;border-radius:var(--r-pill);
  box-shadow:0 4px 12px rgba(46,122,106,.3);
}

.sol-card-header{
  display:flex;align-items:flex-start;gap:14px;margin-bottom:18px;
  padding-bottom:18px;border-bottom:1px solid var(--bdr);
}
.sol-card-icon{
  width:46px;height:46px;border-radius:12px;
  display:grid;place-items:center;flex-shrink:0;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  color:#fff;
  box-shadow:0 4px 12px rgba(53,73,160,.2);
}
.sol-card-title{
  font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;
  line-height:1.2;color:var(--ink);letter-spacing:-.005em;
  margin-bottom:4px;
}
.sol-card-type{
  font-size:11px;font-weight:600;color:var(--teal);
  text-transform:uppercase;letter-spacing:.12em;
}

.sol-card-pitch{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:17px;color:var(--navy);line-height:1.4;
  margin-bottom:18px;
}

.sol-features{list-style:none;margin:0 0 22px;padding:0;flex:1}
.sol-features li{
  position:relative;padding:9px 0 9px 28px;
  font-size:14px;color:var(--ink-2);line-height:1.5;
}
.sol-features li::before{
  content:'';position:absolute;left:0;top:14px;
  width:16px;height:16px;border-radius:50%;
  background:rgba(46,122,106,.12);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E7A6A' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
  background-size:10px;background-repeat:no-repeat;background-position:center;
}
.sol-features li strong{color:var(--ink);font-weight:600}

.sol-card-footer{
  padding-top:18px;border-top:1px solid var(--bdr);
  display:flex;flex-direction:column;gap:10px;
}
.sol-card-stat{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:13px;
}
.sol-card-stat-label{color:var(--smoke);font-weight:500}
.sol-card-stat-value{
  font-family:'Cormorant Garamond',serif;font-size:18px;
  color:var(--navy);font-weight:600;
}
.sol-card-stat-value em{color:var(--teal);font-style:italic}

/* Tabla comparativa */
.sol-compare{
  max-width:1080px;margin:80px auto 0;
}
.sol-compare-head{text-align:center;margin-bottom:40px}
.sol-compare-head h3{
  font-size:30px;color:var(--ink);margin-bottom:12px;
}
.sol-compare-head h3 em{color:var(--teal);font-style:italic}
.sol-compare-head p{color:var(--smoke);font-size:16px;max-width:600px;margin:0 auto}

.sol-table{
  background:var(--white);border:1px solid var(--bdr);
  border-radius:16px;overflow:hidden;
  box-shadow:var(--shd);
}
.sol-table-row{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  align-items:center;
}
.sol-table-row.header{
  background:linear-gradient(135deg,var(--ink),var(--navy-dk));
  color:#fff;
}
.sol-table-row.header > div{
  padding:22px 20px;font-size:13px;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;
}
.sol-table-row.header > div:first-child{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:16px;font-weight:500;text-transform:none;letter-spacing:0;
  color:rgba(255,255,255,.85);
}
.sol-table-row.feature{
  border-top:1px solid var(--bdr);
  transition:background .15s var(--ez);
}
.sol-table-row.feature:hover{background:rgba(53,73,160,.02)}
.sol-table-row.feature > div{
  padding:20px;font-size:14px;color:var(--ink-2);line-height:1.45;
}
.sol-table-row.feature > div:first-child{
  font-family:'Inter',sans-serif;font-weight:600;color:var(--ink);
  font-size:14px;
}
.sol-cell-check{
  display:flex;align-items:center;gap:8px;
}
.sol-cell-check.yes{color:var(--forest)}
.sol-cell-check.partial{color:var(--gold)}
.sol-cell-check.no{color:var(--smoke);opacity:.6}
.sol-cell-icon{
  width:22px;height:22px;border-radius:50%;
  display:grid;place-items:center;flex-shrink:0;
  font-size:13px;font-weight:700;
}
.sol-cell-check.yes .sol-cell-icon{background:rgba(46,107,58,.12);color:var(--forest)}
.sol-cell-check.partial .sol-cell-icon{background:rgba(154,123,79,.15);color:var(--gold)}
.sol-cell-check.no .sol-cell-icon{background:rgba(154,170,180,.15);color:var(--smoke)}

/* CTA del módulo */
.sol-cta-band{
  margin-top:64px;text-align:center;
  background:linear-gradient(135deg,rgba(53,73,160,.04),rgba(46,122,106,.06));
  border:1px solid var(--bdr);border-radius:18px;
  padding:48px 32px;
}
.sol-cta-band h4{
  font-size:26px;color:var(--ink);margin-bottom:12px;
}
.sol-cta-band h4 em{color:var(--teal);font-style:italic}
.sol-cta-band p{
  color:var(--ink-2);font-size:16px;max-width:560px;margin:0 auto 24px;
}
.sol-disclaimer{
  margin-top:40px;max-width:920px;margin-left:auto;margin-right:auto;
  font-size:12px;color:var(--smoke);line-height:1.55;
  padding:20px 24px;background:var(--paper);
  border-left:3px solid var(--silver);border-radius:6px;
}

/* ─── PRODUCTOS / SOLUCIONES ──────────────────── */
.productos{
  padding:120px 0;
  background:
    linear-gradient(180deg,var(--white) 0%,var(--paper) 100%);
  position:relative;overflow:hidden;
}
.productos::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(ellipse 50% 40% at 90% 10%,rgba(46,122,106,.06),transparent 60%),
    radial-gradient(ellipse 40% 30% at 5% 90%,rgba(53,73,160,.05),transparent 60%);
}
.productos-head{text-align:center;margin-bottom:64px;position:relative}
.productos-head h2{max-width:780px;margin:0 auto 16px}
.productos-head h2 em{color:var(--teal);font-style:italic}
.productos-head .lead{
  color:var(--smoke);font-size:17px;max-width:620px;margin:0 auto;
}

/* Selector inteligente por objetivo */
.matcher{
  max-width:980px;margin:0 auto 72px;position:relative;
  background:var(--white);
  border:1px solid var(--bdr);
  border-radius:20px;
  padding:40px 40px 36px;
  box-shadow:var(--shd);
}
.matcher-head{
  display:flex;align-items:center;gap:14px;margin-bottom:28px;
  padding-bottom:24px;border-bottom:1px solid var(--bdr);
}
.matcher-icon{
  width:44px;height:44px;border-radius:11px;flex-shrink:0;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  display:grid;place-items:center;color:#fff;
  box-shadow:0 4px 12px rgba(53,73,160,.25);
}
.matcher-head h3{
  font-family:'Cormorant Garamond',serif;font-size:24px;
  font-weight:500;line-height:1.2;color:var(--ink);margin:0;
}
.matcher-head h3 em{color:var(--teal);font-style:italic}
.matcher-sub{
  font-size:13px;color:var(--smoke);margin-top:4px;
}
.matcher-question{
  font-family:'Inter',sans-serif;font-size:14px;font-weight:600;
  color:var(--ink-2);margin-bottom:14px;
  text-transform:uppercase;letter-spacing:.08em;
}
.matcher-options{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
  margin-bottom:8px;
}
.matcher-opt{
  background:var(--paper);
  border:2px solid var(--bdr);
  border-radius:var(--r);padding:18px 16px;
  cursor:pointer;text-align:left;
  font-family:'Inter',sans-serif;
  transition:all .2s var(--ez);
  display:flex;flex-direction:column;gap:6px;
  color:var(--ink-2);
  overflow:hidden;
}
.matcher-opt-photo{
  position:relative;height:92px;margin:-18px -16px 10px;
  overflow:hidden;background:var(--paper-2);
}
.matcher-opt-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,21,48,0) 45%,rgba(14,21,48,.28) 100%);
}
.matcher-opt-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s var(--ez)}
.matcher-opt:hover{
  border-color:var(--navy-lt);
  background:var(--white);
  transform:translateY(-2px);
  box-shadow:var(--shd-sm);
}
.matcher-opt:hover .matcher-opt-photo img{transform:scale(1.05)}
.matcher-opt.active{
  border-color:var(--navy);
  background:linear-gradient(135deg,rgba(53,73,160,.04),rgba(46,122,106,.04));
  box-shadow:0 0 0 3px rgba(53,73,160,.1);
}
.matcher-opt-icon{
  width:28px;height:28px;border-radius:8px;
  background:var(--paper-2);
  display:grid;place-items:center;color:var(--navy);
  margin-bottom:4px;
  transition:all .2s var(--ez);
}
.matcher-opt.active .matcher-opt-icon{
  background:linear-gradient(135deg,var(--navy),var(--teal));
  color:#fff;
}
.matcher-opt-title{
  font-size:14px;font-weight:600;color:var(--ink);
  line-height:1.25;
}
.matcher-opt-desc{
  font-size:12px;color:var(--smoke);line-height:1.4;
}

/* Resultado del matcher */
.matcher-result{
  margin-top:28px;padding-top:28px;
  border-top:1px solid var(--bdr);
  display:none;
}
.matcher-result.show{display:block;animation:slide-in .4s var(--ez)}
@keyframes slide-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.result-label{
  display:inline-block;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.15em;
  color:var(--teal);margin-bottom:10px;
}
.result-title{
  font-family:'Cormorant Garamond',serif;font-size:24px;
  font-weight:500;color:var(--ink);margin-bottom:10px;line-height:1.3;
}
.result-title em{color:var(--navy);font-style:italic}
.result-desc{
  font-size:15px;color:var(--ink-2);line-height:1.6;margin-bottom:18px;
}
.result-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;color:var(--navy);
  text-decoration:none;
}
.result-cta:hover{color:var(--navy-dk)}
.result-cta .arrow{transition:transform .2s var(--ez)}
.result-cta:hover .arrow{transform:translateX(3px)}

/* Tarjetas de productos */
.prod-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  position:relative;
}
.prod-card{
  background:var(--white);
  border:1px solid var(--bdr);
  border-radius:18px;padding:36px 32px 32px;
  position:relative;overflow:hidden;
  transition:transform .3s var(--ez),box-shadow .3s var(--ez),border-color .2s var(--ez);
  display:flex;flex-direction:column;
}
.prod-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
}
.prod-card-term::before{background:linear-gradient(90deg,var(--silver),var(--silver-lt))}
.prod-card-iul::before{background:linear-gradient(90deg,var(--navy),var(--teal))}
.prod-card-wl::before{background:linear-gradient(90deg,var(--gold),var(--gold-lt))}

.prod-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shd-lg);
  border-color:var(--bdr-dk);
}
.prod-card.featured{
  border:2px solid var(--navy);
  box-shadow:var(--shd);
}
.prod-card.featured::after{
  content:'Más solicitado';
  position:absolute;top:16px;right:16px;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  color:#fff;font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;
  padding:5px 12px;border-radius:var(--r-pill);
  box-shadow:0 4px 12px rgba(53,73,160,.3);
}

.prod-tag{
  display:inline-block;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.15em;
  padding:5px 12px;border-radius:var(--r-pill);
  margin-bottom:18px;
}
.prod-card-term .prod-tag{
  background:rgba(154,170,180,.18);color:var(--smoke);
}
.prod-card-iul .prod-tag{
  background:rgba(46,122,106,.12);color:var(--teal);
}
.prod-card-wl .prod-tag{
  background:rgba(154,123,79,.15);color:var(--gold);
}

.prod-card h3{
  font-size:26px;margin-bottom:6px;color:var(--ink);
  letter-spacing:-.01em;
}
.prod-tagline{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  color:var(--teal);font-size:16px;margin-bottom:22px;
  line-height:1.4;
}
.prod-card-term .prod-tagline{color:var(--smoke)}
.prod-card-wl .prod-tagline{color:var(--gold)}

.prod-desc{
  color:var(--ink-2);font-size:14px;line-height:1.6;
  margin-bottom:22px;
}

.prod-features{
  list-style:none;margin:0 0 24px;padding:0;
  display:flex;flex-direction:column;gap:10px;
  flex:1;
}
.prod-features li{
  font-size:13.5px;color:var(--ink-2);line-height:1.5;
  padding-left:24px;position:relative;
}
.prod-features li::before{
  content:'';position:absolute;left:0;top:7px;
  width:14px;height:14px;border-radius:50%;
  background:rgba(46,122,106,.12);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E7A6A' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:9px;background-position:center;background-repeat:no-repeat;
}
.prod-features li strong{color:var(--ink);font-weight:600}

.prod-meta{
  border-top:1px solid var(--bdr);
  padding-top:18px;margin-bottom:20px;
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.prod-meta-item{display:flex;flex-direction:column;gap:2px}
.prod-meta-lbl{
  font-size:10px;color:var(--smoke);
  text-transform:uppercase;letter-spacing:.1em;font-weight:600;
}
.prod-meta-val{
  font-family:'Cormorant Garamond',serif;font-size:16px;
  font-weight:600;color:var(--ink);line-height:1.2;
}
.prod-meta-val em{color:var(--teal);font-style:italic;font-weight:500}

.prod-cta{
  background:var(--paper);
  color:var(--ink);
  border:1px solid var(--bdr-dk);
  padding:13px 20px;border-radius:var(--r-sm);
  font-family:'Inter',sans-serif;font-size:14px;font-weight:600;
  text-decoration:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .2s var(--ez);
}
.prod-cta:hover{
  border-color:var(--ink);background:var(--ink);color:#fff;
}
.prod-cta .arrow{transition:transform .2s var(--ez)}
.prod-cta:hover .arrow{transform:translateX(3px)}
.prod-card.featured .prod-cta{
  background:linear-gradient(135deg,var(--navy),var(--navy-dk));
  color:#fff;border-color:var(--navy);
}
.prod-card.featured .prod-cta:hover{
  background:linear-gradient(135deg,var(--navy-dk),var(--ink));
  box-shadow:0 8px 22px rgba(53,73,160,.35);
}

.prod-photo{
  height:178px;margin:-36px -32px 26px;
  overflow:hidden;background:var(--paper-2);
  position:relative;
}
.prod-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,21,48,0) 48%,rgba(14,21,48,.22) 100%);
}
.prod-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s var(--ez)}
.prod-card:hover .prod-photo img{transform:scale(1.04)}

/* Tabla comparativa */
.compare{
  max-width:1080px;margin:80px auto 0;
}
.compare-head{text-align:center;margin-bottom:36px}
.compare-head h3{
  font-size:30px;margin-bottom:8px;
}
.compare-head h3 em{color:var(--teal);font-style:italic}
.compare-head p{color:var(--smoke);font-size:15px}

.compare-table{
  background:var(--white);border:1px solid var(--bdr);
  border-radius:16px;overflow:hidden;
  box-shadow:var(--shd-sm);
}
.compare-row{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  border-bottom:1px solid var(--bdr);
}
.compare-row:last-child{border-bottom:none}
.compare-row.head{
  background:linear-gradient(180deg,var(--paper) 0%,var(--white) 100%);
}
.compare-row.head .compare-cell{
  font-weight:600;font-size:13px;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--smoke);
  padding-top:20px;padding-bottom:20px;
}
.compare-row.head .compare-cell.label{color:transparent}
.compare-row.head .compare-cell.col-iul{
  color:var(--teal);
  background:linear-gradient(180deg,rgba(46,122,106,.06),rgba(46,122,106,.02));
}
.compare-row:hover:not(.head){background:var(--paper)}
.compare-cell{
  padding:18px 22px;font-size:14px;color:var(--ink-2);
  display:flex;align-items:center;line-height:1.4;
  border-right:1px solid var(--bdr);
}
.compare-cell:last-child{border-right:none}
.compare-cell.label{
  font-weight:600;color:var(--ink);font-size:13.5px;
  background:var(--paper);
}
.compare-cell.col-iul{
  background:linear-gradient(180deg,rgba(46,122,106,.04),rgba(46,122,106,.01));
  font-weight:500;color:var(--ink);
}
.cell-yes{color:var(--teal);font-weight:600;display:inline-flex;align-items:center;gap:6px}
.cell-no{color:var(--silver);font-weight:500}
.cell-partial{color:var(--gold);font-weight:500}

/* Casos de uso */
.casos{
  max-width:1080px;margin:80px auto 0;
}
.casos-head{text-align:center;margin-bottom:48px}
.casos-head h3{font-size:30px;margin-bottom:10px}
.casos-head h3 em{color:var(--teal);font-style:italic}
.casos-head p{color:var(--smoke);font-size:15px;max-width:560px;margin:0 auto}

.casos-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
.caso-card{
  background:var(--white);
  border:1px solid var(--bdr);
  border-radius:14px;padding:28px 26px;
  position:relative;
  transition:transform .25s var(--ez),box-shadow .25s var(--ez);
}
.caso-card:hover{transform:translateY(-3px);box-shadow:var(--shd)}
.caso-num{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:42px;font-weight:300;color:var(--silver-lt);
  line-height:1;margin-bottom:14px;
}
.caso-card h4{
  font-family:'Cormorant Garamond',serif;font-size:20px;
  font-weight:500;color:var(--ink);margin-bottom:8px;
  line-height:1.3;letter-spacing:-.005em;
}
.caso-card .caso-sit{
  font-size:13px;color:var(--smoke);line-height:1.55;margin-bottom:14px;
}
.caso-solution{
  display:flex;align-items:flex-start;gap:10px;
  padding:14px 16px;background:var(--paper);
  border-radius:10px;border-left:3px solid var(--teal);
}
.caso-solution-lbl{
  font-size:10px;font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;color:var(--teal);margin-bottom:3px;
}
.caso-solution-txt{
  font-size:13px;font-weight:500;color:var(--ink);line-height:1.45;
}
.caso-solution svg{
  flex-shrink:0;color:var(--teal);margin-top:2px;
}

/* Disclaimer */
.prod-disclaimer{
  max-width:880px;margin:64px auto 0;padding:20px 24px;
  background:var(--paper-2);border-radius:10px;
  border:1px solid var(--bdr);
  font-size:12.5px;color:var(--smoke);line-height:1.55;
  text-align:center;
}
.prod-disclaimer strong{color:var(--ink-2)}

/* Utilities */
.delay-05{transition-delay:.05s}
.delay-10{transition-delay:.1s}
.delay-15{transition-delay:.15s}
.delay-20{transition-delay:.2s}
.delay-25{transition-delay:.25s}

/* ─── RESPONSIVE ──────────────────── */
@media (max-width:980px){
  .hero{padding:64px 0 56px}
  .hero-grid,.propuesta-in,.about-in{grid-template-columns:1fr;gap:48px}
  .not-found{padding:72px 0}
  .not-found-grid{grid-template-columns:1fr;gap:44px}
  .not-found-panel{max-width:520px;width:100%;margin:0 auto}
  .hero-visual{max-width:420px;margin:0 auto;width:100%}
  .servicios-grid,.blog-grid,.dif-grid{grid-template-columns:1fr}
  .dif-vs{display:none}
  .dif-grid{gap:20px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .nav-links{display:none}
  .menu-btn{display:block}
  .filtro-grid{grid-template-columns:1fr}
  /* Soluciones por caso responsive */
  .sol-selector{grid-template-columns:repeat(2,1fr)}
  .sol-panel-body{grid-template-columns:1fr;padding:28px 24px}
  .sol-panel-head{padding:28px 24px 22px}
  .sol-table-row{grid-template-columns:1.3fr .9fr .9fr .9fr}
  .sol-table-row > div{padding:14px 12px !important;font-size:13px !important}
  /* Productos responsive */
  .prod-grid{grid-template-columns:1fr;gap:20px}
  .matcher-options{grid-template-columns:repeat(2,1fr)}
  .casos-grid{grid-template-columns:1fr;gap:16px}
  .compare-row{grid-template-columns:1.4fr .9fr .9fr .9fr}
  .compare-cell{padding:14px 12px;font-size:13px}
  .compare-cell.label{font-size:12.5px}
  .brochure-cta-in{flex-direction:column;align-items:flex-start}
  .article-hero{padding:64px 0 52px}
  .article-body-section{padding:52px 0 80px}
  .article-cover{aspect-ratio:16/9;margin-bottom:32px}
}
@media (max-width:640px){
  .hero{padding:48px 0 40px}
  .hero-grid{gap:32px}
  .not-found{padding:52px 0 64px}
  .not-found-panel{min-height:460px;padding:22px;border-radius:18px}
  .not-found-card{left:22px;right:22px;bottom:22px;padding:24px 22px}
  .not-found-card h2{font-size:25px}
  .not-found-links{gap:8px}
  .filtro,.propuesta,.servicios,.diferencia,.about,.blog,.brochure-cta,.instagram-feed,.final-cta,.soluciones,.productos{padding:72px 0}
  .foot-grid{grid-template-columns:1fr}
  .hero-trust{gap:20px}
  .trust-num{font-size:26px}
  .filtro-card{padding:24px 20px 24px 64px}
  .filtro-icon{left:16px;top:24px;width:32px;height:32px}
  .serv-card{padding:32px 24px}
  .dif-col{padding:32px 24px}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .hero-ctas .btn{justify-content:center}
  .brochure-cta-in{padding:28px 22px}
  .brochure-cta .btn{width:100%;justify-content:center}
  .article-hero{padding:44px 0 40px}
  .article-back{margin-bottom:24px}
  .article-hero p{font-size:17px}
  .article-meta{gap:8px}
  .article-meta span{width:100%;padding-right:0;border-right:none}
  .article-content{padding:30px 22px}
  .article-content h2{font-size:26px}
  .article-content p,.article-content li{font-size:16px}
  .article-lead{font-size:18px!important}
  .article-actions .btn{width:100%;justify-content:center}
  /* Soluciones por caso mobile */
  .sol-selector{grid-template-columns:1fr;gap:4px}
  .sol-tab{flex-direction:row;justify-content:flex-start;padding:14px 16px;text-align:left}
  .sol-tab-label,.sol-tab-sub{text-align:left}
  .sol-tab-icon{width:36px;height:36px}
  .sol-card{padding:24px}
  .sol-panel-head h3{font-size:24px}
  .sol-table{font-size:12px}
  .sol-table-row.header > div:first-child{font-size:13px}
  .sol-table-row{grid-template-columns:1.4fr .8fr .8fr .8fr}
  .sol-cta-band{padding:32px 22px}
  .sol-cta-band h4{font-size:22px}
  /* Productos mobile */
  .matcher{padding:28px 22px 26px}
  .matcher-head{flex-direction:column;align-items:flex-start;gap:10px}
  .matcher-options{grid-template-columns:1fr;gap:10px}
  .matcher-opt{padding:14px 14px;flex-direction:row;align-items:center;gap:12px}
  .matcher-opt-photo{width:86px;height:70px;margin:-14px 0 -14px -14px;flex-shrink:0}
  .matcher-opt-icon{margin-bottom:0}
  .prod-card{padding:30px 24px 26px}
  .prod-photo{height:160px;margin:-30px -24px 24px}
  .instagram-widget{padding:16px 0}
  .prod-card h3{font-size:22px}
  .compare-row{grid-template-columns:1.4fr .8fr .8fr .8fr}
  .compare-cell{padding:12px 8px;font-size:12px}
  .compare-cell.label{font-size:11.5px;padding:12px 10px}
  .compare-row.head .compare-cell{font-size:10.5px;letter-spacing:.05em}
  .caso-card{padding:24px 22px}
}
