/* Servicios Legales — Estilo profesional y creativo (fondo blanco) */
:root{
  --bg: #ffffff;
  --text: #0b1220;
  --muted: #556074;
  --line: rgba(12, 18, 32, .12);
  --shadow: 0 14px 40px rgba(2, 12, 27, .10);
  --shadow2: 0 10px 22px rgba(2, 12, 27, .08);
  --radius: 18px;
  --radius2: 14px;

  /* Acentos sobrios (sin “colores corporativos” inventados) */
  --accent: #111827;   /* negro suave */
  --accent2:#0f172a;   /* azul muy oscuro */
  --glass: rgba(255,255,255,.82);
}

*{ box-sizing: border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  line-height:1.55;
}

.container{
  width:min(1120px, calc(100% - 40px));
  margin:0 auto;
}

/* Accesibilidad */
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); border:0;
}

/* Fondo decorativo */
.bg-orbs{ position:fixed; inset:0; pointer-events:none; z-index:-1; overflow:hidden; }
.orb{
  position:absolute; border-radius:999px; filter: blur(30px);
  opacity:.55; transform: translate3d(0,0,0);
}
.o1{ width:520px; height:520px; left:-180px; top:-220px;
  background: radial-gradient(circle at 30% 30%, rgba(15, 23, 42, .22), transparent 60%);
}
.o2{ width:520px; height:520px; right:-220px; top:120px;
  background: radial-gradient(circle at 30% 30%, rgba(17, 24, 39, .18), transparent 60%);
}
.o3{ width:520px; height:520px; left:20%; bottom:-260px;
  background: radial-gradient(circle at 30% 30%, rgba(2, 12, 27, .14), transparent 60%);
}

/* Header */
.site-header{
  position:sticky; top:0; z-index:50;
  background: rgba(255,255,255,.86);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.brand{
  display:flex; align-items:center; gap:12px;
  text-decoration:none; color:inherit;
}
.brand-mark{
  width:38px; height:38px; border-radius:12px;
  background:
    linear-gradient(145deg, rgba(15, 23, 42, .92), rgba(17, 24, 39, .78));
  box-shadow: var(--shadow2);
}
.brand-text{ display:flex; flex-direction:column; gap:2px; }
.brand-name{ font-weight:800; letter-spacing:.2px; }
.brand-tag{ font-size:.85rem; color:var(--muted); }

.nav{ display:flex; align-items:center; gap:10px; }
.nav-menu{
  list-style:none; margin:0; padding:0;
  display:flex; align-items:center; gap:18px;
}
.nav-link{
  text-decoration:none; color:var(--text);
  font-weight:600; font-size:.95rem;
  padding:10px 10px; border-radius:12px;
}
.nav-link:hover{ background: rgba(12, 18, 32, .06); }

.nav-toggle{
  display:none;
  border:1px solid var(--line);
  background: var(--glass);
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
}
.hamburger{
  display:inline-block; width:18px; height:12px; position:relative;
}
.hamburger::before, .hamburger::after, .hamburger span{
  content:""; position:absolute; left:0; right:0; height:2px;
  background: var(--text); border-radius:999px;
}
.hamburger::before{ top:0; }
.hamburger::after{ bottom:0; }
.hamburger span{ top:50%; transform:translateY(-50%); }

/* Hero */
.hero{
  padding:64px 0 36px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:28px;
  align-items:stretch;
}
.pill{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.7);
  margin:0 0 12px;
  color:var(--muted);
  font-size:.95rem;
}
.hero-copy h1{
  font-size: clamp(2.1rem, 3vw, 3rem);
  line-height:1.08;
  margin:0 0 12px;
}
.lead{
  font-size:1.05rem;
  color: var(--muted);
  margin:0 0 18px;
}

.cta-row{ display:flex; gap:12px; flex-wrap:wrap; margin-top:12px; }

.btn{
  appearance:none; border:1px solid var(--line);
  background: transparent;
  border-radius:14px;
  padding:12px 14px;
  font-weight:700;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  cursor:pointer;
  color:var(--text);
  transition: transform .08s ease, box-shadow .18s ease, background .18s ease;
}
.btn:hover{ transform: translateY(-1px); box-shadow: var(--shadow2); }
.btn:active{ transform: translateY(0px); box-shadow:none; }

.btn-primary{
  background: linear-gradient(145deg, rgba(15, 23, 42, .98), rgba(17, 24, 39, .85));
  color:#fff;
  border-color: transparent;
}
.btn-ghost{
  background: rgba(255,255,255,.7);
}
.btn-full{ width:100%; }

.hero-metrics{
  margin-top:18px;
  display:grid;
  grid-template-columns: 1fr;
  gap:10px;
}
.metric{
  border:1px solid var(--line);
  background: rgba(255,255,255,.7);
  border-radius: var(--radius2);
  padding:12px 14px;
}
.metric-k{ display:block; font-size:.85rem; color:var(--muted); }
.metric-v{ display:block; font-weight:700; margin-top:4px; }

.hero-card{
  border:1px solid var(--line);
  background: rgba(255,255,255,.78);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding:18px;
  position:relative;
  overflow:hidden;
}
.hero-card::before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(circle at 20% 0%, rgba(17, 24, 39, .16), transparent 55%);
  pointer-events:none;
}
.hero-card-head{ position:relative; }
.hero-card h2{ margin:0 0 4px; font-size:1.25rem; }
.muted{ color:var(--muted); margin:0; }

.checklist{
  position:relative;
  margin:14px 0 16px;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.checklist li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:14px;
  background: rgba(255,255,255,.86);
}
.checklist li::before{
  content:"✓";
  font-weight:900;
  color: var(--accent2);
  margin-top:1px;
}

/* Secciones */
.section{
  padding:54px 0;
}
.section.alt{
  background: rgba(12, 18, 32, .03);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.section-head h2{
  margin:0;
  font-size: clamp(1.55rem, 2.1vw, 2.1rem);
}
.section-sub{
  margin:8px 0 0;
  color:var(--muted);
  max-width: 70ch;
}
.section-chip{
  border:1px solid var(--line);
  background: rgba(255,255,255,.7);
  padding:10px 12px;
  border-radius:999px;
  font-weight:800;
  font-size:.9rem;
}

/* Layouts */
.grid-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:16px;
}
.grid-3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
  margin-top:16px;
}

.panel{
  border:1px solid var(--line);
  background: rgba(255,255,255,.82);
  border-radius: var(--radius);
  box-shadow: var(--shadow2);
  padding:18px;
}
.panel h3{ margin:0 0 8px; }
.panel p{ margin:0; color:var(--muted); }
.divider{ height:1px; background: var(--line); margin:14px 0; }

.detail{
  border:1px dashed rgba(12, 18, 32, .18);
  border-radius:14px;
  padding:10px 12px;
  background: rgba(255,255,255,.7);
}
.detail summary{
  cursor:pointer;
  font-weight:800;
}
.detail-body{ padding-top:10px; }

.card{
  border:1px solid var(--line);
  background: rgba(255,255,255,.84);
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow2);
}
.card h3{ margin:0 0 8px; }
.card p{ margin:0; color:var(--muted); }

.panel-wide{ margin-top:16px; }
.panel-wide-grid{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap:16px;
  align-items:stretch;
}
.callout{
  border-radius: var(--radius);
  border:1px solid rgba(12, 18, 32, .14);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.70));
  padding:16px;
}
.callout-title{ margin:0 0 6px; font-weight:900; }
.callout-text{ margin:0; color:var(--muted); }

.bullets{
  margin:10px 0 0;
  padding-left:18px;
  color:var(--muted);
}
.bullets li{ margin:6px 0; }

.next-area{
  margin-top:18px;
  display:flex;
}

/* Otras áreas */
.area-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}
.area-card{
  border:1px solid var(--line);
  background: rgba(255,255,255,.86);
  border-radius: var(--radius);
  padding:16px;
  box-shadow: var(--shadow2);
  display:flex;
  flex-direction:column;
  gap:12px;
}
.area-top h3{ margin:0 0 6px; }
.area-top p{ margin:0; }

.access-panels{
  margin-top:18px;
  display:grid;
  gap:12px;
}
.access-panel{
  display:none;
  border:1px solid var(--line);
  background: rgba(255,255,255,.9);
  border-radius: var(--radius);
  padding:16px;
  box-shadow: var(--shadow2);
}
.access-panel.is-open{ display:block; }
.access-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.icon-btn{
  width:38px; height:38px;
  border-radius:12px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.8);
  cursor:pointer;
  font-size:22px;
  line-height:1;
  font-weight:800;
}
.icon-btn:hover{ box-shadow: var(--shadow2); }

/* Footer */
.footer{
  padding:28px 0 14px;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:16px;
  align-items:start;
}
.footer-title{
  margin:0;
  font-weight:900;
}
.brand-row{ display:flex; gap:12px; align-items:flex-start; }
.footer-links{
  display:flex;
  gap:12px;
  justify-content:flex-end;
  flex-wrap:wrap;
}
.footer-links a{
  text-decoration:none;
  color: var(--text);
  border:1px solid var(--line);
  background: rgba(255,255,255,.7);
  padding:10px 12px;
  border-radius:12px;
  font-weight:700;
}
.footer-links a:hover{ box-shadow: var(--shadow2); }
.footer-bottom{
  margin-top:12px;
  border-top:1px solid var(--line);
  padding-top:12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .grid-3{ grid-template-columns: 1fr; }
  .panel-wide-grid{ grid-template-columns: 1fr; }
  .area-grid{ grid-template-columns: 1fr 1fr; }
  .footer-grid{ grid-template-columns: 1fr; }
  .footer-links{ justify-content:flex-start; }
}

@media (max-width: 720px){
  .nav-toggle{ display:inline-flex; align-items:center; justify-content:center; }
  .nav-menu{
    position:absolute;
    right:20px;
    top:64px;
    width:min(340px, calc(100vw - 40px));
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
    padding:12px;
    border:1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.92);
    box-shadow: var(--shadow);
  }
  .nav-menu.is-open{ display:flex; }
  .nav-link{ padding:12px 12px; }

  .grid-2{ grid-template-columns: 1fr; }
  .area-grid{ grid-template-columns: 1fr; }
}
