@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;700;800;900&display=swap";@font-face{font-family:Europa;src:url(/fonts/EuropaNuovaRegular.ttf)format("truetype");font-weight:400;font-style:normal}@font-face{font-family:Europa;src:url(/fonts/EuropaNuovaItalic.ttf)format("truetype");font-weight:400;font-style:italic}@font-face{font-family:Europa;src:url(/fonts/EuropaNuovaBold.ttf)format("truetype");font-weight:700;font-style:normal}@font-face{font-family:Europa;src:url(/fonts/EuropaNuovaBoldItalic.ttf)format("truetype");font-weight:700;font-style:italic}@font-face{font-family:Europa;src:url(/fonts/EuropaNuovaExtraBold.ttf)format("truetype");font-weight:800;font-style:normal}@font-face{font-family:Europa;src:url(/fonts/EuropaNuovaExtraBoldItalic.ttf)format("truetype");font-weight:800;font-style:italic}@font-face{font-family:Muli;src:url(/fonts/Muli-ExtraLight.ttf)format("truetype");font-weight:200;font-style:normal}@font-face{font-family:Muli;src:url(/fonts/Muli-ExtraLightItalic.ttf)format("truetype");font-weight:200;font-style:italic}@font-face{font-family:Muli;src:url(/fonts/Muli-Light.ttf)format("truetype");font-weight:300;font-style:normal}@font-face{font-family:Muli;src:url(/fonts/Muli-LightItalic.ttf)format("truetype");font-weight:300;font-style:italic}@font-face{font-family:Muli;src:url(/fonts/Muli.ttf)format("truetype");font-weight:400;font-style:normal}@font-face{font-family:Muli;src:url(/fonts/Muli-Italic.ttf)format("truetype");font-weight:400;font-style:italic}@font-face{font-family:Muli;src:url(/fonts/Muli-SemiBold.ttf)format("truetype");font-weight:600;font-style:normal}@font-face{font-family:Muli;src:url(/fonts/Muli-Semi-BoldItalic.ttf)format("truetype");font-weight:600;font-style:italic}@font-face{font-family:Muli;src:url(/fonts/Muli-Bold.ttf)format("truetype");font-weight:700;font-style:normal}@font-face{font-family:Muli;src:url(/fonts/Muli-BoldItalic.ttf)format("truetype");font-weight:700;font-style:italic}:root{--bg-color:#f5f3ee;--text-color:#000;--text-secondary:#666;--heading-color:#1a237e;--accent-color:#426bc2;--card-bg:#fff;--timeline-dot:#122c4f;--timeline-line:#ccc}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--text-color);background-color:#0000;font-family:Muli,Inter,sans-serif;line-height:1.6;position:relative;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Europa,Inter,sans-serif}body:before{content:"";pointer-events:none;z-index:9999;will-change:transform;background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='n' x='0' y='0'><feTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='300' height='300' filter='url(%23n)' opacity='0.15'/></svg>");background-repeat:repeat;background-size:300px 300px;width:400%;height:400%;animation:.8s step-end infinite grain;position:fixed;top:-200%;right:-200%;bottom:-200%;left:-200%}@keyframes grain{0%{transform:translate(0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}60%{transform:translate(15%)}70%{transform:translateY(15%)}80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}to{transform:translate(0)}}a{color:inherit;text-decoration:none;transition:color .3s}a:hover{color:var(--accent-color)}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.nav-container{justify-content:space-between;align-items:center;padding:2rem 0;display:flex}.nav-logo{align-items:center;gap:.5rem;font-size:1.5rem;font-weight:800;display:flex}.nav-links{gap:2rem;font-weight:500;display:flex}.nav-link.active{color:var(--accent-color)}.about-page{padding-bottom:6rem}.hero-section{justify-content:center;align-items:center;min-height:50vh;margin-bottom:8rem;display:flex;position:relative}.portfolio-text-bg{z-index:0;pointer-events:none;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute}.floating-letter{-webkit-user-select:none;user-select:none;margin:0 -.5rem;font-family:Inter,sans-serif;display:inline-block}.floating-year{color:#6c9;font-size:4vw;font-weight:800;position:absolute;top:15%;right:18%;transform:rotate(15deg)}.hero-image-container{z-index:1;width:350px;max-width:80%;position:relative}.hero-img{mix-blend-mode:multiply;width:100%;height:auto;display:block}.intro-section{justify-content:space-between;align-items:center;gap:5rem;margin-bottom:8rem;display:flex}.intro-content{flex:1}.intro-heading{color:var(--heading-color);margin-bottom:.5rem;font-size:2.3rem;font-weight:400}.intro-subheading{color:var(--heading-color);margin-bottom:1.5rem;font-size:3.5rem;line-height:1.2}.outline-text{color:#0000;-webkit-text-stroke:2px var(--heading-color)}.intro-text{color:var(--text-secondary);max-width:500px;margin-bottom:2rem;font-size:1rem}.social-links{gap:1rem;display:flex}.social-icon{border:2px solid var(--heading-color);width:40px;height:40px;color:var(--heading-color);border-radius:8px;justify-content:center;align-items:center;transition:all .3s;display:flex}.social-icon:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.intro-image{flex:1;justify-content:center;display:flex}.laptop-img{mix-blend-mode:multiply;width:450px;max-width:100%}.timeline-section-wrapper{margin-top:4rem}.projects-page{padding-bottom:2rem}.section-title-projects{text-align:center;color:var(--heading-color);margin-bottom:3rem;font-family:Europa,Inter,sans-serif;font-size:2.5rem;font-weight:800}.section-title-projects strong{color:var(--heading-color);font-weight:800}.competitions-grid{scrollbar-width:none;gap:1.5rem;padding-bottom:1rem;display:flex;overflow-x:auto}.competitions-grid::-webkit-scrollbar{display:none}.competition-card{background-color:var(--card-bg);cursor:pointer;border-radius:12px;flex-direction:column;min-width:250px;max-width:260px;padding:1.5rem;transition:transform .3s,box-shadow .3s;display:flex}.competition-card:hover{transform:translateY(-4px);box-shadow:0 10px 20px #0000000d}.comp-icon{margin-bottom:.5rem;font-size:1.5rem}.comp-title{color:var(--heading-color);margin-bottom:.5rem;font-size:1rem;font-weight:700;line-height:1.3}.comp-award{background-color:#e3e6ed;border-radius:4px;align-self:flex-start;margin-bottom:1rem;padding:4px 8px;font-size:.8rem;font-weight:500}.comp-date{color:var(--text-secondary);margin-top:auto;font-size:.8rem;font-weight:500}.projects-tabs{flex-wrap:wrap;justify-content:center;gap:2rem;margin-bottom:3rem;display:flex}.tab-button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .3s}.tab-button.active{color:var(--heading-color);font-weight:800}.tab-button:hover{color:var(--accent-color)}.projects-grid{scrollbar-width:none;gap:3rem;padding-bottom:2rem;display:flex;overflow-x:auto}.projects-grid::-webkit-scrollbar{display:none}.project-card{cursor:pointer;background:#e3e6ed;border-radius:30px;flex-direction:column;flex-shrink:0;min-width:320px;max-width:360px;transition:transform .3s;display:flex;overflow:hidden;box-shadow:0 10px 40px #0000000f}.project-card:hover{transform:translateY(-5px)}.project-image-placeholder{aspect-ratio:16/9;width:100%}.project-content{flex-direction:column;flex-grow:1;padding:2rem;display:flex}.project-title{color:var(--heading-color);margin-bottom:1rem;font-family:Europa,Inter,sans-serif;font-size:1.5rem;font-weight:800;line-height:1.2}.project-short-desc{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem;line-height:1.5}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;width:100vw;height:100vh;padding:2rem;display:flex;position:fixed;top:0;left:0}.modal-content{background:var(--bg-color);border-radius:24px;flex-direction:column;width:100%;max-width:700px;max-height:90vh;display:flex;position:relative;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal-header{flex-shrink:0;width:100%;height:200px;position:relative}.modal-close{cursor:pointer;z-index:2;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:transform .2s;display:flex;position:absolute;top:1rem;right:1rem;box-shadow:0 4px 12px #0000001a}.modal-close:hover{transform:scale(1.1)}.modal-body{padding:2.5rem}.modal-title{color:var(--heading-color);margin-bottom:.5rem;font-size:2rem;font-weight:800;line-height:1.2}.modal-tag{color:#555;background:#ede9de;border-radius:20px;margin-bottom:1.5rem;padding:4px 12px;font-size:.8rem;font-weight:700;display:inline-block}.modal-description{color:var(--text-secondary);margin-bottom:2rem;font-size:1.05rem;line-height:1.6}.modal-details{margin-bottom:2.5rem}.modal-details ul{padding-left:1.2rem}.modal-details li{color:#333;margin-bottom:.8rem;line-height:1.6}.modal-footer{border-top:1px solid #e0e0e0;flex-direction:column;gap:1.5rem;padding-top:1.5rem;display:flex}.project-links{gap:1.2rem;display:flex}.project-details{color:#333;margin-bottom:1.5rem;font-size:.85rem}.project-details ul{padding-left:1rem;list-style-type:disc}.project-details li{margin-bottom:.4rem}.project-links{gap:1.2rem;margin-top:auto;margin-bottom:1.5rem;display:flex}.project-link{color:var(--accent-color);align-items:center;gap:.4rem;font-size:.85rem;font-weight:700;transition:color .2s;display:flex}.project-link:hover{color:var(--heading-color)}.project-tech{color:var(--text-secondary);font-size:.8rem;line-height:1.4}.project-tech strong{color:var(--heading-color)}.comp-gallery{scrollbar-width:none;gap:1rem;margin-top:1rem;margin-bottom:1.5rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.comp-gallery::-webkit-scrollbar{display:none}.comp-gallery-img{object-fit:cover;border-radius:12px;flex-shrink:0;width:250px;height:160px}.btn-primary{background-color:var(--heading-color);color:#fff;cursor:pointer;border:none;border-radius:30px;align-items:center;gap:.5rem;padding:.8rem 1.5rem;font-size:.95rem;font-weight:700;text-decoration:none;transition:background-color .3s;display:inline-flex}.btn-primary:hover{background-color:var(--accent-color);color:#fff}.skills-grid{scrollbar-width:none;grid-template-rows:repeat(2,auto);grid-auto-flow:column;gap:1.5rem;padding-bottom:2rem;display:grid;overflow-x:auto}.skills-grid::-webkit-scrollbar{display:none}.skill-card{cursor:default;color:#111;background-color:#0000;border:2px solid #111;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;width:130px;height:130px;transition:all .3s;display:flex}.skill-card:hover{background-color:var(--hover-color);border-color:var(--hover-color);color:#fff;transform:translateY(-3px);box-shadow:0 10px 20px #0000001a}.skill-icon{margin-bottom:1rem}.skill-name{text-align:center;padding:0 .5rem;font-size:.85rem;font-weight:700}@media (width<=900px){.projects-grid{grid-template-columns:1fr}}.section-title strong{text-align:center;color:var(--heading-color);margin-bottom:4rem;font-size:2.5rem;font-weight:800}.section-title{text-align:center;color:var(--heading-color);margin-bottom:4rem;font-size:2.5rem;font-weight:400}.timeline-container{flex-direction:column;max-width:800px;margin:0 auto;display:flex}.timeline-item{min-height:150px;display:flex}.timeline-content{text-align:right;flex:1;padding-top:.5rem;padding-right:3rem}.timeline-title{color:var(--accent-color);margin-bottom:.5rem;font-size:1.5rem;font-weight:800}.timeline-subtitle{color:var(--accent-color);margin-bottom:.5rem;font-weight:500}.timeline-description{color:var(--text-secondary);font-size:.9rem}.timeline-separator{flex-direction:column;align-items:center;margin:0 1rem;display:flex}.timeline-dot{background-color:var(--timeline-dot);border-radius:50%;width:12px;height:12px;margin-top:1rem}.timeline-line-vertical{background-color:var(--timeline-line);flex-grow:1;width:2px;margin-top:.5rem}.timeline-year{flex:1;padding-top:.5rem;padding-left:3rem}.year-text{color:#888;font-size:1.2rem;font-weight:700}.timeline-item:nth-child(2n) .timeline-content{text-align:left;order:3;padding-left:3rem;padding-right:0}.timeline-item:nth-child(2n) .timeline-separator{order:2}.timeline-item:nth-child(2n) .timeline-year{order:1;justify-content:flex-end;padding-left:0;padding-right:3rem;display:flex}.timeline-container.timeline-left-align .timeline-item{flex-direction:row!important}.timeline-container.timeline-left-align .timeline-content{text-align:left!important;order:3!important;padding-left:3rem!important;padding-right:0!important}.timeline-container.timeline-left-align .timeline-separator{order:1!important}.timeline-container.timeline-left-align .timeline-year{order:2!important;flex:unset!important;justify-content:flex-start!important;min-width:120px!important;padding-left:1.5rem!important;padding-right:0!important}.others-page{padding-bottom:4rem}.subsection-title{text-align:center;color:var(--heading-color);align-items:center;margin-bottom:3rem;font-size:2rem;font-weight:800;display:flex}.postcard-grid{flex-wrap:wrap;justify-content:center;gap:3rem;display:flex}.postcard{cursor:pointer;background:#fff;border-radius:4px;width:280px;padding:15px 15px 40px;transition:transform .3s,box-shadow .3s;box-shadow:0 10px 30px #0000001a}.postcard:hover{z-index:10;box-shadow:0 15px 40px #00000026;transform:scale(1.05)rotate(0)!important}.postcard-img{background-color:#eee;border-radius:2px;width:100%;height:200px;margin-bottom:15px}.postcard-caption{color:#333;flex-direction:column;align-items:center;font-family:inherit;display:flex}.postcard-caption strong{font-size:1.1rem}.postcard-caption span{color:#888;margin-top:5px;font-size:.85rem}.content-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:3rem;display:grid}.content-card{background:var(--card-bg);border-radius:24px;flex-direction:column;padding:3rem;transition:transform .3s;display:flex;box-shadow:0 10px 40px #0000000a}.content-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #00000014}.content-icon{margin-bottom:1.5rem;display:inline-flex}.yt-icon{color:red}.red-icon{color:#e60012}.content-card h3{color:var(--heading-color);margin-bottom:1rem;font-size:1.8rem;font-weight:800}.content-card p{color:var(--text-secondary);margin-bottom:2rem;font-size:1.05rem;line-height:1.6}.playlist-card{background:var(--card-bg);border-radius:24px;align-items:center;gap:3rem;padding:3rem;transition:transform .3s;display:flex;box-shadow:0 10px 40px #0000000a}.playlist-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #00000014}.cd-container{background:conic-gradient(#333,#555,#333,#111,#333);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:150px;height:150px;animation:4s linear infinite spin;display:flex;position:relative;box-shadow:0 8px 20px #0000004d,inset 0 0 10px #fff3}.cd-center{background:var(--bg-color);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative;box-shadow:inset 0 2px 5px #00000080}.cd-center:after{content:"";background:#222;border-radius:50%;width:12px;height:12px}.cd-grooves{border:1px solid #ffffff1a;border-radius:50%;position:absolute;top:10%;right:10%;bottom:10%;left:10%;box-shadow:inset 0 0 20px #ffffff0d}@keyframes spin{to{transform:rotate(360deg)}}.playlist-info h3{color:var(--heading-color);margin-bottom:.5rem;font-size:1.8rem;font-weight:800}.playlist-info p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.05rem;line-height:1.6}.contacts-page{padding-top:2rem;padding-bottom:6rem}.contacts-split{justify-content:space-between;align-items:center;gap:4rem;margin-top:4rem;display:flex}.contacts-form-section{flex:1;max-width:500px}.contact-form{flex-direction:column;gap:1.5rem;display:flex}.form-input,.form-textarea{border:2px solid var(--heading-color);background:0 0;border-radius:4px;outline:none;width:100%;padding:1.2rem;font-family:inherit;font-size:1rem;transition:border-color .3s}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-secondary);font-weight:500}.form-input:focus,.form-textarea:focus{border-color:var(--accent-color)}.form-textarea{resize:vertical;min-height:140px}.form-actions{align-items:center;gap:1.5rem;margin-top:.5rem;display:flex}.btn-submit{background-color:var(--heading-color);color:#fff;cursor:pointer;border:none;border-radius:4px;padding:1.2rem 2rem;font-size:1rem;font-weight:800;transition:background-color .3s}.btn-submit:hover{background-color:var(--accent-color)}.social-squares{gap:1rem;display:flex}.social-square{border:2px solid var(--heading-color);width:52px;height:52px;color:var(--heading-color);border-radius:4px;justify-content:center;align-items:center;transition:all .3s;display:flex}.social-square:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.contacts-text-section{flex:1}.contacts-heading{color:var(--heading-color);margin-bottom:2rem;font-size:4.5rem;font-weight:900;line-height:1.1}.outline-text-form{color:#0000;-webkit-text-stroke:2px var(--heading-color);font-family:inherit}.contacts-description{color:var(--text-secondary);max-width:450px;font-size:1.1rem;line-height:1.6}@media (width<=900px){.playlist-card{text-align:center;flex-direction:column;gap:2rem}.playlist-info{flex-direction:column;align-items:center;display:flex}.intro-section{text-align:center;flex-direction:column}.intro-text{margin:0 auto 2rem}.social-links{justify-content:center}.timeline-item,.timeline-item:nth-child(2n){flex-direction:row}.timeline-content,.timeline-item:nth-child(2n) .timeline-content{text-align:left;order:3;padding-left:3rem;padding-right:0}.timeline-separator,.timeline-item:nth-child(2n) .timeline-separator{order:1}.timeline-year,.timeline-item:nth-child(2n) .timeline-year{order:2;flex:unset;justify-content:flex-start;min-width:100px;padding-left:1rem;padding-right:0}.contacts-split{flex-direction:column-reverse}.contacts-text-section{text-align:center;margin-bottom:2rem}.contacts-heading{font-size:3.5rem}.contacts-description{margin:0 auto}.contacts-form-section{width:100%;max-width:100%}.form-actions{flex-direction:column;align-items:stretch}.social-squares{justify-content:center}}.reveal{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(28px)}.reveal-visible{opacity:1;transform:translateY(0)}.guestbook-section{flex-direction:column;gap:2rem;margin-top:2rem;padding-top:2rem;display:flex}.guestbook-title{color:var(--heading-color);font-size:1.8rem;font-weight:800}.typewriter-display{background:#f0ede6;border-radius:12px;flex-direction:column;gap:.5rem;min-height:80px;padding:1.5rem 2rem;font-family:Courier New,monospace;font-size:1.2rem;line-height:1.6;display:flex}.typewriter-text{color:#111}.typewriter-cursor{color:#111;margin-left:1px;animation:.7s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.typewriter-from{color:#888;font-family:Inter,sans-serif;font-size:.85rem;font-style:italic}.typewriter-placeholder{color:#aaa;font-style:italic}.guestbook-form{flex-direction:column;gap:1rem;max-width:560px;display:flex}.guestbook-input{max-width:280px}.guestbook-textarea-wrap{position:relative}.guestbook-textarea{resize:none;width:100%}.guestbook-count{color:#aaa;font-size:.75rem;position:absolute;bottom:.6rem;right:.8rem}.guestbook-thanks{color:#555;font-size:1rem;font-style:italic}.certs-grid{flex-direction:column;gap:1rem;max-width:800px;margin:0 auto;display:flex}.cert-card{background:var(--card-bg);color:inherit;border:1px solid #0000;border-radius:16px;align-items:center;gap:1.5rem;padding:1.5rem 2rem;text-decoration:none;transition:transform .2s,box-shadow .2s;display:flex}.cert-card:hover{border-color:var(--accent-color);color:inherit;transform:translateY(-3px);box-shadow:0 8px 24px #426bc21f}.cert-icon{flex-shrink:0;font-size:2rem}.cert-info{flex-direction:column;gap:.25rem;display:flex}.cert-title{color:var(--heading-color);font-size:1rem;font-weight:700}.cert-issuer{color:var(--accent-color);font-size:.9rem;font-weight:500}.cert-date{color:var(--text-secondary);font-size:.8rem}.comp-gallery-masonry{columns:2;column-gap:.75rem;margin-top:1rem;margin-bottom:1.5rem}.comp-gallery-masonry-img{object-fit:cover;break-inside:avoid;border-radius:10px;width:100%;margin-bottom:.75rem;transition:transform .2s;display:block}.comp-gallery-masonry-img:hover{transform:scale(1.02)}.travel-country-pills{flex-wrap:wrap;gap:.75rem;margin-bottom:3rem;display:flex}.travel-pill{border:2px solid var(--heading-color);color:var(--heading-color);cursor:pointer;background:0 0;border-radius:999px;padding:.5rem 1.4rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s}.travel-pill:hover{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.travel-pill--active{background:var(--heading-color);color:#fff}.travel-carousel-wrap{flex-direction:column;align-items:center;gap:2.5rem;display:flex}.travel-carousel-stage{justify-content:center;align-items:center;width:100%;height:472px;display:flex;position:relative}.travel-carousel-img{object-fit:cover;-webkit-user-select:none;user-select:none;pointer-events:none;border-radius:20px;width:320px;height:430px;display:block;box-shadow:0 20px 60px #0003}.travel-carousel-nav{gap:4rem;display:flex}.travel-nav-btn{border:2px solid var(--heading-color);width:48px;height:48px;color:var(--heading-color);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.travel-nav-btn:hover{background:var(--heading-color);color:#fff}@media (width<=600px){.travel-carousel-img{width:354px;height:472px}.travel-carousel-stage{height:320px}}.dock-outer{z-index:1000;pointer-events:none;justify-content:center;width:100%;display:flex;position:fixed;bottom:0;left:0}.dock-panel{-webkit-backdrop-filter:blur(20px)saturate(180%);pointer-events:auto;background-color:#ffffff4d;border-radius:1rem;align-items:flex-end;gap:1rem;width:fit-content;margin-bottom:2rem;padding:.75rem 1rem;display:flex;box-shadow:0 10px 40px #00000026}.dock-item{cursor:pointer;color:#1a237e;background-color:#0000;border-radius:12px;outline:none;justify-content:center;align-items:center;width:50px;height:50px;transition:all .3s;display:inline-flex;position:relative}.dock-item:hover{color:#fff;background-color:#426bc2;border-color:#426bc2;transform:scale(1.15)translateY(-8px)}.dock-icon{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.dock-svg{stroke-width:2px;width:55%;height:55%;color:inherit}.dock-label{white-space:nowrap;color:#fff;letter-spacing:.5px;pointer-events:none;opacity:0;visibility:hidden;background-color:#122c4f;border:1px solid #122c4f;border-radius:6px;width:fit-content;padding:.3rem .75rem;font-size:.8rem;font-weight:500;transition:all .2s cubic-bezier(.25,1,.5,1);position:absolute;top:-2.8rem;left:50%;transform:translate(-50%)translateY(10px);box-shadow:0 4px 12px #0003}.dock-item:hover .dock-label{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)}.lanyard-wrapper{z-index:0;transform-origin:50%;justify-content:center;align-items:center;width:100%;height:80vh;display:flex;position:relative;transform:scale(1)}.text-type{white-space:pre-wrap;display:inline-block}.text-type__cursor{opacity:1;margin-left:.15rem;display:inline-block}.text-type__cursor--hidden{display:none}.logoloop{--logoloop-gap:32px;--logoloop-logoHeight:28px;--logoloop-fadeColorAuto:#faf9f6;position:relative}.logoloop--vertical{height:100%;display:inline-block}.logoloop--scale-hover{padding-top:calc(var(--logoloop-logoHeight) * .1);padding-bottom:calc(var(--logoloop-logoHeight) * .1)}@media (prefers-color-scheme:dark){.logoloop{--logoloop-fadeColorAuto:#0b0b0b}}.logoloop__track{will-change:transform;-webkit-user-select:none;user-select:none;z-index:0;width:max-content;display:flex;position:relative}.logoloop--vertical .logoloop__track{flex-direction:column;width:100%;height:max-content}.logoloop__list{align-items:center;margin:0;padding:0;list-style-type:none;display:flex}.logoloop--vertical .logoloop__list{flex-direction:column}.logoloop__item{margin-right:var(--logoloop-gap);font-size:var(--logoloop-logoHeight);flex:none;line-height:1}.logoloop--vertical .logoloop__item{margin-right:0;margin-bottom:var(--logoloop-gap)}.logoloop__item:last-child{margin-right:var(--logoloop-gap)}.logoloop--vertical .logoloop__item:last-child{margin-right:0;margin-bottom:var(--logoloop-gap)}.logoloop__node{align-items:center;display:inline-flex}.logoloop__item img{height:var(--logoloop-logoHeight);object-fit:contain;width:auto;image-rendering:-webkit-optimize-contrast;-webkit-user-drag:none;pointer-events:none;transition:transform .3s cubic-bezier(.4,0,.2,1);display:block}.logoloop--scale-hover .logoloop__item{overflow:visible}.logoloop--scale-hover .logoloop__item:hover img,.logoloop--scale-hover .logoloop__item:hover .logoloop__node{transform-origin:50%;transform:scale(1.2)}.logoloop--scale-hover .logoloop__node{transition:transform .3s cubic-bezier(.4,0,.2,1)}.logoloop__link{border-radius:4px;align-items:center;text-decoration:none;transition:opacity .2s;display:inline-flex}.logoloop__link:hover{opacity:.8}.logoloop__link:focus-visible{outline-offset:2px;outline:2px solid}.logoloop--fade:before,.logoloop--fade:after{content:"";pointer-events:none;z-index:10;width:clamp(32px,12%,180px);position:absolute;top:0;bottom:0}.logoloop--fade:before{background:linear-gradient(to right,var(--logoloop-fadeColor,var(--logoloop-fadeColorAuto)) 0%,#0000 100%);left:0}.logoloop--fade:after{background:linear-gradient(to left,var(--logoloop-fadeColor,var(--logoloop-fadeColorAuto)) 0%,#0000 100%);right:0}.logoloop--vertical.logoloop--fade:before,.logoloop--vertical.logoloop--fade:after{width:100%;height:clamp(24px,8%,120px);left:0;right:0}.logoloop--vertical.logoloop--fade:before{background:linear-gradient(to bottom,var(--logoloop-fadeColor,var(--logoloop-fadeColorAuto)) 0%,#0000 100%);top:0;bottom:auto}.logoloop--vertical.logoloop--fade:after{background:linear-gradient(to top,var(--logoloop-fadeColor,var(--logoloop-fadeColorAuto)) 0%,#0000 100%);top:auto;bottom:0}@media (prefers-reduced-motion:reduce){.logoloop__track{transform:translate(0)!important}.logoloop__item img,.logoloop__node{transition:none!important}}.tw-wrapper{justify-content:center;padding:2rem 0 4rem;display:flex}.tw-machine{background:#122c4f;border-radius:24px 24px 32px 32px;width:100%;max-width:680px;padding:0 2rem 2.5rem;box-shadow:0 20px 60px #0000002e,inset 0 2px #ffffff1a,inset 0 -4px #0003}.tw-paper-section{background:#0d1f38;border-radius:12px 12px 0 0;flex-direction:column;gap:.5rem;margin:0 -2rem;padding:1rem 1.5rem;display:flex}.tw-roller-bar{background:linear-gradient(#a4a0db,#d3d4ec,#a4a0db);border-radius:6px;height:18px;box-shadow:0 3px 8px #0006}.tw-paper{background:#faf8f0;border-radius:4px;min-height:120px;padding:1.2rem 1.5rem 2rem;position:relative;overflow:hidden;box-shadow:inset 0 2px 8px #00000014}.tw-paper-lines{pointer-events:none;flex-direction:column;justify-content:space-evenly;padding:1rem 0;display:flex;position:absolute;top:0;right:0;bottom:0;left:0}.tw-line{background:#426bc233;width:100%;height:1px}.tw-typed-text{color:#122c4f;z-index:1;word-break:break-word;min-height:2rem;font-family:Courier New,Courier,monospace;font-size:1.1rem;line-height:1.8;position:relative}.tw-caret{color:#9cb5eb;font-weight:300;animation:.6s step-end infinite tw-blink;display:inline-block}@keyframes tw-blink{0%,to{opacity:1}50%{opacity:0}}.tw-sent{color:#426bc2;font-style:italic}.tw-char-count{color:#bbb;font-family:Courier New,monospace;font-size:.7rem;position:absolute;bottom:.4rem;right:.8rem}.tw-keyboard{background:#4c6988;border-radius:16px;flex-direction:column;gap:1rem;margin-top:1rem;padding:1.8rem 1.2rem 1.5rem;display:flex;box-shadow:inset 0 4px 12px #0000004d,0 4px #0003}.tw-row{justify-content:center;gap:.45rem;display:flex}.tw-key{color:#122c4f;cursor:pointer;-webkit-user-select:none;user-select:none;background:radial-gradient(circle at 35% 35%,#f5f3ee,#ddd8cc);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-family:Courier New,monospace;font-size:.85rem;font-weight:700;transition:transform 80ms,box-shadow 80ms;display:flex;box-shadow:0 4px #8a9bb5,0 5px 6px #00000059}.tw-key:hover{color:#426bc2;background:radial-gradient(circle at 35% 35%,#e8eaf6,#c5cce8)}.tw-key--pressed{transform:translateY(3px);box-shadow:0 1px #8a9bb5,0 2px 3px #0000004d}.tw-key--wide{border-radius:22px;width:60px;font-size:.75rem}.tw-key--space{letter-spacing:.1em;border-radius:22px;width:220px;height:42px;font-size:.8rem}.tw-send-row{justify-content:center;margin-top:.8rem;display:flex}.tw-send-btn{color:#fff;cursor:pointer;background:#426bc2;border:none;border-radius:30px;padding:.7rem 2rem;font-family:Muli,Inter,sans-serif;font-size:.95rem;font-weight:700;transition:background .2s,transform .1s;box-shadow:0 4px #122c4f}.tw-send-btn:hover{background:#122c4f;transform:translateY(-1px)}.tw-send-btn:active{transform:translateY(2px);box-shadow:0 2px #122c4f}.tw-name-prompt{align-items:center;gap:.8rem;display:flex}.tw-name-input{color:#122c4f;background:#f5f3ee;border:2px solid #426bc2;border-radius:30px;outline:none;width:200px;padding:.65rem 1rem;font-family:Muli,Inter,sans-serif;font-size:.9rem}.tw-name-input:focus{border-color:#122c4f}@media (width<=600px){.tw-key{width:34px;height:34px;font-size:.7rem}.tw-key--wide{width:46px}.tw-key--space{width:160px}.tw-row{gap:.3rem}.tw-keyboard{padding:1.2rem .6rem 1rem}}.envelope-container{flex-direction:column;justify-content:center;align-items:center;min-height:500px;padding:2rem;display:flex}.envelope-wrapper{z-index:0;background-color:#3760c9;justify-content:center;width:400px;height:240px;transition:transform .3s;display:flex;position:relative}.envelope-wrapper:not(.envelope-wrapper--open){cursor:pointer}.envelope-wrapper:not(.envelope-wrapper--open):hover{transform:scale(1.05)}.envelope-lid{transform-origin:top;border-bottom:120px solid #0000;border-left:200px solid #0000;border-right:200px solid #0000;width:100%;height:100%;transition:transform .25s linear;position:absolute;top:0;left:0}.envelope-lid.one{z-index:3;border-top:120px solid #658ced;transition-delay:.75s;transform:rotateX(0)}.envelope-lid.two{z-index:1;border-top:120px solid #3760c9;transition-delay:.5s;transform:rotateX(90deg)}.envelope-body{z-index:3;border-top:120px solid #0000;border-bottom:120px solid #c4dff0;border-left:200px solid #a4d4f2;border-right:200px solid #c4dff0;width:100%;height:100%;position:absolute;top:0;left:0}.envelope-letter{z-index:2;background-color:#faf8f0;border-radius:15px;flex-direction:column;justify-content:center;width:80%;min-height:80%;padding:1.5rem 2rem;transition:all 2s;display:flex;position:absolute;top:0;box-shadow:0 4px 12px #0000001a}.envelope-wrapper--open .envelope-lid.one{transition-delay:0s;transform:rotateX(90deg)}.envelope-wrapper--open .envelope-lid.two{transition-delay:.5s;transform:rotateX(180deg)}.envelope-wrapper--open .envelope-letter{transition-delay:.5s;transform:translateY(-140px)}.letter-content{color:#122c4f;font-family:Courier New,Courier,monospace}.letter-content p:first-child{word-wrap:break-word;margin:0;font-size:1.1rem;line-height:1.7}.letter-content p:last-child{text-align:right;opacity:.7;margin-top:1.5rem;font-size:1rem;font-style:italic}.envelope-label{text-align:center;color:#fff;z-index:4;pointer-events:none;font-family:Muli,Inter,sans-serif;animation:2s ease-in-out infinite envelope-pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.envelope-label span{margin-bottom:.5rem;font-size:2rem;display:block}@keyframes envelope-pulse{0%,to{transform:translate(-50%,-50%)scale(1)}50%{transform:translate(-50%,-50%)scale(1.1)}}.envelope-hint{text-align:center;opacity:0;color:#426bc2;margin-top:2rem;font-family:Muli,Inter,sans-serif;font-size:.95rem;animation:.5s ease-in .5s forwards fade-in}@keyframes fade-in{to{opacity:.7}}@media (width<=600px){.envelope-container{min-height:450px}.envelope-wrapper{width:320px;height:200px}.envelope-lid{border-bottom:100px solid #0000;border-left:160px solid #0000;border-right:160px solid #0000}.envelope-lid.one{border-top:100px solid #658ced}.envelope-lid.two{border-top:100px solid #3760c9}.envelope-body{border-top:100px solid #0000;border-bottom:100px solid #c4dff0;border-left:160px solid #a4d4f2;border-right:160px solid #c4dff0}.envelope-wrapper--open .envelope-letter{transform:translateY(-110px)}.letter-content p:first-child{font-size:.95rem}.envelope-label span{font-size:1.5rem}}.logoloop__track--css{animation-name:logoloop-scroll;animation-timing-function:linear;animation-iteration-count:infinite;will-change:transform}.logoloop:hover .logoloop__track--css,body.is-scrolling .logoloop__track--css{animation-play-state:paused}.dock-panel{-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background-color:#fffffff2!important}.lang-toggle{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fffffff2}@keyframes logoloop-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (prefers-reduced-motion: reduce){.logoloop__track--css{animation:none}}.lang-toggle{position:fixed;top:1.25rem;right:1.5rem;z-index:1100;display:flex;align-items:center;gap:.25rem;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:999px;padding:.3rem .6rem;box-shadow:0 4px 16px #00000014}.lang-toggle button{border:none;background:none;cursor:pointer;font-weight:700;font-size:.85rem;color:var(--text-secondary);padding:.15rem .35rem;border-radius:6px;transition:color .2s}.lang-toggle button.active{color:var(--accent-color)}.lang-sep{color:#ccc}.scholar-highlight{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:var(--card-bg);border-radius:1.5rem;padding:2.5rem 3rem;box-shadow:0 10px 40px #00000012;text-align:center}.scholar-number{font-family:Europa,Inter,sans-serif;font-size:4.5rem;font-weight:800;line-height:1;color:var(--accent-color)}.scholar-label{font-size:1.1rem;font-weight:600;color:var(--heading-color)}.scholar-sub{font-size:.9rem;color:var(--text-secondary);max-width:420px}.scholar-link{margin-top:.75rem;display:inline-flex;align-items:center;gap:.4rem;color:var(--accent-color);font-weight:600;text-decoration:none}.modal-hero-img{width:100%;height:auto;border-radius:.75rem;margin-bottom:1.25rem;border:1px solid #ececec;display:block}.paper-venue{font-size:.8rem;font-weight:700;color:var(--accent-color);margin-top:.5rem}.paper-authors{font-size:.85rem;color:var(--text-secondary);margin-top:.35rem;line-height:1.5}.jmp-badge{display:inline-block;background:var(--heading-color);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.5px;padding:.2rem .6rem;border-radius:999px;margin-bottom:.5rem}.project-card.jmp{outline:2px solid var(--accent-color);outline-offset:2px}.modal-venue{font-size:.85rem;font-weight:700;color:var(--accent-color);margin-bottom:.25rem}.modal-authors{font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem;line-height:1.6}.modal-presented{margin-top:1rem;font-size:.85rem;color:var(--text-secondary)}.modal-presented strong{color:var(--heading-color)}.teach-block{background:var(--card-bg);border-radius:1.25rem;padding:2rem 2.5rem;box-shadow:0 10px 40px #0000000a;margin-bottom:2rem}.teach-row{display:flex;justify-content:space-between;gap:1.5rem;padding:.85rem 0;border-bottom:1px solid #eee}.teach-row:last-child{border-bottom:none}.teach-row .teach-when{color:var(--text-secondary);font-style:italic;white-space:nowrap;font-size:.9rem}.interest-pills{display:flex;flex-wrap:wrap;gap:.75rem}.interest-pill{border:2px solid var(--heading-color);color:var(--heading-color);border-radius:999px;padding:.4rem 1.1rem;font-weight:600;font-size:.95rem}.reference-card{background:var(--card-bg);border-radius:1.25rem;padding:1.5rem 1.75rem;box-shadow:0 10px 40px #0000000a;margin-top:2rem}.reference-name{font-weight:700;color:var(--heading-color)}.reference-role{font-size:.9rem;color:var(--text-secondary);margin-top:.25rem}.interests-block{display:grid;grid-template-columns:160px 1fr;gap:1rem 1.5rem;max-width:820px;margin:2.5rem auto 0}.interests-key{font-weight:700;color:var(--heading-color)}.interests-val{color:var(--text-secondary);line-height:1.6}@media (max-width: 640px){.interests-block{grid-template-columns:1fr;gap:.25rem 0}.interests-key{margin-top:1rem}}
