:root{
  --primary:#1d3160;
  --accent:#e0e658;
  --alt:#f6f7fb;
  --text:#1b1b1b;
  --muted:#6b7280;
  --card:#ffffff;
  --radius:14px;
  --shadow:0 10px 25px rgba(0,0,0,.08);
  --shadow-strong:0 24px 60px rgba(0,0,0,.16);
}

*{ box-sizing:border-box; }
html,body{ height:100%; scroll-behavior:smooth; }
body{ margin:0; font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; color:var(--text); background:#fff; }

.container{ width:min(1100px,92%); margin:0 auto; }
.section{ padding:64px 0; }
.section.alt{ background:var(--alt); }

h1,h2,h3{ margin:0 0 12px; line-height:1.2; color:var(--primary); }
p{ margin:0 0 12px; }
a{ color:var(--primary); text-decoration:none; }
a:hover{ text-decoration:underline; }
.btn{ display:inline-block; background:var(--accent); color:#000; padding:12px 18px; border-radius:10px; font-weight:800; border:2px solid transparent; transition:.2s; }
.btn:hover{ transform:translateY(-1px); box-shadow:var(--shadow); }

/* Navbar */
.navbar{ position:sticky; top:0; z-index:1000; background:rgba(255,255,255,.86); backdrop-filter:saturate(130%) blur(8px); border-bottom:1px solid rgba(0,0,0,.06); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; padding:12px 0; }
.brand{ font-weight:800; letter-spacing:.2px; color:var(--primary); }
.nav-menu{ display:flex; gap:18px; align-items:center; }
.nav-menu a{ padding:8px 10px; border-radius:8px; font-weight:600; }
.nav-menu a:hover{ background:var(--alt); }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; }
.nav-toggle span{ display:block; width:24px; height:2px; background:#1c2333; margin:5px 0; transition:.3s; }

/* Hero */
.hero{
  position:relative; min-height:72vh; display:grid; place-items:center; overflow:hidden;
  background: radial-gradient(1200px 400px at 20% 20%, rgba(224,230,88,.25), transparent 60%),
              radial-gradient(800px 400px at 80% 80%, rgba(29,49,96,.20), transparent 60%),
              #0e1222;
}
.hero-bg img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:brightness(.65) saturate(1.1); }
.hero-overlay{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.55)); }
.hero-content{ position:relative; text-align:center; color:#fff; padding:48px 0; }
.hero h1{ color:#fff; font-size:clamp(1.8rem,3.6vw,3rem); }
.hero p{ color:#e9e9e9; margin:8px auto 18px; max-width:680px; font-size:clamp(.98rem,1.4vw,1.1rem); }

/* Perfil */
.grid-2{ display:grid; gap:28px; grid-template-columns:1.1fr 1fr; }
.perfil-media{ display:grid; place-items:center; }
.perfil-img{ width:min(360px,90%); aspect-ratio:1/1; object-fit:cover; border-radius:50%; box-shadow:var(--shadow-strong); border:6px solid #fff; }
.ticks{ list-style:none; padding:0; margin:12px 0 0; display:grid; gap:8px; }
.ticks li::before{ content:"✔"; color:var(--accent); margin-right:10px; }

/* Timeline */
.timeline{ position:relative; display:grid; gap:42px; grid-template-columns:repeat(2,1fr); align-items:start; }
.timeline::before{ content:""; position:absolute; left:50%; top:0; bottom:0; width:3px; background:linear-gradient(var(--primary),var(--accent)); transform:translateX(-50%); }
.tl-item{ position:relative; }
.tl-dot{ position:absolute; top:14px; width:14px; height:14px; border-radius:50%; background:var(--accent); outline:4px solid #fff; box-shadow:var(--shadow); }
.tl-item:nth-child(odd) .tl-dot{ right:-7px; }
.tl-item:nth-child(even) .tl-dot{ left:-7px; }
.tl-card{ background:#fff; border-radius:var(--radius); padding:16px 18px; box-shadow:var(--shadow); border:1px solid rgba(0,0,0,.06); }
.tl-header{ display:flex; align-items:center; gap:12px; margin-bottom:6px; }
.tl-logo{ width:52px; height:52px; object-fit:contain; background:#fff; border-radius:10px; border:1px solid #e5e7eb; padding:6px; cursor:zoom-in; }
.tl-year{ position:absolute; top:-10px; font-weight:800; color:rgba(0,0,0,.12); font-size:42px; pointer-events:none; }

/* Trayectoria como jugador */
.player-career{ margin-top:28px; }
.player-cards{ display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:14px; }
.pcard{ background:#fff; border:1px solid rgba(0,0,0,.06); border-radius: var(--radius); box-shadow: var(--shadow); overflow:hidden; transition: transform .18s, box-shadow .18s; display:grid; grid-template-rows: 82px auto; }
.pcard:hover{ transform: translateY(-4px); box-shadow: var(--shadow-strong); }
.pcard img{ width:100%; height:82px; object-fit:contain; background:#fff; padding:10px; border-bottom:1px solid #eef1f5; cursor:zoom-in; }
.pcard-body{ padding:12px 14px; display:flex; flex-direction:column; gap:6px; }
.pcard-body h4{ margin:0; font-size:1rem; color:#111827; }
.pcard-body .years{ display:inline-block; font-weight:700; font-size:.9rem; color:#0f172a; background:linear-gradient(90deg, rgba(224,230,88,.28), rgba(224,230,88,.12)); border:1px solid rgba(224,230,88,.45); border-radius:999px; padding:4px 10px; }
@media (max-width:1100px){ .player-cards{ grid-template-columns: repeat(3,1fr); } }
@media (max-width:800px){ .player-cards{ grid-template-columns: repeat(2,1fr); } }
@media (max-width:520px){ .player-cards{ grid-template-columns: 1fr; } }

/* Logros */
.stats-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:22px; margin:18px 0 22px; }
.stat-card{ background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:18px; box-shadow:0 18px 36px rgba(13,23,45,.08); padding:22px 18px; text-align:center; position:relative; overflow:hidden; }
.stat-card::after{ content:""; position:absolute; inset:auto -20% -30% -20%; height:60%; background: radial-gradient(300px 120px at 50% 0, rgba(224,230,88,.18), transparent 60%); pointer-events:none; }
.icon-circle{ width:52px; height:52px; margin:0 auto 8px; display:grid; place-items:center; border-radius:50%; background: linear-gradient(180deg, #f7f9ff, #eef2ff); border:1px solid #e6e9f5; font-size:22px; }
.stat-card .num{ display:block; font-size: clamp(2rem, 5vw, 3rem); line-height:1; font-weight:800; color:#182648; margin:6px 0 8px; }
.stat-card p{ margin:0; color:#2a2f3a; font-weight:600; }

.milestones{ display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:12px 22px; margin-top:18px; }
.ms-item{ display:flex; align-items:center; gap:10px; background:#fff; border:1px solid rgba(0,0,0,.05); border-radius:14px; padding:10px 12px; box-shadow: 0 8px 18px rgba(0,0,0,.05); }
.ms-bullet{ width:34px; height:34px; border-radius:50%; display:grid; place-items:center; font-size:18px; background:linear-gradient(180deg, rgba(224,230,88,.28), rgba(224,230,88,.12)); border:1px solid rgba(224,230,88,.45); }
.ms-item h4{ margin:0; font-size:1rem; color:#0f172a; }
.ms-year{ display:inline-block; margin-top:3px; font-size:.85rem; font-weight:700; color:#334155; background:#f3f4f6; border:1px solid #e5e7eb; padding:2px 8px; border-radius:999px; }
@media (max-width:1000px){ .stats-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .stats-grid{ grid-template-columns:1fr; } .milestones{ grid-template-columns:1fr; } }

/* Certificaciones (PDF estático) */
.subtle-title{ margin:28px 0 10px; color:#0f172a; font-size:1.05rem; font-weight:800; opacity:.85; }
.doc-grid{ display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:16px; margin-top:10px; }
.doc-card{ background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:14px; box-shadow:var(--shadow); display:grid; grid-template-columns:72px 1fr; gap:12px; padding:12px; align-items:center; transition:transform .18s, box-shadow .18s; }
.doc-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-strong); }
.thumb-static{ --bg: linear-gradient(180deg, #f8fafc, #eef2ff); width:72px; height:92px; border:1px solid #e5e7eb; border-radius:8px; overflow:hidden; background: var(--cover, var(--bg)); background-size:cover; background-position:center; position:relative; box-shadow: inset 0 0 0 1px rgba(0,0,0,.02); }
.thumb-static::after{ content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.03), transparent 40%), radial-gradient(300px 40px at 50% 0, rgba(0,0,0,.04), transparent 60%); pointer-events:none; }
.thumb-static .fold{ position:absolute; top:0; right:0; width:20px; height:20px; background: linear-gradient(225deg, #e8ecff 45%, #cbd5e1 46%, #cbd5e1 52%, transparent 53%); opacity:.6; }
.pdf-tag{ position:absolute; top:6px; left:6px; font-weight:900; font-size:.7rem; letter-spacing:.4px; color:#0f172a; padding:3px 6px; border-radius:6px; background:linear-gradient(180deg, #f7f9ff, #eef2ff); border:1px solid #e6e9f5; box-shadow: 0 2px 5px rgba(0,0,0,.06); }
.thumb-static .l{ position:absolute; left:10px; right:10px; height:6px; border-radius:4px; background: #d9e0f3; }
.thumb-static .l1{ top:30px; } .thumb-static .l2{ top:42px; width:70%; } .thumb-static .l3{ top:54px; width:45%; }
.doc-body h4{ margin:0; font-size:1rem; color:#0f172a; }
.doc-body p{ margin:4px 0 8px; color:#334155; }
.doc-meta{ display:flex; justify-content:space-between; align-items:center; font-size:.9rem; color:#475569; font-weight:700; }
.doc-meta a{ background:var(--accent); color:#000; padding:6px 10px; border-radius:8px; text-decoration:none; font-weight:800; }
.doc-meta a:hover{ filter:brightness(.95); }
@media (max-width:1100px){ .doc-grid{ grid-template-columns:repeat(3,1fr);} }
@media (max-width:850px){ .doc-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:560px){ .doc-grid{ grid-template-columns:1fr;} }

/* Habilidades */
.skill-grid{ display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:18px; margin-top:12px; }
.skill-card{ background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:18px; box-shadow: var(--shadow); padding:18px; transition: transform .18s, box-shadow .18s, border-color .18s; }
.skill-card:hover{ transform: translateY(-4px); box-shadow: var(--shadow-strong); border-color: rgba(224,230,88,.55); }
.skill-head{ display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.skill-ico{ width:40px; height:40px; display:grid; place-items:center; border-radius:10px; font-size:20px; background: linear-gradient(180deg, #f7f9ff, #eef2ff); border:1px solid #e6e9f5; }
.skill-card h3{ margin:0; color:#0f172a; }
.skill-card p{ color:#374151; margin:6px 0 10px; }
.skill-tags{ display:flex; flex-wrap:wrap; gap:8px; list-style:none; padding:0; margin:0 0 10px; }
.skill-tags li{ padding:6px 10px; border-radius:999px; background:linear-gradient(180deg, rgba(224,230,88,.28), rgba(224,230,88,.12)); border:1px solid rgba(224,230,88,.45); font-weight:700; color:#0f172a; font-size:.9rem; }
.meter{ position:relative; height:10px; border-radius:999px; overflow:hidden; background:#eef2ff; border:1px solid #e6e9f5; }
.meter span{ position:absolute; inset:0 auto 0 0; width:0%; background: linear-gradient(90deg, var(--primary), var(--accent)); border-radius:999px; transition: width 1s ease; }
@media (max-width:1000px){ .skill-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width:620px){ .skill-grid{ grid-template-columns: 1fr; } }

/* Noticias */
.news-grid{ display:grid; gap:18px; grid-template-columns:repeat(2, minmax(0,1fr)); }
@media (max-width:900px){ .news-grid{ grid-template-columns:1fr; } }
.news-card{ position:relative; display:grid; grid-template-columns:140px 1fr; gap:14px; text-decoration:none; color:inherit; background:#fff; border-radius:18px; padding:14px; border:1px solid rgba(0,0,0,.06); box-shadow:0 18px 36px rgba(13,23,45,.08); overflow:hidden; isolation:isolate; transition: transform .18s, box-shadow .18s, border-color .18s; }
.news-card::before{ content:""; position:absolute; inset:0; z-index:-1; padding:1px; border-radius:18px; background:linear-gradient(90deg, rgba(224,230,88,.55), rgba(29,49,96,.35)); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity:0; transition:opacity .18s; }
.news-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-strong); border-color:transparent; }
.news-card:hover::before{ opacity:.9; }
/* antes tenías un background con --img; cámbialo por esto */
.news-thumb{
  width:100%;
  height:120px;
  border-radius:12px;
  overflow:hidden;
  background:#eef2ff;               /* color de fondo mientras carga */
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.04);
}
.news-thumb img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;                  /* recorte elegante */
}

.news-body h3{ margin:0 0 6px; color:#0f172a; font-weight:800; line-height:1.25; }
.news-body p{ margin:0 0 10px; color:#334155; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.news-cta{ display:inline-block; font-weight:800; color:var(--primary); }

/* Instagram grid */
.ig-grid{ display:grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap:18px; align-items:start; }
.ig-item{ display:block; }
.ig-item .instagram-media{ margin:0 !important; max-width:540px !important; width:100% !important; border-radius:12px !important; background:#fff; }

/* Galería */
.gallery-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.gallery-grid img{ width:100%; height:240px; object-fit:cover; border-radius:12px; cursor:zoom-in; }
@media (max-width:900px){ .gallery-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .gallery-grid{ grid-template-columns:1fr; } }

/* Lightbox simple */
.imgbox{ position: fixed; inset: 0; z-index: 99999; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.90); }
.imgbox[hidden]{ display:none; }
.imgbox__img{ max-width: 96vw; max-height: 92vh; width: auto; height: auto; object-fit: contain; display:block; background:#000; }
.imgbox__close{ position: absolute; top: 12px; right: 12px; background: rgba(15,22,40,.65); color:#fff; border:1px solid rgba(255,255,255,.35); border-radius:10px; padding:6px 10px; font-size:18px; cursor:pointer; }
body.no-scroll{ overflow:hidden; }

/* Contacto + Footer */
/* ===== Contacto mejorado ===== */
.contact-wrap{
  display:grid; gap:28px; grid-template-columns:1.05fr 1fr;
}
@media (max-width: 900px){ .contact-wrap{ grid-template-columns:1fr; } }

.contact-card .lead{ color:#2b3342; margin:8px 0 16px; }
.contact-list.pretty{ list-style:none; padding:0; margin:0; display:grid; gap:12px; }
.contact-list.pretty li{ display:flex; gap:12px; align-items:flex-start; }
.contact-list.pretty a{ font-weight:800; text-decoration:none; }
.ci{ width:36px; height:36px; display:grid; place-items:center; border-radius:10px;
     background:linear-gradient(180deg,#f7f9ff,#eef2ff); border:1px solid #e6e9f5; font-size:18px; }

/* Tamaño y alineación perfecta del SVG */
.ci svg{
  width: 20px;
  height: 20px;
  display: block;
}

/* (Opcional) sutil realce para que se vea nítido sobre fondos claros */
.ci.wa svg{ filter: drop-shadow(0 0 0 rgba(0,0,0,0)); }


.mini-highlights{ display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.chip{ padding:6px 10px; border-radius:999px; font-weight:700; color:#0f172a;
       background:linear-gradient(180deg, rgba(224,230,88,.28), rgba(224,230,88,.12));
       border:1px solid rgba(224,230,88,.45); }

/* Formulario con labels flotantes */
.contact-form{ display:grid; gap:14px; align-content:start; }
.field{ position:relative; }
.field input,.field textarea{
  width:100%; padding:14px 14px; border-radius:10px; border:1px solid #d1d5db; font:inherit;
  background:#fff; outline:none; transition:border-color .2s, box-shadow .2s, background .2s;
}
.field textarea{ resize:vertical; min-height:140px; }
.field input:focus,.field textarea:focus{ border-color:var(--primary); box-shadow:0 0 0 3px rgba(29,49,96,.12); }

.field label{
  position:absolute; left:12px; top:12px; padding:0 6px; pointer-events:none; color:#6b7280;
  background:#fff; transform-origin:left top; transition:transform .15s ease, color .15s ease, top .15s;
}
.field input::placeholder,.field textarea::placeholder{ color:transparent; }
.field input:focus + label,
.field input:not(:placeholder-shown) + label,
.field textarea:focus + label,
.field textarea:not(:placeholder-shown) + label{
  top:-9px; transform:scale(.86); color:#0f172a;
}

/* Ayudas y errores */
.hint{ position:absolute; right:10px; bottom:10px; color:#6b7280; font-size:.85rem; }
.error{ display:none; color:#b42318; font-weight:700; margin-top:6px; }
.field.is-invalid input,.field.is-invalid textarea{ border-color:#b42318; box-shadow:0 0 0 3px rgba(180,35,24,.12); }
.field.is-invalid .error{ display:block; }

/* ancho del botón */
.btn-wide{ width:100%; }

/* Honeypot oculto */
.hp{ position:absolute; left:-9999px; opacity:0; }

/* Toast de éxito */
.toast{
  display:none; margin-top:10px; padding:10px 12px; border-radius:10px; font-weight:800;
  background:linear-gradient(180deg, #ecfdf5, #e6fffa); border:1px solid #bbf7d0; color:#065f46;
}
.toast.show{ display:block; }

/* ===== Footer mejorado ===== */
.site-footer{
  color:#cfd8ea;
  background:
    radial-gradient(800px 300px at 80% 0, rgba(224,230,88,.08), transparent 60%),
    #0b0f1a;
  border-top:1px solid rgba(255,255,255,.06);
}
.footer-top{
  display:grid; gap:24px; padding:40px 0;
  grid-template-columns: 1.2fr .9fr 1fr;
}
@media (max-width:900px){ .footer-top{ grid-template-columns:1fr; } }

.footer-brand h3{ margin:0 0 8px; color:#fff; }
.footer-brand p{ margin:0 0 14px; color:#aeb7cc; }
.wa-fab.inline{
  display:inline-grid; place-items:center;
  width:auto; height:auto; padding:10px 14px; border-radius:999px;
  text-decoration:none; color:#000; font-weight:800;
}

.footer-nav h4, .footer-contact h4{
  margin:0 0 10px; color:#fff;
}
.footer-nav ul, .footer-contact ul{ list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.footer-nav a, .footer-contact a{ color:#dbe6ff; text-decoration:none; }
.footer-nav a:hover, .footer-contact a:hover{ text-decoration:underline; }

/* Badge “Hecho por TechTeks.net” */
.made-by{
  --bg1:#e0e658; --bg2:#c7cf2e;
  display:inline-flex; align-items:center; gap:10px;
  margin-top:16px; padding:8px 12px;
  border-radius:12px; text-decoration:none; color:#0b0f1a; font-weight:800;
  background: linear-gradient(180deg, var(--bg1), var(--bg2));
  border:1px solid rgba(0,0,0,.15);
  box-shadow:0 6px 18px rgba(224,230,88,.25);
}
.made-by:hover{ filter:brightness(.98); transform:translateY(-1px); }

.mb-logo{
  width:28px; height:28px; border-radius:8px; display:grid; place-items:center;
  background:#0b0f1a; color:#e0e658; font-weight:900; letter-spacing:.5px;
}
.mb-text{ color:#0b0f1a; }
.mb-text strong{ text-decoration:underline; text-decoration-thickness:2px; }

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.06);
  background:#0a0f1e; 
  text-align:center; padding:12px 0;
}
.footer-bottom p{ margin:0; color:#b6c0d8; }

/* FAB WhatsApp */
.wa-fab{ position:fixed; right:18px; bottom:18px; width:52px; height:52px; display:grid; place-items:center; border-radius:50%; background:var(--accent); color:#000; font-weight:800; box-shadow:var(--shadow-strong); text-decoration:none; transition:.2s; z-index:1001; }
.wa-fab:hover{ transform:translateY(-2px); }

/* Responsive helpers */
@media (max-width:900px){
  .grid-2{ grid-template-columns:1fr; }
  .nav-toggle{ display:block; }
  .nav-menu{
    position:fixed; inset:56px 0 auto 0; background:#fff; border-bottom:1px solid rgba(0,0,0,.06);
    flex-direction:column; gap:0; padding:8px 16px 16px; transform:translateY(-120%); transition:transform .3s ease;
  }
  .nav-menu.open{ transform:translateY(0); }
  .nav-menu a{ width:100%; padding:12px; }
  .timeline{ grid-template-columns:1fr; padding-left:22px; }
  .timeline::before{ left:8px; transform:none; }
  .tl-dot{ left:-13px !important; right:auto !important; }
  .tl-year{ display:none; }
}