@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-tertiary:#1a1a2e;--text-primary:#e4e4e7;--text-secondary:#a1a1aa;--text-tertiary:#71717a;--accent-primary:#6366f1;--accent-secondary:#06b6d4;--accent-gradient:linear-gradient(135deg, #6366f1, #06b6d4);--accent-gradient-text:linear-gradient(135deg, #818cf8, #22d3ee);--border-color:#ffffff0f;--border-color-hover:#ffffff1f;--glow:0 0 40px #6366f126;--glow-strong:0 0 60px #6366f140;--card-bg:#12121acc;--card-bg-hover:#1a1a2ee6;--glass-bg:#12121a99;--glass-border:#ffffff14;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--particle-color:#6366f14d;--particle-color-secondary:#06b6d433;--scrollbar-thumb:#6366f14d;--scrollbar-track:#0a0a0f80;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-heading:"Space Grotesk", "Inter", sans-serif;--section-padding:100px 0;--container-width:1200px;--container-padding:0 24px;--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:16px;--border-radius-xl:24px;--transition-fast:.2s ease;--transition-normal:.3s ease;--transition-slow:.5s ease;--z-back:-1;--z-normal:1;--z-tooltip:10;--z-sticky:50;--z-nav:100;--z-modal:200;--z-overlay:300}[data-theme=light]{--bg-primary:#f8f9fc;--bg-secondary:#fff;--bg-tertiary:#eef0f6;--text-primary:#1a1a2e;--text-secondary:#64748b;--text-tertiary:#94a3b8;--accent-primary:#4f46e5;--accent-secondary:#0891b2;--accent-gradient:linear-gradient(135deg, #4f46e5, #0891b2);--accent-gradient-text:linear-gradient(135deg, #4f46e5, #0891b2);--border-color:#00000014;--border-color-hover:#00000026;--glow:0 0 40px #4f46e51a;--glow-strong:0 0 60px #4f46e526;--card-bg:#ffffffe6;--card-bg-hover:#fff;--glass-bg:#ffffffb3;--glass-border:#0000000f;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 20px #00000014;--shadow-lg:0 8px 40px #0000001f;--particle-color:#4f46e526;--particle-color-secondary:#0891b21a;--scrollbar-thumb:#4f46e54d;--scrollbar-track:#f8f9fc80}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.7;transition:background-color .4s,color .4s;overflow-x:hidden}body::-webkit-scrollbar{width:8px}body::-webkit-scrollbar-track{background:var(--scrollbar-track)}body::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}a{color:var(--accent-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-secondary)}ul,ol{list-style:none}img{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;outline:none;font-family:inherit}.container{max-width:var(--container-width);padding:var(--container-padding);margin:0 auto}.gradient-text{background:var(--accent-gradient-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.section{padding:var(--section-padding);position:relative}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border)}::selection{background:var(--accent-primary);color:#fff}.scroll-progress{background:var(--accent-gradient);z-index:999;width:0%;height:3px;transition:width 50ms linear;position:fixed;top:0;left:0}.theme-toggle{background:var(--card-bg);border:1px solid var(--border-color);width:42px;height:42px;color:var(--accent-primary);transition:background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--card-bg-hover);border-color:var(--accent-primary);box-shadow:var(--glow)}.navbar{width:100%;z-index:var(--z-nav);transition:background var(--transition-normal), padding var(--transition-normal), box-shadow var(--transition-normal);padding:16px 0;position:fixed;top:0;left:0}.navbar--scrolled{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-border);box-shadow:var(--shadow-sm);padding:10px 0}.navbar__container{justify-content:space-between;align-items:center;display:flex}.nav-logo{font-family:var(--font-heading);color:var(--text-primary);transition:color var(--transition-fast);align-items:center;gap:2px;font-size:1.3rem;font-weight:700;text-decoration:none;display:flex}.nav-logo:hover{color:var(--accent-primary)}.nav-logo__bracket{color:var(--accent-primary);font-weight:400}.nav-logo__name{background:var(--accent-gradient-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.navbar__links{align-items:center;gap:32px;display:flex}.nav-link{color:var(--text-secondary);transition:color var(--transition-fast);padding:4px 0;font-size:.9rem;font-weight:500;text-decoration:none;position:relative}.nav-link:after{content:"";background:var(--accent-gradient);width:0;height:2px;transition:width var(--transition-normal);border-radius:2px;position:absolute;bottom:-2px;left:0}.nav-link:hover,.nav-link--active{color:var(--text-primary)}.nav-link:hover:after,.nav-link--active:after{width:100%}.navbar__actions{align-items:center;gap:12px;display:flex}.navbar__hamburger{color:var(--text-primary);background:0 0;border:none;padding:4px;display:none}.navbar__theme-mobile,.navbar__backdrop{display:none}@media (width<=768px){.navbar__links{background:var(--bg-secondary);width:280px;height:100vh;transition:right var(--transition-normal);z-index:var(--z-overlay);border-left:1px solid var(--border-color);box-shadow:var(--shadow-lg);flex-direction:column;justify-content:center;gap:24px;position:fixed;top:0;right:-100%}.navbar__links--open{right:0}.nav-link{font-size:1.1rem}.navbar__hamburger{z-index:calc(var(--z-overlay) + 1);display:flex}.navbar__actions>.theme-toggle{display:none}.navbar__theme-mobile{margin-top:16px;display:block}.navbar__backdrop{z-index:calc(var(--z-overlay) - 1);background:#00000080;display:block;position:fixed;inset:0}}.particle-background{z-index:0;pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.hero{justify-content:center;align-items:center;min-height:100vh;padding-top:80px;display:flex;position:relative;overflow:hidden}.hero__orb{filter:blur(80px);opacity:.4;pointer-events:none;z-index:0;border-radius:50%;position:absolute}.hero__orb--1{background:radial-gradient(circle,#6366f159,#0000 70%);width:500px;height:500px;top:-100px;left:-150px}.hero__orb--2{background:radial-gradient(circle,#06b6d44d,#0000 70%);width:400px;height:400px;bottom:-80px;right:-100px}.hero__orb--3{background:radial-gradient(circle,#a855f740,#0000 70%);width:250px;height:250px;top:40%;left:50%}.hero__content{z-index:var(--z-normal);grid-template-columns:1fr 1fr;align-items:center;gap:40px;width:100%;display:grid;position:relative}.hero__text{text-align:left}.hero__greeting{color:var(--accent-primary);letter-spacing:3px;text-transform:uppercase;align-items:center;gap:10px;margin-bottom:12px;font-size:1rem;font-weight:600;display:inline-flex}.hero__greeting:before{content:"";background:var(--accent-gradient);border-radius:2px;width:32px;height:2px;display:inline-block}.hero__name{font-family:var(--font-heading);margin-bottom:16px;font-size:clamp(2.5rem,5.5vw,4.2rem);font-weight:700;line-height:1.1}.hero__role-wrapper{color:var(--text-secondary);min-height:2em;margin-bottom:20px;font-size:clamp(1.1rem,2.5vw,1.5rem)}.hero__role-prefix{color:var(--text-secondary)}.hero__role{color:var(--accent-secondary);font-weight:600}.hero__cursor{color:var(--accent-primary);font-weight:300;animation:1s step-end infinite blink}@keyframes blink{50%{opacity:0}}.hero__tagline{color:var(--text-tertiary);max-width:480px;margin-bottom:28px;font-size:1.05rem;line-height:1.8}.hero__ctas{flex-wrap:wrap;gap:16px;margin-bottom:28px;display:flex}.hero__cta{border-radius:var(--border-radius-md);transition:all var(--transition-normal);align-items:center;gap:8px;padding:14px 28px;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.hero__cta--primary{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 20px #6366f14d}.hero__cta--primary:after{content:"";opacity:0;background:linear-gradient(135deg,#fff3,#0000);transition:opacity .3s;position:absolute;inset:0}.hero__cta--primary:hover{color:#fff;transform:translateY(-3px)scale(1.02);box-shadow:0 8px 35px #6366f173}.hero__cta--primary:hover:after{opacity:1}.hero__cta--secondary{color:var(--text-primary);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:0 0}.hero__cta--secondary:hover{border-color:var(--accent-primary);background:#6366f114;transform:translateY(-3px)scale(1.02);box-shadow:0 4px 20px #6366f126}.hero__socials{gap:14px;display:flex}.hero__social-link{border:1px solid var(--border-color);width:46px;height:46px;color:var(--text-secondary);transition:all var(--transition-normal);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.hero__social-link:before{content:"";background:var(--accent-gradient);opacity:0;z-index:-1;border-radius:50%;transition:opacity .3s;position:absolute;inset:0}.hero__social-link:hover{color:#fff;border-color:#0000;transform:translateY(-4px)scale(1.1);box-shadow:0 6px 25px #6366f159}.hero__social-link:hover:before{opacity:1}.hero__visual{justify-content:center;align-items:center;display:flex;position:relative}.hero__phone-wrapper{position:relative}.hero__phone{-webkit-backdrop-filter:blur(20px);z-index:2;background:#1e1e3299;border:2px solid #ffffff1f;border-radius:38px;width:260px;height:500px;position:relative;overflow:hidden;box-shadow:0 25px 80px #0006,inset 0 0 0 1px #ffffff0d,0 0 100px #6366f114}[data-theme=light] .hero__phone{background:#ffffffd9;border:2px solid #00000014;box-shadow:0 25px 80px #0000001f,inset 0 0 0 1px #00000008,0 0 100px #4f46e50f}.hero__phone-notch{z-index:5;background:#000000d9;border-radius:14px;width:110px;height:28px;position:absolute;top:10px;left:50%;transform:translate(-50%)}[data-theme=light] .hero__phone-notch{background:#0000001f}.hero__phone-notch:after{content:"";background:#6366f199;border-radius:50%;width:8px;height:8px;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.hero__phone-screen{border-radius:38px;width:100%;height:100%;padding:6px;overflow:hidden}.hero__phone-screen img{object-fit:cover;border-radius:34px;width:100%;height:100%}.hero__floating-badge{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);color:var(--text-primary);white-space:nowrap;z-index:3;box-shadow:var(--shadow-md);border-radius:50px;align-items:center;gap:8px;padding:10px 18px;font-size:.8rem;font-weight:600;display:flex;position:absolute}.hero__floating-badge-icon{border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;font-size:.85rem;display:flex}.hero__floating-badge--java{top:60px;left:-40px}.hero__floating-badge--react{bottom:120px;left:-50px}.hero__floating-badge--spring{top:100px;right:-30px}.hero__floating-badge--cloud{bottom:60px;right:-40px}.hero__phone-glow{background:var(--accent-gradient);opacity:.12;filter:blur(40px);z-index:0;pointer-events:none;border-radius:48px;width:300px;height:540px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hero__scroll-indicator{color:var(--text-tertiary);letter-spacing:1px;z-index:var(--z-normal);flex-direction:column;align-items:center;gap:4px;font-size:.75rem;display:flex;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes floatReverse{0%,to{transform:translateY(0)}50%{transform:translateY(12px)}}@keyframes pulse-ring{0%{opacity:.12;transform:translate(-50%,-50%)scale(1)}50%{opacity:.2;transform:translate(-50%,-50%)scale(1.05)}to{opacity:.12;transform:translate(-50%,-50%)scale(1)}}.hero__phone-glow{animation:4s ease-in-out infinite pulse-ring}.hero__phone-status{color:#ffffff80;z-index:6;pointer-events:none;justify-content:space-between;align-items:center;font-size:.65rem;font-weight:600;display:flex;position:absolute;top:14px;left:20px;right:20px}[data-theme=light] .hero__phone-status{color:#00000059}@media (width<=1024px){.hero__content{text-align:center;grid-template-columns:1fr;gap:50px}.hero__text{text-align:center;order:2}.hero__visual{order:1}.hero__greeting:before{display:none}.hero__tagline{margin-left:auto;margin-right:auto}.hero__ctas,.hero__socials{justify-content:center}.hero__phone{width:240px;height:480px}.hero__phone-glow{width:280px;height:520px}.hero__floating-badge--java{top:20px;left:-20px}.hero__floating-badge--react{bottom:80px;left:-30px}.hero__floating-badge--spring{top:60px;right:-10px}.hero__floating-badge--cloud{bottom:30px;right:-20px}}@media (width<=640px){.hero__phone{border-radius:32px;width:200px;height:400px}.hero__phone-screen{border-radius:30px}.hero__phone-screen img{border-radius:26px}.hero__phone-notch{border-radius:12px;width:90px;height:22px}.hero__phone-glow{border-radius:40px;width:240px;height:440px}.hero__floating-badge{padding:8px 12px;font-size:.7rem}.hero__floating-badge-icon{width:20px;height:20px;font-size:.75rem}.hero__orb--1{width:300px;height:300px}.hero__orb--2{width:250px;height:250px}.hero__orb--3{width:150px;height:150px}}.section-header{text-align:center;margin-bottom:60px}.section-header__number{font-family:var(--font-heading);color:var(--accent-primary);letter-spacing:3px;text-transform:uppercase;margin-bottom:12px;font-size:.875rem;font-weight:600;display:inline-block}.section-header__title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:12px;font-size:clamp(2rem,4vw,2.75rem);font-weight:700;line-height:1.2}.section-header__subtitle{color:var(--text-secondary);max-width:600px;margin:0 auto 20px;font-size:1.05rem;line-height:1.6}.section-header__line{background:var(--accent-gradient);transform-origin:0;border-radius:2px;width:60px;height:3px;margin:0 auto}.about__grid{grid-template-columns:350px 1fr;align-items:center;gap:60px;margin-bottom:60px;display:grid}.about__image-wrapper{border-radius:var(--border-radius-xl);position:relative;overflow:hidden}.about__image{border-radius:var(--border-radius-xl);z-index:2;width:100%;position:relative}.about__image-glow{background:var(--accent-gradient);border-radius:var(--border-radius-xl);filter:blur(40px);opacity:.15;z-index:0;position:absolute;inset:-20px}.about__image-border{background:var(--accent-gradient);border-radius:calc(var(--border-radius-xl) + 3px);z-index:1;opacity:.5;position:absolute;inset:-3px}.about__text{flex-direction:column;gap:16px;display:flex}.about__intro{font-size:1.15rem;line-height:1.8}.about__text p{color:var(--text-secondary);line-height:1.8}.about__text strong{color:var(--text-primary)}.about__stats{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.stat-card{text-align:center;border-radius:var(--border-radius-lg);transition:transform var(--transition-normal), box-shadow var(--transition-normal);padding:28px 20px}.stat-card:hover{box-shadow:var(--glow);transform:translateY(-4px)}.stat-card__value{font-family:var(--font-heading);margin-bottom:4px;font-size:2.5rem;font-weight:700;display:block}.stat-card__label{color:var(--text-secondary);font-size:.85rem;font-weight:500}@media (width<=900px){.about__grid{grid-template-columns:1fr;gap:40px}.about__image-wrapper{max-width:300px;margin:0 auto}}@media (width<=600px){.about__stats{grid-template-columns:repeat(2,1fr)}}.skills__grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.skill-card{border-radius:var(--border-radius-lg);transition:transform var(--transition-normal), box-shadow var(--transition-normal), border-color var(--transition-normal);padding:28px}.skill-card:hover{box-shadow:var(--glow);border-color:var(--accent-primary);transform:translateY(-4px)scale(1.01)}.skill-card--large,.skill-card--medium,.skill-card--small{grid-column:span 1}.skill-card__header{align-items:center;gap:12px;margin-bottom:18px;display:flex}.skill-card__icon{border-radius:var(--border-radius-sm);background:#6366f11a;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.5rem;display:flex}.skill-card__title{font-family:var(--font-heading);color:var(--text-primary);font-size:1rem;font-weight:600}.skill-card__items{flex-wrap:wrap;gap:8px;display:flex}.skill-tag{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);transition:all var(--transition-fast);border-radius:100px;padding:6px 14px;font-size:.8rem;font-weight:500;display:inline-block}.skill-tag:hover{color:var(--accent-primary);border-color:var(--accent-primary);background:#6366f114}@media (width<=900px){.skills__grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.skills__grid{grid-template-columns:1fr}}.timeline{max-width:900px;margin:0 auto;padding:20px 0;position:relative}.timeline__line{background:var(--border-color);width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline__line-fill{background:var(--accent-gradient);border-radius:2px;width:100%;height:100%}.timeline__item{margin-bottom:50px;display:flex;position:relative}.timeline__item--left{justify-content:flex-start;padding-right:calc(50% + 40px)}.timeline__item--right{justify-content:flex-end;padding-left:calc(50% + 40px)}.timeline__dot{z-index:2;width:16px;height:16px;position:absolute;top:30px;left:50%;transform:translate(-50%)}.timeline__dot-inner{background:var(--accent-gradient);width:16px;height:16px;box-shadow:var(--glow);border-radius:50%;display:block}.timeline__card{border-radius:var(--border-radius-lg);width:100%;transition:transform var(--transition-normal), box-shadow var(--transition-normal);padding:28px}.timeline__card:hover{box-shadow:var(--glow);transform:translateY(-2px)}.timeline__card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.timeline__domain-badge{color:var(--accent-primary);text-transform:uppercase;letter-spacing:1px;background:#6366f11f;border-radius:100px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-block}.timeline__duration{color:var(--text-tertiary);font-size:.8rem;font-weight:500}.timeline__role{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:4px;font-size:1.15rem;font-weight:600}.timeline__company{color:var(--accent-secondary);margin-bottom:16px;font-size:.95rem;font-weight:500}.timeline__tech-tags{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.timeline__tech-tags .skill-tag{padding:4px 10px;font-size:.72rem}.timeline__responsibilities{max-height:0;transition:max-height var(--transition-slow);overflow:hidden}.timeline__responsibilities--expanded{max-height:500px}.timeline__responsibilities ul{padding-left:0}.timeline__responsibilities li{color:var(--text-secondary);margin-bottom:8px;padding-left:18px;font-size:.88rem;line-height:1.6;position:relative}.timeline__responsibilities li:before{content:"▹";color:var(--accent-primary);position:absolute;left:0}.timeline__read-more{color:var(--accent-primary);transition:color var(--transition-fast);padding:6px 0;font-size:.85rem;font-weight:600}.timeline__read-more:hover{color:var(--accent-secondary)}@media (width<=768px){.timeline__line{left:20px}.timeline__item--left,.timeline__item--right{justify-content:flex-start;padding-left:56px;padding-right:0}.timeline__dot{left:20px}}.image-viewer{z-index:10000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.image-viewer__backdrop{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;background:#0a0a0fe6;position:absolute;inset:0}.image-viewer__controls{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;gap:12px;padding:8px;display:flex;position:absolute;top:30px;right:30px}.image-viewer__controls button{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;transition:all .2s;display:flex}.image-viewer__controls button:hover{color:var(--accent-primary,#6366f1);background:#ffffff1a;transform:translateY(-2px)}.image-viewer__close{margin-left:4px;border-left:1px solid #ffffff1a!important;border-radius:0 8px 8px 0!important}.image-viewer__img-container{z-index:5;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;width:90vw;height:80vh;display:flex;position:relative}.image-viewer__img-container img{object-fit:contain;border-radius:4px;max-width:100%;max-height:100%;box-shadow:0 25px 50px -12px #00000080}.image-viewer__hint{color:#ffffff80;pointer-events:none;background:#0000004d;border-radius:100px;padding:6px 16px;font-size:.85rem;animation:.5s ease-out fadeIn;position:absolute;bottom:40px;left:50%;transform:translate(-50%)}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}@media (width<=768px){.image-viewer__controls{padding:4px;top:20px;right:20px}.image-viewer__controls button{width:36px;height:36px;font-size:1rem}}.projects__filters{flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:40px;display:flex}.projects__filter-btn{color:var(--text-secondary);border:1px solid var(--border-color);transition:all var(--transition-normal);cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:6px;padding:10px 22px;font-size:.85rem;font-weight:600;display:inline-flex}.projects__filter-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#6366f10f}.projects__filter-btn--active{background:var(--accent-gradient);color:#fff;border-color:#0000}.projects__filter-btn--active:hover{color:#fff}.projects__filter-count{background:#fff3;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;font-size:.7rem;font-weight:700;line-height:1;display:inline-flex}.projects__filter-btn:not(.projects__filter-btn--active) .projects__filter-count{color:var(--accent-primary);background:#6366f11f}.projects__grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.project-card{border-radius:var(--border-radius-lg);transition:transform var(--transition-normal), box-shadow var(--transition-normal), border-color var(--transition-normal);background:var(--card-bg);flex-direction:column;display:flex;overflow:hidden}.project-card__image-wrapper{aspect-ratio:16/10;cursor:pointer;width:100%;position:relative;overflow:hidden}.project-card__img{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.2,.8,.2,1)}.project-card__image-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;background:#0f172a80;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.project-card__image-label{color:#fff;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:100px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:transform .3s;transform:translateY(10px)}.project-card:hover .project-card__img{transform:scale(1.1)}.project-card:hover .project-card__image-overlay{opacity:1}.project-card:hover .project-card__image-label{transform:translateY(0)}.project-card__content{flex-direction:column;flex:1;padding:24px;display:flex}.project-card:hover{box-shadow:var(--glow);border-color:var(--accent-primary);transform:translateY(-4px)}.project-card--featured{background:var(--card-bg);border-color:#6366f133;grid-column:span 2}.project-card__header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.project-card__header-right{align-items:center;gap:6px;display:flex}.project-card__domain{color:var(--accent-primary);text-transform:uppercase;letter-spacing:1px;background:#6366f11f;border-radius:100px;padding:4px 12px;font-size:.72rem;font-weight:600;display:inline-block}.project-card__featured-badge{background:var(--accent-gradient);color:#fff;text-transform:uppercase;letter-spacing:1px;border-radius:100px;padding:4px 12px;font-size:.72rem;font-weight:700}.project-card__oss-badge{color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.5px;background:#06b6d41f;border-radius:100px;padding:4px 10px;font-size:.68rem;font-weight:700}.project-card__name{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:4px;font-size:1.3rem;font-weight:700}.project-card__client{color:var(--accent-secondary);margin-bottom:12px;font-size:.85rem;font-weight:500}.project-card__desc{color:var(--text-secondary);flex:1;margin-bottom:20px;font-size:.9rem;line-height:1.7}.project-card__tech{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.project-card__tech .skill-tag{padding:4px 10px;font-size:.72rem}.project-card__actions{gap:12px;margin-top:auto;display:flex}.project-card__btn{border-radius:var(--border-radius-sm);background:var(--accent-gradient);color:#fff;transition:all var(--transition-normal);align-items:center;gap:6px;padding:10px 20px;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-flex}.project-card__btn:hover{color:#fff;transform:translateY(-2px);box-shadow:0 4px 15px #6366f14d}.project-card__btn--outline{border:1px solid var(--border-color);color:var(--text-primary);background:0 0}.project-card__btn--outline:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#6366f114}.project-modal{z-index:var(--z-modal);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.project-modal__overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;position:absolute;inset:0}.project-modal__content{border-radius:var(--border-radius-xl);background:var(--bg-secondary);border:1px solid var(--border-color);z-index:2;width:100%;max-width:700px;max-height:80vh;padding:36px;position:relative;overflow-y:auto}.project-modal__close{color:var(--text-secondary);transition:color var(--transition-fast);padding:4px;position:absolute;top:16px;right:16px}.project-modal__close:hover{color:var(--accent-primary)}.project-modal__image-wrapper{aspect-ratio:16/9;border-radius:var(--border-radius-md);border:1px solid var(--border-color);cursor:zoom-in;width:100%;margin-bottom:24px;position:relative;overflow:hidden}.project-modal__image-hint{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;opacity:0;pointer-events:none;background:#0009;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;transition:all .3s;display:flex;position:absolute;bottom:12px;right:12px;transform:translateY(10px)}.project-modal__image-wrapper:hover .project-modal__image-hint{opacity:1;transform:translateY(0)}.project-modal__img{object-fit:cover;width:100%;height:100%}.project-modal__header{margin-bottom:20px}.project-modal__badges{align-items:center;gap:8px;display:flex}.project-modal__name{font-family:var(--font-heading);color:var(--text-primary);margin:8px 0 4px;font-size:1.5rem;font-weight:700}.project-modal__client{color:var(--accent-secondary);font-size:.9rem}.project-modal__tech{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.project-modal__desc{color:var(--text-secondary);margin-bottom:24px;font-size:.95rem;line-height:1.7}.project-modal__resp-title{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:12px;font-size:1rem;font-weight:600}.project-modal__list{padding-left:0}.project-modal__list li{color:var(--text-secondary);margin-bottom:10px;padding-left:20px;font-size:.88rem;line-height:1.7;position:relative}.project-modal__list li:before{content:"▹";color:var(--accent-primary);position:absolute;left:0}.project-modal__github-btn{border-radius:var(--border-radius-sm);color:var(--text-primary);border:1px solid var(--border-color);transition:all var(--transition-normal);background:0 0;align-items:center;gap:8px;margin-top:24px;padding:12px 24px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.project-modal__github-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#6366f114;transform:translateY(-2px)}@media (width<=1100px){.projects__grid{grid-template-columns:repeat(2,1fr)}.project-card--featured{grid-column:span 2}}@media (width<=768px){.projects__grid{grid-template-columns:1fr}.project-card--featured{grid-column:span 1}}.education__card{border-radius:var(--border-radius-xl);max-width:700px;transition:transform var(--transition-normal), box-shadow var(--transition-normal);margin:0 auto;padding:40px}.education__card:hover{box-shadow:var(--glow);transform:translateY(-4px)}.education__content{justify-content:space-between;align-items:center;gap:40px;display:flex}.education__info{flex:1}.education__icon-wrapper{width:56px;height:56px;color:var(--accent-primary);border-radius:var(--border-radius-md);background:#6366f11a;justify-content:center;align-items:center;margin-bottom:20px;display:flex}.education__degree{font-family:var(--font-heading);color:var(--text-primary);margin-bottom:8px;font-size:1.3rem;font-weight:700}.education__university{color:var(--accent-secondary);margin-bottom:16px;font-size:1.05rem;font-weight:600}.education__meta{flex-direction:column;gap:8px;display:flex}.education__meta-item{color:var(--text-secondary);align-items:center;gap:8px;font-size:.88rem;display:flex}.education__cgpa{flex-direction:column;align-items:center;gap:8px;display:flex}.cgpa-ring{justify-content:center;align-items:center;display:flex;position:relative}.cgpa-ring__label{text-align:center;position:absolute}.cgpa-ring__value{font-family:var(--font-heading);color:var(--text-primary);font-size:1.4rem;font-weight:700;display:block}.cgpa-ring__max{color:var(--text-tertiary);font-size:.75rem}.education__cgpa-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:2px;font-size:.8rem;font-weight:600}@media (width<=600px){.education__content{text-align:center;flex-direction:column}.education__icon-wrapper{margin:0 auto 20px}.education__meta{align-items:center}}.contact{padding-bottom:0;position:relative;overflow:hidden}.contact__orb{filter:blur(80px);z-index:0;opacity:.15;pointer-events:none;border-radius:50%;width:300px;height:300px;position:absolute}.contact__orb--1{background:var(--accent-primary);top:10%;right:-5%}.contact__orb--2{background:var(--accent-secondary);bottom:20%;left:-5%}.contact__info-grid{z-index:1;grid-template-columns:repeat(2,1fr);gap:24px;max-width:900px;margin:0 auto;display:grid;position:relative}.contact__info-card{border-radius:var(--border-radius-xl);transition:all var(--transition-normal);background:#ffffff08;border:1px solid #ffffff14;align-items:center;gap:24px;padding:32px;text-decoration:none;display:flex}.contact__info-card:hover{border-color:var(--accent-primary);background:#ffffff0d;transform:translateY(-5px);box-shadow:0 20px 40px #0003}.contact__info-icon{width:64px;height:64px;color:var(--accent-primary);transition:all var(--transition-normal);background:#6366f11a;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;display:flex}.contact__info-card:hover .contact__info-icon{background:var(--accent-gradient);color:#fff;transform:rotate(10deg)scale(1.1)}.contact__info-content{flex-direction:column;display:flex}.contact__info-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:2px;margin-bottom:4px;font-size:.75rem;font-weight:700}.contact__info-value{color:var(--text-primary);margin-bottom:4px;font-size:1.1rem;font-weight:600}.contact__info-desc{color:var(--text-secondary);font-size:.85rem}.contact__cta{text-align:center;z-index:1;margin-top:60px;position:relative}.contact__cta-text{color:var(--text-secondary);margin-bottom:24px;font-size:1.1rem}.contact__cta-btn{background:var(--accent-gradient);color:#fff;transition:all var(--transition-normal);border-radius:100px;align-items:center;gap:10px;padding:16px 40px;font-size:1rem;font-weight:700;text-decoration:none;display:inline-flex;box-shadow:0 10px 20px #6366f14d}.contact__cta-btn:hover{transform:translateY(-4px)scale(1.05);box-shadow:0 15px 35px #6366f166}.footer{border-top:1px solid var(--border-color);background:#0000000d;margin-top:100px;padding:40px 0}.footer__text{text-align:center;color:var(--text-secondary);justify-content:center;align-items:center;gap:6px;font-size:.9rem;display:flex}.footer__heart{color:#ef4444;animation:1.5s infinite heartBeat}@keyframes heartBeat{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}@media (width<=900px){.contact__info-grid{grid-template-columns:1fr;max-width:500px}}@media (width<=480px){.contact__info-card{text-align:center;flex-direction:column;padding:24px}.contact__info-value{font-size:1rem}}.app{min-height:100vh}main>section{position:relative}main>section:nth-child(2n){background:var(--bg-secondary)}
