:root{--bg:#0a2540;--bg-alt:#0b2a4a;--text:#e6edf7;--muted:#b8c7e0;--primary:#1463ff;--primary-700:#0f4ed1;--card:#0e1e34;--border:rgba(255,255,255,0.1)}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1120px,92%);margin:0 auto}
.section{padding:72px 0}
.section.alt{background:var(--bg-alt)}
.section h2{margin:0 0 8px;font-size:clamp(24px,4vw,36px)}
.section-sub{margin:0 0 24px;color:var(--muted)}
.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:32px}
@media (max-width:900px){.grid-2{grid-template-columns:1fr}}
.mazo{width: 500px;height: 220px; border-radius: 12px; box-shadow: 5px 5px 10px #888;}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(5,14,28,.85);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{font-weight:700;letter-spacing:.2px;display:flex;align-items:center}
.logo{height:40px;width:auto}
.nav{display:flex;align-items:center;gap:16px}
.menu{list-style:none;display:flex;gap:16px;margin:0;padding:0}
.menu a{color:var(--muted)}
.menu a:hover{color:#ffffff}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:#fff;color:#0a2540;transition:all .2s ease}
.btn:hover{transform:translateY(-1px)}
.btn.primary{ margin-bottom: 0px; background:var(--primary);border-color:var(--primary);color:#ffffff}
.btn.primary:hover{background:var(--primary-700);border-color:var(--primary-700)}
.btn.outline{border-color:var(--border);background:transparent}
.btn.cta{background:#21c25e;border-color:#21c25e;color:#ffffff}
/* Accesibilidad y enfoque */
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(20,99,255,0.4)}
.btn.outline:hover{border-color:rgba(255,255,255,0.4)}
.menu a:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(255,255,255,0.22);border-radius:8px}
.card:focus-within{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.35)}

.nav-toggle{display:none;background:none;border:0;color:var(--text);font-size:22px}
@media (max-width:800px){
  .menu{display:none;position:absolute;top:60px;right:4%;flex-direction:column;background:var(--bg-alt);border:1px solid var(--border);padding:12px;border-radius:10px}
  .nav-toggle{display:inline-flex}
}

/* Hero */
.hero{position:relative;overflow:hidden;min-height:100vh;display:flex;align-items:center;background:linear-gradient(135deg,#0b1e39 0%,#0a2540 40%,#081a33 100%)}
.hero::before{content:"";position:absolute;inset:0;background:none}
.hero::after{content:"";position:absolute;inset:0;background:none}
.hero-bg-legal{position:absolute;inset:0;background:radial-gradient(1000px 500px at 10% 20%, rgba(52,108,220,0.14), transparent 60%), radial-gradient(800px 400px at 90% 30%, rgba(31,82,180,0.12), transparent 60%);opacity:.9;z-index:0}
.hero-bg-images{display:none}
/* Fondo corporativo sutil: cuadrícula y marca de agua */
.hero{background-image:
  radial-gradient(circle at 60% 20%, rgba(98,162,255,0.08) 0 200px, transparent 201px),
  linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px),
  linear-gradient(180deg, rgba(255,255,255,0.04) 1px, transparent 1px);
background-size:
  auto,
  28px 28px,
  28px 28px;
background-position:
  center,
  center,
  center;
}

/* Marca de agua tipo mazo con CSS puro (rombo suave) */
.hero::after{content:"";position:absolute;inset:auto auto 10% -10%;width:380px;height:380px;transform:rotate(45deg);background:linear-gradient(135deg, rgba(20,99,255,0.18), rgba(16,42,86,0.12));filter:blur(2px);opacity:.4;border-radius:24px}
.hero h1{font-size:clamp(28px,5vw,48px);line-height:1.15;margin:0 0 12px;color:#eaf2ff;text-shadow:none;font-weight:700}
.hero p{color:#c8d4e7;text-shadow:none;font-size:18px;line-height:1.6}
.hero .badges{display:flex;flex-wrap:wrap;gap:12px;margin:16px 0 0;padding:0;list-style:none}
.hero .badges li{padding:8px 14px;border:1px solid rgba(255,255,255,0.3);border-radius:999px;color:#ffffff;background:rgba(255,255,255,0.15);backdrop-filter:blur(10px);text-shadow:0 1px 3px rgba(0,0,0,0.3);font-weight:500}
.hero-media{border-radius:16px;overflow:hidden;background:linear-gradient(135deg,rgba(255,255,255,0.08),rgba(255,255,255,0.02));min-height:260px;display:grid;place-items:center}
.hero-media img{object-fit:cover;height:100%;width:100%;opacity:.96}
.actions{display:flex;gap:12px;margin-top:20px}
.actions .btn{box-shadow:0 4px 12px rgba(0,0,0,0.4);border:none;font-weight:600}
.actions .btn.primary{background:var(--primary);color:#ffffff;text-shadow:0 1px 2px rgba(0,0,0,0.4)}
.actions .btn.outline{background:transparent;color:#e6edf7;border:2px solid rgba(255,255,255,0.18);backdrop-filter:none}
.actions .btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,0.4)}
/* Canvas interactivo */
.hero-canvas{position:absolute;inset:0;z-index:0;opacity:.6}
.hero .container{position:relative;z-index:1}

/* Cards servicios */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:900px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.cards{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;transition:transform .2s ease, box-shadow .2s ease;position:relative}
.card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.35)}
.card-icon{margin-bottom:12px;display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:18px;background:linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));box-shadow:0 6px 20px rgba(0,0,0,0.35);border:2px solid rgba(255,255,255,0.08)}
.card-icon svg{color:#62a2ff;transition:color 0.2s ease}
.card:hover .card-icon svg{color:#0f4ed1}
.icon-pro{font-size:24px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.1))}
.card h3{margin:0 0 6px;font-size:18px}
.card p{margin:0;color:var(--muted)}

/* Nosotros */
.list-check{margin:12px 0 0;padding:0;list-style:none;display:grid;gap:8px}
.list-check li{position:relative;padding-left:26px}
.list-check li:before{content:"✔";position:absolute;left:0;top:0;color:var(--primary)}
.profile img{border-radius:12px; box-shadow: 5px 5px 10px #888;}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:700px){.stats{grid-template-columns:1fr 1fr}}
.stat{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;text-align:center;position:relative;overflow:hidden}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--primary)}
.stat-civil::before{background:linear-gradient(90deg, #1463ff, #0f4ed1)}
.stat-penal::before{background:linear-gradient(90deg, #e74c3c, #c0392b)}
.stat-laboral::before{background:linear-gradient(90deg, #27ae60, #229954)}
.stat .num{font-size:28px;font-weight:700}
.stat .label{display:block;color:var(--muted)}

/* Testimonios */
.quotes{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:800px){.quotes{grid-template-columns:1fr}}
.testimonial{margin:0;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;position:relative;overflow:hidden}
.testimonial::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg, #1463ff, #0f4ed1)}
.testimonial-content{position:relative;z-index:1}
.quote-mark{font-size:48px;color:var(--primary);opacity:0.2;line-height:1;margin-bottom:8px;font-family:serif}
.testimonial blockquote{margin:0 0 16px;font-weight:500;font-size:16px;line-height:1.6;color:var(--text)}
.testimonial-author{display:flex;align-items:center;gap:12px}
.author-info{display:flex;flex-direction:column;gap:2px}
.author-info strong{color:var(--text);font-weight:600}
.author-info span{color:var(--muted);font-size:14px}

/* Contacto */
.form{ width:100%; max-width:500px; margin:0 auto; box-sizing:border-box; display:grid;gap:16px;background:#0e2038;border:1px solid rgba(255,255,255,0.08);border-radius:16px;padding:1px 20px;box-shadow: 5px 5px 10px rgba(0,0,0,0.25)}
.formu{margin-top: 30px;}
.form label{display:grid;gap:8px;font-size:14px;color:var(--muted);font-weight:500}
.form input,.form textarea{padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,0.12);background:#0b1d34;color:var(--text);transition:border-color 0.2s ease, box-shadow 5px 5px 10px ease;font-size:14px}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--primary);box-shadow: 0 0 0 3px rgba(20,99,255,0.25)}
.form button[type="submit"]{padding:12px 206px;font-size:14px;font-weight:600;border-radius:10px;background:var(--primary);color:#ffffff;border:none;cursor:pointer;transition:all 0.2s ease;align-self:start;min-width:120px;display:flex;align-items:center;justify-content:center}
.form button[type="submit"]:hover{background:var(--primary-700);transform:translateY(-1px);box-shadow:0 4px 12px rgba(20,99,255,0.3)}
.form .form-msg{margin-top: 0; margin:8px 0 0;color:var(--muted);font-size:13px}
.list-plain{list-style:none;padding:0;margin:10px 0 0;color:var(--muted)}

/* Footer */
.site-footer{width:100%; box-sizing:border-box;border-top: 1px solid rgba(255,255,255,0.08);  padding-top: 20px; background:#071527;}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:16px}
.small{ width:100%; box-sizing:border-box; font-size:13px;color:var(--muted)}

/* WhatsApp FAB */
.whatsapp-fab{position:fixed;right:18px;bottom:18px;width:56px;height:56px;border-radius:50%;background:#21c25e;display:grid;place-items:center;border:0;box-shadow:0 12px 28px rgba(0,0,0,.35);z-index:60}
.whatsapp-fab img{width:28px;height:28px}

/* Misión y Visión */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:20px 0 16px}
@media (max-width:800px){.mv-grid{grid-template-columns:1fr}}
.mv-item{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;box-shadow:0 4px 12px rgba(0,0,0,0.2);transition:transform 0.2s ease, box-shadow 0.2s ease}
.mv-item:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,0.1)}
.mv-item h3{margin:0 0 8px;font-size:18px;color:var(--primary);font-weight:700}
.mv-item p{margin:0;color:var(--muted);line-height:1.6}
