/* =================================================================
   Silvia Tejedor — Editorial Newsprint (broadsheet)
   Spectral + IBM Plex Sans  ·  papel · tinta · rojo
   ================================================================= */

:root{
  --paper:#F5F2EB;
  --white:#FFFFFF;
  --ink:#14110D;
  --plum:#993366;      /* corporativo — ciruela (énfasis/tinta editorial) */
  --magenta:#E32F7F;   /* corporativo — magenta (acción) */
  --red:var(--plum);   /* acento editorial = ciruela */
  --pink-pale:#F2DAE6; /* corporativo — rosa claro (sobre fondos oscuros) */
  --line:#DCD7CC;
  --ink-soft:rgba(20,17,13,.72);
  --ink-faint:rgba(20,17,13,.55);

  /* legacy aliases (clases reutilizadas) */
  --ivory:var(--paper);
  --burgundy:var(--plum);
  --gold:var(--plum);
  --gold-pale:var(--pink-pale);

  --display:'Spectral', Georgia, serif;
  --body:'IBM Plex Sans', system-ui, sans-serif;

  --maxw:1280px;
  --gutter:clamp(20px, 5vw, 72px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}

/* faint newsprint grain */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;z-index:1;
  opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic;font-weight:400;color:var(--red)}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}

/* ---------- Typography helpers ---------- */
.eyebrow{
  font-family:var(--body);font-weight:600;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--red);display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:18px;height:2px;background:var(--red);display:inline-block}
.serif-display{
  font-family:var(--display);font-weight:800;
  letter-spacing:-.02em;line-height:.98;
}
.rule-gold{height:1px;border:0;background:var(--ink)}

/* ---------- Header (masthead) ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(245,242,235,.94);
  backdrop-filter:blur(8px);
  border-bottom:3px double var(--ink);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:104px;gap:24px;
}
.brand{display:flex;align-items:center;line-height:0}
.brand img{height:74px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links > li{position:relative}
.nav-links a{
  font-family:var(--body);font-weight:500;
  font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);transition:color .2s;padding:6px 0;display:inline-block;
}
.nav-links a:hover{color:var(--red)}
.nav-links .has-sub > a::after{content:" +";color:var(--red)}
.submenu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--white);border:1px solid var(--ink);
  padding:14px 22px;min-width:180px;
  display:flex;flex-direction:column;gap:12px;
  opacity:0;visibility:hidden;transition:.24s;
  box-shadow:6px 6px 0 rgba(20,17,13,.12);
}
.nav-links .has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-cta{
  border:1.5px solid var(--ink);padding:11px 22px !important;
  color:var(--ink) !important;transition:.24s;font-weight:600 !important;
}
.nav-cta:hover{background:var(--magenta);border-color:var(--magenta);color:var(--white) !important}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;font-size:22px;color:var(--ink)}

/* ---------- Hero (front page) ---------- */
.hero{position:relative;padding:clamp(46px,7vh,80px) 0 clamp(50px,8vh,96px)}
.hero .wrap{position:relative}
.dateline{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  padding:8px 0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);
  margin-bottom:clamp(34px,5vh,56px);
}
.dateline span{font-weight:500}
.hero-inner{display:grid;grid-template-columns:1.18fr .82fr;gap:clamp(32px,5vw,64px);align-items:start}
.hero-eyebrow{margin-bottom:22px}
.hero h1{
  font-size:clamp(44px,7vw,100px);max-width:15ch;margin-bottom:10px;font-weight:800;
}
.hero h1 .sub{display:block;color:var(--red);font-style:italic;font-weight:400;font-size:.6em;margin-top:.05em}
.hero-lede{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(19px,1.7vw,23px);line-height:1.45;
  max-width:42ch;margin:26px 0 32px;color:var(--ink-soft);
  padding-left:18px;border-left:2px solid var(--red);
}
.hero-aside{
  position:relative;aspect-ratio:3/4;
  border:1px solid var(--ink);background:var(--white);
}
.hero-aside img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05)}
.hero-aside figcaption{
  font-family:var(--body);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);padding:9px 12px;border-top:1px solid var(--ink);
  background:var(--white);
}
.hero-slides{display:flex;gap:0;margin-top:14px;border-top:1px solid var(--ink)}
.hero-slide{
  flex:1;padding:16px 0;font-family:var(--body);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);border-right:1px solid var(--line);
}
.hero-slide:last-child{border-right:0}
.hero-slide b{display:block;font-family:var(--display);font-weight:700;font-size:17px;letter-spacing:0;color:var(--ink);margin-bottom:3px;text-transform:none}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-family:var(--body);font-weight:600;
  font-size:13px;letter-spacing:.04em;text-transform:uppercase;
  padding:14px 30px;border:1.5px solid var(--ink);transition:.24s;cursor:pointer;
}
.btn-dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-dark:hover{background:var(--magenta);border-color:var(--magenta);color:var(--white)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-burg{background:var(--magenta);color:var(--white);border-color:var(--magenta)}
.btn-burg:hover{background:transparent;color:var(--magenta)}

/* ---------- Section frame ---------- */
.section{padding:clamp(58px,9vh,104px) 0;position:relative;z-index:2}
.section-head{max-width:820px;margin-bottom:48px}
.section-head .eyebrow{display:inline-flex;margin-bottom:18px}
.section-head h2{font-family:var(--display);font-weight:800;font-size:clamp(34px,4.6vw,62px);line-height:1;letter-spacing:-.02em}
.section-head p{margin-top:18px;color:var(--ink-soft);font-size:18px;max-width:60ch}

/* ---------- ¿Te pasa algo de esto? (black box) ---------- */
.pain{background:var(--ink);color:var(--paper)}
.pain .eyebrow{color:var(--pink-pale)}
.pain .eyebrow::before{background:var(--pink-pale)}
.pain .section-head h2{color:var(--paper)}
.pain-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid rgba(245,242,235,.28);border-left:1px solid rgba(245,242,235,.28);
}
.pain-item{
  padding:34px 30px;border-right:1px solid rgba(245,242,235,.28);border-bottom:1px solid rgba(245,242,235,.28);
  font-size:18px;line-height:1.45;position:relative;transition:background .25s;
}
.pain-item:hover{background:var(--red)}
.pain-num{
  font-family:var(--display);font-weight:800;font-style:italic;
  color:var(--pink-pale);font-size:30px;display:block;margin-bottom:14px;
}
.pain-closing{
  margin-top:50px;font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(22px,2.6vw,32px);line-height:1.4;color:var(--paper);
  max-width:64ch;padding-left:22px;border-left:3px solid var(--red);
}
.pain-closing em{color:var(--pink-pale)}

/* ---------- Elige tu camino (column cards) ---------- */
.paths{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--ink)}
.path{
  padding:42px 34px;border-right:1px solid var(--line);
  display:flex;flex-direction:column;min-height:340px;background:var(--white);transition:.24s;
}
.path:last-child{border-right:0}
.path:hover{background:var(--paper)}
.path-idx{font-family:var(--display);font-weight:800;font-style:italic;color:var(--red);font-size:22px;margin-bottom:auto}
.path h3{font-family:var(--display);font-weight:700;font-size:28px;margin:24px 0 14px;line-height:1.05;letter-spacing:-.01em}
.path h3 .arrow{color:var(--red)}
.path p{color:var(--ink-soft);font-size:15.5px;margin-bottom:18px}
.path .result{font-family:var(--display);font-style:italic;font-size:15px;border-top:1px solid var(--line);padding-top:16px}
.path .result b{font-family:var(--body);font-style:normal;font-weight:600;color:var(--red);text-transform:uppercase;font-size:11px;letter-spacing:.1em;display:block;margin-bottom:4px}

/* ---------- Mi método ---------- */
.method{background:var(--white);border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.method-lead{
  font-family:var(--display);font-weight:700;
  font-size:clamp(24px,3vw,40px);line-height:1.18;max-width:24ch;margin-bottom:46px;letter-spacing:-.01em;
}
.method-layout{display:grid;grid-template-columns:1fr 1px 1fr;gap:clamp(30px,5vw,60px)}
.method-vrule{background:var(--line);width:1px}
.method-steps{list-style:none;counter-reset:m}
.method-steps li{
  counter-increment:m;padding:20px 0 20px 62px;position:relative;border-bottom:1px solid var(--line);
  font-size:18px;
}
.method-steps li:last-child{border-bottom:0}
.method-steps li::before{
  content:counter(m,decimal-leading-zero);position:absolute;left:0;top:20px;
  font-family:var(--display);font-weight:800;font-style:italic;color:var(--red);font-size:24px;
}
.method-card{background:var(--ink);color:var(--paper);padding:38px}
.method-card h3{font-family:var(--body);font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--pink-pale);margin-bottom:22px}
.method-card ul{list-style:none}
.method-card li{padding:15px 0;border-bottom:1px solid rgba(245,242,235,.2);font-size:16px}
.method-card li:last-child{border-bottom:0}
.method-card li b{color:var(--pink-pale);font-weight:600}
.method-card .btn{margin-top:26px}

/* ---------- CTA final ---------- */
.cta{background:var(--red);color:var(--white);text-align:center;padding:clamp(64px,10vh,118px) 0}
.cta .eyebrow{color:var(--pink-pale);display:inline-flex;margin-bottom:22px}
.cta .eyebrow::before{background:var(--pink-pale)}
.cta h2{font-family:var(--display);font-weight:400;font-style:italic;font-size:clamp(38px,6vw,76px);margin-bottom:32px;letter-spacing:-.01em}
.cta .btn{border-color:var(--white);color:var(--white)}
.cta .btn:hover{background:var(--white);color:var(--red)}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--paper);padding:64px 0 34px;position:relative;z-index:2}
.footer-eu{
  font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:rgba(245,242,235,.55);
  border-bottom:1px solid rgba(245,242,235,.2);padding-bottom:28px;margin-bottom:38px;
  display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:space-between;
}
.footer-eu img{height:42px;background:#fff;padding:5px 8px}
.footer-main{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:46px}
.footer-logo{width:200px;max-width:60%;height:auto;display:block}
.footer-logo + p{color:rgba(245,242,235,.6);margin-top:18px;max-width:34ch;font-size:15px}
.footer-col h4{font-family:var(--body);font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--pink-pale);margin-bottom:18px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:11px}
.footer-col a{color:rgba(245,242,235,.78);font-size:15px;transition:color .2s}
.footer-col a:hover{color:var(--white)}
.footer-social{display:flex;gap:18px;margin-top:6px}
.footer-bottom{
  border-top:1px solid rgba(245,242,235,.2);padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-size:12px;color:rgba(245,242,235,.5);letter-spacing:.03em;
}
.footer-bottom a:hover{color:var(--white)}
.footer-legal{display:flex;gap:18px;flex-wrap:wrap}

/* ---------- Reveal animation ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
  .reveal.in{opacity:1;transform:none}
}

/* ---------- Responsive ---------- */
@media(max-width:920px){
  .hero-inner{grid-template-columns:1fr}
  .hero-aside{max-width:360px;order:-1}
  .pain-grid{grid-template-columns:repeat(2,1fr)}
  .paths{grid-template-columns:1fr}
  .path{border-right:0;border-bottom:1px solid var(--line);min-height:auto}
  .method-layout{grid-template-columns:1fr}
  .method-vrule{display:none}
  .footer-main{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{
    position:fixed;inset:104px 0 auto 0;background:var(--white);
    flex-direction:column;align-items:flex-start;gap:0;padding:10px var(--gutter) 24px;
    border-bottom:3px double var(--ink);
    transform:translateY(-130%);transition:transform .32s;
  }
  .nav-links.open{transform:none}
  .nav-links > li{width:100%;border-bottom:1px solid var(--line)}
  .nav-links a{padding:16px 0;font-size:13px}
  .submenu{position:static;transform:none;opacity:1;visibility:visible;border:0;box-shadow:none;padding:0 0 14px 18px}
  .nav-toggle{display:block}
  .pain-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr}
  .footer-eu{flex-direction:column;align-items:flex-start}
}
