/* ================================================================
   Centro Jurídico — sucesiones.css
   Sistema visual basado en consultas-sucesiones.html
   Oscuro / dorado. Playfair Display + DM Sans.
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:wght@300;400;500&display=swap');

/* ── TOKENS ── */
:root{
  --bg:#0c0d0d;
  --bg2:#111213;
  --surface:#161718;
  --surface2:#1c1d1e;
  --gold:#c9a84c;
  --gold-dim:rgba(201,168,76,.12);
  --gold-line:rgba(201,168,76,.22);
  --gold-glow:rgba(201,168,76,.18);
  --text:#f0ece4;
  --text-soft:#c4bfb8;
  --text-muted:#8a8880;
  --border:rgba(240,236,228,.07);
  --font-serif:'Cormorant Garamond',Georgia,serif;
  --font-sans:'DM Sans',system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:16px;line-height:1.6;overflow-x:hidden}
img{max-width:100%}
a{text-decoration:none}
 
/* ── BUTTONS ── */
.btn-primary{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--gold);color:#0c0d0d;
  font-family:var(--font-sans);font-weight:500;font-size:.8rem;
  letter-spacing:.09em;text-transform:uppercase;
  padding:.84rem 1.65rem;border-radius:3px;border:none;cursor:pointer;
  transition:background .2s,box-shadow .25s,transform .15s;
}
.btn-primary:hover{background:#dab85a;box-shadow:0 8px 28px rgba(201,168,76,.3);transform:translateY(-1px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:.45rem;
  background:transparent;color:var(--text-soft);
  font-family:var(--font-sans);font-weight:400;font-size:.86rem;
  padding:.8rem 1.4rem;border-radius:3px;
  border:1px solid rgba(240,236,228,.12);cursor:pointer;
  transition:color .2s,border-color .2s,transform .15s;
}
.btn-ghost:hover{color:var(--text);border-color:rgba(240,236,228,.28);transform:translateY(-1px)}
 
/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 4rem;height:66px;
  background:rgba(12,13,13,.8);
  backdrop-filter:blur(20px) saturate(1.5);
  border-bottom:1px solid var(--border);
}
.nav-logo{display:flex;align-items:center;gap:.7rem}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.2}
.nav-logo-name{font-family:var(--font-serif);font-size:1.1rem;font-weight:600;color:var(--text)}
.nav-logo-name span{color:var(--gold)}
.nav-logo-sub{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}
.nav-links{display:flex;align-items:center;gap:.15rem}
.nav-links a{font-size:.8rem;color:var(--text-muted);padding:.38rem .82rem;border-radius:3px;transition:color .18s,background .18s}
.nav-links a:hover{color:var(--text);background:rgba(255,255,255,.04)}
.nav-cta{background:var(--gold)!important;color:#0c0d0d!important;font-weight:500!important;font-size:.75rem!important;padding:.42rem 1.1rem!important;letter-spacing:.06em}
.nav-cta:hover{background:#dab85a!important}
 
/* ── HERO ── */
.hero-suc{
  min-height:100svh;
  display:grid;grid-template-columns:1fr 390px;
  align-items:center;gap:5rem;
  padding:100px 4rem 80px;
  max-width:1240px;margin:0 auto;
  position:relative;
}
/* subtle horizontal rule texture */
.hero-suc::before{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(201,168,76,.022) 1px,transparent 1px);
  background-size:100% 80px;
  pointer-events:none;
  mask-image:linear-gradient(to bottom,transparent,rgba(0,0,0,.5) 20%,rgba(0,0,0,.5) 80%,transparent);
  -webkit-mask-image:linear-gradient(to bottom,transparent,rgba(0,0,0,.5) 20%,rgba(0,0,0,.5) 80%,transparent);
}
/* ambient glow behind title */
.hero-suc::after{
  content:'';position:absolute;
  top:10%;left:-5%;width:55%;height:70%;
  background:radial-gradient(ellipse,rgba(201,168,76,.055) 0%,transparent 65%);
  pointer-events:none;
}
 
.hero-left{position:relative;z-index:1}
 
.pill{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--gold-dim);border:1px solid var(--gold-line);
  color:var(--gold);font-size:.66rem;font-weight:500;
  letter-spacing:.15em;text-transform:uppercase;
  padding:.38rem 1rem;border-radius:2rem;margin-bottom:1.7rem;
  opacity:0;animation:fadeUp .7s var(--ease) .05s forwards;
}
.pill::before{content:'●';font-size:.38rem;opacity:.9}
 
h1.hero-title{
  font-family:var(--font-serif);
  font-size:clamp(3rem,4.5vw,4.8rem);
  font-weight:500;line-height:1.05;
  letter-spacing:-.018em;
  margin-bottom:1.6rem;
  opacity:0;animation:fadeUp .85s var(--ease) .18s forwards;
}
h1.hero-title em{
  font-style:italic;color:var(--gold);
  display:block;font-weight:400;
}
 
.hero-sub{
  font-size:.98rem;color:var(--text-soft);
  line-height:1.8;max-width:44ch;
  margin-bottom:2.25rem;
  opacity:0;animation:fadeUp .85s var(--ease) .3s forwards;
}
 
.hero-ctas{
  display:flex;gap:.85rem;flex-wrap:wrap;
  margin-bottom:2.4rem;
  opacity:0;animation:fadeUp .85s var(--ease) .42s forwards;
}
 
.checks{
  list-style:none;display:flex;flex-direction:column;gap:.5rem;
  opacity:0;animation:fadeUp .85s var(--ease) .52s forwards;
}
.checks li{
  font-size:.82rem;color:var(--text-muted);
  display:flex;align-items:center;gap:.6rem;
}
.checks li::before{content:'✓';color:var(--gold);font-weight:600;flex-shrink:0}
 
/* card */
.hero-right{
  position:relative;z-index:1;
  opacity:0;animation:fadeUp .9s var(--ease) .35s forwards;
}
.hero-card-suc{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:10px;padding:2rem;
  position:relative;overflow:hidden;
  box-shadow:0 32px 64px rgba(0,0,0,.55);
}
.hero-card-suc::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.hero-card-suc::after{
  content:'';position:absolute;bottom:-80px;right:-80px;
  width:240px;height:240px;
  background:radial-gradient(circle,rgba(201,168,76,.07) 0%,transparent 70%);
  pointer-events:none;
}
.card-label-sm{
  font-size:.64rem;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold);margin-bottom:.95rem;
  display:flex;align-items:center;gap:.5rem;
}

.card-label-sm::before{content:'';display:block;width:20px;height:1px;background:var(--gold);opacity:.6}
.card-lawyer{display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem}
.card-lawyer img{width:62px;height:62px;object-fit:cover;border-radius:6px;border:1px solid var(--border);flex-shrink:0}
.card-lawyer h3{font-size:1rem;font-weight:500;margin-bottom:.15rem}
.card-lawyer p{font-size:.73rem;color:var(--text-muted)}
.card-bio{font-size:.81rem;color:var(--text-soft);line-height:1.74;margin-bottom:1.2rem}
.card-stats{display:flex;flex-direction:column;gap:.42rem}
.card-stat{display:flex;align-items:center;gap:.55rem;font-size:.76rem;color:var(--text-soft)}
.card-stat::before{content:'✦';color:var(--gold);font-size:.48rem;flex-shrink:0}
.urgency-note{
  background:rgba(201,168,76,.06);border:1px solid rgba(201,168,76,.18);
  border-radius:7px;padding:.9rem 1.1rem;
  display:flex;align-items:flex-start;gap:.7rem;margin-top:1.1rem;
}
.urgency-note p{font-size:.79rem;color:var(--text-soft);margin:0;line-height:1.6}
.urgency-note strong{color:var(--text)}


.avatar-martin {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* El primer valor es horizontal (50% es centro) */
  /* El segundo es vertical: 20% sube la foto, 80% la baja */
  object-position: 50% 20%; 
}

.avatar-francisco {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 15%; /* Ajustá este % hasta que el rostro quede perfecto */
}

 
/* ── STATS BAR ── */
.stats-bar{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--bg2);
  position:relative;overflow:hidden;
}
.stats-bar::after{
  content:'';
  position:absolute;top:0;left:-100%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(201,168,76,.05),transparent);
  animation:shimmer 5s ease-in-out infinite 1.5s;
  pointer-events:none;
}
.stat-item{
  text-align:center;padding:2.25rem 1rem;
  position:relative;transition:background .25s;
}
.stat-item:hover{background:rgba(201,168,76,.04)}
.stat-item+.stat-item::before{
  content:'';position:absolute;left:0;top:28%;bottom:28%;
  width:1px;background:var(--border);
}
.stat-num{
  font-family:var(--font-serif);
  font-size:2.5rem;font-weight:500;
  color:var(--gold);line-height:1;margin-bottom:.35rem;
  letter-spacing:-.02em;
}
.stat-lbl{font-size:.72rem;color:var(--text-muted);letter-spacing:.04em}
 
/* ── POR QUÉ ── */
.sec-porq{
  padding:6.5rem 4rem;
  max-width:1240px;margin:0 auto;
}
.sec-tag{
  font-size:.65rem;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold);
  display:flex;align-items:center;gap:.6rem;margin-bottom:.65rem;
}
.sec-tag::before{content:'';display:block;width:24px;height:1px;background:var(--gold);opacity:.7}
.sec-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:2rem;margin-bottom:3.5rem;flex-wrap:wrap;
}
.sec-title-xl{
  font-family:var(--font-serif);
  font-size:clamp(2rem,3.2vw,3.1rem);
  font-weight:500;line-height:1.1;
  max-width:18ch;letter-spacing:-.01em;
}
.sec-sub{
  font-size:.92rem;color:var(--text-soft);
  max-width:38ch;line-height:1.78;flex-shrink:0;
}
 
/* table */
.compare-table{
  border:1px solid var(--border);border-radius:10px;overflow:hidden;
  position:relative;
}
.compare-table::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent 0%,var(--gold) 50%,transparent 100%);
}
.compare-header{display:grid;grid-template-columns:1fr 1fr}
.compare-header-cell{
  padding:.95rem 2rem;
  font-size:.66rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:.6rem;
}
.compare-header-cell.bad{background:var(--surface2);color:var(--text-muted)}
.compare-header-cell.bad::before{
  content:'';display:block;width:7px;height:7px;border-radius:50%;
  background:#e05454;opacity:.5;flex-shrink:0;
}
.compare-header-cell.good{
  background:rgba(201,168,76,.1);color:var(--gold);
  border-left:1px solid var(--border);
}
.compare-header-cell.good::before{
  content:'';display:block;width:7px;height:7px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
}
.compare-row{
  display:grid;grid-template-columns:1fr 1fr;
  border-bottom:1px solid var(--border);
  transition:background .18s;
}
.compare-row:last-child{border-bottom:none}
.compare-row:hover .compare-cell{background:rgba(255,255,255,.012)}
.compare-row:hover .compare-cell.good{background:rgba(201,168,76,.07)}
.compare-cell{
  padding:1.3rem 2rem;
  display:flex;align-items:flex-start;gap:.85rem;
  font-size:.875rem;line-height:1.58;color:var(--text-soft);
  transition:background .18s;
}
.compare-cell.good{
  border-left:1px solid var(--border);
  background:rgba(201,168,76,.03);
}
.compare-icon{
  width:20px;height:20px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:700;flex-shrink:0;margin-top:.12rem;
}
.compare-icon.x{background:rgba(220,60,60,.14);color:#e05454}
.compare-icon.v{background:rgba(201,168,76,.2);color:var(--gold)}
 
/* CTA bajo la tabla */
.compare-cta{
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;
  margin-top:2rem;
  padding:1.75rem 2rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:8px;
  position:relative;overflow:hidden;
}
.compare-cta::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 0% 50%,rgba(201,168,76,.06) 0%,transparent 55%);
  pointer-events:none;
}
.compare-cta-text p:first-child{
  font-family:var(--font-serif);
  font-size:1.22rem;font-style:italic;color:var(--text);
  margin-bottom:.15rem;
}
.compare-cta-text p:last-child{font-size:.78rem;color:var(--text-muted)}
 
/* ── WHATSAPP FLOAT ── */
.whatsapp-float{
  position:fixed;bottom:1.75rem;right:1.75rem;z-index:150;
  display:flex;align-items:center;gap:.65rem;
  background:#1a1a1a;border:1px solid rgba(255,255,255,.08);
  color:var(--text);font-size:.8rem;
  padding:.7rem 1.2rem .7rem .9rem;border-radius:2rem;
  box-shadow:0 8px 32px rgba(0,0,0,.6);
  transition:background .2s,box-shadow .2s,transform .15s;
}
.whatsapp-float:hover{background:#222;transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,0,0,.7)}
.whatsapp-float svg{width:20px;height:20px;flex-shrink:0;color:#25d366}
 
/* ── ANIMATIONS ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes shimmer{
  0%{left:-100%}60%{left:130%}100%{left:130%}
}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
 
/* ── RESPONSIVE ── */
@media(max-width:1024px){
  nav{padding:0 2rem}
  .hero-suc{grid-template-columns:1fr;gap:2.5rem;padding:100px 2rem 60px}
  .sec-porq{padding:5rem 2rem}
}
@media(max-width:680px){
  .hero-suc{padding:90px 1.25rem 50px}
  h1.hero-title{font-size:2.7rem}
  .stats-bar{grid-template-columns:1fr 1fr}
  .stat-item+.stat-item::before{display:none}
  .compare-cell{padding:1rem 1rem;font-size:.82rem}
  .compare-header-cell{padding:.8rem 1rem}
  .compare-cta{flex-direction:column}
  .hero-ctas{flex-direction:column}
  .sec-header{flex-direction:column;align-items:flex-start}
  .sec-sub{max-width:none}
}
/* ── STATS ── */
.stats-bar { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.stat-item { text-align: center; padding: 1.8rem 1rem; position: relative; }
.stat-item + .stat-item::before { content: ''; position: absolute; left: 0; top: 22%; bottom: 22%; width: 1px; background: var(--border); }
.stat-num { font-family: 'Playfair Display', serif; font-size: 2.1rem; color: var(--gold); line-height: 1; margin-bottom: 0.3rem; }
.stat-lbl { font-size: 0.73rem; color: var(--text-muted); }

/* ── SECCIONES ── */
section { padding: 5rem 6vw; position: relative; }
.sec-dark  { background: var(--surface);  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.sec-dark2 { background: var(--surface2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.section-tag { font-size: 0.67rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); display: block; margin-bottom: 0.6rem; }
.section-title { font-size: clamp(1.6rem, 2.6vw, 2.3rem); margin-bottom: 0.75rem; }
.section-sub { font-size: 0.93rem; color: var(--text-soft); max-width: 52ch; margin-bottom: 2.5rem; line-height: 1.7; }

/* ── TABLA COMPARATIVA ── */
.compare-table { border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
.compare-header { display: grid; grid-template-columns: 1fr 1fr; }
.compare-header-cell { padding: 0.85rem 1.5rem; font-size: 0.68rem; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; border-bottom: 1px solid var(--border); }
.compare-header-cell.bad  { background: var(--surface2); color: var(--text-muted); }
.compare-header-cell.good { background: var(--gold-dim); color: var(--gold); border-left: 1px solid var(--border); }
.compare-row { display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid var(--border); }
.compare-row:last-child { border-bottom: none; }
.compare-row:nth-child(even) .compare-cell      { background: var(--surface); }
.compare-row:nth-child(even) .compare-cell.good { background: rgba(201,168,76,0.04); }
.compare-cell { padding: 1.05rem 1.5rem; display: flex; align-items: flex-start; gap: 0.75rem; font-size: 0.86rem; line-height: 1.55; color: var(--text-soft); }
.compare-cell.good { border-left: 1px solid var(--border); background: rgba(201,168,76,0.025); }
.compare-icon { width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.65rem; font-weight: 700; flex-shrink: 0; margin-top: 0.08rem; }
.compare-icon.x { background: rgba(220,60,60,0.13); color: #e05454; }
.compare-icon.v { background: rgba(201,168,76,0.22); color: var(--gold); }

/* ── TIMELINE ── */
.timeline-wrap { display: grid; grid-template-columns: repeat(5, 1fr); position: relative; margin-top: 3rem; }
.timeline-wrap::before {
  content: ''; position: absolute; top: 1.9rem;
  left: calc(10% + 1.5rem); right: calc(10% + 1.5rem);
  height: 1px; background: linear-gradient(90deg, var(--gold), rgba(201,168,76,0.25) 50%, var(--gold));
}
.tl-step { padding: 0 0.75rem 0 0; }
.tl-circle {
  width: 3.8rem; height: 3.8rem; border-radius: 50%;
  background: var(--bg); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  position: relative; z-index: 1; margin-bottom: 1.5rem;
  transition: background 0.25s, border-color 0.25s;
}
.tl-step:hover .tl-circle { background: var(--surface); border-color: var(--gold); }
.tl-circle svg { width: 17px; height: 17px; stroke: var(--gold); fill: none; stroke-width: 1.5; }
.tl-num-badge {
  position: absolute; top: -3px; right: -3px; width: 15px; height: 15px; border-radius: 50%;
  background: var(--gold); color: #0e0f0f; font-size: 0.56rem; font-weight: 700;
  font-family: 'DM Sans', sans-serif; display: flex; align-items: center; justify-content: center;
}
.tl-step h4 { font-size: 0.88rem; margin-bottom: 0.4rem; color: var(--text); }
.tl-step p  { font-size: 0.78rem; color: var(--text-soft); line-height: 1.65; }
.tl-duration { display: inline-flex; align-items: center; background: var(--gold-dim); border: 1px solid var(--border); color: var(--gold); font-size: 0.65rem; font-weight: 500; padding: 0.18rem 0.6rem; border-radius: 2rem; margin-top: 0.55rem; }

/* ── CALC STEPS ── */
.calc-steps-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: 8px; overflow: hidden;
  margin-bottom: 2.25rem;
}
.calc-step-card { background: var(--bg); padding: 1.6rem 1.4rem; display: flex; flex-direction: column; gap: 0.5rem; transition: background 0.2s; }
.calc-step-card:hover { background: var(--surface); }
.calc-step-num { font-family: 'Playfair Display', serif; font-size: 1.6rem; color: var(--gold); opacity: 0.3; line-height: 1; margin-bottom: 0.15rem; }
.calc-step-icon { width: 34px; height: 34px; background: var(--gold-dim); border: 1px solid var(--border); border-radius: 5px; display: flex; align-items: center; justify-content: center; margin-bottom: 0.4rem; }
.calc-step-icon svg { width: 15px; height: 15px; stroke: var(--gold); fill: none; stroke-width: 1.5; }
.calc-step-card h4 { font-size: 0.87rem; margin-bottom: 0.12rem; color: var(--text); }
.calc-step-card p  { font-size: 0.77rem; color: var(--text-soft); line-height: 1.6; }

/* ── CALC FORM ── */
.calc-wrap {
  max-width: 680px; margin: 0 auto;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 2.75rem; position: relative; overflow: hidden;
}
.calc-wrap::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.calc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.15rem; margin-bottom: 1.15rem; }
.calc-row.full { grid-template-columns: 1fr; }
.calc-field label { display: block; font-size: 0.67rem; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); margin-bottom: 0.42rem; }
input[type="number"], select {
  width: 100%; padding: 0.72rem 0.95rem;
  border: 1px solid var(--border-s); border-radius: var(--radius);
  background: var(--bg); color: var(--text);
  font-family: 'DM Sans', sans-serif; font-size: 0.87rem;
  outline: none; transition: border-color 0.2s; -webkit-appearance: none;
}
input[type="number"]:focus, select:focus { border-color: var(--gold); }
.calc-result { display: none; margin-top: 1.4rem; background: var(--gold-dim); border: 1px solid var(--border); border-radius: 8px; padding: 1.6rem; }
.result-label { font-size: 0.67rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); margin-bottom: 0.45rem; }
.result-range { font-family: 'Playfair Display', serif; font-size: 1.9rem; color: var(--text); margin-bottom: 0.22rem; }
.result-note  { font-size: 0.75rem; color: var(--text-muted); }
.result-extras { margin-top: 1.15rem; padding-top: 1.15rem; border-top: 1px solid var(--border); }
.result-extras-title { font-size: 0.67rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); margin-bottom: 0.65rem; }
.result-extras ul { list-style: none; padding: 0; }
.result-extras li { font-size: 0.8rem; color: var(--text-soft); line-height: 1.85; }
.result-extras li strong { color: var(--text); }
.calc-disclaimer { font-size: 0.72rem; color: var(--text-muted); text-align: center; margin-top: 1rem; }

/* ── CASOS ── */
.casos-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.4rem; }
.caso-card { background: var(--surface); border: 1px solid var(--border); border-radius: 8px; padding: 1.75rem; transition: border-color 0.25s; }
.caso-card:hover { border-color: rgba(201,168,76,0.4); }
.caso-tag { font-size: 0.65rem; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); display: flex; align-items: center; gap: 0.4rem; margin-bottom: 0.7rem; }
.caso-tag::before { content: ''; width: 14px; height: 1px; background: var(--gold); display: block; }
.caso-card h4 { font-size: 0.96rem; margin-bottom: 0.55rem; color: var(--text); }
.caso-card p  { font-size: 0.83rem; color: var(--text-soft); line-height: 1.65; margin-bottom: 1.1rem; }
.caso-badge { display: inline-flex; align-items: center; gap: 0.4rem; background: var(--gold-dim); border: 1px solid var(--border); padding: 0.27rem 0.75rem; border-radius: 2rem; font-size: 0.71rem; color: var(--gold); font-weight: 500; }

/* ── RESEÑAS ── */
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }
.review-card { background: var(--surface); border: 1px solid var(--border); border-radius: 8px; padding: 1.6rem; position: relative; overflow: hidden; }
.review-card::before { content: '"'; font-family: 'Playfair Display', serif; font-size: 4.5rem; color: var(--gold); opacity: 0.11; position: absolute; top: -0.4rem; left: 1.1rem; line-height: 1; pointer-events: none; }
.review-stars { display: flex; gap: 2px; margin-bottom: 0.8rem; }
.review-stars span { color: var(--gold); font-size: 0.74rem; }
.review-text { font-size: 0.84rem; color: var(--text-soft); line-height: 1.7; margin-bottom: 1.1rem; padding-top: 0.5rem; }
.review-author strong { font-size: 0.82rem; color: var(--text); font-weight: 500; display: block; }
.review-author span   { font-size: 0.72rem; color: var(--text-muted); }
.google-badge { display: inline-flex; align-items: center; gap: 0.45rem; background: var(--gold-dim); border: 1px solid var(--border); padding: 0.3rem 0.8rem; border-radius: 2rem; font-size: 0.7rem; color: var(--gold); font-weight: 500; }

/* ── FAQ PREMIUM ── */
.faq-list { max-width: 780px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-q {
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.35rem 0; cursor: pointer; gap: 1.25rem;
  background: none; border: none; width: 100%; text-align: left;
}
.faq-q:hover .faq-question { color: var(--gold); }
.faq-question { font-family: 'DM Sans', sans-serif; font-weight: 400; font-size: 0.93rem; color: var(--text); transition: color 0.2s; line-height: 1.5; }
.faq-icon {
  width: 26px; height: 26px; border-radius: 50%;
  border: 1px solid var(--border); background: var(--surface);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: background 0.2s, border-color 0.2s; position: relative;
}
.faq-icon::before, .faq-icon::after { content: ''; position: absolute; background: var(--gold); border-radius: 2px; transition: transform 0.28s ease, opacity 0.28s; }
.faq-icon::before { width: 9px; height: 1.5px; }
.faq-icon::after  { width: 1.5px; height: 9px; }
.faq-item.open .faq-q .faq-icon { background: var(--gold-dim); border-color: var(--gold); }
.faq-item.open .faq-q .faq-icon::after { transform: rotate(90deg); opacity: 0; }
.faq-item.open .faq-q .faq-question { color: var(--gold); }
.faq-body { max-height: 0; overflow: hidden; transition: max-height 0.38s cubic-bezier(0.4,0,0.2,1), padding 0.3s; }
.faq-item.open .faq-body { max-height: 400px; padding-bottom: 1.5rem; }
.faq-answer { font-size: 0.87rem; color: var(--text-soft); line-height: 1.8; border-left: 2px solid var(--border); padding-left: 1.2rem; }
.faq-item.open .faq-answer { border-left-color: var(--gold); }

/* ── CTA FINAL ── */
.cta-final { text-align: center; padding: 7rem 6vw; position: relative; overflow: hidden; }
.cta-final::before {
  content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 700px; height: 350px; background: radial-gradient(ellipse, rgba(201,168,76,0.08) 0%, transparent 70%); pointer-events: none;
}
.cta-final h2 { font-size: clamp(2rem, 3.5vw, 3rem); max-width: 18ch; margin: 0 auto 1rem; }
.cta-final p  { color: var(--text-soft); max-width: 46ch; margin: 0 auto 2.5rem; }
.cta-buttons  { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ── FOOTER ── */
footer {
  background: var(--surface); border-top: 1px solid var(--border);
  padding: 2.25rem 6vw; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 0.75rem;
}
footer p { font-size: 0.77rem; color: var(--text-muted); }
footer a { color: var(--text-muted); transition: color 0.2s; }
footer a:hover { color: var(--gold); }
.footer-logo { font-family: 'Playfair Display', serif; font-size: 0.95rem; color: var(--text-soft); }
.footer-logo span { color: var(--gold); }
.footer-sub { font-size: 0.68rem; color: var(--text-muted); margin-top: 0.1rem; }

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .nav-links { display: none; flex-direction: column; align-items: flex-start; gap: 1.25rem; position: fixed; top: 0; right: 0; bottom: 0; width: 260px; background: var(--surface); border-left: 1px solid var(--border); padding: 5rem 2rem 2rem; z-index: 95; overflow-y: auto; }
  .nav-links.active { display: flex; }
  .nav-links a { font-size: 1rem; }
  .hamburger { display: flex; }
  .hero { grid-template-columns: 1fr; padding-top: 7rem; gap: 2.5rem; }
  .hero::after { display: none; }
  .stats-bar { grid-template-columns: repeat(2,1fr); }
  .stat-item + .stat-item::before { display: none; }
  .compare-header, .compare-row { grid-template-columns: 1fr; }
  .compare-cell.good { border-left: none; border-top: 1px solid var(--border); }
  .compare-header-cell.good { border-left: none; border-top: 1px solid var(--border); }
  .timeline-wrap { grid-template-columns: 1fr; gap: 2rem; }
  .timeline-wrap::before { display: none; }
  .tl-step { display: flex; gap: 1.25rem; align-items: flex-start; }
  .tl-circle { flex-shrink: 0; margin-bottom: 0; }
  .calc-steps-grid { grid-template-columns: repeat(2,1fr); }
  .calc-row { grid-template-columns: 1fr; }
  .casos-grid { grid-template-columns: 1fr; }
  .reviews-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  section { padding: 4rem 5vw; }
  .stats-bar { grid-template-columns: 1fr 1fr; }
  .hero-ctas { flex-direction: column; }
  .cta-buttons { flex-direction: column; align-items: center; }
  .calc-steps-grid { grid-template-columns: 1fr; }
  .calc-wrap { padding: 2rem 1.5rem; }
  .whatsapp-float span { display: none; }
  .whatsapp-float { padding: 0.85rem; border-radius: 50%; }
}



.about-image img {
  width: 100%;
  border-radius: 16px;

  /* Look editorial */
  filter: contrast(1.05) brightness(0.95);

  /* PRO: fondo menos distractivo */
  mask-image: linear-gradient(to right, 
    rgba(0,0,0,1) 70%, 
    rgba(0,0,0,0)
  );
}

.about-image img {
  filter: grayscale(100%) contrast(1.2);
}

.about-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle, transparent 60%, rgba(0,0,0,0.6));
}



