:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg: #000000;--text: #f5f5f5;--text-soft: #d4d4d4;--text-muted: #9ca3af;--accent: #22c55e;--accent-soft: rgba(34, 197, 94, .22);--card-bg: rgba(0, 0, 0, .88);--card-border: rgba(255, 255, 255, .08);--nav-bg-top: rgba(0, 0, 0, .96);--nav-bg-mid: rgba(0, 0, 0, .6);--shadow-strong: 0 24px 70px rgba(0, 0, 0, .95)}html,body,#root{margin:0;padding:0;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}*,*:before,*:after{box-sizing:border-box}.app-root{position:relative;width:100%;height:100vh;overflow-x:hidden}.bg-canvas{position:fixed!important;inset:0}.ui-overlay{position:relative;z-index:10;min-height:100vh;display:flex;flex-direction:column}.nav{position:sticky;top:0;z-index:998;display:flex;justify-content:space-between;align-items:center;padding:1rem 2.5rem;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:linear-gradient(to bottom,var(--nav-bg-top),var(--nav-bg-mid),transparent);border-bottom:1px solid rgba(255,255,255,.06)}.nav-right{display:flex;align-items:center;gap:1.5rem}.nav-links a{margin-left:1.1rem}.logo{font-weight:700;font-size:.9rem;letter-spacing:.16em;text-transform:uppercase}.nav nav{display:flex;gap:1.5rem;font-size:.9rem}.nav a{text-decoration:none;color:var(--text-soft);position:relative;padding-bottom:.1rem}.nav a:after{content:"";position:absolute;left:0;bottom:-.1rem;width:0;height:2px;background:linear-gradient(to right,var(--accent),transparent);transition:width .16s ease-out}.nav a:hover{color:var(--text)}.nav a:hover:after{width:100%}.lang-dropdown{position:relative;outline:none}.lang-trigger{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:999px;border:1px solid rgba(34,197,94,.55);background:radial-gradient(circle at 30% 0%,#22c55e2e,#000000f2);color:var(--text-soft);font-size:.75rem;cursor:pointer;box-shadow:0 14px 30px #000000e6;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease,color .16s ease}.lang-trigger:hover{border-color:var(--accent);color:var(--text);transform:translateY(-1px);box-shadow:0 20px 45px #22c55e59}.lang-trigger-caret{font-size:.7rem;opacity:.8}.lang-menu{position:absolute;right:0;margin-top:.4rem;min-width:180px;border-radius:14px;padding:.35rem;background:radial-gradient(circle at top,#22c55e40,#000000fa 55%);border:1px solid rgba(34,197,94,.5);box-shadow:0 22px 70px #000,0 0 24px #22c55e59;z-index:40}.lang-option{width:100%;text-align:left;padding:.35rem .6rem;border-radius:10px;border:none;background:transparent;color:var(--text-soft);font-size:.78rem;cursor:pointer;transition:background .15s ease,color .15s ease}.lang-option:hover{background:#22c55e38;color:var(--text)}.lang-option.is-active{background:#22c55e52;color:#bbf7d0}.content{width:min(2000px,100% - 5rem);margin:3rem auto 4rem}.content-inner{width:100%;display:flex;flex-direction:column;gap:2rem}.section-card{width:100%;margin-inline:auto;background:radial-gradient(circle at top left,rgba(34,197,94,.12),transparent 60%),linear-gradient(to bottom right,#000000eb,#0a0a0af0),var(--card-bg);border-radius:1.4rem;padding:1.8rem 2rem;border:1px solid var(--card-border);box-shadow:var(--shadow-strong),0 0 0 1px #ffffff05;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);position:relative;overflow:hidden}.section-card:before{content:"";position:absolute;left:10%;right:10%;top:0;height:1px;background:linear-gradient(to right,rgba(255,255,255,.18),transparent);opacity:.35}.hero{margin-top:.5rem}.hero-eyebrow{text-transform:uppercase;font-size:.78rem;letter-spacing:.18em;color:var(--text-muted);margin-bottom:.6rem;opacity:.9}.hero h1{font-size:clamp(2.2rem,4vw,3.5rem);margin:0 0 .8rem;line-height:1.1;color:var(--text)}.accent{color:var(--accent)}.hero-subtitle{text-align:justify;max-width:95%;color:var(--text-soft);font-size:.95rem;margin-bottom:1.7rem}.buttons{display:flex;flex-wrap:wrap;gap:.9rem}.btn{border-radius:999px;padding:.7rem 1.5rem;font-size:.9rem;border:1px solid transparent;text-decoration:none;cursor:pointer;transition:.16s ease-out}.btn.primary{background:#fff;color:#000;font-weight:600;box-shadow:var(--shadow-strong)}.btn.primary:hover{transform:translateY(-1px)}.btn.ghost{background:#000000a6;border-color:#ffffff38;color:var(--text-soft)}.btn.ghost:hover{background:#ffffff0f;border-color:#ffffff73}.section{display:flex;flex-direction:column;gap:.75rem}.section-title{font-size:1.1rem;font-weight:600;margin:0}.section-text{margin:0;font-size:.95rem;color:var(--text-soft)}.contact-info{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.label{font-size:.75rem;text-transform:uppercase;letter-spacing:.18em;color:var(--text-muted)}.mono-link{color:var(--text);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.3)}.mono-link:hover{border-bottom-color:var(--accent)}.footer{font-size:.8rem;color:var(--text-muted);padding:.75rem 0 .25rem}@media(max-width:900px){.nav{padding-inline:1.5rem}.content{width:100%;margin:2.5rem auto 3rem;padding:0 1.5rem}.section-card{padding:1.5rem 1.4rem}}@media(max-width:640px){.nav{padding-inline:1.1rem}.nav nav{display:none}.content{padding:0 1.1rem;margin:2.2rem auto 2.6rem}.hero h1{font-size:2rem}.hero-subtitle{font-size:.9rem}.section-card{padding:1.4rem 1.2rem;border-radius:1.1rem}.buttons{flex-direction:column;align-items:flex-start}}.projects-section{padding-top:1.8rem}.projects-section .section-text{color:var(--text-muted)}.projects-grid-wrapper{width:100%;display:flex;justify-content:center}.projects-grid{max-width:1400px;width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.4rem}@media(max-width:900px){.projects-grid{grid-template-columns:1fr}}.project-card{background:radial-gradient(120% 140% at 20% -10%,rgba(34,197,94,.2),transparent 50%),radial-gradient(160% 140% at 120% 120%,rgba(34,197,94,.1),transparent 55%),linear-gradient(to bottom right,#000000eb,#080808f0);border:1px solid rgba(34,197,94,.35);box-shadow:0 18px 40px #000000d9,0 0 0 1px #22c55e2e;border-radius:1.2rem;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);transition:.25s ease}.project-card:hover{border-color:#22c55e8c;box-shadow:0 26px 60px #000000f2,0 0 0 1px #22c55e59,0 0 12px #22c55e40;transform:translateY(-2px)}.project-card:after{content:"";position:absolute;inset:auto 18% -2px;height:2px;border-radius:999px;background:radial-gradient(circle,rgba(34,197,94,.55),transparent 70%);opacity:.4}.project-image-wrapper{position:relative;height:190px;overflow:hidden}.project-image-wrapper img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.03);transition:transform .3s ease}.project-image-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#0000001a,#000000d9)}.project-card:hover .project-image-wrapper img{transform:scale(1.08)}.project-info{position:relative;margin-top:-80px;padding:1.1rem 1.2rem 1.2rem;display:flex;flex-direction:column;justify-content:space-between}.project-title{font-size:1.2rem;font-weight:500;margin-bottom:.15rem;color:var(--text)}.project-subtitle{font-size:.9rem;color:var(--text-soft)}.project-tools{margin-top:.7rem;display:flex;flex-wrap:wrap;gap:.4rem;list-style:none;padding:0}.project-tool-pill{font-size:.75rem;padding:.25rem .65rem;border-radius:999px;border:1px solid var(--accent);background:var(--accent-soft);color:#bbf7d0}@media(max-width:640px){.project-image-wrapper{height:160px}.project-info{margin-top:-70px}}.project-image-wrapper img{width:100%;height:100%;object-fit:cover;mask-image:radial-gradient(circle at center,black 65%,transparent 100%);-webkit-mask-image:radial-gradient(circle at center,black 65%,transparent 100%)}.project-modal-backdrop{position:fixed;inset:0;background:radial-gradient(circle at center,#22c55e29,#000000eb);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:999}.project-modal{position:relative;width:100%;max-width:960px;max-height:90vh;border-radius:22px;overflow:hidden;background:radial-gradient(circle at 20% -10%,#22c55e38,#000000f0 40%);border:1px solid rgba(34,197,94,.35);box-shadow:0 28px 90px #000,0 0 35px #22c55e40;padding:1.8rem 2rem;display:flex;flex-direction:column;z-index:1000}.project-modal-title{color:var(--text);letter-spacing:.02em}.project-modal-subtitle{color:var(--text-muted)}.project-modal-close{position:absolute;top:1rem;right:1.2rem;border:none;background:transparent;color:var(--text-soft);font-size:1.3rem;cursor:pointer}.project-modal-header{margin-bottom:1.2rem;padding-right:2rem}.project-modal-content{padding:1.8rem 2.6rem;overflow-y:auto}@media(min-width:1100px){.project-modal-content{padding:2rem 3.2rem}}@media(max-width:768px){.project-modal-content{padding:1.2rem 1.4rem}}.project-modal-section{margin-bottom:1.2rem}.project-modal-video-wrapper{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:16px;overflow:hidden;border:1px solid rgba(34,197,94,.35);background:#000;box-shadow:0 16px 40px #000000e6}.project-modal-video-wrapper iframe{width:100%;height:100%;display:block;border:none}.project-modal-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.project-modal-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-right:3.2rem}.project-modal-link-btn{margin-right:.4rem;margin-top:.35rem;padding:.45rem .9rem;border-radius:10px;border:1px solid var(--accent);background:var(--accent-soft);color:#bbf7d0;text-decoration:none;font-size:.85rem;transition:border-color .15s ease,background .15s ease,color .15s ease}.project-modal-link-btn:hover{border-color:var(--accent);background:#22c55e59;color:#fff}@media(max-width:640px){.project-modal-header{flex-direction:column;align-items:flex-start}}.project-modal-description p,.project-modal-contributions p{font-size:.92rem;color:var(--text-soft);line-height:1.7;text-align:justify;margin-bottom:.6rem}.project-modal-description p:last-child,.project-modal-contributions p:last-child{margin-bottom:0}.project-modal-tags{display:flex;flex-wrap:wrap;gap:.4rem;list-style:none;padding:0;margin:.4rem 0 0}.project-modal-carousel{display:flex;align-items:center;gap:.75rem;margin-top:.4rem}.project-modal-carousel-main{flex:1;border-radius:16px;overflow:hidden;border:1px solid rgba(34,197,94,.35);box-shadow:0 16px 45px #000000e6;cursor:zoom-in;background:#000}.project-modal-carousel-main img{width:100%;height:100%;display:block;object-fit:cover}.project-modal-carousel-btn{border:none;background:#000000d9;color:var(--text);width:32px;height:32px;border-radius:999px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 25px #000000e6;transition:transform .15s ease,background .15s ease}.project-modal-carousel-btn:hover{background:#22c55ecc;transform:translateY(-1px)}.project-modal-carousel-thumbs{margin-top:.6rem;display:flex;gap:.4rem;overflow-x:auto}.project-modal-carousel-thumb{flex:0 0 70px;height:50px;border-radius:10px;overflow:hidden;border:1px solid rgba(148,163,184,.3);padding:0;background:none;cursor:pointer}.project-modal-carousel-thumb img{width:100%;height:100%;object-fit:cover;display:block}.project-modal-carousel-thumb.is-active{border-color:var(--accent)}.project-modal-fullscreen-backdrop{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1001}.project-modal-fullscreen{position:relative;max-width:90vw;max-height:90vh}.project-modal-fullscreen img{max-width:100%;max-height:100%;display:block;border-radius:12px;box-shadow:0 26px 80px #000}.project-modal-fullscreen-close{position:absolute;top:-40px;right:0;border:none;background:#000c;color:var(--text);border-radius:999px;width:30px;height:30px;cursor:pointer}.project-modal-fullscreen-arrow{position:absolute;top:50%;transform:translateY(-50%);border:none;background:#000000bf;color:var(--text);width:36px;height:36px;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center}.project-modal-fullscreen-arrow.left{left:-48px}.project-modal-fullscreen-arrow.right{right:-48px}@media(max-width:768px){.project-modal-fullscreen-arrow.left{left:8px}.project-modal-fullscreen-arrow.right{right:8px}}.about-section .section-text{color:var(--text-muted)}.timeline{position:relative;margin-left:18px}.timeline:before{content:"";position:absolute;left:0;top:.75rem;width:2px;height:calc(100% - .75rem);background:linear-gradient(to bottom,#22c55e99,#22c55e33)}.timeline-item{position:relative;padding-left:22px;margin-bottom:1.8rem}.timeline-marker{position:absolute;left:-5px;top:2.2rem;width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px #22c55e99}.timeline-content{padding-left:1.2rem}.timeline-year{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.timeline-role{font-size:1.05rem;margin:.15rem 0 .3rem;font-weight:500;color:var(--text)}.timeline-desc{font-size:.9rem;color:var(--text-soft);line-height:1.6}.timeline-item:last-child{padding-bottom:0}.skills-section .section-text{color:var(--text-muted)}.skills-groups{margin-top:2rem;display:flex;flex-direction:column;gap:2.4rem}.skills-group{text-align:center}.skills-group-title{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1.3rem}.skills-items{display:flex;flex-wrap:wrap;justify-content:center;gap:1.6rem 2.4rem}.skills-item{position:relative;width:110px;height:110px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 30% 0,var(--accent-soft),#000);border:1px solid rgba(34,197,94,.35);box-shadow:0 18px 40px #000000e6;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.skills-item:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 26px 60px #22c55e73}.skills-item-icon,.skills-item-icon-img{font-size:3.6rem;width:3.6rem;height:3.6rem;color:var(--text);line-height:1;filter:drop-shadow(0 8px 20px rgba(0,0,0,.6))}.skills-tooltip{position:absolute;left:50%;top:100%;transform:translate(-50%,10px);padding:.25rem .6rem;border-radius:999px;background:#000000f2;border:1px solid rgba(34,197,94,.7);color:var(--text-soft);font-size:.75rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:5}.skills-tooltip:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid rgba(0,0,0,.95)}.skills-tooltip:after{content:"";position:absolute;top:-7px;left:50%;transform:translate(-50%);width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:7px solid rgba(34,197,94,.7);z-index:-1}.skills-item:hover .skills-tooltip{opacity:1;transform:translate(-50%,16px)}@media(max-width:768px){.skills-item{width:90px;height:90px}.skills-item-icon,.skills-item-icon-img{font-size:3rem;width:3rem;height:3rem}.skills-tooltip{font-size:.7rem}}.skills-section.section-card{overflow:visible;padding-bottom:3rem}.contact-section .section-text{color:var(--text-muted)}.contact-items{margin-top:2rem;display:flex;flex-wrap:wrap;justify-content:center;gap:2.5rem}.contact-item{display:flex;flex-direction:column;align-items:center;gap:.6rem}.contact-icon-wrapper{display:inline-flex;text-decoration:none}.contact-icon-circle{width:96px;height:96px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 30% 0,var(--accent-soft),#000);border:1px solid rgba(34,197,94,.4);box-shadow:0 18px 40px #000000e6;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.contact-icon-wrapper:hover .contact-icon-circle{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 26px 60px #22c55e73}.contact-icon{font-size:2.6rem;color:var(--text);line-height:1;filter:drop-shadow(0 8px 18px rgba(0,0,0,.7))}.contact-icon-svg{width:34px;height:34px;object-fit:contain;display:block;filter:drop-shadow(0 8px 18px rgba(0,0,0,.7))}.contact-link-text{font-size:.9rem;color:var(--text-soft);text-decoration:none;border-bottom:1px solid transparent;padding-bottom:.05rem;transition:color .15s ease,border-color .15s ease}.contact-link-text:hover{color:var(--accent);border-color:var(--accent)}@media(max-width:640px){.contact-icon-circle{width:84px;height:84px}.contact-icon{font-size:2.2rem}.contact-icon-svg{width:30px;height:30px}}.cv-section .section-text{color:var(--text-muted)}.cv-header{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.4rem}.cv-download-btn{align-self:flex-start}.cv-viewer-wrapper{position:relative;margin:0 auto;max-width:700px;width:100%;border-radius:18px;overflow:hidden;border:1px solid var(--card-border);background:radial-gradient(circle at top left,#020617,#000);box-shadow:var(--shadow-strong)}.cv-iframe{width:100%;height:800px;border:none}@media(max-width:768px){.cv-iframe{height:420px}}.cv-download-wrapper{display:flex;justify-content:center;margin:1.2rem 0 1.6rem}.cv-download-btn{padding:.65rem 1.6rem;border-radius:999px;background:var(--accent-soft);border:1px solid var(--accent);color:var(--text);font-weight:600;cursor:pointer;transition:.2s ease}.cv-download-btn:hover{background:var(--accent);color:#000;transform:translateY(-1px)}
