/*
Theme Name: Abogados y Asociados
Theme URI: https://example.com/
Author: Gamaliel Estrada Rabadan
Description: Tema one-page para despacho legal, compatible con Elementor, con home completa hardcodeada y páginas por servicio/ubicación.
Version: 1.0.0
Text Domain: viveros-human-first
*/

:root{
  --bg:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --line:#e2e8f0;
  --soft:#f8fafc;
  --dark:#020617;
  --radius:26px;
  --radius-sm:18px;
  --container:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(var(--container),calc(100% - 32px));margin:0 auto}
.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{left:16px;top:16px;z-index:999;background:#fff;padding:10px 14px;border-radius:10px;border:1px solid var(--line)}
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:18px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand img{width:48px;height:48px;border-radius:999px;object-fit:contain;border:1px solid var(--line);background:#fff;padding:3px}
.brand-title{font-size:14px;font-weight:700;line-height:1.2}
.brand-sub{font-size:12px;color:var(--muted)}
.nav{display:flex;align-items:center;gap:24px}
.nav a{font-size:14px;color:#475569}
.nav a:hover{color:var(--text)}
.header-cta{display:flex;align-items:center;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--dark);background:var(--dark);color:#fff;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;transition:.2s transform,.2s box-shadow,.2s background,.2s color}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(2,6,23,.12)}
.btn-outline{background:#fff;color:var(--dark)}
.btn-ghost{background:transparent;color:var(--dark);border-color:transparent;padding-left:0}
.menu-toggle{display:none;background:none;border:none;padding:8px;border-radius:12px}
.mobile-panel{display:none;padding:0 0 14px}
.mobile-panel a{display:block;padding:10px 12px;border-radius:14px;color:#334155}
.mobile-panel a:hover{background:var(--soft)}
.section{padding:84px 0}
.section-tight{padding:30px 0}
.section-soft{background:var(--soft)}
.section-dark{background:var(--dark);color:#fff}
.hero-wrap{position:relative;overflow:hidden}
.hero-wrap:before,.hero-wrap:after{content:"";position:absolute;border-radius:999px;filter:blur(34px);opacity:.18;pointer-events:none}
.hero-wrap:before{width:380px;height:380px;background:#94a3b8;top:-120px;right:-80px}
.hero-wrap:after{width:280px;height:280px;background:#cbd5e1;top:-40px;left:-100px}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:38px;align-items:start}
.badge{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.18em;background:#fff}
.hero-title{font-size:clamp(38px,5vw,66px);line-height:1.04;letter-spacing:-.03em;margin:18px 0}
.hero-text{font-size:18px;color:#475569;max-width:740px}
.grid-2,.grid-3,.grid-4{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 8px 24px rgba(15,23,42,.05)}
.card.pad{padding:24px}
.stat,.pill-card{border-radius:20px;border:1px solid var(--line);background:#fff;padding:16px}
.kicker{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;font-weight:700}
.section-title{font-size:clamp(30px,4vw,46px);line-height:1.08;letter-spacing:-.03em;margin:10px 0}
.section-text{font-size:18px;color:#475569;max-width:780px}
.pain-card{display:flex;gap:12px;padding:16px;border-radius:18px;border:1px solid var(--line);background:#fff}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.hero-aside{overflow:hidden}
.hero-aside-head{background:var(--dark);color:#fff;padding:22px;border-bottom:1px solid var(--line)}
.hero-aside-grid{display:grid;grid-template-columns:1fr 1fr}
.video-box,.chat-box{padding:22px}
.video-box .video-placeholder{min-height:220px;display:flex;align-items:center;justify-content:center;border-radius:28px;border:1px solid var(--line);background:#f1f5f9;padding:28px;text-align:center}
.chat-box{background:#f8fafc;border-left:1px solid var(--line)}
.chat-stream{display:flex;flex-direction:column;gap:10px;padding:14px;border:1px solid var(--line);border-radius:28px;background:#fff}
.chat-msg{max-width:92%;padding:12px 14px;border-radius:18px;font-size:14px}
.chat-ai{background:#f1f5f9;color:#334155}
.chat-user{margin-left:auto;background:var(--dark);color:#fff}
.input-row{display:flex;gap:8px;flex-wrap:wrap}
.input, textarea{width:100%;border:1px solid #cbd5e1;border-radius:16px;padding:12px 14px;font:inherit;background:#fff}
textarea{min-height:150px;resize:vertical}
.icon-wrap{width:46px;height:46px;border-radius:18px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.icon-wrap.dark{background:rgba(255,255,255,.08)}
.feature-list{display:grid;gap:10px;margin-top:16px}
.feature-item{display:flex;gap:8px;font-size:14px;color:#334155}
.dark .section-text,.section-dark .section-text,.section-dark .kicker{color:#cbd5e1}
.media-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:26px;padding:24px}
.media-preview{min-height:220px;border-radius:24px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.03)}
.step{display:flex;gap:16px;padding:20px;border:1px solid var(--line);border-radius:24px;background:#fff}
.step-no{width:48px;height:48px;border-radius:18px;background:var(--dark);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex:0 0 auto}
.team-avatar{width:64px;height:64px;border-radius:24px;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#475569}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.tag{font-size:12px;padding:6px 10px;border-radius:999px;background:#f1f5f9;border:1px solid var(--line)}
.review-stars{letter-spacing:2px}
.faq-item{border-top:1px solid var(--line)}
.faq-btn{width:100%;text-align:left;background:none;border:none;padding:18px 0;font:inherit;font-weight:600;display:flex;justify-content:space-between;gap:12px}
.faq-answer{display:none;padding:0 0 18px;color:#475569}
.faq-item.active .faq-answer{display:block}
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:38px}
.contact-row{display:flex;gap:14px;padding:16px;border:1px solid var(--line);border-radius:18px;background:#fff}
.site-footer{border-top:1px solid var(--line);background:#f8fafc}
.footer-inner{display:flex;justify-content:space-between;gap:24px;align-items:center;padding:28px 0;flex-wrap:wrap}
.service-hero,.location-hero{padding:60px 0 24px}
.content-narrow{width:min(900px,calc(100% - 32px));margin:0 auto}
.prose h2{font-size:30px;line-height:1.15;margin:30px 0 12px}
.prose h3{font-size:22px;margin:26px 0 10px}
.prose p,.prose li{font-size:17px;color:#334155}
.prose ul{padding-left:20px}
.archive-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.notice-box{padding:16px;border-radius:18px;background:#f8fafc;border:1px solid var(--line)}
@media (max-width: 1000px){
  .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero-grid,.contact-grid{grid-template-columns:1fr}
  .hero-aside-grid{grid-template-columns:1fr}
  .chat-box{border-left:none;border-top:1px solid var(--line)}
}
@media (max-width: 760px){
  .nav,.header-cta{display:none}
  .menu-toggle{display:inline-flex}
  .mobile-panel.open{display:block}
  .grid-2,.grid-3,.grid-4,.archive-list{grid-template-columns:1fr}
  .section{padding:64px 0}
  .hero-title{font-size:40px}
}


.professional-hero-copy{
  display:flex;
  flex-direction:column;
  gap:22px;
}
.hero-badge{
  font-size:10px;
  padding:4px 10px;
}
.hero-headline-box{
  max-width:720px;
}
.hero-title-pro{
  margin:14px 0 10px;
  font-size:32px;
  line-height:1.15;
  letter-spacing:-0.03em;
  font-weight:700;
  color:#0f172a;
}
.hero-text-pro{
  margin:0;
  font-size:17px;
  line-height:1.75;
  color:#475569;
  max-width:640px;
}
.hero-trust-row{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.hero-trust-item{
  padding:16px 18px;
  border:1px solid #e2e8f0;
  border-radius:18px;
  background:#fff;
}
.hero-trust-label{
  display:block;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#64748b;
  margin-bottom:6px;
  font-weight:700;
}
.hero-problems-box{
  padding:20px;
  border:1px solid #e2e8f0;
  border-radius:24px;
  background:#f8fafc;
}
.hero-problems-head{
  margin-bottom:16px;
}
.hero-problems-head p{
  margin:6px 0 0;
  font-size:14px;
  color:#64748b;
}
.hero-mini-title{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:700;
  color:#334155;
}
.hero-points-grid{
  gap:12px;
}
.pain-card-pro{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:14px;
  border-radius:18px;
  border:1px solid #e2e8f0;
  background:#fff;
}
.pain-icon{
  width:24px;
  height:24px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:700;
  background:#0f172a;
  color:#fff;
  flex:0 0 auto;
  margin-top:2px;
}
.pain-text{
  color:#334155;
  font-size:14px;
  line-height:1.6;
}
.hero-actions-pro{
  margin-top:2px;
}
.hero-note-box{
  padding:14px 16px;
  border-left:3px solid #0f172a;
  background:#fff;
  border-radius:0 16px 16px 0;
  color:#475569;
  font-size:14px;
}
.professional-intake{
  padding:28px;
  border-radius:28px;
  border:1px solid #e2e8f0;
  box-shadow:0 14px 34px rgba(15,23,42,.07);
}
.intake-top{
  padding-bottom:16px;
  border-bottom:1px solid #e2e8f0;
}
.intake-eyebrow{
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:#64748b;
  margin-bottom:8px;
}
.intake-title{
  margin:0;
  font-size:24px;
  line-height:1.2;
  font-weight:700;
  color:#0f172a;
}
.intake-subtitle{
  margin:8px 0 0;
  color:#64748b;
  font-size:14px;
  line-height:1.6;
}
.intake-progress-wrap{
  margin-top:18px;
}
.intake-progress-label{
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  font-size:13px;
  color:#64748b;
  margin-bottom:8px;
}
.intake-progress-bar{
  width:100%;
  height:8px;
  border-radius:999px;
  background:#e2e8f0;
  overflow:hidden;
}
.intake-progress-fill{
  width:25%;
  height:100%;
  border-radius:999px;
  background:#0f172a;
  transition:width .25s ease;
}
.intake-form{
  margin-top:18px;
}
.intake-step{
  display:none;
  animation:fadeIn .25s ease;
}
.intake-step.active{
  display:block;
}
.intake-label{
  display:block;
  margin-bottom:10px;
  font-size:14px;
  font-weight:600;
  color:#0f172a;
}
.choice-grid{
  display:grid;
  gap:12px;
}
.choice-grid-2{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.choice-card{
  border:1px solid #cbd5e1;
  border-radius:18px;
  background:#fff;
  padding:16px;
  text-align:left;
  font:inherit;
  font-weight:600;
  color:#0f172a;
  cursor:pointer;
  transition:.2s ease;
}
.choice-card:hover,
.priority-card:hover{
  transform:translateY(-1px);
  border-color:#0f172a;
}
.choice-card.active,
.priority-card.active{
  background:#f8fafc;
  border-color:#0f172a;
  box-shadow:0 8px 18px rgba(15,23,42,.06);
}
.priority-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.priority-card{
  display:flex;
  flex-direction:column;
  gap:5px;
  padding:14px;
  border:1px solid #cbd5e1;
  border-radius:18px;
  background:#fff;
  text-align:left;
  cursor:pointer;
  transition:.2s ease;
}
.priority-card span{
  font-size:12px;
  color:#64748b;
}
.intake-summary{
  margin-top:18px;
  padding:18px;
  border:1px solid #e2e8f0;
  border-radius:20px;
  background:#f8fafc;
}
.intake-summary-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
  font-size:13px;
  font-weight:700;
  color:#475569;
}
.summary-status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #cbd5e1;
  border-radius:999px;
  padding:5px 10px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  background:#fff;
}
.summary-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.summary-item{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:16px;
  padding:12px;
}
.summary-label{
  display:block;
  font-size:12px;
  color:#64748b;
  margin-bottom:6px;
}
.intake-nav{
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin-top:18px;
}
.intake-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:14px;
}
@keyframes fadeIn{
  from{opacity:0;transform:translateY(4px)}
  to{opacity:1;transform:translateY(0)}
}
@media (max-width:760px){
  .hero-title-pro{
    font-size:28px;
  }
  .hero-trust-row,
  .choice-grid-2,
  .summary-grid,
  .priority-row{
    grid-template-columns:1fr;
  }
}


.quick-action-card{
  padding:22px;
  border-radius:22px;
  background:#fff;
  border:1px solid #e2e8f0;
  box-shadow:0 10px 24px rgba(15,23,42,.04);
}
.quick-action-label{
  display:inline-block;
  margin-bottom:10px;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#64748b;
}
.quick-action-card h3{
  margin:0 0 10px;
  font-size:20px;
  line-height:1.3;
  color:#0f172a;
}
.quick-action-card p{
  margin:0 0 16px;
  font-size:14px;
  line-height:1.7;
  color:#475569;
}

.action-card-dark{
  padding:26px;
  border-radius:24px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.12);
  display:flex;
  flex-direction:column;
  gap:12px;
}
.action-label-dark{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#cbd5e1;
}
.action-card-dark h3{
  margin:0;
  font-size:22px;
  line-height:1.3;
  color:#fff;
}
.action-card-dark p{
  margin:0;
  font-size:14px;
  line-height:1.7;
  color:#cbd5e1;
}
.btn-light-outline{
  border-color:rgba(255,255,255,0.22);
  color:#fff;
  background:transparent;
}
.btn-light-outline:hover{
  background:#fff;
  color:#0f172a;
}


.faq-section-pro{
  background:#fff;
}
.faq-layout-pro{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:36px;
  align-items:start;
}
.faq-intro-panel{
  display:flex;
  flex-direction:column;
  gap:20px;
}
.faq-title-pro{
  margin-bottom:10px;
}
.faq-text-pro{
  max-width:100%;
}
.faq-search-box{
  padding:18px;
  border:1px solid #e2e8f0;
  border-radius:22px;
  background:#f8fafc;
}
.faq-search-label{
  display:block;
  margin-bottom:8px;
  font-size:13px;
  font-weight:600;
  color:#334155;
}
.faq-search-input{
  border-radius:16px;
}
.faq-quick-topics{
  padding:18px;
  border:1px solid #e2e8f0;
  border-radius:22px;
  background:#fff;
}
.faq-topic-label{
  display:block;
  margin-bottom:10px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:700;
  color:#64748b;
}
.faq-topic-chips{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.faq-chip{
  border:1px solid #cbd5e1;
  background:#fff;
  color:#0f172a;
  border-radius:999px;
  padding:8px 14px;
  font:inherit;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  transition:.2s ease;
}
.faq-chip:hover,
.faq-chip.active{
  background:#0f172a;
  color:#fff;
  border-color:#0f172a;
}
.faq-help-card{
  padding:22px;
  border:1px solid #e2e8f0;
  border-radius:24px;
  background:#f8fafc;
}
.faq-help-label{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:700;
  color:#64748b;
  margin-bottom:8px;
}
.faq-content-panel{
  border-radius:28px;
  padding:24px;
}
.faq-panel-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  padding-bottom:16px;
  border-bottom:1px solid #e2e8f0;
  margin-bottom:10px;
}
.faq-panel-label{
  display:block;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:#64748b;
  margin-bottom:6px;
}
.faq-panel-title{
  margin:0;
  font-size:24px;
  line-height:1.3;
  color:#0f172a;
}
.faq-counter{
  white-space:nowrap;
  border:1px solid #e2e8f0;
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:700;
  color:#475569;
  background:#f8fafc;
}
.faq-list-pro{
  display:flex;
  flex-direction:column;
}
.faq-item-pro{
  border-bottom:1px solid #e2e8f0;
}
.faq-btn-pro{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  background:none;
  border:none;
  text-align:left;
  padding:18px 0;
  font:inherit;
  cursor:pointer;
}
.faq-question-text{
  font-size:16px;
  font-weight:600;
  color:#0f172a;
  line-height:1.5;
}
.faq-icon-pro{
  width:28px;
  height:28px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid #cbd5e1;
  color:#0f172a;
  font-size:16px;
  flex:0 0 auto;
  transition:.2s ease;
}
.faq-item-pro.active .faq-icon-pro{
  background:#0f172a;
  color:#fff;
  border-color:#0f172a;
}
.faq-answer-pro{
  display:none;
  padding:0 0 18px;
}
.faq-answer-inner{
  padding:16px 18px;
  border:1px solid #e2e8f0;
  border-radius:18px;
  background:#f8fafc;
  color:#475569;
  line-height:1.8;
  font-size:15px;
}
.faq-empty-state{
  margin-top:16px;
  padding:18px;
  border:1px dashed #cbd5e1;
  border-radius:18px;
  background:#f8fafc;
  color:#475569;
}
@media (max-width: 900px){
  .faq-layout-pro{
    grid-template-columns:1fr;
  }
}
@media (max-width: 760px){
  .faq-panel-head{
    flex-direction:column;
  }
  .faq-panel-title{
    font-size:22px;
  }
  .faq-question-text{
    font-size:15px;
  }
}


/* Version 9: solo mejoras de organización visual, sin cambios de contenido */
.hero-wrap-pro{
  padding-top:72px;
  padding-bottom:72px;
}
.quick-actions-section{
  border-top:1px solid #e2e8f0;
  border-bottom:1px solid #e2e8f0;
}
.section-intro-pro{
  max-width:760px;
  margin-bottom:28px;
}
.section-intro-pro .section-title{
  margin-bottom:12px;
}
.section-intro-dark .section-title,
.section-intro-dark .section-text{
  color:#fff;
}
.services-section .card.pad,
.team-section-pro .card.pad,
.content-section-pro .media-card,
.action-band-pro .media-card,
.quick-actions-section .quick-action-card,
.contact-section-pro .card.pad,
.faq-content-panel{
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.services-section .card.pad:hover,
.team-section-pro .card.pad:hover,
.content-section-pro .media-card:hover,
.action-band-pro .media-card:hover,
.quick-actions-section .quick-action-card:hover,
.contact-section-pro .card.pad:hover,
.faq-content-panel:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 34px rgba(15,23,42,.07);
}
.process-grid-pro{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:36px;
  align-items:start;
}
.process-section-pro .step{
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
}
.team-section-pro .review-stars{
  font-size:15px;
}
.content-section-pro .grid-3,
.action-band-pro .grid-3,
.team-section-pro .grid-3,
.quick-actions-section .grid-3{
  gap:18px;
}
.quick-actions-section .btn,
.action-band-pro .btn{
  margin-top:auto;
}
.content-section-pro .media-card,
.action-band-pro .action-card-dark{
  min-height:100%;
}
.contact-section-pro .contact-row{
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
}
.contact-section-pro form label{
  display:block;
  margin-bottom:8px;
  font-size:13px;
  font-weight:600;
  color:#334155;
}
.faq-intro-panel,
.faq-content-panel{
  position:relative;
}
.faq-help-card,
.hero-problems-box,
.hero-note-box,
.intake-summary,
.quick-action-card,
.action-card-dark{
  overflow:hidden;
}
.quick-action-card::before,
.action-card-dark::before,
.faq-help-card::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:1px;
  background:linear-gradient(90deg,rgba(15,23,42,.12),transparent);
  pointer-events:none;
}
@media (max-width:1000px){
  .process-grid-pro{
    grid-template-columns:1fr;
  }
}


/* ===== Version 10 – refinamiento premium (sin cambiar contenido) ===== */

/* tipografía más limpia */
.hero-title-pro{
  letter-spacing:-0.02em;
}

.section-title{
  letter-spacing:-0.015em;
}

/* mejor ritmo vertical */
.section{
  padding-top:80px;
  padding-bottom:80px;
}

/* contenedores más elegantes */
.container{
  max-width:1180px;
}

/* tarjetas más suaves */
.card,
.media-card,
.quick-action-card,
.action-card-dark{
  border-radius:26px;
  transition:all .25s ease;
}

/* hover más premium */
.card:hover,
.media-card:hover,
.quick-action-card:hover,
.action-card-dark:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 40px rgba(15,23,42,.08);
}

/* mejor espaciado interno */
.pad{
  padding:26px;
}

/* grid más aireado */
.grid-3{
  gap:22px;
}
.grid-4{
  gap:22px;
}

/* botones más refinados */
.btn{
  border-radius:999px;
  padding:10px 18px;
  font-size:14px;
  font-weight:600;
  transition:all .2s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

/* inputs más modernos */
.input,
textarea{
  border-radius:14px;
  padding:10px 12px;
  border:1px solid #e2e8f0;
}

/* intake más limpio */
.intake-form{
  gap:18px;
}

/* FAQ más legible */
.faq-answer-inner{
  font-size:15px;
  line-height:1.75;
}

/* mejor alineación contacto */
.contact-row{
  align-items:center;
}

/* sombras suaves globales */
.card,
.media-card{
  box-shadow:0 8px 20px rgba(15,23,42,.04);
}

/* dark section más elegante */
.section-dark{
  background:#0f172a;
}

/* pequeños detalles visuales */
.kicker{
  font-size:11px;
  letter-spacing:.12em;
  font-weight:700;
}

.hero-note-box{
  font-size:14px;
}

/* responsive refinado */
@media (max-width:900px){
  .section{
    padding-top:60px;
    padding-bottom:60px;
  }
}


/* ===== Version 11 – estilo high-end legal ===== */

body{
  background:#ffffff;
  color:#0b1220;
}

.hero-title-pro{
  font-weight:700;
  letter-spacing:-0.025em;
}

.section-title{
  font-weight:700;
  letter-spacing:-0.02em;
}

.kicker{
  opacity:.75;
}

.card,
.media-card,
.quick-action-card,
.action-card-dark{
  border-radius:28px;
  border:1px solid rgba(15,23,42,.06);
  box-shadow:0 12px 28px rgba(15,23,42,.05);
}

.card:hover,
.media-card:hover,
.quick-action-card:hover,
.action-card-dark:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 50px rgba(15,23,42,.08);
}

.btn{
  font-size:14px;
  letter-spacing:.02em;
  border-radius:999px;
}

.btn-outline{
  border-width:1px;
}

.section-dark{
  background:#0b1220;
}

.section{
  border-bottom:1px solid rgba(15,23,42,.04);
}

.faq-item-pro{
  border-bottom:1px solid rgba(15,23,42,.08);
}

.input,
textarea{
  border:1px solid rgba(15,23,42,.12);
}

.container{
  max-width:1140px;
}

.hero-note-box{
  background:#f8fafc;
}

@media (max-width:900px){
  .container{
    padding-left:16px;
    padding-right:16px;
  }
}


/* ===== Version 12 – ultra premium refinement ===== */

:root{
  --bg:#ffffff;
  --text:#0a1322;
  --muted:#5b677a;
  --line:rgba(15,23,42,.08);
  --line-soft:rgba(15,23,42,.05);
  --dark:#09111f;
}

/* base */
body{
  background:var(--bg);
  color:var(--text);
  text-rendering:optimizeLegibility;
}

.site-header{
  background:rgba(255,255,255,.92);
  border-bottom:1px solid var(--line-soft);
  box-shadow:0 6px 18px rgba(15,23,42,.03);
}

.brand-title,
.section-title,
.hero-title-pro,
.intake-title,
.faq-panel-title{
  color:var(--text);
}

.brand-sub,
.section-text,
.hero-text-pro,
.intake-subtitle,
.action-card-dark p,
.quick-action-card p,
.faq-answer-inner{
  color:var(--muted);
}

/* ultra premium spacing */
.section{
  padding-top:88px;
  padding-bottom:88px;
}

.section-tight{
  padding-top:34px;
  padding-bottom:34px;
}

.container{
  max-width:1120px;
}

/* premium type rhythm */
.hero-title-pro{
  font-size:34px;
  line-height:1.1;
  letter-spacing:-0.03em;
  max-width:13ch;
}

.section-title{
  line-height:1.08;
  letter-spacing:-0.025em;
  max-width:16ch;
}

.kicker{
  letter-spacing:.14em;
  font-size:11px;
  color:#6b7280;
}

/* cards */
.card,
.media-card,
.quick-action-card,
.action-card-dark,
.faq-content-panel,
.hero-problems-box,
.faq-help-card,
.intake-summary{
  border-radius:30px;
  border:1px solid var(--line);
  box-shadow:0 14px 34px rgba(15,23,42,.045);
}

.card:hover,
.media-card:hover,
.quick-action-card:hover,
.action-card-dark:hover,
.faq-content-panel:hover{
  transform:translateY(-2px);
  box-shadow:0 24px 54px rgba(15,23,42,.07);
}

/* refined dark sections */
.section-dark{
  background:linear-gradient(180deg,#0a1322 0%, #0e1727 100%);
}

.section-dark .section-title,
.section-dark h2,
.section-dark h3,
.section-dark strong{
  color:#f8fafc;
}

.section-dark .section-text,
.section-dark p,
.section-dark .kicker{
  color:#c3cfdd;
}

/* buttons */
.btn{
  min-height:42px;
  padding:10px 18px;
  border-radius:999px;
  font-size:13px;
  font-weight:600;
  box-shadow:none;
}

.btn-outline{
  background:#fff;
  border-color:rgba(15,23,42,.12);
}

.btn-light-outline{
  border-color:rgba(255,255,255,.22);
  color:#fff;
  background:transparent;
}

/* form controls */
.input,
textarea,
select{
  min-height:44px;
  border-radius:16px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
}

.input:focus,
textarea:focus,
select:focus{
  outline:none;
  border-color:#0f172a;
  box-shadow:0 0 0 3px rgba(15,23,42,.06);
}

/* hero balance */
.hero-grid{
  align-items:start;
  gap:42px;
}

.hero-trust-item,
.pain-card-pro,
.contact-row,
.summary-item,
.quick-action-card,
.action-card-dark{
  background:linear-gradient(180deg,#ffffff 0%,#fbfcfe 100%);
}

.action-card-dark{
  background:rgba(255,255,255,.05);
}

.hero-note-box{
  border-left:2px solid #0f172a;
  background:#fbfcfe;
  border-radius:0 18px 18px 0;
}

/* faq */
.faq-btn-pro{
  padding:20px 0;
}

.faq-question-text{
  font-size:16px;
}

.faq-icon-pro{
  width:30px;
  height:30px;
}

/* process / content cards */
.step,
.quick-action-card,
.media-card,
.action-card-dark{
  min-height:100%;
}

/* footer */
.site-footer{
  border-top:1px solid var(--line-soft);
  background:#fbfcfd;
}

/* responsive */
@media (max-width:900px){
  .section{
    padding-top:64px;
    padding-bottom:64px;
  }
  .hero-title-pro{
    font-size:30px;
    max-width:none;
  }
  .section-title{
    max-width:none;
  }
}
