*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: oklch(97.5% .007 72);--bg-alt: oklch(93.5% .01 72);--bg-dark: oklch(16% .012 72);--text: oklch(16% .012 72);--text-2: oklch(40% .01 72);--text-3: oklch(62% .008 72);--accent: oklch(52% .13 28);--accent-lt: oklch(90% .04 28);--line: oklch(88% .01 72);--ff-head: "Cormorant Garamond", Georgia, serif;--ff-body: "DM Sans", system-ui, sans-serif;--r: 3px}html{scroll-behavior:smooth}body{font-family:var(--ff-body);background:var(--bg);color:var(--text);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}nav{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--bg);border-bottom:1px solid transparent;display:flex;justify-content:space-between;align-items:center;padding:0 clamp(1.5rem,5vw,4rem);height:60px;transition:border-color .3s,box-shadow .3s}nav.scrolled{border-color:var(--line);box-shadow:0 1px 16px #0000000a}.nav-name{font-family:var(--ff-head);font-weight:500;font-size:1.1rem;letter-spacing:.02em;color:var(--text);text-decoration:none}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);text-decoration:none;font-weight:500;transition:color .2s}.nav-links a:hover{color:var(--accent)}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:4px}.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--text);margin:5px 0;transition:.3s}section{padding:clamp(4rem,8vw,7rem) clamp(1.5rem,5vw,4rem)}.container{max-width:1000px;margin:0 auto}.section-label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:.75rem}.section-title{font-family:var(--ff-head);font-size:clamp(2rem,4vw,2.8rem);font-weight:400;line-height:1.15;margin-bottom:3rem;color:var(--text)}#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:60px;background:var(--bg)}.hero-inner{max-width:1000px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 420px;gap:4rem;align-items:center}.hero-photo{position:relative;aspect-ratio:1/1;border-radius:8px;overflow:hidden;box-shadow:0 24px 64px #00000024}.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}.hero-photo:after{content:"";position:absolute;inset:0;border:1px solid oklch(100% 0 0 / .12);border-radius:8px;pointer-events:none}.hero-eyebrow{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.hero-eyebrow:before{content:"";display:block;width:36px;height:1px;background:var(--accent)}.hero-name{font-family:var(--ff-head);font-size:clamp(3.2rem,8vw,6.5rem);font-weight:300;line-height:1;letter-spacing:-.01em;margin-bottom:.5rem}.hero-name em{font-style:italic;color:var(--accent)}.hero-title{font-family:var(--ff-head);font-weight:300;font-style:italic;font-size:clamp(1.1rem,2.5vw,1.45rem);color:var(--text-2);margin-bottom:2.5rem;line-height:1.4}.hero-meta{display:flex;flex-wrap:wrap;gap:1.5rem;font-size:.85rem;color:var(--text-3);margin-bottom:3rem}.hero-meta a{color:var(--text-3);text-decoration:none;transition:color .2s}.hero-meta a:hover{color:var(--accent)}.hero-meta span{display:flex;align-items:center;gap:.4rem}.hero-cta{display:inline-flex;align-items:center;gap:.6rem;background:var(--text);color:var(--bg);padding:.75rem 1.6rem;font-size:.85rem;font-weight:500;letter-spacing:.04em;text-decoration:none;border-radius:var(--r);transition:background .2s,transform .15s}.hero-cta:hover{background:var(--accent);transform:translateY(-1px)}.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);text-decoration:none}.hero-scroll:after{content:"";display:block;width:1px;height:40px;background:var(--text-3);animation:scrollPulse 2s ease-in-out infinite}@keyframes scrollPulse{0%,to{opacity:.3;transform:scaleY(1);transform-origin:top}50%{opacity:1;transform:scaleY(1.3);transform-origin:top}}#sobre{background:var(--bg-alt)}.sobre-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.sobre-text p{color:var(--text-2);margin-bottom:1.2rem;font-size:.97rem;text-wrap:pretty}.sobre-text p:last-child{margin-bottom:0}.sobre-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.stat-card{background:var(--bg);border-radius:6px;padding:1.5rem;border:1px solid var(--line)}.stat-num{font-family:var(--ff-head);font-size:2.6rem;font-weight:300;color:var(--accent);line-height:1}.stat-label{font-size:.8rem;color:var(--text-3);margin-top:.4rem;line-height:1.3}#educacion{background:var(--bg)}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:grid;grid-template-columns:140px 1fr;gap:0 2.5rem;position:relative;padding-bottom:2.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{content:"";position:absolute;left:140px;top:8px;bottom:0;width:1px;background:var(--line);margin-left:2.5rem;transform:translate(calc(-50% + 0px))}.timeline-item:last-child:before{display:none}.timeline-date{font-size:.78rem;color:var(--text-3);padding-top:.2rem;text-align:right;line-height:1.4}.timeline-body{position:relative;padding-left:1.5rem}.timeline-body:before{content:"";position:absolute;left:0;top:8px;width:9px;height:9px;border-radius:50%;border:2px solid var(--accent);background:var(--bg);transform:translate(-50%)}.timeline-body h3{font-family:var(--ff-head);font-weight:500;font-size:1.35rem;line-height:1.2}.timeline-body .inst{font-size:.85rem;color:var(--accent);font-weight:500;margin-bottom:.3rem}.timeline-body .loc{font-size:.8rem;color:var(--text-3)}#experiencia{background:var(--bg-alt)}.exp-list{display:flex;flex-direction:column;gap:1px}.exp-item{background:var(--bg);border-radius:6px;overflow:hidden;border:1px solid var(--line);margin-bottom:1px}.exp-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;cursor:pointer;gap:1rem;transition:background .15s}.exp-header:hover{background:var(--accent-lt)}.exp-header-left{flex:1}.exp-header h3{font-family:var(--ff-head);font-weight:500;font-size:1.15rem;line-height:1.2}.exp-header .role{font-size:.82rem;color:var(--accent);font-weight:500;margin-top:.15rem}.exp-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}.exp-date{font-size:.75rem;color:var(--text-3);white-space:nowrap}.exp-toggle{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:transform .25s}.exp-item.open .exp-toggle{transform:rotate(45deg)}.exp-body{max-height:0;overflow:hidden;transition:max-height .35s ease}.exp-item.open .exp-body{max-height:600px}.exp-body-inner{padding:0 1.5rem 1.5rem;border-top:1px solid var(--line)}.exp-body-inner ul{padding-top:1rem;padding-left:1.1rem;display:flex;flex-direction:column;gap:.45rem}.exp-body-inner li{font-size:.88rem;color:var(--text-2)}#habilidades{background:var(--bg)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.skill-tag{background:var(--bg-alt);border:1px solid var(--line);border-radius:4px;padding:.7rem 1rem;font-size:.85rem;color:var(--text-2);transition:border-color .2s,color .2s}.skill-tag:hover{border-color:var(--accent);color:var(--text)}.soft-section{margin-top:2.5rem}.soft-section h3{font-family:var(--ff-head);font-size:1.3rem;font-weight:400;margin-bottom:1.2rem;color:var(--text-2)}.soft-grid{display:flex;flex-wrap:wrap;gap:.6rem}.soft-tag{background:transparent;border:1px solid var(--accent);border-radius:20px;padding:.35rem .9rem;font-size:.8rem;color:var(--accent)}.tools-section{margin-top:2.5rem}.tools-section h3{font-family:var(--ff-head);font-size:1.3rem;font-weight:400;margin-bottom:1.2rem;color:var(--text-2)}.tools-list{display:flex;flex-wrap:wrap;gap:.8rem}.tool{background:var(--bg-dark);color:var(--bg);border-radius:4px;padding:.5rem 1rem;font-size:.82rem;font-weight:500;letter-spacing:.03em}#proyecto{background:var(--bg-dark);color:var(--bg)}#proyecto .section-label{color:var(--accent)}#proyecto .section-title{color:var(--bg)}.proyecto-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.proyecto-text p{color:#c7c3bf;font-size:.97rem;margin-bottom:1.2rem;text-wrap:pretty}.proyecto-text p:last-child{margin-bottom:0}.proyecto-highlight{background:#1e1a15;border-radius:8px;padding:2rem;border:1px solid oklch(30% .01 72)}.proyecto-highlight h3{font-family:var(--ff-head);font-size:1.6rem;font-weight:500;color:var(--bg);margin-bottom:.75rem;line-height:1.2;font-style:italic}.proyecto-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}.proyecto-tag{font-size:.75rem;letter-spacing:.06em;background:#312d28;border-radius:3px;padding:.3rem .7rem;color:#b1ada9}.proyecto-tag.accent{background:var(--accent);color:#fff}#cursos{background:var(--bg-alt)}.cursos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem}.curso-card{background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:1.25rem 1.4rem;transition:border-color .2s,transform .15s}.curso-card:hover{border-color:var(--accent);transform:translateY(-2px)}.curso-date{font-size:.72rem;color:var(--accent);font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.4rem}.curso-title{font-family:var(--ff-head);font-size:1.05rem;font-weight:500;line-height:1.3;margin-bottom:.4rem}.curso-org{font-size:.8rem;color:var(--text-3);margin-bottom:.5rem}.curso-desc{font-size:.82rem;color:var(--text-2);line-height:1.5}#contacto{background:var(--bg)}.contacto-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.contacto-text p{color:var(--text-2);font-size:.97rem;text-wrap:pretty;margin-bottom:1rem}.contacto-links{display:flex;flex-direction:column;gap:.9rem}.contacto-link{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-alt);border:1px solid var(--line);border-radius:6px;text-decoration:none;color:var(--text);transition:border-color .2s,transform .15s}.contacto-link:hover{border-color:var(--accent);transform:translate(3px)}.contacto-link-icon{width:36px;height:36px;background:var(--accent-lt);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.contacto-link-label{font-size:.72rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em}.contacto-link-value{font-size:.9rem;font-weight:500}footer{background:var(--bg-dark);color:#75716d;padding:1.75rem clamp(1.5rem,5vw,4rem);display:flex;justify-content:space-between;align-items:center;font-size:.78rem}footer a{color:#75716d;text-decoration:none}@media(max-width:768px){.hero-inner{grid-template-columns:1fr;gap:2.5rem}.hero-photo{max-width:320px;margin:0 auto}.nav-links{display:none;flex-direction:column;gap:1.5rem;position:fixed;inset:60px 0 0;background:var(--bg);padding:3rem 2rem;z-index:99}.nav-links.open{display:flex}.nav-toggle{display:block}.sobre-grid,.proyecto-grid,.contacto-grid{grid-template-columns:1fr;gap:2.5rem}.timeline-item{grid-template-columns:1fr}.timeline-item:before{display:none}.timeline-date{text-align:left;padding-bottom:.25rem;color:var(--accent);font-weight:500}.timeline-body{padding-left:1rem}footer{flex-direction:column;gap:.5rem;text-align:center}}@media(max-width:480px){.sobre-stats{grid-template-columns:1fr 1fr}}.wa-float{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;width:56px;height:56px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #25d36673;transition:transform .25s ease,box-shadow .25s ease;animation:wa-pulse 2.5s ease-in-out infinite}.wa-float:hover{transform:scale(1.12);box-shadow:0 6px 22px #25d36699;animation:none}@keyframes wa-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.07)}}
