*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}:root{--h-white: 0, 0%, 100%;--h-bg: 230, 40%, 98%;--h-bg-alt: 230, 30%, 96%;--h-text: 230, 35%, 8%;--h-text-muted: 230, 16%, 43%;--h-text-light: 230, 20%, 64%;--h-emerald: 165, 100%, 39%;--h-emerald-dark: 165, 100%, 33%;--h-amber: 33, 100%, 50%;--h-navy: 232, 34%, 16%;--h-border: 230, 24%, 92%;--white: hsl(var(--h-white));--bg: hsl(var(--h-bg));--bg-alt: hsl(var(--h-bg-alt));--text: hsl(var(--h-text));--text-muted: hsl(var(--h-text-muted));--text-light: hsl(var(--h-text-light));--emerald: hsl(var(--h-emerald));--emerald-dark: hsl(var(--h-emerald-dark));--emerald-soft: hsla(var(--h-emerald), .1);--amber: hsl(var(--h-amber));--amber-soft: hsla(var(--h-amber), .1);--navy: hsl(var(--h-navy));--border: hsl(var(--h-border));--always-white: #ffffff;--shadow-sm: 0 2px 12px rgba(13,15,26,.04);--shadow-md: 0 8px 32px rgba(13,15,26,.07);--shadow-lg: 0 20px 60px rgba(0,200,150,.12);--shadow-card: 0 4px 24px rgba(13,15,26,.05);--radius: 20px;--radius-sm: 12px;--radius-xs: 8px;--font-display: "Bricolage Grotesque", sans-serif;--font-body: "Nunito", sans-serif}body.dark-mode{--h-white: 232, 22%, 12%;--h-bg: 232, 32%, 5%;--h-bg-alt: 232, 28%, 8%;--h-text: 232, 20%, 93%;--h-text-muted: 232, 14%, 68%;--h-text-light: 232, 12%, 46%;--h-emerald: 165, 95%, 45%;--h-emerald-dark: 165, 90%, 38%;--h-amber: 38, 100%, 55%;--h-navy: 232, 25%, 15%;--h-border: 232, 20%, 15%;--white: hsl(var(--h-white));--bg: hsl(var(--h-bg));--bg-alt: hsl(var(--h-bg-alt));--text: hsl(var(--h-text));--text-muted: hsl(var(--h-text-muted));--text-light: hsl(var(--h-text-light));--emerald: hsl(var(--h-emerald));--emerald-dark: hsl(var(--h-emerald-dark));--emerald-soft: hsla(var(--h-emerald), .1);--amber: hsl(var(--h-amber));--amber-soft: hsla(var(--h-amber), .1);--navy: hsl(var(--h-navy));--border: hsl(var(--h-border));--shadow-sm: 0 2px 12px rgba(0,0,0,.3);--shadow-md: 0 8px 32px rgba(0,0,0,.45);--shadow-lg: 0 20px 60px rgba(0,200,150,.25);--shadow-card: 0 4px 24px rgba(0,0,0,.35)}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.68;overflow-x:hidden}a{text-decoration:none;color:inherit}img{display:block;max-width:100%}#root{min-height:100vh}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--border)}::-webkit-scrollbar-thumb{background:var(--emerald);border-radius:10px}::selection{background:var(--emerald-soft);color:var(--emerald-dark)}.navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;height:68px;background:hsla(var(--h-bg),.9);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid transparent;display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;transition:border-color .3s,box-shadow .3s}.navbar.scrolled{border-color:var(--border);box-shadow:var(--shadow-sm)}.nav-logo{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--text);letter-spacing:-1px}.logo-dot{color:var(--emerald)}.nav-links{display:flex;align-items:center;gap:.25rem}.nav-links a{font-size:.88rem;font-weight:600;color:var(--text-muted);padding:7px 16px;border-radius:50px;transition:all .2s}.nav-links a:hover{color:var(--text);background:var(--bg-alt)}.nav-links a.active{color:var(--always-white);background:var(--navy)}.nav-cta{font-size:.85rem;font-weight:700;background:var(--emerald);color:var(--always-white);padding:9px 22px;border-radius:50px;transition:all .22s;box-shadow:0 4px 14px #00c8964d}.nav-cta:hover{background:var(--emerald-dark);transform:translateY(-2px);box-shadow:0 8px 22px #00c89661}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:100px 2.5rem 60px;position:relative;overflow:hidden;background:var(--white)}.hero-noise{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.hero-shapes{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.shape{position:absolute;border-radius:50%}.shape-1{width:520px;height:520px;background:radial-gradient(circle,rgba(0,200,150,.09) 0%,transparent 70%);top:-100px;right:-80px}.shape-2{width:320px;height:320px;background:radial-gradient(circle,rgba(255,140,0,.07) 0%,transparent 70%);bottom:40px;left:-60px}.shape-3{width:180px;height:180px;background:radial-gradient(circle,rgba(0,200,150,.12) 0%,transparent 70%);top:40%;left:40%}.hero-inner{position:relative;z-index:1;max-width:1140px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr auto;gap:60px;align-items:center}.hero-left{max-width:640px}.badge{display:inline-flex;align-items:center;gap:8px;background:var(--emerald-soft);border:1.5px solid rgba(0,200,150,.25);color:var(--emerald-dark);padding:7px 18px;border-radius:50px;font-family:var(--font-body);font-size:.82rem;font-weight:700;margin-bottom:28px;letter-spacing:.2px}.badge-dot{width:8px;height:8px;border-radius:50%;background:var(--emerald);animation:pulse-dot 1.6s ease infinite}.hero-name{font-family:var(--font-display);line-height:1;margin-bottom:20px;letter-spacing:-2px}.name-first{display:block;font-size:clamp(3.5rem,7vw,6.5rem);font-weight:800;color:var(--text)}.name-last{display:block;font-size:clamp(3.5rem,7vw,6.5rem);font-weight:800;color:var(--emerald);-webkit-text-stroke:2px var(--emerald);color:transparent}.hero-role{display:flex;align-items:center;gap:14px;margin-bottom:22px;font-size:1.15rem;font-weight:600;color:var(--text-muted)}.role-bar{display:block;width:36px;height:3px;background:var(--emerald);border-radius:2px;flex-shrink:0}.hero-desc{font-size:1.08rem;color:var(--text-muted);line-height:1.75;max-width:500px;margin-bottom:36px}.hero-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.hero-right{position:relative;flex-shrink:0;z-index:10}.avatar-frame{position:relative;width:290px;height:350px;border-radius:16px;background:rgba(var(--h-white),.05);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(var(--h-border),.3);padding:16px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:transform .4s cubic-bezier(.175,.885,.32,1.275),border-color .4s}.avatar-frame:hover{transform:translateY(-8px);border-color:#00c89680;box-shadow:0 20px 48px #00c89626}.avatar-glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:24px;background:radial-gradient(circle,rgba(0,200,150,.18) 0%,rgba(255,140,0,.06) 60%,transparent 80%);filter:blur(15px);pointer-events:none;z-index:0;animation:glow-pulse 4s ease-in-out infinite alternate}.avatar-cyber-grid{position:absolute;top:16px;right:16px;bottom:16px;left:16px;border-radius:12px;background-image:linear-gradient(rgba(0,200,150,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,200,150,.03) 1px,transparent 1px);background-size:16px 16px;pointer-events:none;z-index:1}.avatar-bracket{position:absolute;width:14px;height:14px;border:2px solid var(--emerald);z-index:3;pointer-events:none;transition:all .3s}.avatar-frame:hover .avatar-bracket{border-color:var(--amber);width:18px;height:18px}.avatar-bracket.tl{top:8px;left:8px;border-right:none;border-bottom:none}.avatar-bracket.tr{top:8px;right:8px;border-left:none;border-bottom:none}.avatar-bracket.bl{bottom:8px;left:8px;border-right:none;border-top:none}.avatar-bracket.br{bottom:8px;right:8px;border-left:none;border-top:none}.avatar-img-wrap{position:relative;width:100%;height:100%;border-radius:12px;overflow:hidden;border:1px solid var(--border);z-index:2;box-shadow:var(--shadow-sm);background:var(--white)}.avatar-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.avatar-frame:hover .avatar-img{transform:scale(1.05)}.avatar-frame .chip{position:absolute;z-index:5;background:var(--white);border:1.5px solid var(--border);border-radius:10px;padding:8px 14px;font-size:.8rem;font-weight:800;color:var(--text);box-shadow:0 6px 20px #0d0f1a14;white-space:nowrap;display:flex;align-items:center;gap:6px;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}body.dark-mode .avatar-frame .chip{box-shadow:0 6px 24px #0006;border-color:#ffffff26}.avatar-frame .chip:hover{transform:scale(1.08) translateY(-4px);border-color:var(--emerald);box-shadow:0 8px 24px #00c8964d}.chip-1{top:20px;left:-50px;animation:chip-float-1 5s ease-in-out infinite}.chip-2{top:140px;right:-60px;animation:chip-float-2 4.5s ease-in-out infinite}.chip-3{bottom:30px;left:-60px;animation:chip-float-3 5.5s ease-in-out infinite}@keyframes glow-pulse{0%{transform:scale(.96);opacity:.7}to{transform:scale(1.04);opacity:1}}@keyframes chip-float-1{0%,to{transform:translateY(0)}50%{transform:translateY(-6px) translate(2px)}}@keyframes chip-float-2{0%,to{transform:translateY(0)}50%{transform:translateY(-8px) translate(-2px)}}@keyframes chip-float-3{0%,to{transform:translateY(0)}50%{transform:translateY(-7px) translate(3px)}}.scroll-hint{position:absolute;bottom:2.5rem;left:2.5rem;display:flex;align-items:center;gap:12px;color:var(--text-light);font-size:.78rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;z-index:1}.scroll-line{width:40px;height:1px;background:linear-gradient(to right,var(--emerald),transparent)}.section{max-width:1140px;margin:0 auto;padding:100px 2.5rem}.about-section,.edu-section{max-width:100%;background:var(--bg-alt);padding-left:0;padding-right:0}.about-section>*,.edu-section>*{max-width:1140px;margin-left:auto;margin-right:auto;padding-left:2.5rem;padding-right:2.5rem}.about-section .about-grid{padding:0 2.5rem;max-width:1140px;margin:0 auto}.section-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:16px}.eyebrow-num{font-family:var(--font-display);font-size:.78rem;font-weight:800;color:var(--emerald);letter-spacing:1px}.eyebrow-line{flex:0 0 36px;height:1.5px;background:var(--emerald);border-radius:2px}.eyebrow-label{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px}.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:800;color:var(--text);letter-spacing:-1.2px;line-height:1.1;margin-bottom:40px}.section{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}.section.revealed{opacity:1;transform:translateY(0)}.about-grid{display:grid;grid-template-columns:340px 1fr;gap:80px;align-items:start}.about-photo-wrap{position:relative;width:260px;height:280px;margin-bottom:24px}.about-photo-wrap img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-md);position:relative;z-index:1}.about-photo-accent{position:absolute;top:12px;right:-12px;bottom:-12px;left:12px;border-radius:var(--radius);background:var(--emerald-soft);border:2px solid rgba(0,200,150,.2);z-index:0}.about-stat-row{display:flex;gap:0;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--white);box-shadow:var(--shadow-sm)}.about-stat{flex:1;text-align:center;padding:16px 8px;border-right:1.5px solid var(--border)}.about-stat:last-child{border-right:none}.stat-n{display:block;font-family:var(--font-display);font-size:1.6rem;font-weight:800;color:var(--emerald)}.stat-l{display:block;font-size:.72rem;font-weight:600;color:var(--text-muted);line-height:1.3}.about-tagline{font-size:1.2rem;font-weight:700;color:var(--emerald-dark);margin-bottom:18px}.about-body{color:var(--text-muted);font-size:1rem;margin-bottom:14px;max-width:540px;line-height:1.75}.about-body strong{color:var(--text);font-weight:700}.about-detail-grid{display:flex;flex-wrap:wrap;gap:10px;margin:28px 0}.detail-pill{display:flex;align-items:center;gap:7px;background:var(--white);border:1.5px solid var(--border);border-radius:50px;padding:7px 16px;font-size:.84rem;font-weight:600;color:var(--text-muted)}.about-btns{display:flex;gap:12px;flex-wrap:wrap}.skills-section{background:var(--white)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px}.skill-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:28px 26px;transition:all .28s;cursor:default}.skill-card:hover{border-color:var(--emerald);transform:translateY(-6px);box-shadow:var(--shadow-lg);background:var(--white)}.skill-highlight{border-color:#ff8c0040;background:linear-gradient(135deg,#fffbf4,#f7f8fc)}.skill-highlight:hover{border-color:var(--amber);box-shadow:0 16px 48px #ff8c0024}.skill-card-top{display:flex;align-items:center;gap:12px;margin-bottom:18px}.skill-icon{font-size:1.4rem}.skill-card h4{font-family:var(--font-display);font-size:1.02rem;font-weight:700;color:var(--text)}.tags{display:flex;flex-wrap:wrap;gap:8px}.tag{background:#00c89614;color:var(--emerald-dark);border:1.5px solid rgba(0,200,150,.18);padding:5px 13px;border-radius:50px;font-size:.82rem;font-weight:600;transition:all .2s}.tag:hover{background:var(--emerald);color:var(--white);border-color:var(--emerald)}.tag.learning{background:var(--amber-soft);color:var(--amber);border-color:#ff8c0038}.tag.learning:hover{background:var(--amber);color:var(--white);border-color:var(--amber)}.projects-section{background:var(--bg-alt)}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:22px}.project-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:0;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:all .28s}.project-card:hover{transform:translateY(-8px);border-color:var(--emerald);box-shadow:var(--shadow-lg)}.project-card-header{display:flex;justify-content:space-between;align-items:center;padding:22px 26px 0}.project-num{font-family:var(--font-display);font-size:.72rem;font-weight:800;color:var(--emerald);letter-spacing:1px;text-transform:uppercase}.project-links-row{display:flex;gap:8px}.icon-btn{width:34px;height:34px;border-radius:var(--radius-xs);border:1.5px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--text-muted);transition:all .2s}.icon-btn:hover{background:var(--emerald);color:var(--white);border-color:var(--emerald)}.project-title{font-family:var(--font-display);font-size:1.3rem;font-weight:800;color:var(--text);padding:14px 26px 0;letter-spacing:-.3px}.project-desc{color:var(--text-muted);font-size:.95rem;padding:10px 26px 16px;flex:1;line-height:1.7}.tech-stack{display:flex;flex-wrap:wrap;gap:7px;padding:0 26px 20px}.tech-tag{background:var(--bg);border:1.5px solid var(--border);color:var(--text-muted);padding:4px 11px;border-radius:6px;font-size:.77rem;font-weight:700}.project-ctas{display:flex;gap:10px;padding:18px 26px;border-top:1.5px solid var(--border);background:var(--bg)}.btn{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-body);font-weight:700;font-size:.92rem;border-radius:50px;border:2px solid transparent;cursor:pointer;transition:all .22s;padding:11px 26px;line-height:1}.btn-sm{padding:8px 18px;font-size:.83rem}.btn-primary{background:var(--emerald);color:var(--always-white);box-shadow:0 4px 16px #00c89647}.btn-primary:hover{background:var(--emerald-dark);transform:translateY(-2px);box-shadow:0 8px 24px #00c89661}.btn-outline{background:transparent;border-color:var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--emerald);color:var(--emerald-dark);background:var(--emerald-soft)}.btn-ghost{background:var(--bg-alt);border-color:var(--border);color:var(--text-muted)}.btn-ghost:hover{background:var(--navy);border-color:var(--navy);color:var(--always-white)}.edu-card{display:flex;gap:28px;align-items:flex-start;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:36px 40px;border-left:5px solid var(--emerald);box-shadow:var(--shadow-sm);transition:all .25s;max-width:1140px;margin:0 auto}.edu-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.edu-icon{font-size:2.2rem;width:60px;height:60px;background:var(--emerald-soft);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.edu-body h4{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--text);margin-bottom:7px}.edu-degree{color:var(--emerald-dark);font-weight:700;margin-bottom:5px}.edu-focus{color:var(--text-muted);font-size:.97rem}.cert-section{background:var(--white)}.cert-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.cert-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px;max-width:300px;width:100%;text-align:center;box-shadow:var(--shadow-sm);transition:all .25s}.cert-card:hover{transform:translateY(-6px) scale(1.02);border-color:var(--emerald);box-shadow:var(--shadow-lg)}.cert-card img{width:100%;border-radius:var(--radius-sm);margin-bottom:12px}.cert-label{font-weight:700;font-size:.9rem;color:var(--text-muted)}.contact-section{background:var(--navy);max-width:100%;padding:100px 2.5rem}.contact-section .section-eyebrow .eyebrow-label{color:#ffffff80}.contact-section .section-eyebrow .eyebrow-num{color:var(--emerald)}.contact-inner{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.contact-title{color:var(--always-white)!important;margin-bottom:20px}.contact-desc{color:#ffffff8c;font-size:1.05rem;margin-bottom:36px;line-height:1.7}.contact-btn{background:var(--emerald);color:var(--always-white)}.contact-btn:hover{background:var(--emerald-dark)}.contact-right{display:flex;flex-direction:column;gap:14px}.contact-card{display:flex;align-items:center;gap:16px;background:#ffffff0f;border:1.5px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:18px 22px;transition:all .22s}.contact-card:hover{background:#00c8961f;border-color:#00c89666;transform:translate(6px)}.contact-card-icon{width:42px;height:42px;flex-shrink:0;background:#00c89626;border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--emerald);font-family:var(--font-display);font-weight:800}.contact-card-label{font-size:.7rem;font-weight:700;color:#fff6;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:3px}.contact-card-value{font-size:.95rem;font-weight:700;color:var(--always-white)}.contact-arrow{margin-left:auto;color:#ffffff40;font-size:1.1rem;transition:all .2s}.contact-card:hover .contact-arrow{color:var(--emerald);transform:translate(4px)}footer{background:#0d0f1a;border-top:1px solid rgba(255,255,255,.06);padding:28px 2.5rem}.footer-inner{max-width:1140px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.footer-logo{font-family:var(--font-display);font-size:1.3rem;font-weight:800;color:var(--always-white)}.footer-logo span{color:var(--emerald)}footer p{color:#ffffff59;font-size:.85rem}footer p strong{color:#fff9}.footer-links{display:flex;gap:20px}.footer-links a{color:#ffffff59;font-size:.85rem;font-weight:600;transition:color .2s}.footer-links a:hover{color:var(--emerald)}@keyframes fadeDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}@keyframes chip-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes blob-morph{0%,to{border-radius:60% 40% 50% 60%/50% 60% 40% 50%}33%{border-radius:50% 50% 60% 40%/60% 40%}66%{border-radius:40% 60%/40% 60% 50% 50%}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-up{animation:fadeUp .75s ease both}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.22s}.delay-3{animation-delay:.36s}.delay-4{animation-delay:.5s}.delay-5{animation-delay:.62s}@media (max-width: 1024px){.hero-chips{right:-60px}.about-grid{grid-template-columns:280px 1fr;gap:50px}}@media (max-width: 860px){.hero-inner{grid-template-columns:1fr;text-align:center;gap:40px}.hero-right{display:none}.hero-desc{margin-left:auto;margin-right:auto}.hero-role,.hero-btns{justify-content:center}.about-grid{grid-template-columns:1fr}.about-photo-col{display:flex;flex-direction:column;align-items:center}.about-body{margin:0 auto}.contact-inner{grid-template-columns:1fr;gap:40px}.navbar{padding:0 1.2rem}.nav-links a{padding:6px 10px;font-size:.82rem}.nav-cta{padding:8px 16px;font-size:.82rem}}@media (max-width: 600px){.section,.contact-section{padding:70px 1.2rem}.about-section,.edu-section{padding:70px 0}.about-section .about-grid{padding:0 1.2rem}.project-grid{grid-template-columns:1fr}.name-first,.name-last{font-size:3rem}.nav-links{display:none}.edu-card{flex-direction:column;padding:24px}.footer-inner{flex-direction:column;text-align:center}}.wip-section{background:var(--white)}.wip-eyebrow .eyebrow-num{color:var(--amber)}.wip-eyebrow .eyebrow-line{background:var(--amber)}.wip-card{position:relative;background:var(--navy);border-radius:28px;overflow:hidden;padding:56px 52px 40px;box-shadow:0 24px 80px #0d0f1a47}.wip-bg-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(0,200,150,.1) 0%,transparent 65%);top:-200px;right:-100px;pointer-events:none;animation:wip-glow-drift 8s ease infinite}@keyframes wip-glow-drift{0%,to{transform:translate(0)}50%{transform:translate(-40px,30px)}}.wip-grid-dots{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px);background-size:28px 28px}.wip-top{position:relative;z-index:1;display:grid;grid-template-columns:1fr 380px;gap:56px;align-items:start;margin-bottom:44px}.wip-status-badge{display:inline-flex;align-items:center;gap:8px;background:#00c8961f;border:1.5px solid rgba(0,200,150,.3);color:var(--emerald);padding:6px 16px;border-radius:50px;font-size:.78rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:20px}.wip-pulse{width:8px;height:8px;border-radius:50%;background:var(--emerald);animation:pulse-dot 1.4s ease infinite;flex-shrink:0}.wip-name{font-family:var(--font-display);font-size:clamp(2.8rem,5vw,4.8rem);font-weight:800;letter-spacing:-2px;line-height:1;margin-bottom:12px;background:linear-gradient(135deg,#fff,#00c896d9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 20px rgba(0,200,150,.3))}.wip-tagline{font-size:1.05rem;font-weight:700;color:var(--emerald);margin-bottom:14px}.wip-desc{color:#ffffff8c;font-size:.97rem;line-height:1.75;max-width:480px;margin-bottom:28px}.wip-btn{background:var(--emerald);color:var(--navy)!important;font-weight:800;box-shadow:0 6px 24px #00c89659}.wip-btn:hover{background:#00e6ab;transform:translateY(-2px);box-shadow:0 10px 32px #00c89673}.wip-progress-wrap{background:#ffffff0d;border:1.5px solid rgba(255,255,255,.1);border-radius:18px;padding:24px 26px;margin-bottom:18px}.wip-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:.82rem;font-weight:700;color:#ffffff73;text-transform:uppercase;letter-spacing:1px}.wip-progress-pct{font-family:var(--font-display);font-size:1.4rem;font-weight:800;color:var(--emerald)}.wip-progress-track{height:6px;background:#ffffff14;border-radius:10px;overflow:hidden;margin-bottom:18px}.wip-progress-bar{height:100%;background:linear-gradient(90deg,var(--emerald),#00e6ab);border-radius:10px;box-shadow:0 0 12px #00c89680;transition:width 1s ease;position:relative}.wip-progress-bar:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:10px;height:10px;border-radius:50%;background:#fff;box-shadow:0 0 8px #00c896cc}.wip-progress-steps{display:flex;justify-content:space-between;gap:4px}.wip-step{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:.68rem;font-weight:600;color:#ffffff40;text-align:center;flex:1}.wip-step.done{color:var(--emerald)}.wip-step-dot{width:10px;height:10px;border-radius:50%;background:#ffffff1f;border:2px solid rgba(255,255,255,.15)}.wip-step.done .wip-step-dot{background:var(--emerald);border-color:var(--emerald);box-shadow:0 0 8px #00c89699}.wip-tech-wrap{background:#ffffff0a;border:1.5px solid rgba(255,255,255,.08);border-radius:14px;padding:18px 20px}.wip-tech-label{font-size:.72rem;font-weight:700;color:#ffffff4d;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px}.wip-tech-tags{display:flex;flex-wrap:wrap;gap:7px}.wip-tech-tag{background:#00c8961a;border:1px solid rgba(0,200,150,.2);color:var(--emerald);padding:4px 12px;border-radius:6px;font-size:.76rem;font-weight:700;transition:all .2s}.wip-tech-tag:hover{background:#00c89638;border-color:var(--emerald)}.wip-features{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;border-top:1px solid rgba(255,255,255,.07);padding-top:36px}.wip-feature{display:flex;gap:14px;align-items:flex-start;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:20px 18px;transition:all .25s}.wip-feature:hover{background:#00c89612;border-color:#00c89638;transform:translateY(-3px)}.wip-feature-icon{font-size:1.5rem;flex-shrink:0;width:40px;height:40px;background:#00c8961a;border-radius:10px;display:flex;align-items:center;justify-content:center}.wip-feature-title{font-weight:800;font-size:.9rem;color:#ffffffe6;margin-bottom:5px}.wip-feature-desc{font-size:.8rem;color:#ffffff61;line-height:1.6}@media (max-width: 1024px){.wip-top{grid-template-columns:1fr;gap:32px}.wip-features{grid-template-columns:repeat(2,1fr)}.wip-card{padding:40px 36px 32px}}@media (max-width: 600px){.wip-card{padding:28px 20px 24px;border-radius:20px}.wip-features{grid-template-columns:1fr}.wip-feature{flex-direction:row}}.project-banner-wrap{position:relative;width:100%;height:200px;overflow:hidden;flex-shrink:0}.project-banner{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .5s ease}.project-card:hover .project-banner{transform:scale(1.07)}.project-banner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(to bottom,#0000 40%,#0d0f1a7a)}.card-character{position:absolute;bottom:-4px;left:14px;font-size:4rem;line-height:1;z-index:3;pointer-events:none;opacity:0;transform:translate(-48px);transition:opacity .5s ease,transform .5s ease;filter:drop-shadow(0 4px 14px rgba(0,0,0,.45))}.project-card:hover .card-character,.project-card.is-active .card-character{opacity:1;transform:translate(0)}.upcoming-section{background:var(--bg)}.upcoming-jarvis-card{position:relative;width:100%;min-height:600px;border-radius:28px;overflow:hidden;display:flex;align-items:stretch;box-shadow:0 32px 100px #00000059}.ujc-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.ujc-bg-img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;filter:brightness(.38) saturate(1.3);transition:transform 9s ease}.upcoming-jarvis-card:hover .ujc-bg-img{transform:scale(1.05)}.ujc-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,#0a0c16f5,#0a0c16cc 40%,#00c8960f 75%,#0a0c16a6)}.ujc-scanlines{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:repeating-linear-gradient(to bottom,transparent 0px,transparent 3px,rgba(0,200,150,.022) 3px,rgba(0,200,150,.022) 4px)}.ujc-glow-orb{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(0,200,150,.12) 0%,transparent 65%);top:-100px;right:50px;pointer-events:none;animation:ujc-drift 9s ease-in-out infinite}@keyframes ujc-drift{0%,to{transform:translate(0)}50%{transform:translate(-30px,30px)}}.ujc-content{position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto;padding:64px max(5vw,28px);display:grid;grid-template-columns:1fr 420px;gap:60px;align-items:start}.ujc-badges{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:22px}.ujc-status-badge{display:inline-flex;align-items:center;gap:8px;background:#00c8961f;border:1.5px solid rgba(0,200,150,.35);color:var(--emerald);padding:6px 16px;border-radius:50px;font-size:.78rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}.ujc-pulse{width:8px;height:8px;border-radius:50%;background:var(--emerald);animation:pulse-dot 1.4s ease infinite;flex-shrink:0}.ujc-pct-badge{background:#ff8c001f;border:1.5px solid rgba(255,140,0,.32);color:var(--amber);padding:6px 14px;border-radius:50px;font-size:.78rem;font-weight:700}.ujc-name{font-family:var(--font-display);font-size:clamp(3rem,6vw,5.8rem);font-weight:800;letter-spacing:-3px;line-height:1;background:linear-gradient(135deg,#fff 40%,#00c896e6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 30px rgba(0,200,150,.35));margin-bottom:14px}.ujc-tagline{font-size:1.05rem;font-weight:700;color:var(--emerald);margin-bottom:14px}.ujc-desc{color:#ffffff85;font-size:.97rem;line-height:1.8;max-width:480px;margin-bottom:28px}.ujc-tech-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}.ujc-tech-tag{background:#00c8961a;border:1px solid rgba(0,200,150,.22);color:var(--emerald);padding:5px 13px;border-radius:6px;font-size:.76rem;font-weight:700;transition:all .2s}.ujc-tech-tag:hover{background:#00c89638;border-color:var(--emerald)}.ujc-btn{display:inline-flex;align-items:center;gap:8px;background:var(--emerald);color:var(--navy)!important;font-weight:800;font-size:.95rem;padding:13px 30px;border-radius:50px;transition:all .22s;box-shadow:0 8px 28px #00c89666}.ujc-btn:hover{background:#00e6ab;transform:translateY(-3px);box-shadow:0 14px 36px #00c89685}.ujc-right{display:flex;flex-direction:column;gap:14px}.ujc-glass-card{background:#ffffff0f;border:1.5px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:18px;padding:22px 24px}.ujc-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:.78rem;font-weight:700;color:#ffffff61;text-transform:uppercase;letter-spacing:1.2px}.ujc-progress-pct{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--emerald)}.ujc-track{height:6px;background:#ffffff14;border-radius:10px;overflow:hidden;margin-bottom:18px}.ujc-bar{height:100%;background:linear-gradient(90deg,var(--emerald),#00e6ab);border-radius:10px;box-shadow:0 0 14px #00c89699;transition:width 1.2s ease;position:relative}.ujc-bar:after{content:"";position:absolute;right:-1px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:#fff;box-shadow:0 0 10px #00c896e6}.ujc-steps{display:flex;justify-content:space-between;gap:4px}.ujc-step{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:.65rem;font-weight:600;color:#ffffff38;text-align:center;flex:1}.ujc-step.done{color:var(--emerald)}.ujc-step-dot{width:10px;height:10px;border-radius:50%;background:#ffffff1a;border:2px solid rgba(255,255,255,.14)}.ujc-step.done .ujc-step-dot{background:var(--emerald);border-color:var(--emerald);box-shadow:0 0 8px #00c896b3}.ujc-features{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ujc-feature{display:flex;gap:11px;align-items:flex-start;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:14px;padding:14px 13px;transition:all .25s}.ujc-feature:hover{background:#00c89614;border-color:#00c89640;transform:translateY(-2px)}.ujc-feature-icon{font-size:1.25rem;flex-shrink:0;width:34px;height:34px;background:#00c8961a;border-radius:9px;display:flex;align-items:center;justify-content:center}.ujc-feature-title{font-weight:800;font-size:.8rem;color:#ffffffe0;margin-bottom:4px}.ujc-feature-desc{font-size:.72rem;color:#ffffff59;line-height:1.55}@media (max-width: 1024px){.ujc-content{grid-template-columns:1fr;gap:40px}.upcoming-jarvis-card{min-height:auto}}@media (max-width: 600px){.ujc-content{padding:40px 20px}.ujc-features{grid-template-columns:1fr}.ujc-name{letter-spacing:-2px}.upcoming-jarvis-card{border-radius:20px}}.jarvis-chatbot{position:fixed;bottom:30px;right:30px;z-index:9999;font-family:var(--font-body)}.jarvis-toggle{width:60px;height:60px;border-radius:50%;background:var(--emerald);color:var(--always-white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 8px 32px #00c89666;position:relative;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s}.jarvis-toggle:hover{transform:scale(1.08) rotate(5deg);box-shadow:0 12px 40px #00c89699}.jarvis-toggle:active{transform:scale(.95)}.jarvis-toggle:before,.jarvis-toggle:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:1.5px solid var(--emerald);opacity:.5;animation:jarvis-pulse-ring 2.2s cubic-bezier(.215,.61,.355,1) infinite}.jarvis-toggle:after{animation-delay:1.1s}@keyframes jarvis-pulse-ring{0%{transform:scale(.95);opacity:.8}to{transform:scale(1.4);opacity:0}}.jarvis-chat-window{position:absolute;bottom:75px;right:0;width:380px;height:500px;background:hsla(var(--h-white),.82);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:0 20px 80px #0d0f1a40;display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(20px) scale(.95);pointer-events:none;transition:opacity .35s cubic-bezier(.165,.84,.44,1),transform .35s cubic-bezier(.165,.84,.44,1)}.jarvis-chat-window.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all}.jarvis-chat-header{padding:16px 20px;background:var(--bg-alt);border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}.jarvis-header-info{display:flex;align-items:center;gap:10px}.jarvis-avatar{width:32px;height:32px;border-radius:50%;background:#00c89626;border:1.5px solid var(--emerald);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--emerald);position:relative}.jarvis-avatar-dot{position:absolute;bottom:0;right:0;width:8px;height:8px;border-radius:50%;background:var(--emerald);border:1.5px solid var(--always-white)}.jarvis-header-text h5{font-family:var(--font-display);font-size:.95rem;font-weight:800;color:var(--text);margin:0}.jarvis-header-text span{font-size:.7rem;font-weight:600;color:var(--emerald-dark);display:block}.jarvis-close-btn{background:transparent;border:none;font-size:1.2rem;color:var(--text-light);cursor:pointer;padding:4px;transition:color .2s}.jarvis-close-btn:hover{color:var(--text)}.jarvis-chat-messages{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth}.jarvis-chat-messages::-webkit-scrollbar{width:4px}.jarvis-chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.jarvis-msg{max-width:85%;padding:12px 16px;border-radius:16px;font-size:.88rem;line-height:1.5;animation:jarvis-msg-appear .28s cubic-bezier(.175,.885,.32,1) both}@keyframes jarvis-msg-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.jarvis-msg.jarvis{background:var(--bg-alt);color:var(--text);border-bottom-left-radius:4px;align-self:flex-start;border:1px solid var(--border)}.jarvis-msg.user{background:var(--emerald);color:var(--always-white);border-bottom-right-radius:4px;align-self:flex-end;box-shadow:0 4px 12px #00c89633}.jarvis-chat-chips{padding:10px 20px;display:flex;flex-wrap:wrap;gap:6px;border-top:1px solid var(--border);background:hsla(var(--h-white),.4)}.jarvis-chip{background:var(--bg-alt);border:1px solid var(--border);color:var(--text-muted);font-size:.76rem;font-weight:700;padding:6px 12px;border-radius:50px;cursor:pointer;transition:all .2s}.jarvis-chip:hover{background:var(--emerald-soft);color:var(--emerald-dark);border-color:var(--emerald)}.jarvis-chat-input-area{padding:12px 20px;border-top:1.5px solid var(--border);background:var(--bg-alt);display:flex;gap:8px}.jarvis-chat-input{flex:1;background:var(--white);border:1.5px solid var(--border);border-radius:50px;padding:8px 16px;font-size:.85rem;color:var(--text);outline:none;transition:border-color .2s}.jarvis-chat-input:focus{border-color:var(--emerald)}.jarvis-chat-input::placeholder{color:var(--text-light)}.jarvis-send-btn{width:36px;height:36px;border-radius:50%;background:var(--emerald);color:var(--always-white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:transform .2s,background-color .2s}.jarvis-send-btn:hover{background:var(--emerald-dark);transform:scale(1.05)}.jarvis-send-btn:active{transform:scale(.95)}@media (max-width: 600px){.jarvis-chatbot{bottom:20px;right:20px}.jarvis-toggle{width:52px;height:52px;font-size:1.3rem}.jarvis-chat-window{position:fixed;bottom:0;right:0;left:0;top:0;width:100vw;height:100dvh;border-radius:0;border:none;z-index:10000;transform:translateY(100%) scale(1);transition:transform .35s cubic-bezier(.165,.84,.44,1),opacity .35s ease}.jarvis-chat-window.open{transform:translateY(0)}.jarvis-chat-messages{padding:16px}.jarvis-chat-chips{padding:8px 16px;flex-wrap:nowrap;overflow-x:auto;gap:8px;-webkit-overflow-scrolling:touch}.jarvis-chat-chips::-webkit-scrollbar{display:none}.jarvis-chip{flex-shrink:0}.jarvis-chat-input-area{padding:12px 16px calc(12px + env(safe-area-inset-bottom,0px))}.jarvis-close-btn{font-size:1.6rem;padding:8px}.scroll-to-top-wrap{bottom:20px;left:20px}}.projects-header-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;margin-bottom:40px}.projects-filter-pills{display:flex;gap:8px;flex-wrap:wrap}.filter-pill{background:var(--white);border:1.5px solid var(--border);color:var(--text-muted);padding:8px 18px;border-radius:50px;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .22s;box-shadow:var(--shadow-sm)}.filter-pill:hover{color:var(--text);background:var(--bg-alt)}.filter-pill.active{background:var(--navy);border-color:var(--navy);color:var(--always-white)}body.dark-mode .filter-pill.active{background:var(--emerald);border-color:var(--emerald);color:var(--bg)}.projects-search-box{position:relative;max-width:320px;width:100%}.projects-search-input{width:100%;padding:10px 16px 10px 40px;background:var(--white);border:1.5px solid var(--border);border-radius:50px;font-size:.88rem;color:var(--text);box-shadow:var(--shadow-sm);outline:none;transition:all .25s}.projects-search-input:focus{border-color:var(--emerald);box-shadow:0 0 0 4px var(--emerald-soft)}.projects-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:.95rem;color:var(--text-light);pointer-events:none}.scroll-to-top-wrap{position:fixed;bottom:30px;left:30px;z-index:9999;width:48px;height:48px;opacity:0;pointer-events:none;transform:translateY(10px) scale(.9);transition:opacity .3s,transform .3s}.scroll-to-top-wrap.visible{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}.scroll-progress-svg{width:100%;height:100%;transform:rotate(-90deg)}.scroll-progress-bg{fill:none;stroke:var(--border);stroke-width:3.5}.scroll-progress-bar{fill:none;stroke:var(--emerald);stroke-width:3.5;stroke-linecap:round;transition:stroke-dashoffset .1s linear}.scroll-to-top-btn{position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;background:var(--white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);font-size:1.1rem;box-shadow:var(--shadow-sm);transition:background-color .2s,color .2s,transform .2s}.scroll-to-top-btn:hover{background:var(--emerald-soft);color:var(--emerald-dark);transform:scale(1.05)}.copy-tooltip{position:fixed;bottom:30px;left:50%;transform:translate(-50%) translateY(20px);background:var(--navy);color:var(--always-white);padding:10px 24px;border-radius:50px;font-size:.88rem;font-weight:700;box-shadow:0 10px 30px #0000004d;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s cubic-bezier(.175,.885,.32,1.275);z-index:10000;display:flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.1)}.copy-tooltip.visible{opacity:1;transform:translate(-50%) translateY(0)}.theme-toggle-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:background-color .2s,color .2s,transform .3s;border:1.5px solid var(--border);box-shadow:var(--shadow-sm);background:var(--white)}.theme-toggle-btn:hover{background:var(--bg-alt);color:var(--text);transform:rotate(15deg)}body.dark-mode .theme-toggle-btn:hover{color:var(--amber)}body,section,footer,.navbar,.btn,.skill-card,.project-card,.edu-card,.contact-card,.chip,.tag,.filter-pill,.projects-search-input,.ujc-glass-card,.ujc-feature,.ujc-btn,.wip-card,.wip-progress-wrap,.wip-tech-wrap,.wip-feature{transition:background .4s ease,background-color .4s ease,border-color .4s ease,color .4s ease,box-shadow .4s ease}
