/* ===== PAMWEB – Tema (ajusta aquí a los colores de tu logo) ===== */
:root{
  --primary: #2563eb;   /* ← COLOR PRINCIPAL pamweb */
  --accent:  #d75be2;   /* ← ACENTO pamweb */
  --success: #10b981;
  --text:    #1e293b;
  --muted:   #64748b;
  --border:  #e2e8f0;
  --bg1:     #f5f7fa;
  --bg2:     #c3cfe2;

  --grad:         linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  --grad-accent:  linear-gradient(135deg, var(--accent) 0%, #9f7aea 100%);
  --grad-success: linear-gradient(135deg, var(--success) 0%, #059669 100%);

  --shadow:   0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05);
}

/* ===== Reset & base ===== */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  line-height:1.6; color:var(--text);
  background:linear-gradient(135deg,var(--bg1) 0%,var(--bg2) 100%); min-height:100vh;
}

/* ===== Navbar ===== */
.navbar{position:fixed;inset:0 0 auto 0;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);z-index:1000;padding:1rem 0;transition:.3s}
.navbar.scrolled{background:rgba(255,255,255,.98);box-shadow:var(--shadow)}
.nav-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}
.nav-logo{font-weight:700;color:var(--primary);text-decoration:none}
.nav-menu{display:flex;list-style:none;gap:1.25rem}
.nav-link{padding:.5rem 1rem;border-radius:8px;color:var(--text);text-decoration:none;font-weight:500;transition:.3s}
.nav-link:hover,.nav-link.active{background:#f8fafc;color:var(--primary)}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer}
.nav-toggle span{width:26px;height:3px;background:var(--text)}
@media (max-width:900px){
  .nav-menu{position:fixed;left:-100%;top:70px;flex-direction:column;background:#fff;width:100%;
    text-align:center;transition:.3s;box-shadow:var(--shadow);padding:1.25rem 0}
  .nav-menu.active{left:0}
  .nav-toggle{display:flex}
}

/* ===== Logo PJ ===== */
.pj-logo {
  font-family: 'Inter', sans-serif; /* o la que uses en tu logo */
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--primary);
  text-decoration: none;
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* ===== Layout ===== */
.container{max-width:1200px;margin:0 auto;padding:2rem;padding-top:6rem}
.header{position:relative;text-align:center;margin-bottom:3rem;padding:3rem 1rem;border-radius:20px;color:#fff;
  background:var(--grad);box-shadow:var(--shadow-lg);overflow:hidden}
.header h1{font-size:2.6rem;margin-bottom:.25rem}
.header .subtitle{opacity:.95}
.header .kicker{display:inline-block;margin-top:.7rem;padding:.25rem .7rem;border-radius:999px;background:rgba(255,255,255,.15);font-size:.9rem}

/* ===== Cards ===== */
.card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:1.6rem;margin-bottom:1.6rem;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:.3s}
.card::before{content:'';position:absolute;inset:0 auto auto 0;height:4px;width:100%;background:var(--grad)}
.card.accent::before{background:var(--grad-accent)}
.card.success::before{background:var(--grad-success)}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.card-title{font-size:1.35rem;font-weight:600;margin-bottom:1rem;display:flex;gap:.5rem;align-items:center}
.card-title::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--primary)}
.section-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-weight:700}

/* ===== Grids ===== */
.grid{display:grid;gap:1.5rem}
.two-col{grid-template-columns:1fr 1fr}
.three-col{grid-template-columns:repeat(3,1fr)}
@media (max-width:900px){.two-col,.three-col{grid-template-columns:1fr}}

/* ===== Items ===== */
.experience-item{padding:1rem;border:1px solid var(--border);border-radius:12px;background:#f8fafc;margin-bottom:1rem;transition:.2s}
.experience-item:hover{background:#fff;transform:translateY(-1px)}
.experience-item.current{border-left:4px solid var(--success);background:linear-gradient(135deg,#ecfdf5 0%,#f0fdf4 100%)}
.experience-title{font-weight:700;color:var(--primary)}
.experience-company{font-weight:600}
.experience-date{font-size:.9rem;color:var(--muted);margin:.25rem 0 .5rem}
.experience-description{color:var(--muted)}
ul.clean{margin:.25rem 0 0 1.25rem}
ul.clean li{margin:.25rem 0}

/* ===== Skills ===== */
.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}
.skill-item{padding:.7rem;border:1px solid var(--border);border-radius:10px;background:#fff;text-align:center;font-weight:600}
.tech-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}
.tech-tag{background:var(--primary);color:#fff;padding:.2rem .6rem;border-radius:14px;font-size:.8rem;font-weight:600}

/* ===== Stats ===== */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-top:1rem}
.stat{background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:1rem;text-align:center}
.stat .n{font-size:1.8rem;color:var(--primary);font-weight:800}

/* ===== Buttons ===== */
.pill{display:flex;align-items:center;gap:.5rem;padding:.7rem 1.1rem;background:#fff;border-radius:999px;border:1px solid var(--border);box-shadow:var(--shadow);text-decoration:none;color:var(--text)}
.btn-primary {
  display:inline-block;margin-top:1rem;padding:0.9rem 1.6rem;
  background: var(--primary); color:#fff; font-weight:700; text-decoration:none;
  border-radius:10px; box-shadow:var(--shadow); letter-spacing:.2px; transition:.25s;
}
.btn-primary:hover { background: var(--accent); transform: translateY(-2px); box-shadow: var(--shadow-lg); }

/* ===== FX ===== */
.fade{opacity:0;transform:translateY(18px);transition:all .6s ease-out}
.fade.show{opacity:1;transform:none}
