/* ===========================================================
   APFC — Asociación Peritos Judiciales Cerrajero Forense
   Hoja de estilos · mobile-first · rápida y accesible
   =========================================================== */
:root{
  --navy:#0d2340;
  --navy-700:#122c4f;
  --navy-600:#1c3c66;
  --gold:#c8a24a;
  --gold-dark:#a8842f;
  --ink:#1f2937;
  --muted:#5b6675;
  --line:#e4e8ee;
  --bg:#f6f8fb;
  --white:#ffffff;
  --radius:14px;
  --shadow-sm:0 1px 3px rgba(13,35,64,.08);
  --shadow:0 8px 30px rgba(13,35,64,.10);
  --shadow-lg:0 18px 50px rgba(13,35,64,.16);
  --maxw:1140px;
  --font:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  line-height:1.65;font-size:17px;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy-600);text-decoration:none}
a:hover{color:var(--gold-dark)}
h1,h2,h3,h4{line-height:1.2;color:var(--navy);margin:0 0 .5em;font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(1.9rem,5vw,3rem)}
h2{font-size:clamp(1.5rem,4vw,2.2rem)}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.section--tight{padding:44px 0}
.bg-white{background:var(--white)}
.bg-soft{background:linear-gradient(180deg,#eef2f8,#f6f8fb)}
.text-center{text-align:center}
.eyebrow{display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--gold-dark);margin-bottom:.6rem}
.lead{font-size:1.12rem;color:var(--muted);max-width:62ch}
.section .lead{margin-left:auto;margin-right:auto}
.muted{color:var(--muted)}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-size:1rem;
  padding:.85em 1.5em;border-radius:999px;border:2px solid transparent;cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;line-height:1}
.btn:active{transform:translateY(1px)}
.btn--gold{background:var(--gold);color:#241c08;box-shadow:0 6px 18px rgba(200,162,74,.4)}
.btn--gold:hover{background:#d4b25e;color:#241c08;transform:translateY(-2px)}
.btn--navy{background:var(--navy);color:#fff}
.btn--navy:hover{background:var(--navy-700);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.btn--outline{background:#fff;color:var(--navy);border-color:var(--line)}
.btn--outline:hover{border-color:var(--gold);color:var(--gold-dark)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.96);
  backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800;color:var(--navy);font-size:1.05rem}
.brand:hover{color:var(--navy)}
.brand__mark{width:auto;height:42px;flex:0 0 auto;object-fit:contain}
.brand__txt small{display:block;font-size:.62rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);line-height:1.1}
.nav__links{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
.nav__links a{display:block;padding:.6em .95em;border-radius:8px;font-weight:600;font-size:.95rem;color:var(--navy)}
.nav__links a:hover{background:var(--bg);color:var(--navy)}
.nav__links a.active{color:var(--gold-dark)}
.nav__cta{margin-left:.6rem}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;width:44px;height:44px}
.nav__toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px auto;
  border-radius:2px;transition:.25s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:920px){
  .nav__toggle{display:block}
  .nav__links{position:fixed;inset:68px 0 auto 0;flex-direction:column;align-items:stretch;
    gap:0;background:#fff;border-bottom:1px solid var(--line);padding:8px 16px 18px;
    box-shadow:var(--shadow);transform:translateY(-120%);transition:transform .3s ease;}
  .nav__links.open{transform:translateY(0)}
  .nav__links a{padding:.9em .6em;border-bottom:1px solid var(--line);border-radius:0}
  .nav__cta{margin:.7rem 0 0}
  .nav__cta .btn{width:100%;justify-content:center}
}

/* ---------- Hero ---------- */
.hero{position:relative;color:#eaf0f8;background:radial-gradient(120% 120% at 80% -10%,#1c3c66 0%,#0d2340 55%,#091a30 100%);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M0 59h60M59 0v60' stroke='%23ffffff' stroke-opacity='.05' fill='none'/%3E%3C/svg%3E");}
.hero__inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;
  align-items:center;padding:78px 0 86px}
.hero h1{color:#fff}
.hero h1 span{color:var(--gold)}
.hero p{color:#c4d2e6;font-size:1.16rem;max-width:54ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.hero__badges{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:30px;font-size:.92rem;color:#aebfd6}
.hero__badges span{display:inline-flex;align-items:center;gap:.5em}
.hero__badges svg{flex:0 0 18px;color:var(--gold)}
.hero__card{position:relative;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:20px;padding:14px;box-shadow:var(--shadow-lg)}
.hero__card img{border-radius:13px;width:100%;object-fit:cover;aspect-ratio:4/3}
.hero__chip{position:absolute;left:-14px;bottom:22px;background:#fff;color:var(--navy);
  border-radius:12px;padding:12px 16px;box-shadow:var(--shadow);font-weight:700;font-size:.95rem;
  display:flex;align-items:center;gap:.6rem}
.hero__chip b{color:var(--gold-dark);font-size:1.4rem;line-height:1}
@media(max-width:860px){
  .hero__inner{grid-template-columns:1fr;gap:30px;padding:54px 0 60px}
  .hero__card{order:-1;max-width:460px}
}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stats .stat b{display:block;font-size:2.2rem;color:var(--navy);font-weight:800;line-height:1}
.stats .stat span{color:var(--muted);font-size:.92rem;font-weight:600}
@media(max-width:680px){.stats{grid-template-columns:repeat(2,1fr);gap:26px 14px}}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:24px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;
  box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card__icon{width:52px;height:52px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,#16335a,#0d2340);color:var(--gold);margin-bottom:16px}
.card h3{margin-bottom:.4rem}
.card p{color:var(--muted);margin:0;font-size:.98rem}

/* ---------- Split (texto + imagen) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split--reverse .split__media{order:2}
.split__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;
  object-fit:cover;aspect-ratio:5/4}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:28px}.split--reverse .split__media{order:0}}

.checklist{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:12px}
.checklist li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink)}
.checklist svg{flex:0 0 22px;color:var(--gold-dark);margin-top:2px}

/* ---------- Mapa ---------- */
.mapa-wrap{display:grid;grid-template-columns:1fr 330px;gap:24px}
#mapa{height:560px;width:100%;border-radius:var(--radius);box-shadow:var(--shadow);
  border:1px solid var(--line);z-index:1;background:#dfe7f1}
.mapa-side{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;max-height:560px}
.mapa-side__head{padding:14px 16px;border-bottom:1px solid var(--line);font-weight:700;color:var(--navy);
  display:flex;align-items:center;justify-content:space-between;font-size:.95rem}
.mapa-side__head span{background:var(--bg);color:var(--gold-dark);font-size:.78rem;
  padding:2px 9px;border-radius:999px}
.mapa-list{list-style:none;margin:0;padding:6px;overflow-y:auto}
.mapa-list li{margin:0}
.mapa-list li{display:flex;align-items:stretch;gap:2px}
.mapa-list .mapa-go{flex:1;min-width:0;display:flex;align-items:center;gap:12px;text-align:left;
  background:none;border:0;border-radius:10px;padding:9px 10px;cursor:pointer;font:inherit;color:var(--ink)}
.mapa-list .mapa-go:hover,.mapa-list .mapa-go:focus{background:var(--bg)}
.mapa-list img{width:40px;height:40px;border-radius:9px;object-fit:contain;background:#fff;
  border:1px solid var(--line);padding:3px;flex:0 0 40px}
.mapa-list .nm{font-weight:700;font-size:.92rem;color:var(--navy);line-height:1.2}
.mapa-list .ct{font-size:.8rem;color:var(--muted)}
.mapa-list .mapa-web{flex:0 0 auto;display:flex;align-items:center;gap:.3em;padding:0 12px;
  color:var(--gold-dark);font-weight:700;font-size:.78rem;border-radius:10px;white-space:nowrap}
.mapa-list .mapa-web:hover{background:var(--bg);color:var(--gold-dark)}
@media(max-width:860px){
  .mapa-wrap{grid-template-columns:1fr}
  #mapa{height:62vh;min-height:380px}
  .mapa-side{max-height:300px}
}
/* marcador tipo chincheta */
.apfc-pin{filter:drop-shadow(0 3px 4px rgba(13,35,64,.4));transition:transform .12s ease}
.apfc-pin:hover{transform:scale(1.18);z-index:1000}
.leaflet-popup-content{margin:12px 14px;font-family:var(--font)}
.popup-soc{text-align:center;min-width:150px}
.popup-soc img{width:74px;height:74px;object-fit:contain;margin:0 auto 8px;border:1px solid var(--line);
  border-radius:12px;padding:5px;background:#fff}
.popup-soc strong{display:block;color:var(--navy);font-size:1rem}
.popup-soc .ct{color:var(--muted);font-size:.85rem;margin-bottom:8px}
.popup-soc a.btn{padding:.5em 1em;font-size:.86rem}

/* ---------- Directorio socios ---------- */
.socios-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:980px){.socios-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:720px){.socios-grid{grid-template-columns:repeat(2,1fr)}}
.soc-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;
  text-align:center;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease;
  display:flex;flex-direction:column;align-items:center}
.soc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#d9e0ea}
.soc-card__logo{width:100%;height:96px;display:grid;place-items:center;margin-bottom:12px}
.soc-card__logo img{max-height:88px;width:auto;object-fit:contain}
.soc-card .nm{font-weight:700;color:var(--navy);font-size:.98rem;line-height:1.25}
.soc-card .ct{color:var(--muted);font-size:.84rem;margin:2px 0 12px;display:flex;align-items:center;
  justify-content:center;gap:.3em}
.soc-card .lnk{margin-top:auto;font-weight:700;font-size:.86rem;color:var(--gold-dark);
  display:inline-flex;align-items:center;gap:.3em}

/* ---------- Colaboradores ---------- */
.colab-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:760px){.colab-grid{grid-template-columns:repeat(2,1fr)}}
.colab{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 18px;
  text-align:center;box-shadow:var(--shadow-sm)}
.colab__logo{height:64px;display:grid;place-items:center;margin-bottom:10px}
.colab__logo img{max-height:60px;width:auto}
.colab__logo .ph{font-weight:800;color:var(--navy);font-size:1.1rem}
.colab b{display:block;color:var(--navy);font-size:.95rem}
.colab .desc{display:inline-block;margin-top:6px;background:#fbf5e6;color:var(--gold-dark);
  font-weight:700;font-size:.82rem;padding:3px 10px;border-radius:999px}

/* ---------- Directiva ---------- */
.team{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
@media(max-width:860px){.team{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.team{grid-template-columns:repeat(2,1fr)}}
.team .member{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;text-align:center;box-shadow:var(--shadow-sm);
  transition:transform .18s ease,box-shadow .18s ease}
.team .member:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.team .photo{width:100%;aspect-ratio:4/5;background:#eef2f8;overflow:hidden}
.team .photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
.team .avatar{width:100%;aspect-ratio:4/5;display:grid;place-items:center;
  background:linear-gradient(135deg,#16335a,#0d2340);color:var(--gold);font-weight:800;font-size:2.6rem}
.team .info{padding:13px 10px 16px}
.team b{color:var(--navy);font-size:1rem}
.team span{display:block;color:var(--muted);font-size:.82rem}

/* ---------- CTA band ---------- */
.cta-band{background:radial-gradient(120% 140% at 10% 0%,#1c3c66,#0d2340);color:#fff;text-align:center;
  border-radius:20px;padding:54px 28px;box-shadow:var(--shadow-lg)}
.cta-band h2{color:#fff}
.cta-band p{color:#c4d2e6;max-width:56ch;margin:0 auto 22px}
.cta-band .btn{margin:6px}

/* ---------- Pasos ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:step}
@media(max-width:760px){.steps{grid-template-columns:1fr}}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 24px 24px;box-shadow:var(--shadow-sm)}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-18px;left:24px;
  width:42px;height:42px;border-radius:50%;background:var(--gold);color:#241c08;font-weight:800;
  display:grid;place-items:center;font-size:1.1rem;box-shadow:0 5px 14px rgba(200,162,74,.45)}
.step h3{margin-top:8px}
.step p{color:var(--muted);margin:0;font-size:.96rem}

/* ---------- Page header ---------- */
.page-head{background:radial-gradient(120% 130% at 85% -20%,#1c3c66,#0d2340);color:#fff;
  padding:54px 0 46px;text-align:center}
.page-head h1{color:#fff;margin-bottom:.3em}
.page-head p{color:#c4d2e6;max-width:64ch;margin:0 auto}
.breadcrumb{font-size:.86rem;color:#9fb3d1;margin-bottom:14px}
.breadcrumb a{color:#cdd9ec}
.breadcrumb a:hover{color:var(--gold)}

/* ---------- Prose ---------- */
.prose h2{margin-top:1.6em}
.prose h3{margin-top:1.3em;color:var(--navy-600)}
.prose p,.prose li{color:#384455}
.prose ul{padding-left:1.2em}
.prose li{margin-bottom:.4em}
.prose .note{background:#fff;border-left:4px solid var(--gold);border-radius:0 12px 12px 0;
  padding:16px 20px;box-shadow:var(--shadow-sm);margin:1.4em 0}

/* ---------- Formulario ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:30px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.92rem;color:var(--navy);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;padding:.8em 1em;border:1px solid var(--line);
  border-radius:10px;font:inherit;color:var(--ink);background:#fbfcfe;transition:border .15s,box-shadow .15s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(200,162,74,.18)}
.field textarea{min-height:140px;resize:vertical}
.form-aside{display:grid;gap:16px;align-content:start}
.info-row{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:16px;box-shadow:var(--shadow-sm)}
.info-row .ic{width:42px;height:42px;flex:0 0 42px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg,#16335a,#0d2340);color:var(--gold)}
.info-row b{display:block;color:var(--navy);font-size:.95rem}
.info-row a,.info-row span{color:var(--muted);font-size:.92rem;word-break:break-word}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#b9c6dc;padding:54px 0 24px;margin-top:8px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:32px}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.site-footer a{color:#b9c6dc}
.site-footer a:hover{color:var(--gold)}
.footer-brand{display:flex;align-items:center;gap:.6rem;margin-bottom:14px}
.footer-brand img{width:48px;height:48px;background:#fff;border-radius:10px;padding:4px;object-fit:contain}
.footer-brand b{color:#fff;font-size:1.05rem}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:9px;font-size:.94rem}
.footer-social{display:flex;gap:10px;margin-top:12px}
.footer-social a{width:40px;height:40px;border-radius:10px;border:1px solid rgba(255,255,255,.18);
  display:grid;place-items:center;color:#cdd9ec}
.footer-social a:hover{background:rgba(255,255,255,.1);color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:34px;padding-top:18px;
  display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:space-between;font-size:.84rem;color:#8ea1bd}
.footer-bottom a{color:#8ea1bd}

/* ---------- util ---------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;left:-999px;top:0;background:var(--gold);color:#241c08;padding:10px 16px;
  z-index:2000;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}}
