:root{--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: #eef2ff;--bg-color: #ffffff;--bg-alt: #fbfbfe;--text-main: #1e1b4b;--text-muted: #475569;--card-bg: #f8fafc;--border-color: #e2e8f0;--nav-height: 70px;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;min-height:100vh;scroll-behavior:smooth}body{font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--text-main);background-color:var(--bg-color);line-height:1.6;-webkit-font-smoothing:antialiased}.container{max-width:1100px;margin:0 auto;padding:0 2rem;width:100%}.section{padding:50px 0;width:100%}.section-title{font-size:3rem;font-weight:900;color:var(--primary);letter-spacing:-.03em;line-height:1.1;display:inline-block;position:relative;margin-bottom:3.5rem}.section-title:after{content:"";position:absolute;left:0;bottom:-10px;width:40px;height:4px;background:var(--primary);border-radius:2px;opacity:.3}@media(max-width:1024px){.section-title{text-align:center;width:100%;margin-left:auto;margin-right:auto}.section-title:after{left:50%;transform:translate(-50%)}}.navbar{width:100%;height:var(--nav-height);position:sticky;top:0;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);z-index:1000}.nav-content{display:flex;align-items:center;height:100%}.flex-end{justify-content:flex-end}.nav-links{display:flex;list-style:none;gap:2.5rem}.nav-links a{text-decoration:none;color:var(--text-main);font-weight:500;transition:var(--transition)}.nav-links a:hover{color:var(--primary)}.footer{padding:4rem 0;text-align:center;border-top:1px solid var(--border-color);color:var(--text-muted);font-size:.9rem}.reveal-element{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out;visibility:hidden}.reveal-element.is-visible{opacity:1;transform:translateY(0);visibility:visible}body.is-restoring-scroll #root{opacity:0;visibility:hidden;transition:none}#root{opacity:1;visibility:visible;transition:opacity .15s ease-in-out}.projects-container{display:flex;flex-direction:column;gap:3rem}.project-row{background:var(--bg-color);border:1px solid var(--border-color);border-radius:20px;transition:var(--transition);cursor:pointer;overflow:visible}.project-row-link{display:flex;align-items:center;justify-content:space-between;padding:2.5rem;gap:3rem;text-decoration:none;color:inherit;width:100%}.project-row:hover{transform:translateY(-8px);border-color:var(--primary);box-shadow:0 20px 40px #00000014}.project-image-container{flex:0 0 45%;height:280px;border-radius:12px;border:1px solid var(--border-color);perspective:1000px;overflow:visible;background:transparent}.project-image{width:100%;height:100%;object-fit:cover;border-radius:12px;transform:rotateY(-12deg) rotateX(5deg) scale(.95);transition:transform .6s cubic-bezier(.23,1,.32,1),box-shadow .6s ease;box-shadow:15px 15px 40px #0000001a}.project-row:nth-child(2n) .project-row-link{flex-direction:row-reverse;text-align:right}.project-row:nth-child(2n) .project-image{transform:rotateY(12deg) rotateX(5deg) scale(.95);box-shadow:-15px 15px 40px #0000001a}.project-row:nth-child(2n) .tags{justify-content:flex-end}.project-row:hover .project-image{transform:rotateY(0) rotateX(0) scale(1.02);box-shadow:0 20px 50px #00000026}.tags{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.25rem}.tags span{font-size:.75rem;font-weight:600;color:var(--primary);background:var(--primary-light);padding:.4rem 1rem;border-radius:100px;border:1px solid rgba(37,99,235,.1)}@media(max-width:1024px){.project-row-link{flex-direction:column!important;align-items:flex-start;padding:1.5rem;gap:1.5rem}.project-row:nth-child(2n) .project-row-link{flex-direction:column!important;text-align:left}.project-details,.project-image-container{flex:0 0 100%;width:100%}.project-row:nth-child(2n) .tags{justify-content:flex-start}.project-image-container{height:220px;perspective:none}.project-image{transform:none!important;box-shadow:0 10px 20px #0000001a}}.hero-section{padding:160px 0;min-height:70vh;display:flex;align-items:center}.hero-container{display:flex;align-items:center;position:relative}.hero-image-wrapper{width:500px;height:500px;flex-shrink:0;z-index:1}.profile-image-large{width:100%;height:100%;object-fit:cover;border-radius:40px;box-shadow:20px 20px 60px #0000001a}.hero-content{flex:1;margin-left:-160px;z-index:2}.bleed-wrapper{position:relative}.hero-name{font-size:8.5rem;font-weight:900;line-height:.9;letter-spacing:-.05em;margin:0}.hero-typing{font-size:3.5rem;font-weight:600;margin-top:.5rem}.layer-black{color:var(--primary)}.layer-white{color:#fff;position:absolute;top:0;left:0;pointer-events:none;clip-path:inset(0 calc(100% - 160px) 0 0)}.cursor{color:var(--primary);animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}@media(max-width:1024px){.hero-container{flex-direction:column;text-align:center}.hero-image-wrapper{width:320px;height:320px}.hero-content{margin-left:0;margin-top:2rem}.hero-name{font-size:4.5rem}.layer-white{display:none}}.text-center{text-align:center}.about-wrapper{position:relative;padding:220px 2rem;min-height:80vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.paint-png{position:absolute;top:50%;left:50%;width:150%;max-width:1800px;height:auto;transform:translate(-50%,-50%) rotate(-5deg);z-index:0;pointer-events:none;filter:invert(1) brightness(.95);opacity:.6;object-fit:contain}.about-left{flex:1.2;max-width:550px}.about-description{font-size:1.1rem;line-height:1.8;color:var(--text-main);text-align:justify;-webkit-hyphens:auto;hyphens:auto;max-width:600px}.about-content{position:relative;z-index:1;max-width:1200px;margin:0 auto;display:flex;justify-content:center;align-items:center;gap:6rem;width:100%;padding:0 5rem}.about-right{flex:0 0 auto}.about-image-frame{width:380px;height:380px;border-radius:32px;overflow:hidden;box-shadow:0 30px 70px #0000001f;background-color:#fff}.profile-img{width:100%;height:100%;object-fit:cover}@media(max-width:1024px){.about-wrapper{padding:140px 1.5rem}.about-content{flex-direction:column-reverse;text-align:center;gap:3.5rem;padding:0 2rem}.paint-png{width:200%;transform:translate(-50%,-50%) rotate(-12deg)}.about-image-frame{width:300px;height:300px}}.awards-container{display:flex;align-items:center;gap:4rem;margin-top:2rem}.awards-visual{flex:1;display:flex;justify-content:center}.image-frame-premium{position:relative;width:100%;max-width:450px;border-radius:24px;border:1px solid rgba(255,255,255,.2);box-shadow:0 20px 40px #0003,inset 0 0 0 1px #ffffff1a;overflow:hidden}.award-photo{width:100%;height:auto;display:block;filter:contrast(1.05)}.ambient-glow{position:absolute;top:50%;left:50%;width:120%;height:120%;background:var(--primary);opacity:.15;filter:blur(80px);transform:translate(-50%,-50%);z-index:-1}.awards-content{flex:1.2}.awards-list-sleek{display:flex;flex-direction:column;gap:2rem}.award-item{padding-bottom:2rem;border-bottom:1px solid var(--border-color);transition:border-color .3s ease}.award-item:last-child{border-bottom:none;padding-bottom:0}.award-item:hover{border-bottom-color:var(--primary)}.award-meta{font-size:.85rem;font-weight:600;color:var(--text-muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.05em}.award-date{color:var(--primary)}.award-title{font-size:1.35rem;font-weight:800;margin:0 0 .75rem;color:var(--text-main)}.award-description{font-size:.95rem;line-height:1.5;color:var(--text-muted);margin:0}@media(max-width:1024px){.awards-container{flex-direction:column;gap:1.5rem}.awards-visual{display:none}.awards-content{width:100%;padding:0 1rem}.award-title{font-size:1.2rem}}.contact-container{max-width:700px;margin:0 auto;text-align:center}.availability-tag{display:inline-flex;align-items:center;gap:.5rem;background:var(--primary-light);color:var(--primary);padding:.5rem 1rem;border-radius:100px;font-size:.85rem;font-weight:700;margin-bottom:1.5rem}.pulse-dot{width:8px;height:8px;background:var(--primary);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #2563ebb3}70%{transform:scale(1);box-shadow:0 0 0 10px #2563eb00}to{transform:scale(.95);box-shadow:0 0 #2563eb00}}.contact-subtitle{color:var(--text-muted);margin-bottom:3rem;font-size:1.1rem;line-height:1.6}.contact-main{display:flex;flex-direction:column;gap:1rem}.contact-card{display:flex;align-items:center;padding:1.5rem;border-radius:16px;text-decoration:none;transition:all .3s ease;border:1px solid var(--border-color);background:var(--card-bg)}.contact-card.primary{background:var(--primary);color:#fff;gap:1.5rem;text-align:left;padding:1.5rem}.contact-card.primary:hover{transform:translateY(-4px);box-shadow:0 20px 40px #2563eb33}.card-info span{font-size:.8rem;opacity:.8;display:block}.card-info strong{font-size:1.2rem}.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.contact-card.secondary{justify-content:center;gap:.75rem;color:var(--text-main);font-weight:600}.contact-card.secondary:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.arrow{margin-left:auto;opacity:.6}.resume-cta{background:var(--primary-dark, #1e40af)!important}.semester-block{margin-bottom:4rem}.semester-term{font-size:1.1rem;color:var(--text-muted);margin-bottom:1.5rem;text-transform:uppercase;font-weight:600}.module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.module-card{background:var(--card-bg);padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border-color);border-radius:12px;transition:var(--transition)}.module-header-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.1rem}.top-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;color:var(--primary);background:var(--primary-light);padding:.15rem .5rem;border-radius:4px;letter-spacing:.02em}.module-info{display:flex;flex-direction:column;flex:1}.module-code{font-weight:700;color:var(--text-main)}.module-name{font-size:.8rem;color:var(--text-muted);line-height:1.2}.module-grade{font-weight:800;color:var(--primary);background:var(--primary-light);width:48px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0}.module-card:hover{border-color:var(--primary);transform:translateY(-2px)}
