:root{--bg: #0a0a0a;--bg2: #111111;--bg3: #1a1a1a;--border: rgba(255, 255, 255, .07);--border-hover: rgba(255, 255, 255, .15);--text: #f0ede8;--text-muted: #6b6b6b;--text-soft: #a0a0a0;--accent: #c8f542;--accent-dim: rgba(200, 245, 66, .12);--accent-dim2: rgba(200, 245, 66, .06);--nav-bg: rgba(10, 10, 10, .85);--mobile-menu-bg: linear-gradient(rgba(10, 10, 10, .92), rgba(10, 10, 10, .98)), radial-gradient(circle at top, rgba(200, 245, 66, .08), transparent 40%);--grain-opacity: .4;--radius: 14px;--radius-sm: 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{min-width:320px;overflow-x:hidden;background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;font-size:16px;line-height:1.7;cursor:none}body.menu-open,body.modal-open{overflow:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:9990;opacity:var(--grain-opacity);pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E")}a{color:inherit}button{font:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{border-radius:4px;background:var(--border-hover)}.container{max-width:1080px;margin:0 auto;padding:0 2rem}.cursor,.cursor-ring{position:fixed;transform:translate(-50%,-50%);pointer-events:none}.cursor{z-index:9999;width:10px;height:10px;border-radius:50%;background:var(--accent);mix-blend-mode:difference;transition:transform .1s,width .2s,height .2s,opacity .2s}.cursor.expand{width:20px;height:20px}.cursor-ring{z-index:9998;width:36px;height:36px;border:1px solid rgba(200,245,66,.5);border-radius:50%;transition:transform .18s ease,width .25s,height .25s,opacity .25s}.cursor-ring.expand{width:56px;height:56px;border-color:var(--accent)}nav{position:fixed;top:0;right:0;left:0;z-index:100;padding:1.25rem 0;transition:background .3s,backdrop-filter .3s,border-bottom .3s}nav.scrolled{border-bottom:.5px solid var(--border);background:var(--nav-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1080px;margin:0 auto;padding:0 2rem}.nav-logo{color:var(--text);font-family:Syne,sans-serif;font-size:18px;font-weight:800;letter-spacing:-.02em;text-decoration:none}.nav-logo span{color:var(--accent)}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{color:var(--text-muted);font-size:13px;letter-spacing:.06em;text-decoration:none;text-transform:uppercase;transition:color .2s}.nav-links a:hover{color:var(--accent)}.nav-cta,.social-link{transition:background .2s,border-color .2s,color .2s}.nav-actions{display:flex;align-items:center;gap:10px}.nav-cta{padding:8px 20px;border:.5px solid var(--border-hover);border-radius:40px;color:var(--text);font-size:13px;text-decoration:none}.nav-cta:hover,.nav-cta--accent{border-color:var(--accent);background:var(--accent);color:var(--bg)}.nav-cta--accent:hover{background:transparent;color:var(--accent)}.hamburger{display:none;flex-direction:column;gap:5px;padding:4px;border:0;background:none;cursor:none}.hamburger span{display:block;width:22px;height:1.5px;background:var(--text);transition:all .3s}.hamburger.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.hamburger.is-open span:nth-child(2){opacity:0}.hamburger.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.mobile-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;background:var(--mobile-menu-bg);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s ease,visibility .3s ease}.mobile-menu.open{opacity:1;visibility:visible;pointer-events:auto}.mobile-menu a{color:var(--text);font-family:Syne,sans-serif;font-size:28px;font-weight:700;text-decoration:none;opacity:0;transform:translateY(18px);transition:color .2s,opacity .35s ease,transform .35s ease}.mobile-menu a:hover{color:var(--accent)}.mobile-menu.open a{opacity:1;transform:translateY(0)}.mobile-menu.open a:nth-of-type(1){transition-delay:.08s}.mobile-menu.open a:nth-of-type(2){transition-delay:.14s}.mobile-menu.open a:nth-of-type(3){transition-delay:.2s}.mobile-menu.open a:nth-of-type(4){transition-delay:.26s}.mobile-close{position:absolute;top:1.5rem;right:2rem;padding:.25rem;border:0;background:none;color:var(--text);font-size:32px;line-height:1;cursor:none}#hero{position:relative;display:flex;min-height:100vh;flex-direction:column;justify-content:center;overflow:hidden;padding:7rem 0 4rem}.hero-grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.5;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 30%,transparent 100%);mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 30%,transparent 100%)}.hero-glow{position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-55%);pointer-events:none;background:radial-gradient(circle,rgba(200,245,66,.07) 0%,transparent 65%)}.hero-tag{display:inline-flex;align-items:center;gap:8px;margin-bottom:1.5rem;color:var(--accent);font-size:12px;letter-spacing:.1em;text-transform:uppercase;opacity:0;transform:translateY(20px);animation:fade-up .7s .2s forwards}.hero-tag:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}h1{margin-bottom:1.5rem;font-family:Syne,sans-serif;font-size:clamp(42px,7vw,88px);font-weight:800;letter-spacing:-.04em;line-height:.95;opacity:0;transform:translateY(30px);animation:fade-up .8s .35s forwards}h1 em{color:var(--text-muted);font-style:normal}.hero-desc{max-width:500px;margin-bottom:2.5rem;color:var(--text-soft);font-size:17px;line-height:1.75;opacity:0;transform:translateY(20px);animation:fade-up .7s .5s forwards}.hero-actions{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;opacity:0;transform:translateY(20px);animation:fade-up .7s .65s forwards}.btn-main,.btn-ghost,.back-top{display:inline-flex;align-items:center;gap:8px;text-decoration:none}.btn-main{padding:14px 28px;border-radius:40px;background:var(--accent);color:var(--bg);font-family:Syne,sans-serif;font-size:14px;font-weight:700;letter-spacing:.02em;transition:transform .2s,box-shadow .2s,filter .2s}.btn-main:hover{transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 8px 30px #c8f54240}.btn-ghost{color:var(--text-soft);font-size:14px;transition:color .2s}.btn-ghost:hover{color:var(--text)}.hero-scroll{position:absolute;bottom:2rem;left:50%;display:flex;flex-direction:column;align-items:center;gap:8px;transform:translate(-50%);opacity:0;animation:fade-in 1s 1.2s forwards}.hero-scroll span{color:var(--text-muted);font-size:11px;letter-spacing:.1em;text-transform:uppercase}.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--text-muted),transparent);animation:scroll-down 2s infinite}.hero-stats{display:flex;gap:3rem;margin-top:4rem;opacity:0;transform:translateY(20px);animation:fade-up .7s .8s forwards}.stat-num{margin-bottom:4px;color:var(--text);font-family:Syne,sans-serif;font-size:32px;font-weight:800;line-height:1}.stat-num span{color:var(--accent)}.stat-label{color:var(--text-muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase}section{padding:6rem 0}.section-header{display:flex;align-items:baseline;gap:1rem;margin-bottom:3rem}.section-num{color:var(--accent);font-family:Syne,sans-serif;font-size:12px;letter-spacing:.1em}h2{font-family:Syne,sans-serif;font-size:clamp(28px,4vw,42px);font-weight:800;letter-spacing:-.03em;line-height:1.1}.divider{flex:1;height:1px;margin-left:1rem;background:var(--border)}.about-grid{display:grid;grid-template-columns:1fr 1fr;align-items:start;gap:4rem}.about-text p{margin-bottom:1.25rem;color:var(--text-soft);font-size:17px;line-height:1.8}.about-text strong{color:var(--text);font-weight:500}.skills-list,.project-stack,.social-row{display:flex;flex-wrap:wrap}.skills-list{gap:8px;margin-top:2rem}.skill-tag{padding:6px 14px;border:.5px solid var(--border);border-radius:40px;color:var(--text-soft);font-size:12px;transition:border-color .2s,color .2s,background .2s}.skill-tag:hover{border-color:var(--accent);background:var(--accent-dim2);color:var(--accent)}.about-card{padding:2rem;border:.5px solid var(--border);border-radius:var(--radius);background:var(--bg2)}.about-card-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-bottom:.5px solid var(--border)}.about-card-row:last-child{border-bottom:0}.acr-label{color:var(--text-muted);font-size:13px}.acr-val{color:var(--text);font-size:14px;font-weight:500}.acr-val.green{color:var(--accent)}#projects{background:var(--bg)}.projects-grid{display:grid;gap:1.5px;overflow:hidden;border:.5px solid var(--border);border-radius:var(--radius);background:var(--border);grid-template-columns:repeat(2,1fr)}.project-card{position:relative;display:flex;flex-direction:column;gap:1rem;overflow:hidden;padding:2rem 2.5rem;background:var(--bg2);transition:background .3s}.project-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;pointer-events:none;background:radial-gradient(circle at var(--mx, 50%) var(--my, 50%),rgba(200,245,66,.05),transparent 60%);transition:opacity .3s}.project-card:hover{background:var(--bg3)}.project-card:hover:before{opacity:1}.project-card:hover .project-arrow{border-color:var(--accent);background:var(--accent);color:var(--bg)}.project-card.featured{grid-column:span 2;flex-direction:row;align-items:center;gap:2rem}.project-card>*{position:relative;z-index:1}.project-top{display:flex;align-items:flex-start;justify-content:space-between}.project-top--featured{margin-bottom:1rem}.project-badge{padding:4px 12px;border:.5px solid rgba(200,245,66,.25);border-radius:40px;background:var(--accent-dim);color:var(--accent);font-size:11px;font-weight:500}.project-arrow{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:.5px solid var(--border);border-radius:50%;background:transparent;color:var(--text-muted);cursor:none;font-size:14px;transition:background .2s,color .2s,border-color .2s}.project-title{color:var(--text);font-family:Syne,sans-serif;font-size:20px;font-weight:700;letter-spacing:-.02em}.project-media{display:flex;width:100%;height:116px;align-items:center;justify-content:center;overflow:hidden;border:.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg3)}.project-media img{display:block;width:100%;height:100%;object-fit:cover}.project-media--featured{width:min(38%,300px);height:140px;flex-shrink:0}.project-media--pockety{background:#fff}.project-media--pockety img{object-fit:contain;padding:.35rem;transform:scale(2.32)}.project-media--madrid{background:#fff}.project-media--madrid img{object-fit:contain}.project-media--baleares,.project-media--policia{background:#fff}.project-media--baleares img,.project-media--policia img{object-fit:contain;padding:.8rem}.project-title--featured{margin-bottom:.5rem;font-size:24px}.project-desc{color:var(--text-muted);font-size:14px;line-height:1.7}.project-stack{gap:6px;margin-top:auto}.project-stack--featured{margin-top:1.25rem}.project-modal__stack{display:flex;flex-wrap:wrap;gap:6px}.stack-chip{padding:3px 10px;border:.5px solid var(--border);border-radius:4px;background:var(--bg3);color:var(--text-muted);font-size:11px}.project-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:210;display:grid;place-items:center;padding:1rem;opacity:0;pointer-events:none;visibility:hidden;transition:opacity .16s,visibility 0s .16s}.project-modal.is-open{opacity:1;pointer-events:auto;visibility:visible;transition:opacity .16s,visibility 0s}.project-modal.is-open .project-modal__panel{transform:translateY(0) scale(1)}.project-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 42%,rgba(200,245,66,.08),transparent 34%),#0a0a0aeb}.project-modal__panel{position:relative;z-index:1;width:min(100%,760px);max-height:min(88vh,780px);overflow-y:auto;transform:translateY(8px) scale(.98);padding:28px;border:.5px solid var(--border-hover);border-radius:var(--radius-sm);background:radial-gradient(circle at top right,var(--accent-dim),transparent 42%),var(--bg2);box-shadow:0 18px 48px #00000061;transition:transform .16s ease}.project-modal__panel h2{margin:1rem 0 .75rem;font-family:Syne,sans-serif;font-size:clamp(24px,4vw,34px);letter-spacing:-.02em;line-height:1.1}.project-modal__panel p{color:var(--text-soft);font-size:15px;line-height:1.8}.project-modal__close{position:absolute;top:14px;right:14px;z-index:2;width:34px;height:34px;border:.5px solid var(--border);border-radius:50%;background:var(--bg);color:var(--text);cursor:none;font-size:24px;line-height:1}.project-modal__close:hover{border-color:var(--accent);color:var(--accent)}.project-modal__media{display:flex;width:100%;height:210px;align-items:center;justify-content:center;overflow:hidden;border:.5px solid var(--border);border-radius:var(--radius-sm);background:#fff}.project-modal__media img{display:block;width:100%;height:100%;object-fit:contain}.project-modal__media--pockety img{transform:scale(2)}.project-modal__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.25rem}.project-modal__details{margin-top:1.5rem;padding-top:1.25rem;border-top:.5px solid var(--border)}.project-modal__details h3{margin-bottom:.75rem;color:var(--text);font-family:Syne,sans-serif;font-size:16px}.project-modal__details ul{display:grid;gap:.5rem;padding-left:1.1rem;color:var(--text-soft);font-size:14px;line-height:1.7}.featured-info{flex:1}#experience{background:var(--bg2)}.exp-list{display:flex;flex-direction:column}.exp-item{display:grid;gap:2rem;padding:2rem 0;border-bottom:.5px solid var(--border);grid-template-columns:160px 1fr}.exp-item:last-child{border-bottom:0}.exp-date{padding-top:4px;color:var(--text-muted);font-size:13px}.exp-company{margin-bottom:4px;color:var(--text);font-family:Syne,sans-serif;font-size:18px;font-weight:700}.exp-role{margin-bottom:.75rem;color:var(--accent);font-size:13px}.exp-desc{color:var(--text-muted);font-size:14px;line-height:1.7}#contact{position:relative;overflow:hidden;background:var(--bg);text-align:center}.contact-glow{position:absolute;top:50%;left:50%;width:700px;height:400px;transform:translate(-50%,-50%);pointer-events:none;background:radial-gradient(ellipse,rgba(200,245,66,.06) 0%,transparent 70%)}.contact-title{margin-bottom:1rem;font-family:Syne,sans-serif;font-size:clamp(36px,6vw,72px);font-weight:800;letter-spacing:-.04em;line-height:1}.contact-sub{margin-bottom:3rem;color:var(--text-muted);font-size:16px}.contact-email{display:inline-block;margin-bottom:3rem;padding-bottom:4px;border:0;border-bottom:2px solid var(--accent);background:transparent;color:var(--text);cursor:none;font-family:Syne,sans-serif;font-size:clamp(18px,3vw,28px);font-weight:700;letter-spacing:-.02em;text-decoration:none;transition:color .2s}.contact-email:hover{color:var(--accent)}.contact-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:grid;place-items:center;padding:1rem;opacity:0;pointer-events:none;visibility:hidden;transition:opacity .16s,visibility 0s .16s}.contact-modal.is-open{opacity:1;pointer-events:auto;visibility:visible;transition:opacity .16s,visibility 0s}.contact-modal.is-open .contact-modal__panel{transform:translateY(0) scale(1)}.contact-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 42%,rgba(200,245,66,.08),transparent 34%),#0a0a0ae6}.contact-modal__panel{position:relative;z-index:1;width:min(100%,480px);transform:translateY(8px) scale(.98);padding:28px;border:.5px solid var(--border-hover);border-radius:var(--radius-sm);background:radial-gradient(circle at top right,var(--accent-dim),transparent 42%),var(--bg2);box-shadow:0 18px 48px #00000061;contain:layout paint;transition:transform .16s ease}.contact-modal__panel h2{margin-bottom:1.5rem;font-family:Syne,sans-serif;font-size:28px;letter-spacing:-.02em}.contact-modal__close{position:absolute;top:14px;right:14px;width:34px;height:34px;border:.5px solid var(--border);border-radius:50%;background:var(--bg);color:var(--text);cursor:none;font-size:24px;line-height:1}.contact-modal__close:hover{border-color:var(--accent);color:var(--accent)}.form-field{display:grid;gap:8px;margin-bottom:1rem;text-align:left}.form-field span{color:var(--text-soft);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.form-field input,.form-field textarea{width:100%;border:.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font:inherit;outline:none;padding:12px 14px;resize:vertical}.form-field input:focus,.form-field textarea:focus{border-color:var(--accent)}.form-field--hidden{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.form-status{min-height:22px;margin-bottom:.75rem;color:var(--accent);font-size:13px;text-align:center}.modal-submit{width:100%;margin-top:.5rem;padding:13px 18px;border:.5px solid var(--accent);border-radius:40px;background:var(--accent);color:var(--bg);cursor:none;font-weight:700}.modal-submit:hover{background:transparent;color:var(--accent)}.modal-submit:disabled{opacity:.65;pointer-events:none}.social-row{justify-content:center;gap:1rem;margin-top:1rem}.social-link{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:.5px solid var(--border);border-radius:40px;color:var(--text-muted);font-size:13px;text-decoration:none}.social-link:hover{border-color:var(--accent);background:var(--accent-dim2);color:var(--accent)}.social-link--accent{border-color:var(--accent);background:var(--accent);color:var(--bg)}.social-link--accent:hover{background:transparent;color:var(--accent)}footer{padding:2rem 0;border-top:.5px solid var(--border)}footer .container{display:flex;align-items:center;justify-content:space-between}.footer-copy{color:var(--text-muted);font-size:13px}.footer-copy span{color:var(--accent)}.back-top{color:var(--text-muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase;transition:color .2s}.back-top:hover{color:var(--accent)}.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}@keyframes scroll-down{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}to{transform:scaleY(0);transform-origin:bottom}}@keyframes fade-up{to{opacity:1;transform:translateY(0)}}@keyframes fade-in{to{opacity:1}}@media (max-width: 768px){body{cursor:auto}.cursor,.cursor-ring,.nav-links,.nav-actions{display:none}.hamburger{display:flex}h1{letter-spacing:-.03em}.hero-stats{gap:2rem}.about-grid{grid-template-columns:1fr;gap:2.5rem}.projects-grid{grid-template-columns:1fr}.project-card.featured{grid-column:span 1;flex-direction:column}.project-media--featured{width:100%}.exp-item{gap:.5rem;grid-template-columns:1fr}.exp-date{padding-top:0}section{padding:4rem 0}footer .container{flex-direction:column;gap:1rem}}@media (max-width: 480px){.container,.nav-inner{padding:0 1.25rem}.hero-stats{flex-wrap:wrap;gap:1.5rem}.projects-grid{gap:1px}.project-card{padding:1.5rem}}
