:root{--bg:#f3efe7;--paper:#fffdf8;--ink:#111827;--muted:#667085;--line:#ded7ca;--navy:#142033;--navy2:#0b1220;--gold:#c79a42;--gold2:#f2d18a;--blue:#3557d4;--shadow:0 24px 70px rgba(15,23,42,.12);--radius:26px;--max:1180px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:radial-gradient(circle at top left,rgba(199,154,66,.18),transparent 32rem),linear-gradient(180deg,#fbf8f1 0%,var(--bg) 45%,#e9e3d8 100%);line-height:1.58;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.wrap{width:min(var(--max),calc(100% - 44px));margin-inline:auto}.skip{position:absolute;left:-9999px}.skip:focus{left:16px;top:16px;background:white;padding:10px 14px;border-radius:10px;z-index:999}.site-header{position:sticky;top:0;z-index:20;background:rgba(255,253,248,.84);backdrop-filter:blur(18px);border-bottom:1px solid rgba(222,215,202,.72)}.nav{height:72px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:center;gap:12px;font-weight:850;letter-spacing:-.02em;color:var(--navy)}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--navy),#2e3d60);color:var(--gold2);font-size:.88rem;letter-spacing:.04em;box-shadow:0 10px 22px rgba(15,23,42,.18)}.nav-links{display:flex;align-items:center;gap:26px;font-size:.94rem;color:#475467}.nav-links a{transition:.2s}.nav-links a:hover{color:var(--ink)}.nav-toggle{display:none;border:1px solid var(--line);background:white;border-radius:999px;padding:9px 14px;font-weight:750;color:var(--ink)}.section{padding:84px 0}.hero{padding:94px 0 64px}.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 290px;gap:64px;align-items:center}.eyebrow,.section-label,.tag{margin:0 0 12px;text-transform:uppercase;letter-spacing:.14em;font-size:.76rem;font-weight:850;color:var(--gold)}h1{margin:0;color:var(--navy);font-size:clamp(2.55rem,5.5vw,5.4rem);line-height:.94;letter-spacing:-.07em;max-width:880px}.lead{margin:28px 0 0;font-size:clamp(1.12rem,2vw,1.38rem);line-height:1.45;color:#334155;max-width:760px}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 20px;border-radius:999px;font-weight:850;border:1px solid transparent;transition:.2s;white-space:nowrap}.btn.primary{background:var(--navy);color:white;box-shadow:0 15px 35px rgba(15,23,42,.20)}.btn.primary:hover,.btn.ghost:hover{transform:translateY(-2px)}.btn.ghost{background:rgba(255,255,255,.72);border-color:var(--line);color:var(--navy)}.btn.light{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.24);color:white}.profile-card{background:var(--paper);border:1px solid rgba(222,215,202,.94);border-radius:30px;padding:18px;box-shadow:var(--shadow);justify-self:end;width:100%;max-width:290px}.portrait{border-radius:22px;overflow:hidden;background:linear-gradient(135deg,#e8ded0,#fff9ee);border:1px solid var(--line);padding:10px;max-width:230px;margin-inline:auto}.portrait img{width:100%;height:auto;max-height:230px;object-fit:contain;margin:auto;border-radius:16px}.profile-info{padding:18px 6px 4px;display:grid;gap:6px;color:#475467;font-size:.94rem;text-align:left}.profile-title{margin:0 0 8px;color:var(--navy);font-weight:900}.profile-info a{color:var(--navy);font-weight:800}.profile-info a:hover{text-decoration:underline;text-underline-offset:4px}.stats-section{padding:24px 0}.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.stats div{background:rgba(255,253,248,.75);border:1px solid rgba(222,215,202,.85);border-radius:20px;padding:20px}.stats span{display:block;color:var(--navy);font-size:1.55rem;font-weight:900;line-height:1}.stats p{margin:6px 0 0;color:#475467;font-size:.94rem}.split{display:grid;grid-template-columns:360px minmax(0,1fr);gap:70px;align-items:start}.intro{background:rgba(255,253,248,.55);border-block:1px solid rgba(222,215,202,.7)}h2{margin:0;color:var(--navy);font-size:clamp(2rem,3.4vw,3.25rem);line-height:1.03;letter-spacing:-.045em}.prose{font-size:1.08rem;color:#344054}.prose p{margin:0}.prose p+p{margin-top:18px}.section-head{max-width:820px;margin-bottom:34px}.section-head.compact{margin-bottom:28px}.section-head p:last-child{color:#475467;font-size:1.05rem;margin:14px 0 0}.work-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.work-card{background:var(--paper);border:1px solid rgba(222,215,202,.92);border-radius:24px;overflow:hidden;box-shadow:0 18px 45px rgba(15,23,42,.08);transition:.22s}.work-card:hover{transform:translateY(-4px);box-shadow:0 26px 60px rgba(15,23,42,.12)}.work-card.featured{grid-column:span 2}.thumb{position:relative;display:block;aspect-ratio:16/9;background:#111827;overflow:hidden}.thumb img{width:100%;height:100%;object-fit:cover;transition:transform .28s,opacity .28s}.work-card:hover .thumb img{transform:scale(1.035);opacity:.86}.play{position:absolute;left:18px;bottom:18px;background:rgba(255,255,255,.94);color:var(--navy);font-weight:900;border-radius:999px;padding:9px 14px;font-size:.9rem;box-shadow:0 10px 24px rgba(0,0,0,.18)}.work-content{padding:22px}.work-content h3{margin:0;font-size:1.25rem;line-height:1.18;color:var(--navy)}.work-content p:last-child{margin:10px 0 0;color:#475467}.tag{margin-bottom:8px;color:var(--blue);letter-spacing:.1em;font-size:.70rem}.timeline-section{background:linear-gradient(180deg,#111827,#172033);color:white}.timeline-section h2,.timeline-section .section-label{color:white}.timeline-section .section-label{color:var(--gold2)}.timeline{display:grid;gap:16px}.timeline article{display:grid;grid-template-columns:150px minmax(0,1fr);gap:28px;padding:26px;border-radius:22px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.11)}.year{color:var(--gold2);font-weight:900;white-space:nowrap;padding-top:2px}.timeline-content{min-width:0}.timeline h3{margin:0;font-size:1.22rem;line-height:1.25}.timeline p{margin:9px 0 0;color:#d0d5dd;max-width:860px}.skill-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.skill-grid article{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:24px}.skill-grid h3{margin:0 0 10px;color:var(--navy)}.skill-grid p{margin:0;color:#475467}.cv-band{background:linear-gradient(135deg,var(--navy),#263454);color:white}.cv-band h2{color:white}.cv-grid{display:flex;align-items:center;justify-content:space-between;gap:28px}.cv-grid p:last-child{color:#d0d5dd}.cv-actions{display:flex;gap:14px;flex-wrap:wrap}.contact-card{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:40px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:30px;padding:34px;box-shadow:0 18px 55px rgba(15,23,42,.08)}.contact-links{display:grid;gap:10px;color:#475467}.contact-links a{font-weight:900;color:var(--navy)}.contact-links a:hover{text-decoration:underline;text-underline-offset:4px}.footer{padding:28px 0;border-top:1px solid var(--line);color:#667085}.footer-inner{display:flex;justify-content:space-between;gap:20px}.footer p{margin:0}.footer a{font-weight:800;color:var(--navy)}@media (max-width:980px){.hero-grid,.split,.contact-card{grid-template-columns:1fr}.profile-card{justify-self:start;max-width:280px}.work-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.skill-grid,.stats{grid-template-columns:repeat(2,minmax(0,1fr))}.cv-grid{align-items:flex-start;flex-direction:column}}@media (max-width:720px){.wrap{width:min(100% - 28px,var(--max))}.nav-toggle{display:inline-flex}.nav-links{position:absolute;top:72px;left:14px;right:14px;display:none;flex-direction:column;align-items:flex-start;gap:12px;padding:18px;background:white;border:1px solid var(--line);border-radius:18px;box-shadow:0 18px 50px rgba(15,23,42,.14)}.nav-links.open{display:flex}.section{padding:58px 0}.hero{padding:64px 0 54px}.hero-grid{gap:34px}.work-grid,.skill-grid,.stats{grid-template-columns:1fr}.work-card.featured{grid-column:auto}.timeline article{grid-template-columns:1fr;gap:8px}.contact-card{padding:24px}.footer-inner{flex-direction:column}.brand span:last-child{display:none}}

/* v5: vídeo incrustado en portfolio */
.video-embed{position:relative;aspect-ratio:16/9;background:#0b1220;overflow:hidden;border-bottom:1px solid rgba(222,215,202,.92)}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;background:#0b1220}
.external-link{display:inline-flex;margin-top:16px;color:var(--blue);font-weight:900;text-decoration:underline;text-underline-offset:4px}
.work-card:hover{transform:none;box-shadow:0 18px 45px rgba(15,23,42,.08)}
.work-card.featured .video-embed{aspect-ratio:16/9}


/* v6: portfolio videos uniformes */
.work-grid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch}
.work-card,.work-card.featured{grid-column:auto;display:flex;flex-direction:column;height:100%}
.video-embed,.work-card.featured .video-embed{aspect-ratio:16/9;flex:0 0 auto}
.work-content{display:flex;flex-direction:column;flex:1}
.work-content .external-link{margin-top:auto;padding-top:14px}
@media (max-width:980px){.work-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:720px){.work-grid{grid-template-columns:1fr}}


/* v8: miniaturas con reproductor modal, para no cargar todos los iframes a la vez */
.video-embed{display:none}
.video-thumb{
  position:relative;
  display:block;
  width:100%;
  aspect-ratio:16/9;
  padding:0;
  border:0;
  background:#0b1220;
  overflow:hidden;
  cursor:pointer;
  border-bottom:1px solid rgba(222,215,202,.92);
  text-align:left;
}
.video-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.001);
  transition:transform .28s ease, opacity .28s ease, filter .28s ease;
}
.video-thumb::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(7,12,24,.05),rgba(7,12,24,.42));
  opacity:.82;
  transition:opacity .2s ease;
}
.work-card:hover .video-thumb img{transform:scale(1.035);filter:saturate(1.05)}
.work-card:hover .video-thumb::after{opacity:.62}
.play-badge{
  position:absolute;
  left:18px;
  bottom:18px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  gap:9px;
  background:rgba(255,253,248,.96);
  color:var(--navy);
  font-weight:900;
  border-radius:999px;
  padding:10px 15px;
  font-size:.92rem;
  box-shadow:0 14px 30px rgba(0,0,0,.22);
}
.play-icon{
  width:0;
  height:0;
  border-top:7px solid transparent;
  border-bottom:7px solid transparent;
  border-left:11px solid var(--navy);
  display:inline-block;
  margin-left:2px;
}
.video-modal{
  position:fixed;
  inset:0;
  z-index:1000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.video-modal.open{display:flex}
.video-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(7,12,24,.82);
  backdrop-filter:blur(5px);
}
.video-modal-panel{
  position:relative;
  z-index:1;
  width:min(1100px,96vw);
  background:#0b1220;
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px;
  box-shadow:0 36px 100px rgba(0,0,0,.46);
  overflow:hidden;
}
.video-modal-close{
  position:absolute;
  right:12px;
  top:12px;
  z-index:3;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.94);
  color:var(--navy);
  border-radius:999px;
  padding:9px 13px;
  font-weight:900;
  cursor:pointer;
}
.video-modal-frame{
  position:relative;
  aspect-ratio:16/9;
  width:100%;
  background:#000;
}
.video-modal-frame iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
body.modal-open{overflow:hidden}
@media (max-width:720px){
  .video-modal{padding:12px}
  .video-modal-panel{border-radius:16px}
  .video-modal-close{right:8px;top:8px;padding:8px 11px}
}


/* v9: enlace de rescate dentro del modal por si YouTube bloquea la inserción */
.modal-youtube-link{
  position:absolute;
  left:18px;
  bottom:18px;
  z-index:4;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  background:rgba(255,255,255,.94);
  color:var(--navy);
  font-weight:900;
  box-shadow:0 12px 28px rgba(0,0,0,.22);
  text-decoration:none;
}
.modal-youtube-link:hover{text-decoration:underline;text-underline-offset:4px}


/* v10: reproductor modal más contenido para material SD/antiguo */
.video-modal-panel{
  width:min(760px,92vw);
  max-height:86vh;
}
.video-modal{
  padding:18px;
}
.video-modal-frame{
  aspect-ratio:16/9;
}
@media (min-width:1280px){
  .video-modal-panel{
    width:min(820px,72vw);
  }
}
@media (max-width:720px){
  .video-modal-panel{
    width:96vw;
  }
}


/* v16: modal limpio sin botones superpuestos; se cierra haciendo clic fuera o con ESC */
.video-modal-close{
  display:none !important;
}
.modal-youtube-link{
  display:none !important;
}
.video-modal-panel{
  cursor:default;
}
.video-modal-backdrop{
  cursor:pointer;
}
