*{margin:0;padding:0;box-sizing:border-box}:root{font-family:DM Sans,Segoe UI,system-ui,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #08080b;--bg-elevated: #0e0e12;--bg-card: #121218;--border: #222228;--border-light: #2a2a32;--text: #f4f4f5;--text-muted: #a1a1aa;--accent: #06b6d4;--accent-light: #22d3ee;--accent-glow: rgba(6, 182, 212, .4);--gradient-accent: linear-gradient(135deg, #06b6d4, #22d3ee, #67e8f9);--shadow-glow: 0 0 40px rgba(6, 182, 212, .15);--shadow-card: 0 4px 24px rgba(0, 0, 0, .4);--radius: 12px;--radius-lg: 20px;--transition: .35s cubic-bezier(.4, 0, .2, 1)}body{margin:0;min-width:320px;min-height:100vh;min-height:100dvh;background:var(--bg);color:var(--text);position:relative;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none;z-index:9999}::selection{background:#06b6d459;color:var(--text)}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:Outfit,sans-serif}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}html{scroll-behavior:smooth}body{font-family:DM Sans,Segoe UI,system-ui,sans-serif;line-height:1.6;color:var(--text);overflow-x:hidden;background:var(--bg)}.App{min-height:100vh;background:var(--bg)}.scroll-progress{position:fixed;top:env(safe-area-inset-top);left:0;height:3px;background:var(--gradient-accent);z-index:1001;transition:width .1s ease-out;box-shadow:0 0 12px var(--accent-glow)}main{padding-top:80px}.container{width:100%;max-width:1200px;margin-left:auto;margin-right:auto;padding:0 20px;box-sizing:border-box}@media(max-width:768px){main{padding-top:78px}.container{padding:0 16px}}@media(max-width:480px){main{padding-top:72px}.container{padding:0 12px}}.section-title{font-family:Outfit,sans-serif;font-size:2.5rem;font-weight:700;letter-spacing:-.02em;text-align:center;margin-bottom:1rem;color:var(--text);position:relative;display:inline-block;width:100%}.section-title:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:64px;height:4px;background:var(--gradient-accent);border-radius:2px;box-shadow:0 0 16px var(--accent-glow)}.section-subtitle{text-align:center;font-size:1.15rem;color:var(--text-muted);margin:2rem auto 3rem;max-width:560px}.btn{padding:14px 32px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition);text-decoration:none;display:inline-block;position:relative;overflow:hidden}.btn-primary{background:var(--gradient-accent);color:#08080b;box-shadow:0 4px 20px #06b6d44d}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transition:left .6s ease}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 36px #06b6d473}.btn-primary:hover:before{left:100%}.btn-secondary{background:transparent;color:var(--accent-light);border:2px solid var(--accent)}.btn-secondary:hover{background:#06b6d41f;color:var(--accent-light);border-color:var(--accent-light);transform:translateY(-3px);box-shadow:0 8px 24px #06b6d433}@media(max-width:768px){.section-title{font-size:2rem}.section-subtitle{font-size:1rem;margin:1.5rem auto 2rem}}@media(max-width:480px){.section-title{font-size:1.65rem;margin-bottom:.75rem}.section-title:after{width:48px;height:3px}.section-subtitle{font-size:.95rem;margin:1rem auto 1.5rem}.btn{padding:12px 24px;font-size:.95rem}}.navbar{position:fixed;top:0;left:0;right:0;padding-top:env(safe-area-inset-top);background:linear-gradient(180deg,#08080beb,#08080bc7);backdrop-filter:blur(24px) saturate(1.1);-webkit-backdrop-filter:blur(24px) saturate(1.1);border-bottom:1px solid transparent;z-index:1000;transition:background .35s ease,border-color .35s ease,box-shadow .35s ease;box-shadow:0 1px #ffffff0a}.navbar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(6,182,212,.25) 50%,transparent 100%);opacity:0;transition:opacity .35s ease;pointer-events:none}.navbar-scrolled{background:linear-gradient(180deg,#0e0e12fa,#08080bf2);border-bottom-color:var(--border);box-shadow:0 4px 28px #0006,0 1px #ffffff0d}.navbar-scrolled:before{opacity:1}.navbar-container{width:100%;max-width:100%;margin:0;padding:.5rem 2.5rem .5rem 0;display:flex;justify-content:space-between;align-items:center;position:relative;box-sizing:border-box}.navbar-burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;padding:10px;background:#06b6d414;border:1px solid rgba(6,182,212,.25);border-radius:8px;cursor:pointer;transition:background .25s ease,border-color .25s ease,transform .2s ease}.navbar-burger:hover{background:#06b6d426;border-color:#06b6d473}.navbar-burger span{display:block;width:20px;height:2px;background:var(--accent-light);border-radius:1px;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .25s ease}.navbar-menu-open .navbar-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navbar-menu-open .navbar-burger span:nth-child(2){opacity:0;transform:scaleX(0)}.navbar-menu-open .navbar-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navbar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:998;-webkit-tap-highlight-color:transparent}.navbar-logo{cursor:pointer;transition:transform .3s ease,filter .3s ease;display:flex;align-items:center;background:transparent;margin-right:2.5rem;flex-shrink:0}.navbar-logo:hover{transform:scale(1.03);filter:drop-shadow(0 0 12px rgba(6,182,212,.2))}.navbar-logo img{height:92px;width:auto;max-width:220px;display:block;object-fit:contain;object-position:left center;background:transparent}.navbar-right{display:flex;align-items:center;gap:1.25rem;flex-shrink:0;flex-wrap:nowrap}.navbar-menu{display:flex;list-style:none;gap:3rem;align-items:center;flex-wrap:wrap}.navbar-link{background:none;border:none;font-size:1.3rem;letter-spacing:.02em;color:var(--text-muted);cursor:pointer;padding:.5rem 1.25rem;border-radius:8px;transition:color .25s ease,background .25s ease;position:relative;font-weight:500}.navbar-link:before{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--accent-light);border-radius:1px;transform:translate(-50%);transition:width .25s ease}.navbar-link:hover{color:var(--accent-light);background:#06b6d40f}.navbar-link:hover:before{width:28px}.navbar-link.active:before{display:none}.navbar-link.active{color:var(--accent-light);font-weight:600}.navbar-link.active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:32px;height:2px;background:var(--gradient-accent);border-radius:1px;box-shadow:0 0 12px var(--accent-glow)}.navbar-lang{display:flex;gap:2px;margin-left:.5rem;padding:.25rem .25rem .25rem 1rem;border-left:1px solid var(--border);background:#ffffff08;border-radius:8px}.navbar-lang .lang-btn:first-child{border-radius:5px 0 0 5px}.navbar-lang .lang-btn:last-child{border-radius:0 5px 5px 0}.lang-btn{background:transparent;border:none;color:var(--text-muted);font-size:.7rem;font-weight:600;letter-spacing:.05em;padding:.4rem .65rem;border-radius:4px;cursor:pointer;transition:color .2s ease,background .2s ease}.lang-btn:hover{color:var(--accent-light)}.lang-btn.active{color:var(--text);background:#06b6d433;box-shadow:0 0 0 1px #06b6d44d}@media(max-width:992px){.navbar-burger{display:flex;order:1}.navbar-right{position:fixed;top:0;right:0;width:min(320px,100vw);height:100vh;height:100dvh;background:linear-gradient(180deg,var(--bg-elevated) 0%,var(--bg-card) 100%);border-left:1px solid var(--border);flex-direction:column;justify-content:flex-start;align-items:stretch;padding:5rem 1.5rem 2rem;gap:0;z-index:999;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s ease;box-shadow:-12px 0 40px #00000080;overflow-y:auto}.navbar-menu-open .navbar-right{transform:translate(0)}.navbar-menu-open .navbar-backdrop{display:block}.navbar-menu{flex-direction:column;align-items:stretch;gap:0;margin-bottom:1.5rem}.navbar-menu li{border-bottom:1px solid var(--border)}.navbar-link{display:block;width:100%;text-align:left;padding:1rem .75rem;font-size:1rem;border-radius:0}.navbar-link:before,.navbar-link:after{display:none}.navbar-link.active:after{display:none}.navbar-lang{border-left:none;margin-left:0;padding:1rem .5rem .5rem;margin-top:.5rem;border-top:1px solid var(--border);justify-content:center;gap:4px}.lang-btn{padding:.5rem .75rem;font-size:.8rem}}@media(max-width:768px){.navbar-container{padding:.75rem 16px}.navbar-logo img{height:65px;width:auto}.navbar-right{width:min(280px,100vw);padding:4.5rem 1.25rem 1.5rem}}@media(max-width:480px){.navbar-container{padding:.6rem 12px}.navbar-logo img{height:52px;width:auto}.navbar-burger{width:40px;height:40px}}.home{min-height:100vh;display:flex;align-items:center;background:var(--bg);color:var(--text);padding:2rem 0;position:relative;overflow:hidden}.home-glow{position:fixed;width:480px;height:480px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(6,182,212,.2) 0%,rgba(6,182,212,.06) 40%,transparent 68%);pointer-events:none;z-index:0;transition:opacity .3s ease}.home:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse 100% 60% at 30% 10%,rgba(6,182,212,.2),transparent 50%),radial-gradient(ellipse 80% 50% at 70% 80%,rgba(6,182,212,.08),transparent 45%),radial-gradient(ellipse 60% 40% at 50% -10%,rgba(34,211,238,.12),transparent 50%),url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2306b6d4' fill-opacity='0.025'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}.home-container{width:100%;max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1.15fr .85fr;gap:3.5rem;align-items:center;position:relative;z-index:1;box-sizing:border-box}.home-content{max-width:540px}.home-content .home-title{animation:fadeInUp .8s cubic-bezier(.4,0,.2,1) both}.home-content .home-subtitle{animation:fadeInUp .8s cubic-bezier(.4,0,.2,1) .1s both}.home-content .home-description{animation:fadeInUp .8s cubic-bezier(.4,0,.2,1) .2s both}.home-content .home-buttons{animation:fadeInUp .8s cubic-bezier(.4,0,.2,1) .35s both}.home-title{font-size:3.5rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin-bottom:1rem}.highlight{background:linear-gradient(135deg,var(--accent-light),#67e8f9,#a5f3fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-subtitle{font-size:1.8rem;font-weight:600;margin-bottom:1.5rem;color:var(--accent-light);text-shadow:0 0 30px rgba(6,182,212,.25);min-height:1.4em}.typewriter-cursor{display:inline-block;animation:blink 1s step-end infinite;margin-left:2px}@keyframes blink{50%{opacity:0}}.home-description{font-size:1.2rem;line-height:1.8;margin-bottom:2rem;color:var(--text-muted)}.home-buttons{display:flex;gap:1rem;flex-wrap:wrap}.home-image{display:flex;justify-content:center;align-items:center;animation:fadeInRight 1s cubic-bezier(.4,0,.2,1) .2s both}.home-image .profile-placeholder{max-width:100%}.profile-placeholder{width:520px;height:520px;border-radius:50%;background:linear-gradient(160deg,var(--bg-card) 0%,rgba(18,18,24,.98) 100%);display:flex;align-items:center;justify-content:center;border:1px solid var(--border);box-shadow:0 0 0 1px #ffffff0a,0 24px 48px #00000059,0 0 80px #06b6d414,inset 0 1px #ffffff0a;overflow:hidden;position:relative;transition:transform .4s ease,box-shadow .4s ease}.profile-placeholder:hover{transform:translateY(-4px);box-shadow:0 0 0 1px #ffffff0d,0 0 80px #06b6d433,0 0 160px #06b6d41a,inset 0 1px #ffffff08}.profile-placeholder .profile-img{width:100%;height:100%;object-fit:cover;object-position:center 28%}.profile-placeholder .profile-svg,.profile-placeholder svg{width:160px;height:220px;color:var(--accent);opacity:.6}@media(max-width:968px){.home-container{grid-template-columns:1fr;text-align:center;gap:2.5rem;padding:0 1.5rem}.home-content{max-width:520px;margin:0 auto}.home-title{font-size:2.5rem}.home-subtitle{font-size:1.4rem}.home-buttons{justify-content:center}.profile-placeholder{width:420px;height:420px}.profile-placeholder .profile-svg,.profile-placeholder svg{width:130px;height:130px}}@media(max-width:480px){.home{padding:1.5rem 0}.home-container{gap:2rem;padding:0 12px}.home-title{font-size:1.85rem;margin-bottom:.75rem}.home-subtitle{font-size:1.15rem;margin-bottom:1rem}.home-description{font-size:.95rem;margin-bottom:1.5rem}.home-buttons{gap:.75rem}.profile-placeholder{width:360px;height:360px}.profile-placeholder .profile-svg,.profile-placeholder svg{width:100px;height:100px}}@media(max-width:360px){.home-title{font-size:1.6rem}.home-subtitle{font-size:1rem}.profile-placeholder{width:300px;height:300px}}.about{padding:5rem 0;background:var(--bg-elevated);position:relative}.about:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:1px;height:60px;background:linear-gradient(180deg,transparent,rgba(6,182,212,.2));pointer-events:none}.about:not(.in-view) .about-content{opacity:0;transform:translateY(24px)}.about.in-view .about-content{animation:fadeInUp .7s cubic-bezier(.4,0,.2,1) both}.about-content{max-width:800px;margin:2rem auto 0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg, 20px);padding:2.5rem 2.5rem 2.5rem 2.75rem;position:relative;overflow:hidden;box-shadow:var(--shadow-card);transition:box-shadow .4s ease,border-color .4s ease}.about-content:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gradient-accent);border-radius:3px 0 0 3px;box-shadow:0 0 20px var(--accent-glow)}.about-content:hover{border-color:#06b6d44d;box-shadow:var(--shadow-card),0 0 40px #06b6d414}.about-text{font-size:1.1rem;line-height:1.9;color:var(--text-muted)}.about-text p{margin-bottom:1.5rem}.about-text p:last-child{margin-bottom:0}.about-achievements{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border);font-size:.95rem;color:var(--text-muted)}@media(max-width:768px){.about{padding:3.5rem 0}.about-content{padding:2rem 1.75rem;margin-top:1.5rem}.about-text{font-size:1rem}}@media(max-width:480px){.about{padding:2.5rem 0}.about-content{padding:1.5rem 1.25rem;margin-top:1.25rem;border-radius:var(--radius, 12px)}.about-text{font-size:.95rem;line-height:1.75}.about-text p{margin-bottom:1.25rem}}.skills{padding:5rem 0;background:var(--bg)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-top:3rem}.skills:not(.in-view) .skills-card{opacity:0;transform:translateY(20px)}.skills.in-view .skills-card{animation:fadeInUp .55s cubic-bezier(.4,0,.2,1) both}.skills.in-view .skills-card:nth-child(1){animation-delay:.05s}.skills.in-view .skills-card:nth-child(2){animation-delay:.12s}.skills.in-view .skills-card:nth-child(3){animation-delay:.19s}.skills.in-view .skills-card:nth-child(4){animation-delay:.26s}.skills.in-view .skills-card:nth-child(5){animation-delay:.33s}.skills-card{background:var(--bg-card);border-radius:var(--radius, 12px);padding:1.5rem;border:1px solid var(--border);transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s ease,border-color .35s ease;box-shadow:0 2px 12px #0003}.skills-card:hover{border-color:#06b6d480;box-shadow:0 0 0 1px #06b6d426,0 12px 40px #06b6d41f,0 0 50px #06b6d40f;transform:translateY(-4px)}.skills-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.skills-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:1.75rem;height:1.75rem;color:#00d4ff;filter:drop-shadow(0 0 6px rgba(0,212,255,.5))}.skills-icon svg{width:100%;height:100%}.skills-card h3{font-size:1.1rem;font-weight:600;color:var(--text);margin:0}.skills-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem}.skills-list li{background:var(--bg-elevated);color:var(--accent-light);padding:.45rem .8rem;border-radius:8px;font-size:.9rem;font-weight:500;border:1px solid var(--border);transition:transform .25s ease,background .25s ease,border-color .25s ease,color .25s ease,box-shadow .25s ease}.skills-list li:hover{background:var(--accent);color:#08080b;border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px #06b6d44d}@media(max-width:768px){.skills{padding:3.5rem 0}.skills-grid{grid-template-columns:1fr;margin-top:2rem;gap:1.25rem}}@media(max-width:480px){.skills{padding:2.5rem 0}.skills-grid{margin-top:1.5rem;gap:1rem}.skills-card{padding:1.25rem}.skills-card h3{font-size:1rem}.skills-list li{padding:.35rem .6rem;font-size:.8rem}}.experience{padding:5rem 0;background:var(--bg-elevated)}.timeline{position:relative;max-width:700px;margin:3rem auto 0;padding-left:2rem}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--accent),var(--accent-light),var(--accent));border-radius:3px;box-shadow:0 0 20px var(--accent-glow)}.experience:not(.in-view) .timeline-item{opacity:0;transform:translate(-20px)}.experience.in-view .timeline-item{animation:fadeInLeft .55s cubic-bezier(.4,0,.2,1) both}.experience.in-view .timeline-item:nth-child(1){animation-delay:.06s}.experience.in-view .timeline-item:nth-child(2){animation-delay:.14s}.experience.in-view .timeline-item:nth-child(3){animation-delay:.22s}.experience.in-view .timeline-item:nth-child(4){animation-delay:.3s}.timeline-item{position:relative;padding-bottom:2.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:-2rem;top:.25rem;width:14px;height:14px;margin-left:-5.5px;background:var(--gradient-accent);border-radius:50%;border:3px solid var(--bg-elevated);box-shadow:0 0 0 2px var(--accent),0 0 20px var(--accent-glow);transition:transform .3s ease,box-shadow .3s ease}.timeline-item:hover .timeline-marker{transform:scale(1.2);box-shadow:0 0 0 2px var(--accent),0 0 28px var(--accent-glow),0 0 40px #06b6d433}.timeline-content{background:var(--bg-card);padding:1.5rem 1.75rem;border-radius:var(--radius, 12px);border:1px solid var(--border);transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease;box-shadow:0 2px 12px #0003}.timeline-content:hover{border-color:#06b6d466;box-shadow:0 0 0 1px #06b6d41a,0 12px 36px #06b6d41f,0 0 40px #06b6d40f;transform:translate(4px)}.timeline-period{display:inline-block;font-size:.85rem;font-weight:600;color:var(--accent-light);margin-bottom:.35rem}.timeline-role{font-size:1.2rem;font-weight:600;color:var(--text);margin:0 0 .75rem}.timeline-content ul{margin:0;padding-left:1.2rem;color:var(--text-muted);line-height:1.7;font-size:.95rem}.timeline-content li{margin-bottom:.4rem}.timeline-content li:last-child{margin-bottom:0}@media(max-width:768px){.experience{padding:3.5rem 0}.timeline{padding-left:1.5rem;margin-top:2rem}.timeline-marker{left:-1.5rem;margin-left:-5px;width:12px;height:12px}.timeline-content{padding:1.25rem 1.5rem}.timeline-role{font-size:1.1rem}.timeline-content ul{font-size:.9rem}}@media(max-width:480px){.experience{padding:2.5rem 0}.timeline{padding-left:1.25rem;margin-top:1.5rem}.timeline-marker{width:10px;height:10px;left:-1.25rem;margin-left:-4px}.timeline-content{padding:1rem 1.25rem}.timeline-period{font-size:.8rem}.timeline-role{font-size:1rem}.timeline-content ul{font-size:.85rem;padding-left:1rem}}.education{padding:5rem 0;background:var(--bg)}.education-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem;max-width:920px;margin-left:auto;margin-right:auto}.education:not(.in-view) .edu-block{opacity:0;transform:translateY(20px)}.education.in-view .edu-block{animation:fadeInUp .5s cubic-bezier(.4,0,.2,1) both}.education.in-view .edu-block:nth-child(1){animation-delay:.05s}.education.in-view .edu-block:nth-child(2){animation-delay:.12s}.education.in-view .edu-block:nth-child(3){animation-delay:.19s}.education.in-view .edu-block:nth-child(4){animation-delay:.26s}.edu-block{aspect-ratio:1;display:flex;flex-direction:column;background:var(--bg-card);padding:1.75rem;border-radius:var(--radius, 12px);border:1px solid var(--border);transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease;box-shadow:0 2px 12px #0003}.edu-block:hover{border-color:#06b6d459;box-shadow:0 0 0 1px #06b6d414,0 8px 28px #06b6d414;transform:translateY(-2px)}.edu-block-header{display:flex;align-items:center;gap:.8rem;margin-bottom:1.1rem;padding-bottom:.6rem;border-bottom:2px solid var(--accent);flex-shrink:0}.edu-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:1.85rem;height:1.85rem;color:#00d4ff;filter:drop-shadow(0 0 6px rgba(0,212,255,.5))}.edu-icon svg{width:100%;height:100%}.edu-block-content{flex:1;min-height:0;overflow-y:auto}.edu-block h3{font-size:1.15rem;font-weight:600;color:var(--text);margin:0}.edu-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.6rem}.edu-item{display:block;background:var(--bg-elevated);color:var(--text);padding:.55rem .9rem;border-radius:6px;font-size:.925rem;font-weight:500;border:1px solid var(--border);line-height:1.5;transition:border-color .25s ease,color .25s ease,box-shadow .25s ease}.edu-item:hover{border-color:#06b6d480;box-shadow:0 0 0 1px #06b6d426}.edu-item strong{font-weight:600;color:var(--text)}.edu-item-muted{display:block;font-size:.875rem;font-weight:400;color:var(--text-muted);margin-top:.25rem}@media(max-width:600px){.education-grid{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto;gap:1.5rem;margin-top:2rem}}@media(max-width:480px){.education{padding:2.5rem 0}.education-grid{max-width:100%;gap:1.25rem;margin-top:1.5rem}.edu-block{padding:1.35rem}.edu-block h3{font-size:1.05rem}.edu-item{padding:.45rem .75rem;font-size:.875rem}.edu-item-muted{font-size:.8rem}}.projects{padding:5rem 0;background:var(--bg-elevated)}.projects:not(.in-view) .project-card{opacity:0;transform:translateY(20px)}.projects.in-view .project-card{animation:fadeInUp .55s cubic-bezier(.4,0,.2,1) both}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:3rem}.project-card{background:var(--bg-card);border-radius:var(--radius, 12px);padding:1.5rem;border:1px solid var(--border);transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease;box-shadow:0 2px 12px #0003;display:flex;flex-direction:column}.project-card:hover{border-color:#06b6d480;box-shadow:0 0 0 1px #06b6d426,0 12px 40px #06b6d41f,0 0 50px #06b6d40f;transform:translateY(-4px)}.project-card-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.project-card-title-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;flex:1;min-width:0}.project-badge{display:inline-flex;align-items:center;padding:.25rem .6rem;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.project-badge--dev{color:var(--accent-light);background:#06b6d41f;border:1px solid rgba(6,182,212,.35);box-shadow:0 0 12px #06b6d426;animation:badgePulse 2.5s ease-in-out infinite}@keyframes badgePulse{0%,to{opacity:1;box-shadow:0 0 12px #06b6d426}50%{opacity:.9;box-shadow:0 0 18px #06b6d440}}.project-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:1.75rem;height:1.75rem;color:#00d4ff;filter:drop-shadow(0 0 6px rgba(0,212,255,.5))}.project-icon svg{width:100%;height:100%}.project-card-title-wrap h3{font-size:1.2rem;font-weight:600;color:var(--text);margin:0}.project-card-desc{color:var(--text-muted);font-size:.95rem;line-height:1.6;margin:0 0 1rem;flex:1}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.project-tag{background:var(--bg-elevated);color:var(--accent-light);padding:.35rem .7rem;border-radius:6px;font-size:.8rem;font-weight:500;border:1px solid var(--border)}.project-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--accent);font-size:.9rem;font-weight:600;text-decoration:none;transition:color .25s ease,gap .25s ease}.project-link:hover{color:var(--accent-light);gap:.65rem}.project-link--private{cursor:default;color:var(--text-muted)}.project-link--private:hover{color:var(--text-muted)}.project-link-icon{display:flex;color:inherit}.project-link-icon svg{width:1rem;height:1rem}@media(max-width:768px){.projects{padding:3.5rem 0}.projects-grid{grid-template-columns:1fr;margin-top:2rem;gap:1.25rem}}@media(max-width:480px){.projects{padding:2.5rem 0}.projects-grid{margin-top:1.5rem;gap:1rem;grid-template-columns:1fr}.project-card{padding:1.25rem}.project-card h3{font-size:1.05rem}.project-card-desc{font-size:.9rem}.project-tag{font-size:.75rem;padding:.3rem .6rem}}.contact{padding:5rem 0;background:var(--bg);border-top:1px solid var(--border);position:relative}.contact:before{content:"";position:absolute;top:0;left:0;right:0;height:200px;background:radial-gradient(ellipse 70% 100% at 50% 0%,rgba(6,182,212,.08),transparent);pointer-events:none}.contact .section-title,.contact .section-subtitle{color:var(--text)}.contact .section-subtitle{color:var(--text-muted)}.contact .section-title:after{background:linear-gradient(90deg,var(--accent),var(--accent-light))}.contact:not(.in-view) .contact-content{opacity:0;transform:translateY(24px)}.contact.in-view .contact-content{animation:fadeInUp .65s cubic-bezier(.4,0,.2,1) both}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:3rem;position:relative;z-index:1}.contact-info{display:flex;flex-direction:column;gap:2rem}.contact-item{display:flex;align-items:start;gap:1.5rem;background:var(--bg-card);padding:1.5rem;border-radius:var(--radius, 12px);border:1px solid var(--border);transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s ease,border-color .35s ease;color:inherit;text-decoration:none;box-shadow:0 2px 12px #00000026}.contact-item:hover{border-color:#06b6d473;transform:translate(8px);box-shadow:0 0 0 1px #06b6d41a,0 8px 28px #06b6d41f,0 0 40px #06b6d40f}.contact-item-static{cursor:default}.contact-item-static:hover{transform:none;border-color:var(--border);box-shadow:0 2px 12px #00000026}.contact-item-static:hover .contact-icon{background:#06b6d414;box-shadow:none}.contact-icon{min-width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:#06b6d414;border-radius:12px;border:1px solid rgba(6,182,212,.15);flex-shrink:0;transition:background .3s ease,box-shadow .3s ease;color:#00d4ff;filter:drop-shadow(0 0 6px rgba(0,212,255,.4))}.contact-icon svg{width:1.5rem;height:1.5rem}.contact-item:hover .contact-icon{background:#06b6d426;box-shadow:0 0 20px #06b6d433}.contact-item h3{font-size:1.2rem;margin-bottom:.5rem;color:var(--text)}.contact-item p{color:var(--text-muted);font-size:1rem}.contact-form{background:var(--bg-card);padding:2.5rem;border-radius:var(--radius, 12px);border:1px solid var(--border);box-shadow:0 4px 20px #0003;transition:border-color .35s ease,box-shadow .35s ease}.contact-form:focus-within{border-color:#06b6d459;box-shadow:0 0 0 1px #06b6d41a,0 8px 32px #06b6d414}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text)}.form-group input,.form-group textarea{width:100%;padding:.875rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-elevated);color:var(--text);font-size:1rem;font-family:inherit;transition:all .3s ease;box-sizing:border-box}.form-group input.input-error,.form-group textarea.input-error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-group input.input-error:focus,.form-group textarea.input-error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef444433,0 0 20px #ef44441a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted);opacity:.7}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #06b6d433,0 0 20px #06b6d41a}.form-group textarea{resize:vertical;min-height:120px}.contact-form .btn{width:100%;margin-top:1rem;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#0a0a0d;font-weight:600}.contact-form .btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #06b6d44d}.contact-form .btn:disabled{opacity:.6;cursor:not-allowed}.form-status{margin-top:1rem;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;text-align:center;animation:fadeInUp .3s ease}.form-status-success{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.form-status-error{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.error-message{display:block;margin-top:.5rem;font-size:.875rem;color:#ef4444;animation:fadeInUp .3s ease}.file-input-wrapper{position:relative}.file-input-hidden{position:absolute;width:0;height:0;opacity:0;overflow:hidden;pointer-events:none;z-index:-1}.file-select-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.25rem;border:2px dashed var(--border);border-radius:8px;background:var(--bg-elevated);color:var(--text);font-size:1rem;font-family:inherit;cursor:pointer;transition:all .3s ease;box-sizing:border-box;position:relative;z-index:1}.file-select-btn svg{width:1.25rem;height:1.25rem;color:#00d4ff;filter:drop-shadow(0 0 4px rgba(0,212,255,.4));flex-shrink:0}.file-select-btn span{color:var(--text);font-weight:500}.file-select-btn:hover{border-color:#06b6d480;background:#06b6d40d;transform:translateY(-1px);box-shadow:0 4px 12px #06b6d426}.file-select-btn:active{transform:translateY(0)}.file-select-btn-error{border-color:#ef4444!important;background:#ef44440d!important}.file-select-btn-error:hover{border-color:#ef4444!important;background:#ef44441a!important;box-shadow:0 4px 12px #ef444433!important}.file-preview{display:flex;align-items:center;justify-content:space-between;margin-top:.75rem;padding:.75rem 1rem;background:#06b6d414;border:1px solid rgba(6,182,212,.2);border-radius:8px;color:var(--text);font-size:.9rem}.file-preview span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-remove{background:transparent;border:none;color:#ef4444;font-size:1.5rem;line-height:1;cursor:pointer;padding:0 .5rem;margin-left:.5rem;transition:transform .2s ease;font-weight:700}.file-remove:hover{transform:scale(1.2);color:#dc2626}@media(max-width:968px){.contact-content{grid-template-columns:1fr;gap:2.5rem;margin-top:2rem}.contact-form{padding:2rem}}@media(max-width:480px){.contact{padding:2.5rem 0}.contact-content{gap:2rem;margin-top:1.5rem}.contact-info{gap:1.25rem}.contact-item{padding:1.25rem;gap:1.25rem}.contact-icon{min-width:44px;height:44px}.contact-icon svg{width:1.25rem;height:1.25rem}.contact-item h3{font-size:1.05rem}.contact-item p{font-size:.9rem}.contact-form{padding:1.5rem}.form-group input,.form-group textarea{padding:.75rem;font-size:16px}.file-select-btn{padding:.75rem 1rem;font-size:.95rem}}.terminal-wrap{position:fixed;bottom:max(1.5rem,env(safe-area-inset-bottom));right:max(1.5rem,env(safe-area-inset-right));z-index:998;font-family:SF Mono,Consolas,Monaco,JetBrains Mono,monospace}.terminal-tab{padding:.5rem .9rem;font-size:.95rem;font-weight:600;color:#06b6d4f2;background:#0a0a0de6;border:1px solid rgba(6,182,212,.35);border-radius:8px 8px 0 0;cursor:pointer;transition:background .2s,border-color .2s,color .2s;box-shadow:0 -2px 12px #0000004d}.terminal-tab:hover{background:#121218f2;border-color:#06b6d48c;color:var(--accent-light)}.terminal-panel{position:absolute;bottom:calc(100% - 1px);right:0;width:520px;max-width:calc(100vw - 3rem);height:450px;max-height:65vh;background:#0c0c0f;border:1px solid rgba(6,182,212,.3);border-bottom:none;border-radius:10px 10px 0 0;box-shadow:0 0 0 1px #00000080,0 -8px 32px #00000080,0 0 40px #06b6d414;display:flex;flex-direction:column;overflow:hidden;animation:terminalOpen .25s ease}@keyframes terminalOpen{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.terminal-title{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#0006;border-bottom:1px solid rgba(6,182,212,.2);flex-shrink:0}.terminal-dots{display:flex;gap:5px}.terminal-dots span{width:10px;height:10px;border-radius:50%;background:#5a5a5a}.terminal-dots span:nth-child(1){background:#ff5f56}.terminal-dots span:nth-child(2){background:#ffbd2e}.terminal-dots span:nth-child(3){background:#27c93f}.terminal-title-text{flex:1;font-size:.75rem;color:var(--text-muted);text-align:center}.terminal-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;line-height:1;cursor:pointer;padding:0 .25rem;border-radius:4px;transition:color .2s,background .2s}.terminal-close:hover{color:var(--accent-light);background:#06b6d426}.terminal-body{flex:1;overflow-y:auto;padding:.75rem 1rem;font-size:.85rem;line-height:1.5}.terminal-line{margin-bottom:.35rem}.terminal-line.output .terminal-text{white-space:pre-wrap;color:#a8e6cf}.terminal-line.input .terminal-text{color:var(--accent-light)}.terminal-prompt{color:#06b6d4e6;margin-right:.25rem}.terminal-input-row{display:flex;align-items:center;padding:.5rem 1rem;background:#00000059;border-top:1px solid rgba(6,182,212,.2);flex-shrink:0}.terminal-input{flex:1;background:none;border:none;color:var(--text);font:inherit;font-size:.85rem;outline:none}.terminal-input::placeholder{color:var(--text-muted);opacity:.6}@media(max-width:480px){.terminal-wrap{bottom:max(1rem,env(safe-area-inset-bottom));right:max(1rem,env(safe-area-inset-right))}.terminal-panel{width:calc(100vw - 2rem);max-width:calc(100vw - env(safe-area-inset-right) - env(safe-area-inset-left) - 1rem);height:min(380px,65vh)}}
