*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:    #f5f0e8;
  --bg2:   #ede8df;
  --cream: #faf7f2;
  --ink:   #1a1610;
  --ink2:  #3d3529;
  --muted: #7a6e5f;
  --gold:  #c9963a;
  --gold2: #e8b85a;
  --rust:  #8b3a1e;
  --teal:  #1e6b5e;
  --glass: rgba(255,255,255,.58);
}
body{font-family:Georgia,'Times New Roman',serif;background:var(--bg);color:var(--ink);overflow-x:hidden;line-height:1.6}

/* ==================== KEYFRAMES ==================== */
@keyframes fadeUp  {from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:none}}
@keyframes fadeL   {from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:none}}
@keyframes fadeR   {from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}
@keyframes fadeIn  {from{opacity:0}to{opacity:1}}
@keyframes slideUp {from{opacity:0;transform:translateY(105%)}to{opacity:1;transform:none}}
@keyframes growW   {from{width:0}to{width:100%}}
@keyframes growBar {from{width:0}to{width:var(--w,80%)}}
@keyframes scaleIn {from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}
@keyframes float   {0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes floatR  {0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-8px) rotate(2deg)}}
@keyframes shine   {0%{left:-100%}45%,100%{left:150%}}
@keyframes pulse   {0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.25)}}
@keyframes glow    {0%,100%{opacity:.35}50%{opacity:1}}
@keyframes orbDrift{0%{transform:translate(0,0) scale(1)}40%{transform:translate(35px,-25px) scale(1.08)}100%{transform:translate(0,0) scale(1)}}
@keyframes blink   {0%,100%{opacity:1;transform:translateY(0)}50%{opacity:.25;transform:translateY(7px)}}
@keyframes borderP {0%,100%{border-color:rgba(201,150,58,.2)}50%{border-color:rgba(201,150,58,.6)}}
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
@keyframes bounce {
  0%, 80%, 100% { transform: scale(0.6); opacity: 0.3; }
  40% { transform: scale(1); opacity: 1; }
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes pulseGlow {
  0% { box-shadow: 0 0 0 0 rgba(201, 150, 58, 0.4); }
  70% { box-shadow: 0 0 0 10px rgba(201, 150, 58, 0); }
  100% { box-shadow: 0 0 0 0 rgba(201, 150, 58, 0); }
}

/* ==================== ORB DECORATIVOS ==================== */
.orb{position:fixed;border-radius:50%;pointer-events:none;z-index:0;filter:blur(72px)}
.o1{width:600px;height:600px;background:radial-gradient(circle,rgba(201,150,58,.13),transparent 70%);top:-180px;right:-160px;animation:orbDrift 20s ease-in-out infinite}
.o2{width:480px;height:480px;background:radial-gradient(circle,rgba(30,107,94,.09),transparent 70%);bottom:-120px;left:-120px;animation:orbDrift 26s 7s ease-in-out infinite}
.o3{width:280px;height:280px;background:radial-gradient(circle,rgba(139,58,30,.07),transparent 70%);top:45%;left:35%;animation:orbDrift 16s 4s ease-in-out infinite}

/* ==================== BARRA DE NAVEGACIÓN ==================== */
.navbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(201, 150, 58, 0.2);
  z-index: 1000;
  padding: 12px 32px;
  transition: all 0.3s;
}
.nav-container {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.nav-logo {
  font-family: 'Courier New', monospace;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 2px;
  color: var(--ink);
  text-decoration: none;
  transition: color 0.3s;
}
.nav-logo:hover { color: var(--gold); }
.nav-links { display: flex; gap: 28px; }
.nav-link {
  font-family: 'Courier New', monospace;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1px;
  text-decoration: none;
  color: var(--ink2);
  transition: color 0.2s;
}
.nav-link:hover { color: var(--gold); }
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
}
.nav-toggle span {
  width: 25px;
  height: 2px;
  background: var(--ink);
  transition: 0.3s;
}
@media (max-width: 768px) {
  .nav-links {
    position: fixed;
    top: 60px;
    left: -100%;
    width: 100%;
    height: auto;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(16px);
    flex-direction: column;
    align-items: center;
    padding: 20px 0;
    gap: 20px;
    transition: left 0.3s ease;
    border-bottom: 1px solid rgba(201, 150, 58, 0.2);
  }
  .nav-links.active { left: 0; }
  .nav-toggle { display: flex; }
  .navbar { padding: 12px 20px; }
}
section { scroll-margin-top: 80px; }

/* ==================== HERO ==================== */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:80px 56px;position:relative;z-index:1;overflow:hidden;background:linear-gradient(150deg,var(--cream) 0%,var(--bg) 55%,var(--bg2) 100%)}
#hero::before{content:'PAV';position:absolute;right:-20px;bottom:-40px;font-size:340px;font-weight:900;line-height:1;color:transparent;-webkit-text-stroke:1.5px rgba(201,150,58,.07);user-select:none;pointer-events:none;letter-spacing:-20px;animation:float 14s ease-in-out infinite}
#hero::after{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--teal),var(--gold),var(--rust),var(--gold),var(--teal));background-size:200% 100%;animation:shine 4s linear infinite}

.hero-wrap{max-width:1060px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Courier New',monospace;font-size:11px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:22px;animation:fadeUp .6s .1s both}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:26px;height:1px;background:var(--gold)}
.hero-name{font-size:clamp(40px,5.2vw,70px);font-weight:900;line-height:1.0;margin-bottom:14px}
.hero-name .line{display:block;overflow:hidden}
.hero-name .line span{display:block;animation:slideUp .9s cubic-bezier(.16,1,.3,1) both}
.hero-name .line:nth-child(1) span{animation-delay:.2s}
.hero-name .line:nth-child(2) span{animation-delay:.35s}
.hero-name .line:nth-child(3) span{animation-delay:.5s}
.ng{color:var(--gold)}.ni{font-style:italic;color:var(--rust)}
.hero-rule{width:0;height:2px;margin:20px 0;background:linear-gradient(90deg,var(--gold),var(--rust),transparent);animation:growW 1.1s .85s cubic-bezier(.16,1,.3,1) forwards}
.hero-bio{font-size:15px;line-height:1.82;color:var(--ink2);max-width:440px;animation:fadeUp .8s .8s both}
.hero-bio strong{color:var(--ink);border-bottom:1px solid rgba(201,150,58,.32)}
.hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px;animation:fadeUp .7s .95s both}
.htag{padding:5px 14px;border-radius:20px;font-family:'Courier New',monospace;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:1px solid;transition:all .2s;cursor:default}
.htag-gold{background:rgba(201,150,58,.1);border-color:rgba(201,150,58,.3);color:var(--gold)}
.htag-teal{background:rgba(30,107,94,.08);border-color:rgba(30,107,94,.25);color:var(--teal)}
.htag-rust{background:rgba(139,58,30,.08);border-color:rgba(139,58,30,.25);color:var(--rust)}
.htag:hover{transform:translateY(-2px) scale(1.05)}
.hero-btns{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap;animation:fadeUp .7s 1.05s both}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--ink);padding:13px 28px;border-radius:4px;font-size:13px;font-weight:700;letter-spacing:.4px;text-decoration:none;box-shadow:0 4px 18px rgba(201,150,58,.3);position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s}
.btn-gold::after{content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);animation:shine 3.5s 1.5s ease-in-out infinite}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,150,58,.42)}
.btn-out{background:transparent;color:var(--ink2);padding:13px 28px;border-radius:4px;font-size:13px;text-decoration:none;border:1.5px solid rgba(26,22,16,.18);transition:all .2s}
.btn-out:hover{border-color:var(--gold);color:var(--gold)}

/* ==================== KPI CARDS ==================== */
.kpi-stack{display:flex;flex-direction:column;gap:13px;animation:fadeR .9s .55s cubic-bezier(.16,1,.3,1) both}
.kpi{display:flex;align-items:center;gap:16px;padding:18px 22px;border-radius:14px;background:var(--glass);border:1px solid rgba(201,150,58,.2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 4px 20px rgba(26,22,16,.07),inset 0 1px 0 rgba(255,255,255,.78);position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s;animation:scaleIn .7s both}
.kpi::before{content:'';position:absolute;top:0;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent)}
.kpi::after{content:'';position:absolute;top:0;left:0;right:0;height:2.5px;background:var(--kb,linear-gradient(90deg,var(--gold),var(--gold2)))}
.kpi:nth-child(1){animation-delay:.8s;--kb:linear-gradient(90deg,var(--gold),var(--gold2))}
.kpi:nth-child(2){animation-delay:.95s;--kb:linear-gradient(90deg,var(--teal),#3dbaaa)}
.kpi:nth-child(3){animation-delay:1.1s;--kb:linear-gradient(90deg,var(--rust),#c05a3a)}
.kpi:nth-child(4){animation-delay:1.25s;--kb:linear-gradient(90deg,#6b48c8,#9b7de8)}
.kpi:nth-child(5){animation-delay:1.4s;--kb:linear-gradient(90deg,#1a7cb8,#4aaee8)}
.kpi:hover{transform:translateX(7px) scale(1.01);box-shadow:0 10px 30px rgba(26,22,16,.12),inset 0 1px 0 rgba(255,255,255,.82)}
.kpi-icon{font-size:24px;flex-shrink:0;animation:float 5s ease-in-out infinite}
.kpi:nth-child(2) .kpi-icon{animation-delay:.5s}
.kpi:nth-child(3) .kpi-icon{animation-delay:1s}
.kpi:nth-child(4) .kpi-icon{animation-delay:1.5s}
.kpi:nth-child(5) .kpi-icon{animation-delay:2s}
.kpi-val{font-size:24px;font-weight:900;color:var(--ink);line-height:1}
.kpi-val span{color:var(--gold)}
.kpi-desc{font-family:'Courier New',monospace;font-size:10px;color:var(--muted);margin-top:2px;letter-spacing:.3px}

.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;animation:fadeIn .8s 1.9s both}
.scroll-hint span{font-family:'Courier New',monospace;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);opacity:.45}
.mouse{width:18px;height:30px;border:1.5px solid rgba(26,22,16,.18);border-radius:9px;display:flex;justify-content:center;padding-top:5px}
.mouse::after{content:'';width:3px;height:6px;background:var(--gold);border-radius:2px;animation:blink 2s ease-in-out infinite}

/* ==================== SECCIONES BASE ==================== */
.sec{padding:90px 56px;position:relative;z-index:1}
.sec-inner{max-width:1060px;margin:0 auto}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Courier New',monospace;font-size:10px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;animation:fadeIn .7s both}
.eyebrow::before{content:'';width:20px;height:1px;background:var(--gold)}
.sec-title{font-size:clamp(28px,3.8vw,48px);font-weight:900;line-height:1.1;animation:fadeUp .8s both}
.sec-title em{font-style:italic;color:var(--gold)}
.sec-rule{width:0;height:2px;margin:16px 0 40px;background:linear-gradient(90deg,var(--gold),transparent);animation:growW .9s both}

/* ==================== ACERCA DE ==================== */
#acerca{background:var(--cream)}
#acerca::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);animation:glow 4s ease-in-out infinite}
.acerca-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:70px;align-items:start}
.acerca-text{font-size:15px;line-height:1.85;color:var(--ink2);animation:fadeL .8s 1.7s both}
.acerca-text p{margin-bottom:15px}
.acerca-text strong{color:var(--ink);border-bottom:1px solid rgba(201,150,58,.3)}
.badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;animation:fadeUp .8s 1.9s both}
.badge{display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border-radius:30px;font-size:11px;font-weight:600;font-family:'Courier New',monospace;letter-spacing:.4px;background:rgba(201,150,58,.09);border:1px solid rgba(201,150,58,.22);color:var(--ink2);transition:all .22s;cursor:default}
.badge::before{content:'◆';color:var(--gold);font-size:7px}
.badge:hover{background:var(--gold);color:var(--ink);border-color:var(--gold);transform:translateY(-2px)}
.badge.teal{background:rgba(30,107,94,.08);border-color:rgba(30,107,94,.22)}
.badge.teal::before{color:var(--teal)}
.badge.teal:hover{background:var(--teal);color:#fff}
.badge.rust{background:rgba(139,58,30,.07);border-color:rgba(139,58,30,.2)}
.badge.rust::before{color:var(--rust)}
.badge.rust:hover{background:var(--rust);color:#fff}

.skills-panel{animation:fadeR .8s 1.8s both}
.sp-title{font-size:18px;font-weight:700;margin-bottom:22px;color:var(--ink)}
.sk{margin-bottom:18px}
.sk-hdr{display:flex;justify-content:space-between;font-size:12px;color:var(--ink2);margin-bottom:6px;font-family:'Courier New',monospace}
.sk-track{height:5px;background:rgba(26,22,16,.08);border-radius:3px;overflow:hidden}
.sk-bar{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--gold),var(--rust));width:0;animation:growBar 1.2s cubic-bezier(.16,1,.3,1) both}
.sw-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:24px}
.sw-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-radius:8px;background:rgba(201,150,58,.06);border:1px solid rgba(201,150,58,.12);font-size:12px;font-family:'Courier New',monospace;animation:fadeIn .6s both}
.sw-stars{color:var(--gold);letter-spacing:1px;font-size:11px}

/* ==================== CERTIFICACIONES ==================== */
#certs{background:var(--bg)}
.cert-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cert-card{background:var(--glass);border:1px solid rgba(201,150,58,.15);border-radius:14px;padding:24px 20px;text-align:center;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 3px 16px rgba(26,22,16,.07),inset 0 1px 0 rgba(255,255,255,.68);position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s;animation:scaleIn .7s both}
.cert-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--cb,linear-gradient(90deg,var(--gold),var(--gold2)));animation:growW .7s both;animation-delay:inherit}
.cert-card::after{content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:shine 5s ease-in-out infinite}
.cert-card:hover{transform:translateY(-6px);box-shadow:0 14px 36px rgba(26,22,16,.12)}
.cert-icon{font-size:28px;margin-bottom:12px;display:block;animation:float 5s ease-in-out infinite}
.cert-title{font-size:13px;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:6px}
.cert-inst{font-family:'Courier New',monospace;font-size:10px;color:var(--rust);font-weight:700;letter-spacing:.5px;margin-bottom:8px}
.cert-year{font-family:'Courier New',monospace;font-size:10px;color:var(--muted)}

/* ==================== EXPERIENCIA ==================== */
#exp{background:var(--cream)}
#exp::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(201,150,58,.3),transparent)}
.timeline{padding-left:36px;position:relative}
.timeline::before{content:'';position:absolute;left:6px;top:0;bottom:0;width:1.5px;background:linear-gradient(180deg,var(--gold),rgba(201,150,58,.06));animation:glow 5s ease-in-out infinite}
.job{position:relative;margin-bottom:44px;animation:fadeL .8s both}
.job::before{content:'';position:absolute;left:-32px;top:7px;width:11px;height:11px;border-radius:50%;background:var(--gold);border:2.5px solid var(--cream);box-shadow:0 0 0 3px rgba(201,150,58,.2);animation:pulse 3s ease-in-out infinite}
.job:first-child::before{background:var(--rust);box-shadow:0 0 0 3px rgba(139,58,30,.2)}
.job-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:10px;margin-bottom:5px}
.job-title{font-size:18px;font-weight:700}
.job-badge{font-family:'Courier New',monospace;font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--gold);background:rgba(201,150,58,.1);border:1px solid rgba(201,150,58,.22);padding:4px 11px;border-radius:20px;white-space:nowrap}
.job-co{font-family:'Courier New',monospace;font-size:11px;font-weight:700;color:var(--rust);margin-bottom:11px;letter-spacing:1px;display:flex;align-items:center;gap:7px}
.job-co::before{content:'';width:12px;height:1px;background:var(--rust)}
.job-card{background:rgba(255,255,255,.5);border:1px solid rgba(201,150,58,.12);border-radius:12px;padding:18px 22px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 2px 12px rgba(26,22,16,.06),inset 0 1px 0 rgba(255,255,255,.65);position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.job-card::before{content:'';position:absolute;top:0;left:25%;right:25%;height:1px;background:linear-gradient(90deg,transparent,rgba(201,150,58,.38),transparent)}
.job-card:hover{transform:translateX(8px);box-shadow:0 6px 24px rgba(26,22,16,.10),inset 0 1px 0 rgba(255,255,255,.75)}
.bullets{list-style:none;display:flex;flex-direction:column;gap:7px}
.bullets li{font-size:13.5px;line-height:1.65;color:var(--ink2);display:flex;gap:9px;align-items:flex-start}
.bullets li::before{content:'◆';color:var(--gold);font-size:7px;margin-top:5px;flex-shrink:0}

/* ==================== FORMACIÓN ==================== */
#form{background:var(--bg)}
.edu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.edu-card{background:var(--glass);border:1px solid rgba(201,150,58,.14);border-radius:16px;padding:28px 22px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 4px 18px rgba(26,22,16,.07),inset 0 1px 0 rgba(255,255,255,.7);position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s;animation:scaleIn .8s both}
.edu-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--eb,linear-gradient(90deg,var(--gold),var(--gold2)));animation:growW .8s both;animation-delay:inherit}
.edu-card::after{content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:shine 6s ease-in-out infinite}
.edu-card:hover{transform:translateY(-6px);box-shadow:0 14px 36px rgba(26,22,16,.11)}
.edu-icon{font-size:28px;margin-bottom:14px;display:block;animation:floatR 5s ease-in-out infinite}
.edu-year{font-family:'Courier New',monospace;font-size:10px;color:var(--gold);font-weight:700;letter-spacing:2px;margin-bottom:8px}
.edu-deg{font-size:15px;font-weight:700;margin-bottom:6px;line-height:1.25;color:var(--ink)}
.edu-inst{font-family:'Courier New',monospace;font-size:10px;color:var(--rust);font-weight:700;letter-spacing:.5px;margin-bottom:9px}
.edu-desc{font-size:12px;color:var(--muted);line-height:1.6}

/* ==================== MÉRITOS ==================== */
#meritos{background:var(--cream)}
#meritos::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.meritos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.merito-card{background:rgba(255,255,255,.52);border:1px solid rgba(201,150,58,.13);border-radius:12px;padding:22px 20px;text-align:center;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 3px 14px rgba(26,22,16,.06),inset 0 1px 0 rgba(255,255,255,.68);transition:transform .3s;animation:scaleIn .7s both}
.merito-card:hover{transform:translateY(-5px)}
.merito-icon{font-size:26px;margin-bottom:10px;display:block;animation:float 5s ease-in-out infinite}
.merito-text{font-size:13px;color:var(--ink2);line-height:1.5;font-weight:500}
.merito-year{font-family:'Courier New',monospace;font-size:10px;color:var(--gold);margin-top:6px;font-weight:700}

/* ==================== CONTACTO ==================== */
#contact{background:var(--ink);color:var(--bg);position:relative;overflow:hidden}
#contact::before{content:'';position:absolute;top:-250px;right:-150px;width:650px;height:650px;border-radius:50%;background:radial-gradient(circle,rgba(201,150,58,.10),transparent 70%);pointer-events:none;animation:orbDrift 22s ease-in-out infinite}
#contact .eyebrow{color:var(--gold2)}
#contact .eyebrow::before{background:var(--gold2)}
#contact .sec-title{color:var(--bg)}
#contact .sec-title em{color:var(--gold2)}
#contact .sec-rule{background:linear-gradient(90deg,var(--gold2),transparent)}
.sigma-wm{position:absolute;right:-50px;bottom:-80px;font-size:360px;font-weight:900;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(201,150,58,.05);user-select:none;pointer-events:none;animation:float 14s ease-in-out infinite}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:start}
.contact-copy{font-size:15px;line-height:1.8;color:rgba(245,240,232,.7);animation:fadeL .8s 5.8s both}
.contact-copy p{margin-bottom:14px}
.contact-items{display:flex;flex-direction:column;gap:12px;animation:fadeR .8s 5.9s both}
.ci{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:16px 20px;backdrop-filter:blur(10px);box-shadow:inset 0 1px 0 rgba(255,255,255,.07);transition:all .3s;text-decoration:none;color:inherit;position:relative;overflow:hidden}
.ci::before{content:'';position:absolute;top:0;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent)}
.ci:hover{background:rgba(255,255,255,.09);border-color:rgba(201,150,58,.3);transform:translateX(8px)}
.ci-icon{font-size:20px;flex-shrink:0}
.ci-lbl{font-family:'Courier New',monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gold2);margin-bottom:2px;font-weight:700}
.ci-val{font-size:13px;color:var(--bg)}

/* ==================== BLOG PAGES ==================== */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 32px;
  margin-top: 40px;
}
.blog-card {
  background: var(--glass);
  border: 1px solid rgba(201,150,58,.15);
  border-radius: 24px;
  padding: 28px;
  backdrop-filter: blur(16px);
  transition: transform 0.3s, box-shadow 0.3s;
  text-decoration: none;
  color: inherit;
  display: block;
}
.blog-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 30px rgba(26,22,16,.1);
}
.blog-icon { font-size: 48px; margin-bottom: 20px; }
.blog-title { font-size: 22px; font-weight: 700; margin-bottom: 12px; }
.blog-meta { font-family: 'Courier New', monospace; font-size: 11px; color: var(--gold); margin-bottom: 16px; }
.blog-excerpt { font-size: 14px; line-height: 1.6; color: var(--ink2); margin-bottom: 20px; }
.blog-link { font-size: 13px; font-weight: 600; color: var(--gold); transition: transform 0.2s; display: inline-block; }
.blog-card:hover .blog-link { transform: translateX(6px); }

/* ==================== ARTÍCULOS INDIVIDUALES ==================== */
.article-content {
  max-width: 800px;
  margin: 0 auto;
  font-size: 17px;
  line-height: 1.8;
  color: var(--ink2);
}
.article-content h2 {
  font-size: 28px;
  margin: 40px 0 20px;
  color: var(--ink);
  font-weight: 700;
}
.article-content h3 {
  font-size: 22px;
  margin: 32px 0 16px;
  color: var(--ink);
  font-weight: 600;
}
.article-content p { margin-bottom: 24px; }
.article-content ul, .article-content ol { margin: 20px 0 20px 30px; }
.article-content li { margin-bottom: 10px; }
.article-content blockquote {
  border-left: 4px solid var(--gold);
  margin: 28px 0;
  font-style: italic;
  background: rgba(201,150,58,.05);
  padding: 20px 24px;
  border-radius: 12px;
}
.table-of-contents {
  background: var(--glass);
  border: 1px solid rgba(201,150,58,.15);
  border-radius: 16px;
  padding: 24px 28px;
  margin: 32px 0;
}
.table-of-contents h3 { margin-top: 0; margin-bottom: 16px; }
.table-of-contents ul { margin: 0; list-style: none; padding-left: 0; }
.table-of-contents li { margin-bottom: 10px; }
.table-of-contents a { color: var(--gold); text-decoration: none; }
.table-of-contents a:hover { text-decoration: underline; }
.back-link {
  display: inline-block;
  margin: 40px 0 20px;
  color: var(--gold);
  text-decoration: none;
  font-weight: 600;
}
.back-link:hover { text-decoration: underline; }

/* ==================== BOTÓN VOLVER ARRIBA ==================== */
.back-to-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 52px;
  height: 52px;
  background: linear-gradient(135deg, #c9963a, #e8b85a);
  color: #1a1610;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: bold;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  z-index: 999;
  box-shadow: 0 4px 15px rgba(201, 150, 58, 0.3);
}
.back-to-top.visible {
  opacity: 1;
  visibility: visible;
  animation: pulseGlow 1.5s ease-out 1;
}
.back-to-top:hover {
  transform: translateY(-5px) scale(1.08);
  background: linear-gradient(135deg, #e8b85a, #c9963a);
  box-shadow: 0 8px 25px rgba(201, 150, 58, 0.5);
}
@media (max-width: 768px) {
  .back-to-top {
    width: 44px;
    height: 44px;
    font-size: 24px;
    bottom: 20px;
    right: 20px;
  }
}

/* ==================== ANIMACIONES AL SCROLL ==================== */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.6s cubic-bezier(0.2, 0.9, 0.4, 1.1);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ==================== LOADER ==================== */
.loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--bg) 0%, var(--cream) 50%, var(--bg2) 100%);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.5s ease, visibility 0.5s ease;
  opacity: 1;
  visibility: visible;
}
.loader.hide {
  opacity: 0;
  visibility: hidden;
}
.loader-content {
  text-align: center;
  animation: fadeInUp 0.6s ease;
}
.loader-spinner {
  width: 60px;
  height: 60px;
  margin: 0 auto 20px;
  border: 4px solid rgba(201, 150, 58, 0.2);
  border-top: 4px solid var(--gold);
  border-right: 4px solid var(--gold2);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
.loader-text {
  font-family: 'Courier New', monospace;
  font-size: 14px;
  letter-spacing: 2px;
  color: var(--gold);
  margin-bottom: 16px;
  text-transform: uppercase;
}
.loader-dots {
  display: flex;
  gap: 8px;
  justify-content: center;
}
.loader-dots span {
  width: 8px;
  height: 8px;
  background: var(--gold);
  border-radius: 50%;
  animation: bounce 1.4s ease-in-out infinite;
}
.loader-dots span:nth-child(1) { animation-delay: 0s; }
.loader-dots span:nth-child(2) { animation-delay: 0.2s; }
.loader-dots span:nth-child(3) { animation-delay: 0.4s; }

/* ==================== SCROLL SMOOTH ==================== */
html {
  scroll-behavior: smooth;
}

/* ==================== RESPONSIVE ==================== */
@media(max-width:920px){
  .hero-wrap,.acerca-grid,.contact-grid{grid-template-columns:1fr}
  .kpi-stack{display:none}
  .edu-grid,.cert-grid{grid-template-columns:1fr 1fr}
  .meritos-grid{grid-template-columns:1fr 1fr}
  #hero::before{font-size:180px}
  .sec,#hero{padding-left:24px;padding-right:24px}
  .sec{padding-top:68px;padding-bottom:68px}
}
@media(max-width:600px){
  .edu-grid,.cert-grid,.meritos-grid{grid-template-columns:1fr}
  .sw-grid{grid-template-columns:1fr}
}
.article-content {
  max-width: 800px;
  margin: 40px auto;
  font-size: 18px;
  line-height: 1.8;
  color: #333;
}

/* Párrafos */
.article-content p {
  margin-bottom: 20px;
}

/* Títulos dentro del contenido */
.article-content h2 {
  margin-top: 40px;
  margin-bottom: 15px;
  font-size: 26px;
}

.article-content h3 {
  margin-top: 30px;
  margin-bottom: 10px;
  font-size: 22px;
}

/* Listas */
.article-content ul,
.article-content ol {
  margin: 20px 0 20px 25px;
}

/* Links */
.article-content a {
  color: #c9963a;
  text-decoration: none;
}

.article-content a:hover {
  text-decoration: underline;
}