:root{
  --orange:#f96011;
  --orange-dark:#d94f08;
  --black:#111111;
  --ink:#1a1a1a;
  --muted:#6b6b6b;
  --line:#e8e8e8;
  --bg:#ffffff;
  --bg-soft:#faf8f6;
  --max:1120px;
  --radius:14px;
  --shadow:0 10px 30px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.65;font-size:17px;
}
a{color:var(--orange);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
h1,h2,h3,h4{line-height:1.2;color:var(--black);font-weight:800}
h1{font-size:clamp(2rem,5vw,3.2rem);letter-spacing:-.02em}
h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-top:1.6em}
h3{font-size:1.3rem}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--black)}
.brand img{height:46px;width:46px}
.brand span{font-size:1.15rem}
.nav a{color:var(--black);font-weight:600;margin-left:26px;font-size:.98rem}
.nav a:hover{color:var(--orange);text-decoration:none}
.nav a.btn,.nav a.btn:hover{color:#fff}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;background:none;border:0;cursor:pointer;margin-left:auto}
.nav-toggle span{display:block;width:100%;height:3px;border-radius:2px;background:var(--black);transition:transform .25s ease,opacity .2s ease}
.nav-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.btn{
  display:inline-block;background:var(--orange);color:#fff;font-weight:700;
  padding:13px 24px;border-radius:999px;border:0;cursor:pointer;font-size:1rem;
  transition:transform .12s ease,background .2s ease;text-align:center;
}
.btn:hover{background:var(--orange-dark);text-decoration:none;transform:translateY(-1px);color:#fff}
.btn-ghost{background:transparent;color:var(--black);border:2px solid var(--black)}
.btn-ghost:hover{background:var(--black);color:#fff}
.btn-block{display:block;width:100%}

/* Hero */
.hero{background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);padding:80px 0 70px}
.hero .eyebrow{color:var(--orange);font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:.85rem}
.hero h1{margin:.3em 0 .4em}
.hero .pain{font-size:clamp(1.3rem,3.2vw,2rem);font-weight:800;color:var(--black);
  border-left:5px solid var(--orange);padding-left:18px;margin:24px 0;font-style:italic}
.hero p.lead{font-size:1.2rem;color:var(--muted);max-width:640px}
.hero-actions{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}

/* Sections — vertical only so .container horizontal padding is preserved */
.section{padding-top:64px;padding-bottom:64px}
.section--bare{padding-top:0;padding-bottom:0}
.section--subscribe{background:var(--orange);min-height:100vh;display:flex;align-items:center;padding:40px 0}
.section--subscribe .form-card{margin:0 auto}
.section.alt{background:var(--bg-soft)}
.section-head{text-align:center;max-width:680px;margin:0 auto 44px}
.section-head p{color:var(--muted);font-size:1.1rem}
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.card .ico{width:48px;height:48px;border-radius:12px;background:rgba(249,96,17,.12);color:var(--orange);
  display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;margin-bottom:16px}

/* Blog */
.blog-layout{display:grid;grid-template-columns:320px 1fr;gap:36px;align-items:start}
.blog-sidebar{position:sticky;top:90px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.blog-sidebar-title{margin:0 0 14px;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.blog-cat-nav{display:flex;flex-direction:column;gap:4px}
.blog-cat-nav a{display:block;padding:10px 12px;border-radius:10px;color:var(--ink);font-weight:600;font-size:.92rem;line-height:1.35;text-decoration:none;transition:background .15s ease,color .15s ease}
.blog-cat-nav a:hover{background:var(--bg-soft);color:var(--orange);text-decoration:none}
.blog-cat-nav a.active{background:rgba(249,96,17,.12);color:var(--orange-dark)}
.blog-main{min-width:0}
.blog-pagination{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}
.blog-page-link{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;border-radius:999px;border:1.5px solid var(--line);color:var(--ink);font-weight:700;text-decoration:none}
.blog-page-link:hover,.blog-page-link.active{background:var(--orange);border-color:var(--orange);color:#fff;text-decoration:none}
.post-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s ease,box-shadow .15s ease}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.post-card .thumb{aspect-ratio:16/9;background:#f0eeec;overflow:hidden}
.post-card .thumb img{width:100%;height:100%;object-fit:cover}
.post-card .body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.post-card h3{font-size:1.15rem;margin:0}
.post-card h3 a{color:var(--black)}
.tag{display:inline-block;background:rgba(249,96,17,.12);color:var(--orange-dark);font-weight:700;
  font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;padding:5px 10px;border-radius:999px}
.post-meta{color:var(--muted);font-size:.85rem}
.article-author{display:flex;gap:14px;align-items:flex-start;margin:18px 0 22px;padding:16px 18px;background:var(--bg-soft);border-radius:var(--radius);border:1px solid var(--line)}
.article-author-photo{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0}
.article-author-name{margin:0 0 4px;font-size:.95rem;color:var(--ink)}
.article-author-name a{color:var(--black);font-weight:800;text-decoration:none}
.article-author-name a:hover{color:var(--orange)}
.article-author-bio{margin:0 0 8px;font-size:.88rem;color:var(--muted);line-height:1.45}
.article-author-social{display:flex;flex-wrap:wrap;gap:8px 14px}
.article-author-social a{font-size:.8rem;font-weight:700;color:var(--orange);text-decoration:none}
.article-author-social a:hover{text-decoration:underline}
.comments{padding-top:10px}
.comments-title{font-size:1.5rem;margin:0 0 18px}
.comments-count{color:var(--muted);font-weight:600}
.comment-list{display:flex;flex-direction:column;gap:16px;margin-bottom:34px}
.comment{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.comment-reply{margin-left:28px;border-left:3px solid var(--orange);background:var(--bg-soft)}
.comment-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.comment-author{font-weight:800;color:var(--black)}
.comment-badge{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#fff;background:var(--orange);border-radius:999px;padding:2px 8px}
.comment-date{color:var(--muted);font-size:.8rem;margin-left:auto}
.comment-body{color:var(--ink);line-height:1.55}
.comment-form-wrap{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:22px}
.comment-form-wrap h3{margin:0 0 14px}
.comment-note{margin:10px 0 0;font-size:.82rem;color:var(--muted)}

/* Article */
.breadcrumbs{font-size:.85rem;color:var(--muted);padding:18px 0}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs span{color:var(--black)}
.article{max-width:760px;margin:0 auto}
.article-hero img{border-radius:var(--radius);margin:20px 0 10px}
.article-body{font-size:1.12rem}
.article-body p{margin:1.1em 0}
.article-body h2,.article-body h3{margin-top:1.6em}
.article-body ul{padding-left:1.3em}
.article-body img{border-radius:10px;margin:1.2em 0}
.toc{background:var(--bg-soft);border:1px solid var(--line);border-left:4px solid var(--orange);border-radius:12px;padding:18px 22px;margin:24px 0}
.toc-head{display:flex;align-items:center;justify-content:space-between;gap:14px}
.toc-title{font-weight:800;color:var(--black);margin:0;font-size:1rem;text-transform:uppercase;letter-spacing:.04em}
.toc-toggle{background:var(--orange);color:#fff;border:0;border-radius:999px;padding:6px 16px;font-weight:700;font-size:.85rem;cursor:pointer}
.toc-toggle:hover{background:var(--orange-dark)}
.toc ul{list-style:none;margin:12px 0 0;padding:0}
.toc.collapsed ul{display:none}
.toc li{margin:6px 0}
.toc li a{color:var(--ink);font-weight:600}
.toc li a:hover{color:var(--orange)}
.toc li.toc-sub{padding-left:18px}
.toc li.toc-sub a{font-weight:500;font-size:.95rem;color:var(--muted)}
.article-body h2[id],.article-body h3[id]{scroll-margin-top:90px}
/* Ebook promo — shared two-column layout (banner + popup) */
.ebook-banner{background:linear-gradient(135deg,#fff8f4 0%,#fff 100%);border:1px solid var(--line);border-left:4px solid var(--orange);border-radius:14px;padding:20px;margin:28px 0}
.ebook-promo{display:grid;grid-template-columns:140px 1fr;gap:20px;align-items:center}
.ebook-promo-cover{display:flex;align-items:center;justify-content:center}
.ebook-promo-cover img{width:100%;max-width:140px;height:auto;display:block;border:0;border-radius:0;box-shadow:none;transform:none;background:transparent}
.ebook-promo-content{min-width:0}
.ebook-promo-eyebrow{margin:0 0 6px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--orange)}
.ebook-promo-title{margin:0 0 8px;font-size:1.15rem;font-weight:800;color:var(--black);line-height:1.25}
.ebook-promo-text{margin:0 0 14px;color:var(--muted);font-size:.95rem;line-height:1.5}
.ebook-promo-btn{margin-top:4px}
.ebook-promo-note{margin:12px 0 0;font-size:.78rem;color:var(--muted)}
@media(max-width:640px){
  .ebook-promo{grid-template-columns:1fr;text-align:center}
  .ebook-promo-cover img{max-width:120px;margin:0 auto}
  .ebook-promo-btn{display:block;width:100%}
}
.locked{position:relative}
.locked .fade{position:absolute;left:0;right:0;bottom:0;height:220px;
  background:linear-gradient(180deg,rgba(255,255,255,0),#fff 75%);pointer-events:none}

/* Footer */
.site-footer{background:var(--black);color:#cfcfcf;padding:48px 0 28px}
.site-footer a{color:#cfcfcf}
.site-footer a:hover{color:var(--orange)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px}
.footer-grid h4{color:#fff;font-size:1rem}
.footer-social{margin-top:18px;display:flex;gap:12px}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:#2a2a2a;color:#cfcfcf;transition:background .15s ease,color .15s ease}
.footer-social a:hover{background:var(--orange);color:#fff;text-decoration:none}
.footer-bottom{border-top:1px solid #2a2a2a;margin-top:30px;padding-top:18px;font-size:.85rem;color:#8a8a8a;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* Content blocker popup */
.cp-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.62);padding:20px}
.cp-modal.open{display:flex}
.cp-modal .box{background:#fff;border-radius:18px;max-width:620px;width:100%;padding:28px 28px 24px;box-shadow:0 25px 60px rgba(0,0,0,.35);position:relative}
.cp-modal .ebook-promo--modal .ebook-promo-title{font-size:1.35rem}
.cp-modal .close{position:absolute;top:10px;right:14px;z-index:2;font-size:28px;color:#aaa;background:none;border:0;cursor:pointer;line-height:1}
@media(max-width:640px){
  .cp-modal .box{padding:22px 18px 18px}
  .cp-modal .ebook-promo--modal{text-align:center}
}

/* Cookie banner */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:900;background:var(--black);color:#fff;
  border-radius:14px;padding:18px 22px;display:none;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap;box-shadow:0 12px 40px rgba(0,0,0,.4)}
.cookie-banner.show{display:flex}
.cookie-banner p{margin:0;font-size:.92rem;color:#dcdcdc;flex:1;min-width:240px}
.cookie-banner a{color:var(--orange)}
.cookie-actions{display:flex;gap:10px}
.cookie-banner .btn{padding:10px 18px;font-size:.9rem}

/* Forms */
.form-card{max-width:560px;margin:40px auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:700;margin-bottom:6px;color:var(--black)}
.field .hint{font-weight:400;color:var(--muted);font-size:.88rem}
.form-question{font-size:1.35rem;font-weight:800;color:var(--black);margin:0 0 14px;line-height:1.25}
.form-question .required{color:var(--orange);margin-left:2px}
.form-question-hint{margin:-8px 0 14px;color:var(--muted);font-size:.92rem}
.form-step-actions{display:flex;gap:10px;margin-top:20px}
.form-step-actions .btn-block{flex:1}
.field input[type=text],.field input[type=email],.field select,.field textarea{
  width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:10px;font-size:1rem;font-family:inherit}
.field input:focus,.field select:focus{outline:none;border-color:var(--orange)}
.choices{display:grid;gap:10px;margin-top:4px}
.choice{display:flex;align-items:center;gap:12px;border:1.5px solid var(--line);border-radius:12px;padding:14px 16px;cursor:pointer;background:#fff;transition:border-color .15s ease}
.choice:hover,.choice:has(input:checked){border-color:var(--orange);background:rgba(249,96,17,.04)}
.choice span{font-weight:600;color:var(--black);line-height:1.35}
.choice input{accent-color:var(--orange);flex-shrink:0}
.choice--consent{align-items:flex-start}
.choice--consent span{font-weight:500;font-size:.95rem}
.choice--consent a{color:var(--orange)}
.alert{padding:14px 16px;border-radius:10px;margin-bottom:18px;font-weight:600}
.alert-error{background:#fdecec;color:#b3261e}
.alert-success{background:#e7f6ec;color:#1b7a3d}
.steps{display:flex;gap:8px;margin-bottom:22px}
.steps .dot{flex:1;height:6px;border-radius:999px;background:var(--line);transition:background .2s ease}
.steps .dot.active{background:var(--orange)}

/* Calculadora de pensión */
.section--calc{position:relative;background:linear-gradient(155deg,#ff8038 0%,var(--orange) 52%,var(--orange-dark) 100%);padding:48px 0;overflow:hidden}
.section--calc::before{content:"";position:absolute;top:-130px;right:-110px;width:380px;height:380px;border-radius:50%;background:rgba(255,255,255,.10);pointer-events:none}
.section--calc::after{content:"";position:absolute;bottom:-160px;left:-120px;width:340px;height:340px;border-radius:50%;background:rgba(0,0,0,.05);pointer-events:none}
.section--calc .container{position:relative;z-index:1}
.section--calc .form-card{margin:0 auto;width:100%;max-width:720px;border-top:5px solid var(--orange);padding-top:30px;box-shadow:0 24px 60px rgba(0,0,0,.18)}

/* Cabecera con marca de la calculadora */
.calc-intro{text-align:center;margin-bottom:8px}
.calc-pill{display:inline-flex;align-items:center;gap:7px;background:rgba(249,96,17,.12);color:var(--orange-dark);font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;padding:6px 14px;border-radius:999px;margin-bottom:14px}
.calc-pill svg{width:14px;height:14px}

/* Cabecera de cada paso: icono + contador */
.calc-step-head{display:flex;align-items:center;gap:13px;margin-bottom:16px}
.calc-step-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,rgba(249,96,17,.16),rgba(249,96,17,.06));color:var(--orange);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.calc-step-icon svg{width:25px;height:25px}
.calc-step-count{font-size:.74rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}
.calc-step-head .form-question{margin:2px 0 0}

.calc-value{font-size:2.6rem;font-weight:800;color:var(--orange);text-align:center;line-height:1.1;margin:18px 0 2px}
.calc-value small{font-size:1rem;font-weight:600;color:var(--muted)}
.calc-range{width:100%;-webkit-appearance:none;appearance:none;height:10px;border-radius:999px;outline:none;margin:14px 0 6px;
  background:linear-gradient(90deg,var(--orange) 0%,var(--orange) var(--pct,50%),var(--line) var(--pct,50%),var(--line) 100%)}
.calc-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:30px;height:30px;border-radius:50%;background:#fff;cursor:pointer;border:4px solid var(--orange);box-shadow:0 3px 10px rgba(249,96,17,.45);transition:transform .1s ease}
.calc-range::-webkit-slider-thumb:active{transform:scale(1.12)}
.calc-range::-moz-range-thumb{width:30px;height:30px;border-radius:50%;background:#fff;cursor:pointer;border:4px solid var(--orange);box-shadow:0 3px 10px rgba(249,96,17,.45)}
.calc-range:focus{outline:none}
.calc-range-labels{display:flex;justify-content:space-between;color:var(--muted);font-size:.78rem}

/* Señales de confianza bajo el formulario */
.calc-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 22px;margin-top:24px;padding-top:18px;border-top:1px solid var(--line)}
.calc-trust span{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;color:var(--muted);font-weight:600}
.calc-trust svg{width:17px;height:17px;color:var(--orange);flex-shrink:0}

.calc-result{text-align:center}
.calc-result-amount{font-size:clamp(2.6rem,9vw,3.6rem);font-weight:800;color:var(--orange);line-height:1.05;margin:6px 0 4px}
.calc-result-amount small{font-size:1rem;color:var(--muted);font-weight:600}
.calc-breakdown{margin:22px 0 4px;text-align:left}
.calc-breakdown-row{display:flex;justify-content:space-between;gap:14px;padding:11px 2px;border-bottom:1px solid var(--line)}
.calc-breakdown-row span:first-child{color:var(--muted)}
.calc-breakdown-row span:last-child{font-weight:700;color:var(--black);text-align:right}
.calc-warning{background:#fff8f4;border:1px solid var(--line);border-left:4px solid var(--orange);border-radius:10px;padding:12px 14px;font-size:.9rem;color:var(--ink);margin:10px 0;text-align:left}
.calc-disclaimer{font-size:.8rem;color:var(--muted);margin-top:18px;line-height:1.5}

.text-center{text-align:center}
.mt{margin-top:20px}

@media(max-width:860px){
  .container{padding-left:24px;padding-right:24px}
  .blog-layout{grid-template-columns:1fr;gap:24px}
  .blog-sidebar{position:static}
  .grid-3,.grid-2,.post-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .nav-toggle{display:flex}
  .nav{position:absolute;top:74px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
    display:flex;flex-direction:column;align-items:stretch;padding:6px 24px 18px;gap:0;
    box-shadow:0 18px 30px rgba(0,0,0,.10);transform:translateY(-12px);opacity:0;visibility:hidden;
    transition:transform .22s ease,opacity .22s ease,visibility .22s}
  .nav.open{transform:translateY(0);opacity:1;visibility:visible}
  .nav a{margin-left:0;padding:14px 4px;font-size:1.05rem;border-bottom:1px solid var(--line)}
  .nav a.btn{margin-top:14px;border-bottom:0}
}
