:root{--bg:#0b0c0f;--bg2:#111318;--bg3:#181b22;--accent:#4a90c4;--accent-dim:rgba(74,144,196,0.11);--accent-border:rgba(74,144,196,0.26);--text:#e8eaf0;--muted:#7a7f8e;--border:rgba(255,255,255,0.07);--card:rgba(255,255,255,0.03);}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'DM Mono',monospace;font-size:15px;line-height:1.7;overflow-x:hidden;}
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.1rem 3rem;display:flex;justify-content:space-between;align-items:center;background:rgba(11,12,15,0.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);}
.nav-logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.1rem;color:var(--accent);text-decoration:none;letter-spacing:-0.02em;}
.nav-links{display:flex;gap:1.75rem;list-style:none;}
.nav-links a{color:var(--muted);text-decoration:none;font-size:0.74rem;letter-spacing:0.09em;text-transform:uppercase;transition:color 0.2s;}
.nav-links a:hover{color:var(--text);}
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:8rem 3rem 4rem;position:relative;max-width:none;}
.grid-deco{position:absolute;top:0;right:0;width:45vw;height:100%;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;mask-image:linear-gradient(to left,rgba(0,0,0,0.25),transparent);pointer-events:none;}
.hero-eyebrow{font-size:0.73rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem;display:flex;align-items:center;gap:0.75rem;}
.hero-eyebrow::before{content:'';display:inline-block;width:22px;height:1px;background:var(--accent);}
.hero-name{font-family:'Syne',sans-serif;font-size:clamp(3.5rem,10vw,8rem);font-weight:800;line-height:0.95;letter-spacing:-0.04em;color:var(--text);margin-bottom:2rem;}
.hero-name span{color:transparent;-webkit-text-stroke:1px var(--accent);}
.hero-sub{font-family:'Lora',serif;font-style:italic;font-size:clamp(1rem,2.5vw,1.3rem);color:var(--muted);max-width:520px;line-height:1.65;margin-bottom:3rem;}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;}
.btn{display:inline-block;padding:0.7rem 1.6rem;border-radius:4px;text-decoration:none;font-family:'DM Mono',monospace;font-size:0.8rem;letter-spacing:0.05em;transition:all 0.2s;cursor:pointer;}
.btn-primary{background:var(--accent);color:#0b0c0f;font-weight:500;}
.btn-primary:hover{background:#5fa3d4;transform:translateY(-1px);}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border);}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);}
.hero-scroll{position:absolute;bottom:2.5rem;left:3rem;display:flex;align-items:center;gap:0.75rem;color:var(--muted);font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;}
.scroll-line{width:38px;height:1px;background:var(--muted);animation:scrollLine 2s ease-in-out infinite;}
@keyframes scrollLine{0%,100%{width:38px;opacity:1;}50%{width:16px;opacity:0.3;}}
section{padding:5.5rem 3rem;max-width:1100px;margin:0 auto;position:relative;z-index:1;}
.section-label{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--accent);margin-bottom:2.75rem;display:flex;align-items:center;gap:1rem;}
.section-label::after{content:'';flex:1;height:1px;background:var(--border);}
.about-grid{display:grid;grid-template-columns:auto 1fr;gap:3.5rem;align-items:start;}
.about-left{display:flex;flex-direction:column;align-items:center;gap:1.5rem;}
.about-photo{width:200px;aspect-ratio:1;border-radius:10px;object-fit:cover;border:1px solid var(--border);display:block;}
.sticker-board{width:200px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:10px;padding:12px;display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.sticker{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:8px;padding:9px 6px 7px;transition:transform 0.2s,box-shadow 0.2s;cursor:default;overflow:hidden;}
.sticker:nth-child(1){transform:rotate(-2deg);}
.sticker:nth-child(2){transform:rotate(1.5deg);}
.sticker:nth-child(3){transform:rotate(2deg);}
.sticker:nth-child(4){transform:rotate(-1.5deg);}
.sticker:hover{transform:rotate(0deg) scale(1.06) !important;box-shadow:0 4px 16px rgba(0,0,0,0.45);}
.sticker img{width:44px;height:44px;object-fit:cover;border-radius:6px;}
.sticker-label{font-size:0.52rem;color:var(--muted);letter-spacing:0.05em;text-align:center;line-height:1.3;}
.about-text h2{font-family:'Syne',sans-serif;font-size:clamp(1.7rem,3.5vw,2.4rem);font-weight:700;line-height:1.15;letter-spacing:-0.03em;margin-bottom:1.25rem;}
.about-text p{color:var(--muted);line-height:1.8;margin-bottom:0.85rem;font-size:0.86rem;}
.about-text p strong{color:var(--text);font-weight:500;}
.about-meta{display:flex;flex-wrap:wrap;gap:0.45rem;margin-bottom:1.1rem;}
.meta-pill{font-size:0.7rem;padding:0.28rem 0.65rem;border-radius:4px;border:1px solid var(--border);color:var(--muted);background:var(--card);}
.skills-flex{display:flex;flex-wrap:wrap;gap:0.45rem;margin-top:1.4rem;}
.skill-tag{padding:0.3rem 0.7rem;border-radius:4px;font-size:0.7rem;letter-spacing:0.04em;border:1px solid var(--border);background:var(--card);color:var(--muted);transition:all 0.2s;}
.skill-tag:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);}
.exp-list{display:flex;flex-direction:column;gap:1.25rem;}
.exp-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1.5rem 1.75rem;transition:border-color 0.25s;}
.exp-card:hover{border-color:var(--accent-border);}
.exp-header{display:flex;align-items:center;gap:1.1rem;margin-bottom:1rem;}
.logo-box{width:44px;height:44px;flex-shrink:0;border-radius:10px;border:1px solid var(--border);overflow:hidden;}
.logo-box img{width:100%;height:100%;object-fit:cover;display:block;}
.logo-box-xl{width:58px;height:58px;flex-shrink:0;border-radius:10px;border:1px solid var(--border);overflow:hidden;}
.logo-box-xl img{width:100%;height:100%;object-fit:cover;display:block;}
.exp-header-text{flex:1;min-width:0;}
.exp-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;}
.exp-role{font-family:'Syne',sans-serif;font-size:0.98rem;font-weight:700;color:var(--text);}
.exp-date{font-size:0.7rem;color:var(--muted);letter-spacing:0.05em;white-space:nowrap;padding-top:2px;}
.exp-company{font-size:0.78rem;color:var(--accent);margin-top:0.2rem;}
.exp-bullets{list-style:none;display:flex;flex-direction:column;gap:0.4rem;}
.exp-bullets li{font-size:0.8rem;color:var(--muted);line-height:1.65;padding-left:1rem;position:relative;}
.exp-bullets li::before{content:'/';position:absolute;left:0;color:var(--accent);font-weight:500;}
.projects-list{display:flex;flex-direction:column;gap:1.4rem;}
.project-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1.6rem 1.75rem;transition:all 0.25s;position:relative;overflow:hidden;}
.project-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--card-accent,var(--accent)),transparent);opacity:0;transition:opacity 0.3s;}
.project-card:hover{border-color:rgba(255,255,255,0.11);transform:translateY(-2px);}
.project-card:hover::before{opacity:1;}
.project-header{display:flex;align-items:center;gap:0.9rem;margin-bottom:0.75rem;}
.project-title-wrap{display:flex;flex-direction:column;gap:0.1rem;flex:1;}
.project-title{font-family:'Syne',sans-serif;font-size:1.1rem;font-weight:700;letter-spacing:-0.02em;color:var(--text);}
.project-stack{font-size:0.7rem;color:var(--muted);letter-spacing:0.02em;}
.project-desc{font-size:0.82rem;color:var(--muted);line-height:1.75;}
.project-tech{display:flex;flex-wrap:wrap;gap:0.38rem;margin-top:0.9rem;}
.tech-badge{font-size:0.67rem;padding:0.18rem 0.48rem;border-radius:3px;background:var(--accent-dim);color:var(--accent);letter-spacing:0.04em;border:1px solid var(--accent-border);}
.project-footer{display:flex;align-items:center;gap:1rem;margin-top:1rem;flex-wrap:wrap;}
.proj-link{font-size:0.7rem;padding:0.27rem 0.7rem;border-radius:4px;border:1px solid var(--border);color:var(--muted);text-decoration:none;transition:all 0.2s;display:inline-flex;align-items:center;gap:0.35rem;}
.proj-link:hover{border-color:var(--accent);color:var(--accent);}
.proj-link svg{width:11px;height:11px;flex-shrink:0;}
.status-pill{display:inline-flex;align-items:center;gap:0.32rem;font-size:0.68rem;color:var(--muted);}
.dot{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:pulse 2s ease-in-out infinite;}
.dot.off{background:var(--muted);animation:none;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.2;}}
.edu-card{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color 0.25s;}
.edu-card:hover{border-color:var(--accent-border);}
.edu-header{display:flex;align-items:center;gap:1.25rem;padding:1.6rem 1.75rem;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.edu-logos{display:flex;align-items:center;gap:0.75rem;flex-shrink:0;}
.edu-logo-box{height:44px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,0.96);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:4px;}
.edu-logo-york{width:44px;}
.edu-logo-lassonde{width:52px;}
.edu-logo-box img{height:100%;width:100%;object-fit:contain;}
.edu-divider{width:1px;height:28px;background:var(--border);flex-shrink:0;}
.edu-header-text{flex:1;min-width:0;}
.edu-school{font-family:'Syne',sans-serif;font-size:0.98rem;font-weight:700;color:var(--text);}
.edu-faculty{font-size:0.75rem;color:var(--accent);margin-top:0.1rem;}
.edu-dates-badge{margin-left:auto;font-size:0.68rem;color:var(--muted);white-space:nowrap;text-align:right;}
.edu-body{padding:1.4rem 1.75rem;display:grid;grid-template-columns:1fr 1fr;gap:1.75rem;}
.edu-section h4{font-size:0.65rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);margin-bottom:0.65rem;}
.edu-degree{font-size:0.88rem;color:var(--text);font-weight:500;margin-bottom:0.2rem;}
.edu-subdegree{font-size:0.74rem;color:var(--muted);margin-bottom:1.1rem;}
.award-item{display:flex;align-items:flex-start;gap:0.5rem;margin-bottom:0.45rem;}
.award-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:7px;}
.award-text{font-size:0.78rem;color:var(--muted);line-height:1.5;}
.course-tags{display:flex;flex-wrap:wrap;gap:0.4rem;}
.course-tag{font-size:0.66rem;padding:0.22rem 0.5rem;border-radius:3px;border:1px solid var(--border);color:var(--muted);background:var(--card);}
.resume-box{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:2.5rem 3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;transition:border-color 0.25s;}
.resume-box:hover{border-color:var(--accent-border);}
.resume-box-left h3{font-family:'Syne',sans-serif;font-size:1.35rem;font-weight:700;letter-spacing:-0.02em;margin-bottom:0.5rem;}
.resume-box-left p{font-size:0.82rem;color:var(--muted);max-width:380px;line-height:1.65;margin-bottom:1rem;}
.resume-tags{display:flex;gap:0.45rem;flex-wrap:wrap;}
.resume-tag{font-size:0.67rem;padding:0.22rem 0.55rem;border-radius:3px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-border);}
.contact-inner{text-align:center;}
.contact-inner h2{font-family:'Syne',sans-serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:800;letter-spacing:-0.04em;margin-bottom:1rem;}
.contact-inner p{color:var(--muted);max-width:400px;margin:0 auto 2.5rem;font-size:0.86rem;line-height:1.7;}
footer{border-top:1px solid var(--border);padding:2.5rem 3rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;position:relative;z-index:1;}
footer .logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1rem;color:var(--accent);}
footer p{font-size:0.73rem;color:var(--muted);}
.fade-up{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}
@media(max-width:768px){nav{padding:1rem 1.5rem;}.nav-links{display:none;}#hero,section{padding-left:1.5rem;padding-right:1.5rem;}.about-grid{grid-template-columns:1fr;gap:2rem;}.about-left{flex-direction:row;align-items:flex-start;flex-wrap:wrap;}.edu-body{grid-template-columns:1fr;gap:1rem;}.edu-dates-badge{margin-left:0;text-align:left;}.resume-box{flex-direction:column;align-items:flex-start;}footer{padding:2rem 1.5rem;flex-direction:column;text-align:center;}.hero-scroll{left:1.5rem;}}