﻿:root{--c-navy:#0f1117;--c-indigo:#6366f1;--c-cream:#faf9f6;--c-navy-mid:#1a1d2e;--c-indigo-soft:rgba(99,102,241,0.10);--c-indigo-glow:rgba(99,102,241,0.22);--c-cream-dim:#f0ede8;--text-dark:var(--c-navy);--text-mid:#4a4a5a;--text-light:#8888a0;--border:rgba(99,102,241,0.10);--font-display:'Plus Jakarta Sans',system-ui,sans-serif;--font-sans:'Inter',system-ui,sans-serif;--glass-bg:rgba(255,255,255,0.52);--glass-bg-deep:rgba(255,255,255,0.68);--glass-border:rgba(255,255,255,0.78);--glass-blur:blur(12px) saturate(150%) brightness(1.02);--glass-shadow:0 8px 40px rgba(99,102,241,0.10),0 2px 8px rgba(0,0,0,0.06),inset 0 1.5px 0 rgba(255,255,255,0.95),inset 0 -1px 0 rgba(99,102,241,0.05);}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-sans);color:var(--text-dark);background:var(--c-cream);overflow-x:hidden;}html{overflow-x:hidden;}
.container{max-width:1200px;margin:0 auto;padding:40px 20px;}
p{font-family:var(--font-sans);font-size:1rem;line-height:1.75;color:var(--text-mid);}
h3{font-family:var(--font-display);font-size:1.15rem;font-weight:700;letter-spacing:-0.3px;color:var(--text-dark);margin-bottom:8px;}
.main-title{font-family:var(--font-display);font-size:clamp(3.2rem,5.5vw,5.5rem);font-weight:800;line-height:1.02;letter-spacing:-2px;color:var(--text-dark);}
.section-title{font-family:var(--font-display);font-size:clamp(2.4rem,3.8vw,3.6rem);font-weight:800;line-height:1.08;letter-spacing:-1.5px;color:var(--text-dark);}
.hero-title{font-family:var(--font-display);font-size:clamp(3.4rem,6vw,6rem);font-weight:800;line-height:1.0;letter-spacing:-2.5px;color:var(--text-dark);}
.gradient-text{background:linear-gradient(135deg,var(--c-indigo) 0%,#818cf8 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.section-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:0.7rem;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--c-indigo);margin-bottom:14px;}
.section-eyebrow::before{content:'';display:inline-block;width:22px;height:1.5px;background:var(--c-indigo);border-radius:2px;}
.section-head{display:flex;flex-direction:column;gap:0;margin-bottom:32px;}
section{position:relative;}
section::after{content:'';position:absolute;bottom:0;left:0;right:0;height:120px;pointer-events:none;z-index:2;}
.image-placeholder{background:linear-gradient(135deg,#d4d2e8 0%,#b8b5d4 100%);border-radius:24px;display:flex;align-items:center;justify-content:center;color:var(--text-light);font-weight:600;overflow:hidden;}
.glass-card{background:var(--glass-bg-deep);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:28px;box-shadow:var(--glass-shadow);position:relative;overflow:hidden;transition:transform 0.35s cubic-bezier(0.22,1,0.36,1),box-shadow 0.35s;}
.glass-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.9),transparent);}
.glass-card:hover{transform:translateY(-6px);box-shadow:0 32px 64px rgba(99,102,241,0.13),inset 0 1.5px 0 rgba(255,255,255,0.98);}
.preloader-overlay{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:32px;background:linear-gradient(180deg,rgba(11,14,24,0.94),rgba(29,35,61,0.95));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);}
.preloader-panel{width:min(92vw,720px);max-height:calc(100vh - 48px);overflow:hidden;padding:34px;}
.preloader-header{margin-bottom:26px;}
.preloader-badge{display:inline-flex;padding:8px 16px;border-radius:999px;font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;background:rgba(99,102,241,0.14);color:#e4e8ff;}
.preloader-title{margin:18px 0 10px;font-family:var(--font-display);font-size:clamp(2rem,3vw,3.3rem);line-height:1.05;color:#ffffff;}
.preloader-desc{max-width:560px;font-size:0.98rem;line-height:1.75;color:rgba(255,255,255,0.82);}
.preloader-console{background:rgba(10,12,24,0.82);border:1px solid rgba(255,255,255,0.08);border-radius:26px;padding:24px;display:grid;gap:14px;}
.console-line{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;font-size:0.95rem;color:rgba(222,229,255,0.95);min-height:1.45rem;overflow:hidden;position:relative;}
.console-line::after{content:'';position:absolute;right:0;top:0;width:8px;height:1rem;background:linear-gradient(180deg,rgba(255,255,255,0.95),rgba(255,255,255,0.12));animation:consoleCaret 0.8s steps(2,end) infinite;}
.console-progress{height:10px;border-radius:999px;background:rgba(255,255,255,0.08);overflow:hidden;}
.console-progress-bar{width:0%;height:100%;border-radius:999px;background:linear-gradient(90deg,rgba(99,102,241,0.95),rgba(132,123,255,0.95));transition:width 0.3s ease;}
.preloader-hidden{opacity:0;pointer-events:none;transform:translateY(-12px);transition:opacity 0.6s ease,transform 0.6s ease;}
@keyframes consoleCaret{0%,100%{opacity:0;}50%{opacity:1;}}
@media(max-width:768px){
    .preloader-overlay{padding:18px;}
    .preloader-panel{padding:24px;max-height:calc(100vh - 36px);}
    .preloader-title{font-size:clamp(1.6rem,6vw,2.4rem);}
    .preloader-desc{font-size:0.92rem;line-height:1.6;}
    .preloader-console{padding:18px;gap:12px;}
    .console-line{font-size:0.88rem;min-height:1.3rem;}
    .console-line::after{height:0.9rem;}
    .console-progress{height:8px;}
}
@media(max-width:480px){
    .preloader-overlay{padding:12px;}
    .preloader-panel{padding:18px;}
    .preloader-title{font-size:clamp(1.4rem,7vw,2rem);}
    .preloader-desc{font-size:0.84rem;}
}
.tech-tag{padding:5px 14px;border-radius:50px;font-size:0.78rem;font-weight:600;background:var(--c-indigo-soft);border:1px solid rgba(99,102,241,0.18);color:var(--c-indigo);}
.btn-primary{text-decoration:none;background:var(--c-indigo);color:#fff;padding:14px 30px;border-radius:50px;font-size:0.92rem;font-weight:600;transition:background 0.2s,transform 0.18s,box-shadow 0.2s;box-shadow:0 4px 24px var(--c-indigo-glow);}
.btn-primary:hover{background:#4f52e0;transform:translateY(-2px);box-shadow:0 8px 32px var(--c-indigo-glow);}
.btn-ghost{text-decoration:none;color:var(--c-navy);padding:14px 30px;border-radius:50px;font-size:0.92rem;font-weight:600;border:1.5px solid rgba(99,102,241,0.25);transition:border-color 0.2s,background 0.2s;}
.btn-ghost:hover{background:var(--c-indigo-soft);border-color:var(--c-indigo);}

.main-nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;justify-content:center;padding:16px 24px;pointer-events:none;transition:padding 0.4s cubic-bezier(0.22,1,0.36,1);}
.main-nav.scrolled{padding:10px 24px;}
.nav-container{pointer-events:all;display:flex;align-items:center;gap:4px;padding:6px 6px 6px 14px;border-radius:50px;background:rgba(255,255,255,0.55);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border:1px solid rgba(255,255,255,0.75);box-shadow:0 8px 40px rgba(99,102,241,0.10),0 2px 8px rgba(0,0,0,0.06),inset 0 1.5px 0 rgba(255,255,255,0.95);position:relative;overflow:visible;transition:box-shadow 0.4s,background 0.4s;max-width:980px;width:100%;}
.nav-container::before{content:'';position:absolute;inset:0;border-radius:50px;background:conic-gradient(from var(--angle,0deg),transparent 60%,rgba(99,102,241,0.35) 75%,rgba(180,182,255,0.5) 80%,rgba(99,102,241,0.35) 85%,transparent 100%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:1px;animation:borderSpin 4s linear infinite;opacity:0.7;pointer-events:none;}
@property --angle{syntax:'<angle>';initial-value:0deg;inherits:false;}
@keyframes borderSpin{to{--angle:360deg;}}
.nav-container::after{content:'';position:absolute;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,0.18) 0%,transparent 70%);transform:translate(-50%,-50%);left:var(--mx,50%);top:var(--my,50%);pointer-events:none;opacity:0;transition:opacity 0.3s;}
.nav-container:hover::after{opacity:1;}
.main-nav.scrolled .nav-container{background:rgba(255,255,255,0.72);box-shadow:0 12px 48px rgba(99,102,241,0.14),0 2px 8px rgba(0,0,0,0.08),inset 0 1.5px 0 rgba(255,255,255,0.98);}
.logo-name{display:flex;align-items:center;gap:8px;font-size:0.88rem;font-weight:600;white-space:nowrap;color:var(--c-navy);padding-right:10px;border-right:1px solid rgba(99,102,241,0.15);flex-shrink:0;text-decoration:none;transition:color 0.2s;position:relative;z-index:2;}
.logo-name:hover{color:var(--c-indigo);}
.nav-pill{display:flex;align-items:center;gap:2px;flex:1;justify-content:center;}
.nav-link{text-decoration:none;color:rgba(15,17,23,0.65);font-weight:500;font-size:0.82rem;padding:6px 11px;border-radius:50px;transition:background 0.2s,color 0.2s,transform 0.2s;position:relative;white-space:nowrap;}
.nav-link:hover{background:rgba(99,102,241,0.08);color:var(--c-indigo);transform:translateY(-1px);}
.nav-link.active{background:var(--c-indigo-soft);color:var(--c-indigo);font-weight:600;}
.nav-link.active::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--c-indigo);}
.nav-resume-btn{text-decoration:none;font-size:0.82rem;font-weight:700;color:#fff;background:var(--c-indigo);border:1px solid rgba(255,255,255,0.2);border-radius:50px;padding:8px 18px;white-space:nowrap;flex-shrink:0;box-shadow:0 4px 20px var(--c-indigo-glow);transition:background 0.22s,transform 0.22s;position:relative;overflow:hidden;}
.nav-resume-btn::before{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent);transition:left 0.5s;}
.nav-resume-btn:hover::before{left:160%;}
.nav-resume-btn:hover{background:#4f52e0;transform:translateY(-2px);}
.nav-ripple{position:absolute;border-radius:50%;background:rgba(99,102,241,0.25);transform:scale(0);animation:rippleOut 0.55s ease-out forwards;pointer-events:none;}
@keyframes rippleOut{to{transform:scale(4);opacity:0;}}
.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:38px;height:38px;background:none;border:none;cursor:pointer;padding:6px;border-radius:10px;flex-shrink:0;transition:background 0.2s;}
.nav-hamburger:hover{background:var(--c-indigo-soft);}
.nav-hamburger span{display:block;height:2px;background:var(--c-navy);border-radius:2px;transition:transform 0.3s,opacity 0.3s,width 0.3s;}
.nav-hamburger span:nth-child(3){width:65%;}
.nav-container.menu-open .nav-hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-container.menu-open .nav-hamburger span:nth-child(2){opacity:0;}
.nav-container.menu-open .nav-hamburger span:nth-child(3){width:100%;transform:translateY(-7px) rotate(-45deg);}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;padding:90px 24px 36px;background:rgba(255,255,255,0.95);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border-bottom:1px solid rgba(99,102,241,0.12);box-shadow:0 20px 60px rgba(99,102,241,0.12);flex-direction:column;gap:4px;z-index:998;transform:translateY(-110%);transition:transform 0.4s cubic-bezier(0.22,1,0.36,1);}
.mobile-menu.open{transform:translateY(0);display:flex;}
.mobile-link{text-decoration:none;font-size:1.1rem;font-weight:600;color:var(--text-dark);padding:14px 16px;border-radius:14px;transition:background 0.2s,color 0.2s;}
.mobile-link:hover{background:var(--c-indigo-soft);color:var(--c-indigo);}
.mobile-resume{margin-top:8px;background:var(--c-indigo);color:#fff !important;text-align:center;border-radius:50px;padding:14px 24px;box-shadow:0 4px 20px var(--c-indigo-glow);}
.mobile-resume:hover{background:#4f52e0 !important;}

.section-hero{background:linear-gradient(160deg,var(--c-cream) 0%,#eeeaf8 55%,var(--c-cream-dim) 100%);min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;}
.section-hero::after{background:linear-gradient(to bottom,transparent,var(--c-cream));}
#cloud-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:0.88;}
.hero-bg-orb{position:absolute;border-radius:50%;filter:blur(40px);pointer-events:none;z-index:0;}
.orb-1{width:600px;height:600px;background:radial-gradient(circle,var(--c-indigo-glow) 0%,transparent 65%);top:-120px;right:-100px;animation:orbFloat1 9s ease-in-out infinite;}
.orb-2{width:450px;height:450px;background:radial-gradient(circle,rgba(99,102,241,0.12) 0%,transparent 65%);bottom:60px;left:-80px;animation:orbFloat2 11s ease-in-out infinite;}
.orb-3{width:500px;height:500px;background:radial-gradient(circle,rgba(99,102,241,0.08) 0%,transparent 65%);top:50%;left:50%;transform:translate(-50%,-50%);}
@keyframes orbFloat1{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(-30px,40px) scale(1.08);}}
@keyframes orbFloat2{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(25px,-35px) scale(1.06);}}
.hero-container{display:grid;grid-template-columns:1fr 0.85fr;gap:32px;align-items:center;position:relative;z-index:1;padding-top:100px;padding-bottom:80px;}
.hero-left{display:flex;flex-direction:column;gap:28px;}
.hero-eyebrow{font-size:0.78rem;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;color:var(--c-indigo);display:inline-flex;align-items:center;gap:8px;}
.hero-eyebrow::before{content:'';display:inline-block;width:28px;height:1.5px;background:var(--c-indigo);}
.hero-desc{font-size:1.05rem;line-height:1.7;color:var(--text-mid);max-width:440px;}
.hero-ctas{display:flex;gap:14px;align-items:center;flex-wrap:wrap;}
.hero-stats{display:flex;align-items:center;gap:20px;padding-top:8px;}
.stat{display:flex;flex-direction:column;gap:3px;}
.stat-num{font-family:var(--font-display);font-size:1.7rem;font-weight:800;line-height:1;color:var(--c-indigo);display:inline-block;transition:transform 0.3s cubic-bezier(0.22,1,0.36,1);}
.stat:hover .stat-num{transform:scale(1.15);}
.stat-label{font-size:0.72rem;font-weight:500;letter-spacing:0.5px;color:var(--text-light);text-transform:uppercase;}
.stat-divider{width:1px;height:36px;background:var(--border);}
.hero-right{position:relative;}
.hero-image-card{width:100%;height:620px;border-radius:28px;overflow:hidden;}
.hero-image-card img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;}
.hero-float-badge{position:absolute;background:rgba(255,255,255,0.82);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,0.7);border-radius:50px;padding:10px 18px;font-size:0.82rem;font-weight:600;color:var(--text-dark);box-shadow:0 8px 32px rgba(0,0,0,0.10),inset 0 1px 0 rgba(255,255,255,0.9);white-space:nowrap;}
.badge-1{top:28px;left:-24px;animation:badgeFloat 5s ease-in-out infinite;}
.badge-2{bottom:40px;right:-20px;animation:badgeFloat 5s 1.5s ease-in-out infinite;}
.badge-3{top:50%;right:-28px;transform:translateY(-50%);}
@keyframes badgeFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

.section-about{background:linear-gradient(160deg,var(--c-cream) 0%,#eeeaf8 60%,var(--c-cream) 100%);padding:100px 0;}
.section-about::after{background:linear-gradient(to bottom,transparent,#f4f2fc);}
.about-container{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start;}
.about-text p+p{margin-top:16px;}
.about-quick-facts{display:flex;flex-direction:column;gap:10px;margin-top:24px;}
.quick-fact{display:flex;align-items:center;gap:10px;font-size:0.9rem;font-weight:500;color:var(--text-mid);}
.qf-icon{font-size:1.1rem;}
.about-glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:28px;padding:44px 48px;box-shadow:var(--glass-shadow);transition:transform 0.35s cubic-bezier(0.22,1,0.36,1),box-shadow 0.35s;}
.about-glass:hover{transform:translateY(-6px);box-shadow:0 32px 64px rgba(99,102,241,0.13),inset 0 1.5px 0 rgba(255,255,255,0.95);}
.about-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;}
.about-tag{padding:6px 16px;border-radius:50px;font-size:0.8rem;font-weight:600;background:var(--c-indigo-soft);border:1px solid rgba(99,102,241,0.18);color:var(--c-indigo);}
.know-more-btn{display:inline-flex;align-items:center;gap:6px;margin-top:24px;text-decoration:none;font-size:0.88rem;font-weight:700;color:var(--c-indigo);background:var(--c-indigo-soft);border:1.5px solid rgba(99,102,241,0.22);border-radius:50px;padding:10px 22px;transition:background 0.2s,border-color 0.2s,transform 0.2s,box-shadow 0.2s;}
.know-more-btn:hover{background:var(--c-indigo);color:#fff;border-color:var(--c-indigo);transform:translateY(-2px);box-shadow:0 8px 24px rgba(99,102,241,0.28);}
.section-skills{background:linear-gradient(180deg,#f4f2fc 0%,var(--c-cream) 100%);padding:120px 0;}
.section-skills::after{background:linear-gradient(to bottom,transparent,var(--c-cream-dim));}
.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.skill-category{padding:36px 40px;}
.skill-cat-header{display:flex;align-items:center;gap:14px;margin-bottom:24px;}
.skill-cat-icon{font-size:1.5rem;line-height:1;}
.skill-cat-header h3{margin-bottom:0;font-size:1.1rem;}
.skill-items{display:flex;flex-wrap:wrap;gap:10px;}
.skill-chip{display:inline-flex;align-items:center;gap:7px;padding:7px 16px;border-radius:50px;font-size:0.84rem;font-weight:600;background:rgba(255,255,255,0.7);border:1px solid rgba(99,102,241,0.12);color:var(--text-dark);transition:background 0.2s,border-color 0.2s,transform 0.2s;cursor:default;}
.skill-chip:hover{background:rgba(255,255,255,0.95);border-color:rgba(99,102,241,0.3);transform:translateY(-2px);}
.chip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.dot-orange{background:#f97316;}.dot-blue{background:#3b82f6;}.dot-yellow{background:#eab308;}.dot-green{background:#22c55e;}.dot-purple{background:#a855f7;}
.section-projects-intro{background:linear-gradient(180deg,#f4f2fc 0%,var(--c-cream) 100%);padding:100px 0;}
.section-projects-intro::after{background:linear-gradient(to bottom,transparent,var(--c-cream-dim));}
.projects-masonry{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:250px 250px;gap:20px;margin-top:60px;}
.masonry-item:nth-child(1){grid-column:span 1;grid-row:span 1;}
.masonry-item:nth-child(2){grid-column:span 1;grid-row:span 2;}
.masonry-item:nth-child(3){grid-column:span 1;grid-row:span 1;}
.masonry-item:nth-child(4){grid-column:span 1;grid-row:span 1;}
.masonry-item{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:24px;box-shadow:var(--glass-shadow);transition:transform 0.35s cubic-bezier(0.22,1,0.36,1),box-shadow 0.35s;position:relative;overflow:hidden;}
.masonry-item::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.9),transparent);z-index:1;}
.masonry-item:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 32px 70px rgba(99,102,241,0.20),inset 0 1.5px 0 rgba(255,255,255,0.98);}
.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:60px;}
.pill-badge{display:inline-flex;align-items:center;border:1.5px solid rgba(99,102,241,0.3);border-radius:50px;padding:10px 22px;font-size:0.78rem;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--c-indigo);background:var(--c-indigo-soft);position:relative;overflow:hidden;}
.pill-badge::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(99,102,241,0.15),transparent);animation:shimmer 3s ease-in-out infinite;}
@keyframes shimmer{0%{left:-100%;}100%{left:200%;}}
.project-details-grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:60px;align-items:center;}
.project-details-grid.reverse{grid-template-columns:1.2fr 0.8fr;}
.info-card{background:var(--glass-bg-deep);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);padding:50px;border-radius:28px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);position:relative;overflow:hidden;transition:transform 0.35s cubic-bezier(0.22,1,0.36,1),box-shadow 0.35s;}
.info-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.9),transparent);}
.info-card:hover{transform:translateY(-8px);box-shadow:0 36px 70px rgba(99,102,241,0.16),inset 0 1.5px 0 rgba(255,255,255,0.98);}
.info-block{display:flex;gap:25px;margin-bottom:40px;}
.info-block:last-child{margin-bottom:0;}
.info-block .number{font-family:var(--font-display);font-size:1.8rem;font-weight:800;line-height:1;color:var(--c-indigo);opacity:0.35;flex-shrink:0;min-width:48px;}
.info-block h3{font-size:1.15rem;font-weight:700;letter-spacing:-0.3px;color:var(--text-dark);margin-bottom:8px;}
.project-mockup{height:400px;width:100%;transition:transform 0.4s cubic-bezier(0.22,1,0.36,1),box-shadow 0.4s;}
.project-mockup:hover{transform:perspective(800px) rotateY(-4deg) translateY(-6px);box-shadow:0 30px 70px rgba(99,102,241,0.15);}
.project-tech-stack{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;}
.section-project-1{background:linear-gradient(180deg,var(--c-cream-dim) 0%,#eeeaf8 100%);padding:120px 0;}
.section-project-1::after{background:linear-gradient(to bottom,transparent,#f4f2fc);}
.section-project-2{background:linear-gradient(180deg,#f4f2fc 0%,var(--c-cream) 100%);padding:120px 0;}
.section-project-2::after{background:linear-gradient(to bottom,transparent,var(--c-cream));}

.section-experience{background:linear-gradient(180deg,var(--c-cream-dim) 0%,#eeeaf8 100%);padding:120px 0;}
.section-experience::after{background:linear-gradient(to bottom,transparent,var(--c-cream));}
.timeline{display:flex;flex-direction:column;position:relative;padding-left:32px;}
.timeline::before{content:'';position:absolute;left:10px;top:16px;bottom:16px;width:2px;background:linear-gradient(to bottom,var(--c-indigo),rgba(99,102,241,0.15));border-radius:2px;}
.timeline-item{position:relative;padding-bottom:32px;}
.timeline-item:last-child{padding-bottom:0;}
.timeline-dot{position:absolute;left:-27px;top:28px;width:14px;height:14px;border-radius:50%;background:var(--c-indigo);border:3px solid var(--c-cream);box-shadow:0 0 0 2px var(--c-indigo);z-index:1;}
.timeline-card{padding:36px 40px;}
.timeline-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;}
.timeline-header h3{margin-bottom:4px;}
.timeline-company{font-size:0.88rem;font-weight:500;color:var(--c-indigo);}
.timeline-date{font-size:0.78rem;font-weight:600;color:var(--text-light);white-space:nowrap;padding:5px 14px;border-radius:50px;background:var(--c-indigo-soft);border:1px solid rgba(99,102,241,0.15);flex-shrink:0;}
.timeline-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;}
.section-blog{background:linear-gradient(180deg,var(--c-cream) 0%,#eeeaf8 60%,var(--c-cream-dim) 100%);padding:120px 0;}
.section-blog::after{background:linear-gradient(to bottom,transparent,var(--c-cream));}
.blog-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px;align-items:start;}
.blog-card{padding:36px 40px;display:flex;flex-direction:column;gap:16px;}
.featured-blog h3{font-size:1.35rem;letter-spacing:-0.5px;}
.blog-tag{display:inline-flex;align-items:center;padding:5px 14px;border-radius:50px;font-size:0.72rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--c-indigo);background:var(--c-indigo-soft);border:1px solid rgba(99,102,241,0.18);width:fit-content;}
.blog-card h3{font-size:1.05rem;line-height:1.4;margin-bottom:0;}
.blog-card p{font-size:0.93rem;line-height:1.7;flex:1;}
.blog-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:16px;border-top:1px solid rgba(99,102,241,0.08);}
.blog-date{font-size:0.78rem;font-weight:500;color:var(--text-light);}
.blog-read{text-decoration:none;font-size:0.84rem;font-weight:700;color:var(--c-indigo);display:inline-flex;align-items:center;gap:4px;transition:opacity 0.2s;}
.blog-read:hover{opacity:0.75;}
.section-contact{background:linear-gradient(160deg,var(--c-cream) 0%,#eeeaf8 55%,var(--c-cream-dim) 100%);padding:120px 0;}
.section-contact::after{background:linear-gradient(to bottom,transparent,var(--c-navy));}
.contact-header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:64px;gap:10px;}
.contact-tagline{font-size:1rem;font-weight:400;color:var(--text-light);max-width:360px;text-align:center;line-height:1.6;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;max-width:960px;margin:0 auto;}
.contact-form-container{background:rgba(255,255,255,0.45);backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);border:1px solid rgba(255,255,255,0.88);border-radius:32px;padding:48px 44px;position:relative;overflow:hidden;box-shadow:inset 0 2px 0 rgba(255,255,255,1),inset 0 -1px 0 rgba(99,102,241,0.07),0 32px 64px rgba(99,102,241,0.14),0 8px 24px rgba(0,0,0,0.06);}
.contact-form-container::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,1) 50%,transparent);}
.contact-form-container::after{content:'';position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,0.07) 0%,transparent 70%);top:-80px;right:-60px;pointer-events:none;}
.contact-form{display:flex;flex-direction:column;gap:20px;position:relative;z-index:1;}
.form-group{display:flex;flex-direction:column;gap:7px;}
.form-group label{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-mid);}
.form-group input,.form-group textarea{padding:14px 18px;border:1px solid rgba(99,102,241,0.15);border-radius:14px;font-family:var(--font-sans);font-size:0.97rem;background:rgba(255,255,255,0.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-dark);transition:border-color 0.25s,box-shadow 0.25s,background 0.25s;box-shadow:inset 0 1px 0 rgba(255,255,255,0.8);}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--c-indigo);background:rgba(255,255,255,0.85);box-shadow:0 0 0 3px rgba(99,102,241,0.12),0 4px 16px rgba(99,102,241,0.08),inset 0 1px 0 rgba(255,255,255,0.9);}
.submit-btn{align-self:flex-start;background:linear-gradient(135deg,#6366f1 0%,#4f52e0 100%);color:#fff;border:none;padding:15px 38px;border-radius:50px;font-size:1rem;font-weight:700;cursor:pointer;transition:transform 0.22s,box-shadow 0.22s;box-shadow:0 4px 20px rgba(99,102,241,0.35),inset 0 1px 0 rgba(255,255,255,0.2);position:relative;overflow:hidden;}
.submit-btn::before{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.22),transparent);transition:left 0.5s;}
.submit-btn:hover::before{left:160%;}
.submit-btn:hover{transform:translateY(-3px);box-shadow:0 10px 36px rgba(99,102,241,0.45),inset 0 1px 0 rgba(255,255,255,0.2);}
.contact-image-wrap{display:flex;align-items:center;justify-content:center;}
.contact-side-img{width:100%;max-width:420px;height:auto;display:block;object-fit:contain;filter:drop-shadow(0 20px 40px rgba(99,102,241,0.20));transition:transform 0.5s cubic-bezier(0.22,1,0.36,1),filter 0.5s;}
.contact-image-wrap:hover .contact-side-img{transform:translateY(-8px) scale(1.02);filter:drop-shadow(0 32px 56px rgba(99,102,241,0.30));}

.main-footer{background:linear-gradient(160deg,var(--c-navy) 0%,var(--c-navy-mid) 100%);padding:0;position:relative;overflow:hidden;}
.main-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--c-indigo),transparent);}
.footer-glass{max-width:1200px;margin:0 auto;padding:70px 32px 36px;}
.footer-top{display:grid;grid-template-columns:1fr 1.6fr;gap:60px;margin-bottom:60px;}
.footer-brand{display:flex;flex-direction:column;gap:20px;}
.footer-logo{display:inline-flex;align-items:center;gap:9px;font-size:1rem;font-weight:600;color:#fff;background:rgba(255,255,255,0.08);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.14);border-radius:50px;padding:9px 18px;width:fit-content;}
.footer-tagline{font-size:1.05rem;line-height:1.65;color:rgba(255,255,255,0.45);font-weight:400;}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;}
.footer-col{display:flex;flex-direction:column;gap:12px;}
.footer-col h4{font-size:0.75rem;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:4px;}
.footer-col a{text-decoration:none;color:rgba(255,255,255,0.65);font-size:0.92rem;transition:color 0.2s;display:flex;align-items:center;gap:7px;}
.footer-col a:hover{color:#fff;padding-left:4px;}
.footer-social svg{opacity:0.6;flex-shrink:0;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid rgba(255,255,255,0.08);}
.footer-bottom p{color:rgba(255,255,255,0.3);font-size:0.82rem;}
.footer-made{font-size:0.82rem;color:rgba(255,255,255,0.3);}
.chatbot-fab{position:fixed;bottom:30px;right:30px;width:60px;height:60px;background:var(--c-indigo);color:white;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px var(--c-indigo-glow);cursor:pointer;z-index:1000;transition:transform 0.3s,box-shadow 0.3s;}
.chatbot-fab:hover{transform:scale(1.08);box-shadow:0 14px 40px var(--c-indigo-glow);}
.chatbot-fab::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--c-indigo);opacity:0;animation:fabPulse 2.5s ease-out infinite;}
@keyframes fabPulse{0%{transform:scale(1);opacity:0.6;}100%{transform:scale(1.6);opacity:0;}}
.fade-in{opacity:0;transform:translateY(12px);transition:opacity 0.25s ease,transform 0.25s ease cubic-bezier(0.22,1,0.36,1);}
.fade-in.visible{opacity:1;transform:translateY(0);}
.slide-left{opacity:0;transform:translateX(-16px);transition:opacity 0.25s ease,transform 0.25s ease cubic-bezier(0.22,1,0.36,1);}
.slide-left.visible{opacity:1;transform:translateX(0);}
.slide-right{opacity:0;transform:translateX(16px);transition:opacity 0.25s ease,transform 0.25s ease cubic-bezier(0.22,1,0.36,1);}
.slide-right.visible{opacity:1;transform:translateX(0);}
.scale-in{opacity:0;transform:scale(0.97);transition:opacity 0.22s ease,transform 0.22s ease cubic-bezier(0.22,1,0.36,1);}
.scale-in.visible{opacity:1;transform:scale(1);}
.section-hero .fade-in{opacity:1;transform:none;}
.section-hero .hero-left.fade-in{animation:heroSlideUp 1s cubic-bezier(0.22,1,0.36,1) both;}
.section-hero .hero-right.fade-in{animation:heroSlideUp 1s 0.2s cubic-bezier(0.22,1,0.36,1) both;}
@keyframes heroSlideUp{from{opacity:0;transform:translateY(50px);}to{opacity:1;transform:translateY(0);}}
.typing-cursor::after{content:'|';animation:blink 0.7s step-end infinite;color:var(--c-indigo);margin-left:2px;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}
.highlight-green{border-left:3px solid var(--c-indigo);background:linear-gradient(90deg,rgba(99,102,241,0.10) 0%,var(--glass-bg) 60%);}
.highlight-coral{border-left:3px solid #f97316;background:linear-gradient(90deg,rgba(249,115,22,0.08) 0%,var(--glass-bg) 60%);}
@media(max-width:1024px){
.hero-container{gap:40px;}.hero-image-card{height:500px;}
.about-container{grid-template-columns:1fr;gap:40px;}
.project-details-grid,.project-details-grid.reverse{grid-template-columns:1fr;gap:40px;}
.project-details-grid.reverse .info-card{order:1;}.project-details-grid.reverse .project-mockup{order:2;}
.contact-grid{grid-template-columns:1fr;gap:40px;max-width:100%;}
.contact-image-wrap{order:-1;}
.footer-top{grid-template-columns:1fr;gap:40px;}.footer-cols{grid-template-columns:repeat(3,1fr);}
.projects-masonry{grid-template-columns:repeat(2,1fr);grid-template-rows:220px 220px 220px;}
.masonry-item:nth-child(1){grid-column:span 1;grid-row:span 1;}.masonry-item:nth-child(2){grid-column:span 1;grid-row:span 1;}.masonry-item:nth-child(3){grid-column:span 1;grid-row:span 1;}.masonry-item:nth-child(4){grid-column:span 2;grid-row:span 1;}
.skills-grid{grid-template-columns:1fr 1fr;}.blog-grid{grid-template-columns:1fr 1fr;}.featured-blog{grid-column:span 2;}
}
@media(max-width:768px){
.container{padding:28px 18px;}
.main-nav{padding:12px 16px;}.nav-pill,.nav-resume-btn{display:none;}.nav-hamburger{display:flex;}.mobile-menu{display:flex;}
.main-nav{padding:10px 14px;}
.nav-container{border-radius:20px;padding:8px 8px 8px 14px;justify-content:space-between;border-color:rgba(255,255,255,0.6);background:rgba(255,255,255,0.75);}
.logo-name{border-right:none;padding-right:0;}
.hero-container{grid-template-columns:1fr;gap:36px;padding-top:20px;padding-bottom:60px;text-align:center;}
.hero-left{align-items:center;}.hero-eyebrow{justify-content:center;}.hero-desc{max-width:100%;}.hero-ctas{justify-content:center;}.hero-stats{justify-content:center;flex-wrap:wrap;gap:16px;}
.hero-right{order:-1;padding-top:80px;}.hero-image-card{height:300px;}
.badge-1{display:none;}.badge-2{bottom:12px;left:50%;transform:translateX(-50%);font-size:0.74rem;padding:8px 16px;}.badge-3{display:none;}
.section-about{padding:70px 0;}.about-container{grid-template-columns:1fr;gap:28px;}.about-glass{padding:28px 24px;}
.section-projects-intro{padding:70px 0;}.projects-masonry{grid-template-columns:1fr;grid-template-rows:repeat(4,200px);gap:14px;margin-top:36px;}.masonry-item:nth-child(n){grid-column:span 1;grid-row:span 1;}
.section-project-1,.section-project-2{padding:70px 0;}
.project-header{flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:36px;}
.project-details-grid,.project-details-grid.reverse{grid-template-columns:1fr;gap:28px;}
.project-details-grid.reverse .info-card{order:1;}.project-details-grid.reverse .project-mockup{order:2;}
.info-card{padding:28px 24px;}.info-block{gap:16px;margin-bottom:28px;}.info-block .number{font-size:1.4rem;min-width:36px;}.project-mockup{height:260px;}
.section-skills,.section-experience,.section-blog{padding:70px 0;}
.skills-grid{grid-template-columns:1fr;gap:16px;}.skill-category{padding:24px 22px;}
.timeline{padding-left:24px;}.timeline-dot{left:-20px;}.timeline-card{padding:24px 22px;}.timeline-header{flex-direction:column;gap:10px;}
.blog-grid{grid-template-columns:1fr;}.featured-blog{grid-column:span 1;}.blog-card{padding:24px 22px;}
/* Mobile responsive fixes for blog read links */
.blog-read{font-size:0.88rem;padding:8px 16px;border-radius:20px;background:var(--c-indigo-soft);color:var(--c-indigo);font-weight:600;display:inline-flex;align-items:center;gap:4px;margin-top:8px;}
.blog-read:hover{background:var(--c-indigo);color:#fff;}
.blog-footer{flex-direction:column;align-items:flex-start;gap:8px;}
.section-contact{padding:70px 0;}.contact-grid{grid-template-columns:1fr;gap:32px;max-width:100%;}.contact-image-wrap{order:-1;}.contact-side-img{max-width:280px;}.contact-form-container{padding:32px 24px;}
.footer-glass{padding:50px 20px 28px;}.footer-top{grid-template-columns:1fr;gap:32px;}.footer-cols{grid-template-columns:repeat(2,1fr);gap:28px;}
.footer-bottom{flex-direction:column;gap:8px;text-align:center;}
.section-head{margin-bottom:24px;}.chatbot-fab{bottom:20px;right:20px;width:52px;height:52px;}

}
@media(max-width:480px){
.container{padding:24px 16px;}.hero-image-card{height:240px;}.hero-stats{gap:12px;}.stat-num{font-size:1.4rem;}
.btn-primary,.btn-ghost{padding:12px 22px;font-size:0.88rem;}
.footer-cols{grid-template-columns:1fr;gap:24px;}
.info-card{padding:22px 18px;}.contact-form-container{padding:24px 18px;}.about-glass{padding:22px 18px;}
.projects-masonry{grid-template-rows:repeat(4,170px);}.project-mockup{height:210px;}
.contact-side-img{max-width:220px;}.skill-category{padding:20px 18px;}.timeline-card{padding:20px 18px;}.blog-card{padding:20px 18px;}
}

/* ===================== SKILLS SHOWCASE ===================== */
.section-skills{background:linear-gradient(180deg,#f4f2fc 0%,var(--c-cream) 100%);padding:72px 0;}
.section-skills::after{background:linear-gradient(to bottom,transparent,var(--c-cream-dim));}

.skills-glass-wrap{
    background:rgba(255,255,255,0.42);
    backdrop-filter:blur(16px) saturate(160%);
    -webkit-backdrop-filter:blur(16px) saturate(160%);
    border:1px solid rgba(255,255,255,0.85);
    border-radius:28px;
    padding:36px 44px;
    box-shadow:0 8px 40px rgba(99,102,241,0.09),0 2px 8px rgba(0,0,0,0.04),inset 0 1.5px 0 rgba(255,255,255,1);
    display:flex;
    flex-direction:column;
    gap:24px;
    position:relative;
    overflow:hidden;
    max-width:720px;
    margin:0 auto;
}
.skills-glass-wrap::before{
    content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,1) 50%,transparent);
}

.sg-group{display:flex;flex-direction:column;gap:12px;}

.sg-label{
    display:inline-flex;align-items:center;gap:7px;
    font-size:0.7rem;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;
    color:var(--text-light);
}
.sg-icon{font-size:0.95rem;line-height:1;}

.sg-pills{display:flex;flex-wrap:wrap;gap:8px;}
.sg-logo{width:18px;height:18px;object-fit:contain;flex-shrink:0;}

.sg-pill{
    display:inline-flex;align-items:center;gap:6px;
    padding:7px 16px;border-radius:50px;
    font-size:0.84rem;font-weight:600;color:var(--text-dark);
    background:rgba(255,255,255,0.65);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,0.92);
    box-shadow:0 2px 10px rgba(99,102,241,0.06),inset 0 1px 0 rgba(255,255,255,1);
    transition:transform 0.22s cubic-bezier(0.22,1,0.36,1),box-shadow 0.22s,background 0.22s;
    cursor:default;
}
.sg-pill:hover{
    transform:translateY(-3px);
    background:rgba(255,255,255,0.95);
    box-shadow:0 8px 22px rgba(99,102,241,0.13),inset 0 1px 0 rgba(255,255,255,1);
}
.sg-pill-ongoing{
    background:rgba(99,102,241,0.07);
    border-color:rgba(99,102,241,0.18);
    color:var(--c-indigo);
}
.sg-pill-ongoing:hover{
    background:rgba(99,102,241,0.12);
    box-shadow:0 8px 22px rgba(99,102,241,0.16),inset 0 1px 0 rgba(255,255,255,0.7);
}
.sg-badge{
    font-size:0.58rem;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;
    background:rgba(99,102,241,0.14);color:var(--c-indigo);
    border:1px solid rgba(99,102,241,0.22);border-radius:50px;padding:1px 6px;
}

.sg-divider{
    height:1px;
    background:linear-gradient(90deg,transparent,rgba(99,102,241,0.10) 30%,rgba(99,102,241,0.10) 70%,transparent);
}

@media(max-width:768px){
.skills-glass-wrap{padding:24px 20px;gap:18px;}
.sg-pill{font-size:0.8rem;padding:6px 14px;}
}

/* ===================== ROADMAP / JOURNEY ===================== */
.roadmap-track{display:flex;align-items:flex-start;gap:0;position:relative;padding:40px 0 20px;overflow-x:auto;scrollbar-width:none;}
.roadmap-track::-webkit-scrollbar{display:none;}
.roadmap-track::before{content:'';position:absolute;top:62px;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--c-indigo) 0%,rgba(99,102,241,0.3) 100%);z-index:0;}
.rm-node{display:flex;flex-direction:column;align-items:center;gap:10px;flex:1;min-width:130px;position:relative;z-index:1;cursor:pointer;transition:transform 0.3s cubic-bezier(0.22,1,0.36,1);}
.rm-node:hover{transform:translateY(-6px);}
.rm-bubble{width:80px;min-height:64px;padding:10px;border-radius:18px;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--glass-bg-deep);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:2px solid var(--glass-border);box-shadow:var(--glass-shadow);transition:transform 0.3s,box-shadow 0.3s;color:var(--c-indigo);font-size:0.72rem;line-height:1.25;}
.rm-node.state-done .rm-bubble{border-color:rgba(99,102,241,0.45);box-shadow:0 0 0 4px rgba(99,102,241,0.08),var(--glass-shadow);}
.rm-node.state-active .rm-bubble{border-color:var(--c-indigo);box-shadow:0 0 0 6px rgba(99,102,241,0.14),0 0 24px rgba(99,102,241,0.35);animation:bubblePulse 2.5s ease-in-out infinite;}
.rm-node.state-next .rm-bubble{border-color:rgba(99,102,241,0.20);opacity:0.65;}
@keyframes bubblePulse{0%,100%{box-shadow:0 0 0 6px rgba(99,102,241,0.14),0 0 24px rgba(99,102,241,0.30);}50%{box-shadow:0 0 0 10px rgba(99,102,241,0.08),0 0 40px rgba(99,102,241,0.45);}}
.rm-year{font-size:0.72rem;font-weight:700;color:var(--c-indigo);letter-spacing:0.5px;}
.rm-label{font-size:0.82rem;font-weight:600;color:var(--text-dark);text-align:center;}
.rm-node.state-next .rm-label{color:var(--text-light);}
.rm-detail-panel{margin-top:32px;display:none;animation:fadeSlideUp 0.35s cubic-bezier(0.22,1,0.36,1) both;}
.rm-detail-panel.open{display:block;}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
.rm-panel-inner{background:var(--glass-bg-deep);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:28px;padding:40px 44px;box-shadow:var(--glass-shadow);position:relative;}
.rm-panel-inner::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.9),transparent);}
.rm-panel-close{position:absolute;top:16px;right:16px;background:rgba(99,102,241,0.08);border:none;width:32px;height:32px;border-radius:50%;font-size:0.9rem;cursor:pointer;color:var(--text-mid);display:flex;align-items:center;justify-content:center;transition:background 0.2s;}
.rm-panel-close:hover{background:rgba(99,102,241,0.18);}
.rm-panel-header{display:flex;align-items:center;gap:14px;margin-bottom:16px;}
.rm-panel-emoji,.rm-panel-icon{width:44px;height:44px;border-radius:12px;background:var(--c-indigo-soft);border:1px solid rgba(99,102,241,0.18);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--c-indigo);}
.rm-panel-meta{display:flex;flex-direction:column;gap:4px;}
.rm-panel-badge{display:inline-flex;align-items:center;padding:3px 12px;border-radius:50px;font-size:0.68rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;background:var(--c-indigo-soft);color:var(--c-indigo);border:1px solid rgba(99,102,241,0.2);width:fit-content;}
.rm-panel-year-label{font-size:0.78rem;font-weight:600;color:var(--text-light);}
.rm-panel-inner h3{font-size:1.3rem;font-weight:800;letter-spacing:-0.4px;margin-bottom:10px;}
.rm-panel-inner p{font-size:0.97rem;line-height:1.75;margin-bottom:0;}
.rm-panel-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;}

/* Responsive skills + journey */
@media(max-width:1024px){.skills-showcase{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){
.skills-showcase{grid-template-columns:1fr;gap:18px;}
.skill-big-card{padding:28px 24px;}
.sbar span{min-width:90px;}
.roadmap-track{gap:0;padding:32px 0 16px;}
.rm-bubble{width:72px;min-height:56px;font-size:0.75rem;}
.rm-node{min-width:110px;}
.rm-panel-inner{padding:28px 24px;}
}
@media(max-width:480px){.skill-big-card{padding:22px 18px;}.rm-panel-inner{padding:22px 18px;}}

/* ===================== VISION AI CHAT ===================== */
.vision-fab{position:fixed;bottom:28px;right:28px;z-index:1000;background:none;border:none;cursor:pointer;padding:0;}
.vision-fab-inner{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,0.62);backdrop-filter:blur(32px) saturate(220%) brightness(1.1);-webkit-backdrop-filter:blur(32px) saturate(220%) brightness(1.1);border:1px solid rgba(255,255,255,0.88);border-radius:50px;padding:11px 20px 11px 14px;box-shadow:0 8px 32px rgba(99,102,241,0.22),0 2px 8px rgba(0,0,0,0.06),inset 0 1.5px 0 rgba(255,255,255,1);transition:transform 0.3s cubic-bezier(0.22,1,0.36,1),box-shadow 0.3s;color:var(--c-indigo);}
.vision-fab:hover .vision-fab-inner{transform:translateY(-3px) scale(1.04);box-shadow:0 16px 48px rgba(99,102,241,0.28),inset 0 1.5px 0 rgba(255,255,255,0.98);}
.vision-fab-label{font-family:var(--font-display);font-size:0.88rem;font-weight:800;letter-spacing:1.5px;color:var(--c-indigo);}
.vision-fab-pulse{position:absolute;top:-3px;right:-3px;width:12px;height:12px;border-radius:50%;background:#22c55e;border:2px solid #fff;animation:visionPulse 2.5s ease-in-out infinite;}
@keyframes visionPulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,0.5);}50%{box-shadow:0 0 0 6px rgba(34,197,94,0);}}

.vision-overlay{position:fixed;inset:0;background:rgba(15,17,23,0.25);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1001;opacity:0;pointer-events:none;transition:opacity 0.35s;}
.vision-overlay.open{opacity:1;pointer-events:all;}

.vision-panel{position:fixed;bottom:90px;right:16px;width:min(380px,calc(100vw - 32px));max-height:min(580px,calc(100vh - 120px));z-index:1002;display:flex;flex-direction:column;border-radius:28px;background:rgba(255,255,255,0.52);backdrop-filter:blur(52px) saturate(240%) brightness(1.1);-webkit-backdrop-filter:blur(52px) saturate(240%) brightness(1.1);border:1px solid rgba(255,255,255,0.85);box-shadow:0 2px 0 rgba(255,255,255,1) inset,0 32px 80px rgba(99,102,241,0.18),0 8px 24px rgba(0,0,0,0.08);transform:translateY(20px) scale(0.96);opacity:0;pointer-events:none;transition:transform 0.4s cubic-bezier(0.22,1,0.36,1),opacity 0.4s;}
.vision-panel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all;}
.vision-panel::before{content:'';position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,1) 50%,transparent);border-radius:50%;}

.vision-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid rgba(99,102,241,0.08);}
.vision-header-left{display:flex;align-items:center;gap:12px;}
.vision-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--c-indigo) 0%,#818cf8 100%);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 0 0 3px rgba(99,102,241,0.2),0 4px 16px rgba(99,102,241,0.35);flex-shrink:0;}
.vision-name{font-family:var(--font-display);font-size:0.95rem;font-weight:800;letter-spacing:0.5px;color:var(--text-dark);}
.vision-status{display:flex;align-items:center;gap:5px;font-size:0.72rem;font-weight:500;color:var(--text-light);}
.vision-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;animation:visionPulse 2.5s ease-in-out infinite;}
.vision-close{background:rgba(99,102,241,0.08);border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-mid);transition:background 0.2s,transform 0.2s;}
.vision-close:hover{background:rgba(99,102,241,0.18);transform:rotate(90deg);}

.vision-messages{flex:1;overflow-y:auto;padding:16px 16px 8px;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:rgba(99,102,241,0.2) transparent;}
.vision-messages::-webkit-scrollbar{width:4px;}
.vision-messages::-webkit-scrollbar-thumb{background:rgba(99,102,241,0.2);border-radius:4px;}

.vision-msg{display:flex;flex-direction:column;gap:4px;max-width:85%;}
.vision-msg-ai{align-self:flex-start;}
.vision-msg-user{align-self:flex-end;}
.vision-msg-bubble{padding:11px 16px;border-radius:18px;font-size:0.9rem;line-height:1.6;font-weight:400;}
.vision-msg-ai .vision-msg-bubble{background:rgba(255,255,255,0.72);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.85);color:var(--text-dark);border-bottom-left-radius:6px;box-shadow:0 2px 12px rgba(99,102,241,0.08),inset 0 1px 0 rgba(255,255,255,0.9);}
.vision-msg-user .vision-msg-bubble{background:linear-gradient(135deg,var(--c-indigo) 0%,#4f52e0 100%);color:#fff;border-bottom-right-radius:6px;box-shadow:0 4px 16px rgba(99,102,241,0.30);}
.vision-msg-time{font-size:0.68rem;color:var(--text-light);padding:0 4px;}
.vision-msg-user .vision-msg-time{text-align:right;}

.vision-typing .vision-msg-bubble{display:flex;align-items:center;gap:5px;padding:14px 18px;}
.vision-typing-dot{width:7px;height:7px;border-radius:50%;background:var(--c-indigo);opacity:0.5;animation:typingBounce 1.2s ease-in-out infinite;}
.vision-typing-dot:nth-child(2){animation-delay:0.2s;}
.vision-typing-dot:nth-child(3){animation-delay:0.4s;}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0);}30%{transform:translateY(-6px);opacity:1;}}

.vision-suggestions{display:flex;flex-wrap:wrap;gap:7px;padding:8px 16px;}
.vision-chip{background:rgba(255,255,255,0.65);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(99,102,241,0.15);border-radius:50px;padding:6px 14px;font-size:0.78rem;font-weight:600;color:var(--c-indigo);cursor:pointer;transition:background 0.2s,transform 0.2s,box-shadow 0.2s;}
.vision-chip:hover{background:rgba(255,255,255,0.95);transform:translateY(-2px);box-shadow:0 4px 16px rgba(99,102,241,0.14);}

.vision-input-row{display:flex;align-items:center;gap:10px;padding:12px 16px 16px;}
.vision-input{flex:1;background:rgba(255,255,255,0.6);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(99,102,241,0.15);border-radius:50px;padding:11px 18px;font-family:var(--font-sans);font-size:0.9rem;color:var(--text-dark);outline:none;transition:border-color 0.2s,box-shadow 0.2s;box-shadow:inset 0 1px 0 rgba(255,255,255,0.8);}
.vision-input:focus{border-color:var(--c-indigo);box-shadow:0 0 0 3px rgba(99,102,241,0.10),inset 0 1px 0 rgba(255,255,255,0.9);}
.vision-input::placeholder{color:var(--text-light);}
.vision-send{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--c-indigo) 0%,#4f52e0 100%);border:none;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;flex-shrink:0;box-shadow:0 4px 16px rgba(99,102,241,0.35);transition:transform 0.2s,box-shadow 0.2s;}
.vision-send:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(99,102,241,0.45);}

@media(max-width:480px){
.vision-panel{width:calc(100vw - 24px);right:12px;bottom:76px;border-radius:20px;max-height:calc(100vh - 100px);}
.vision-fab{bottom:16px;right:12px;}
}

/* ===================== EDUCATION SECTION ===================== */
.section-education {
    background: linear-gradient(180deg, #f4f2fc 0%, var(--c-cream) 100%);
    padding: 120px 0;
    overflow: hidden;
}
.section-education::after {
    background: linear-gradient(to bottom, transparent, var(--c-cream-dim));
}

.edu-timeline {
    display: flex;
    flex-direction: row;
    gap: 24px;
    position: relative;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 16px;
    scrollbar-width: none;
}
.edu-timeline::-webkit-scrollbar { display: none; }
.edu-timeline .edu-card {
    scroll-snap-align: start;
    flex: 0 0 260px;
}

/* Horizontal connector line */
.edu-timeline::before {
    content: '';
    position: absolute;
    top: 40px;
    left: 130px;
    width: calc((260px + 24px) * 4);
    height: 2px;
    background: linear-gradient(to right, var(--c-indigo) 0%, rgba(99,102,241,0.15) 100%);
    border-radius: 2px;
    z-index: 0;
}

.edu-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative;
    padding-bottom: 0;
}

.edu-connector { display: none; }

/* Circle logo */
.edu-logo-circle {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: #ffffff;
    border: 2px solid var(--glass-border);
    box-shadow: var(--glass-shadow), 0 0 0 4px rgba(99,102,241,0.06);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
    z-index: 2;
    margin-bottom: 20px;
    overflow: hidden;
    transition: transform 0.3s cubic-bezier(0.22,1,0.36,1), box-shadow 0.3s;
}
.edu-card:hover .edu-logo-circle {
    transform: scale(1.10);
    box-shadow: var(--glass-shadow), 0 0 0 6px rgba(99,102,241,0.12), 0 8px 32px rgba(99,102,241,0.20);
}
.edu-card-college .edu-logo-circle {
    border-color: var(--c-indigo);
    box-shadow: var(--glass-shadow), 0 0 0 5px rgba(99,102,241,0.14), 0 0 28px rgba(99,102,241,0.25);
}

.edu-logo-fallback {
    font-size: 2rem;
    line-height: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
}
.edu-logo-img {
    width: 72%;
    height: 72%;
    object-fit: contain;
    display: block;
    flex-shrink: 0;
}

/* Content card */
.edu-content {
    background: var(--glass-bg-deep);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: 24px;
    padding: 24px 20px;
    box-shadow: var(--glass-shadow);
    position: relative;
    overflow: hidden;
    width: 100%;
    transition: transform 0.35s cubic-bezier(0.22,1,0.36,1), box-shadow 0.35s;
}
.edu-content::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.9), transparent);
}
.edu-card:hover .edu-content {
    transform: translateY(-6px);
    box-shadow: 0 24px 56px rgba(99,102,241,0.13), inset 0 1.5px 0 rgba(255,255,255,0.98);
}
.edu-card-college .edu-content {
    border-color: rgba(99,102,241,0.25);
    background: rgba(255,255,255,0.72);
}

.edu-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 14px;
    border-radius: 50px;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    background: var(--c-indigo-soft);
    color: var(--c-indigo);
    border: 1px solid rgba(99,102,241,0.18);
    margin-bottom: 10px;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
}
.edu-badge-current {
    background: var(--c-indigo);
    color: #fff;
    border-color: var(--c-indigo);
    box-shadow: 0 4px 16px rgba(99,102,241,0.30);
    animation: badgeGlow 2.5s ease-in-out infinite;
}
@keyframes badgeGlow {
    0%,100% { box-shadow: 0 4px 16px rgba(99,102,241,0.30); }
    50%      { box-shadow: 0 4px 28px rgba(99,102,241,0.55); }
}

.edu-name {
    font-family: var(--font-display);
    font-size: 0.95rem;
    font-weight: 800;
    letter-spacing: -0.2px;
    color: var(--text-dark);
    margin-bottom: 4px;
    line-height: 1.3;
}
.edu-school {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--c-indigo);
    margin-bottom: 2px;
}
.edu-period {
    font-size: 0.76rem;
    font-weight: 500;
    color: var(--text-light);
    margin-bottom: 10px;
}
.edu-desc {
    font-size: 0.82rem;
    line-height: 1.6;
    color: var(--text-mid);
    margin-bottom: 12px;
}
.edu-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
}
.edu-tag {
    padding: 3px 10px;
    border-radius: 50px;
    font-size: 0.7rem;
    font-weight: 600;
    background: rgba(99,102,241,0.07);
    border: 1px solid rgba(99,102,241,0.14);
    color: var(--c-indigo);
}

@media (max-width: 1024px) {
    .edu-timeline { grid-template-columns: repeat(2, 1fr); }
    .edu-timeline::before { display: none; }
}
@media (max-width: 600px) {
    .section-education { padding: 70px 0; }
    .edu-timeline { grid-template-columns: 1fr; gap: 16px; }
    .edu-logo-circle { width: 60px; height: 60px; overflow: hidden; }
    .edu-logo-img { width: 70%; height: 70%; }
    .edu-content { padding: 20px 16px; }
}

/* ===================== CONTACT SOCIALS ===================== */
.contact-image-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

.contact-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
}

.csoc-btn {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(255,255,255,0.62);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid rgba(255,255,255,0.82);
    box-shadow: 0 4px 16px rgba(99,102,241,0.10), inset 0 1.5px 0 rgba(255,255,255,0.95);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-mid);
    text-decoration: none;
    transition: transform 0.25s cubic-bezier(0.22,1,0.36,1), box-shadow 0.25s, background 0.25s, color 0.25s;
    position: relative;
    overflow: hidden;
}

.csoc-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(255,255,255,0.4) 0%, transparent 60%);
    pointer-events: none;
}

.csoc-btn:hover {
    transform: translateY(-4px) scale(1.08);
    background: rgba(255,255,255,0.88);
    box-shadow: 0 12px 32px rgba(99,102,241,0.20), inset 0 1.5px 0 rgba(255,255,255,1);
    color: var(--c-indigo);
}

/* Individual brand colors on hover */
.csoc-btn[title="GitHub"]:hover       { color: #24292e; }
.csoc-btn[title="LinkedIn"]:hover     { color: #0077b5; }
.csoc-btn[title="Discord"]:hover      { color: #5865f2; }
.csoc-btn[title="Twitter / X"]:hover  { color: #000; }
.csoc-btn[title="Email"]:hover        { color: #ea4335; }
.csoc-btn[title="Google Dev Profile"]:hover { color: #4285f4; }

@media(max-width:768px) {
    .csoc-btn { width: 44px; height: 44px; }
    .contact-socials { gap: 10px; }
}

/* ===================== PROJECT MOCKUP WITH IMAGE ===================== */
.project-mockup-img {
    height: auto;
    max-height: 500px;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(99,102,241,0.18);
    display: flex;
    align-items: center;
    justify-content: center;
}
.project-mockup-img img {
    width: auto;
    max-width: 100%;
    max-height: 500px;
    display: block;
    border-radius: 24px;
    object-fit: contain;
}

/* ===================== PROJECTS GRID ===================== */
.section-projects { background: linear-gradient(180deg, #f4f2fc 0%, var(--c-cream) 100%); padding: 120px 0; }
.section-projects::after { background: linear-gradient(to bottom, transparent, var(--c-cream-dim)); }

.proj-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

.proj-card {
    background: var(--glass-bg-deep);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: 28px;
    overflow: hidden;
    box-shadow: var(--glass-shadow);
    transition: transform 0.35s cubic-bezier(0.22,1,0.36,1), box-shadow 0.35s;
    display: flex;
    flex-direction: column;
}
.proj-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 32px 64px rgba(99,102,241,0.16), inset 0 1.5px 0 rgba(255,255,255,0.98);
}
.proj-card-featured {
    grid-column: span 3;
    flex-direction: row;
}

/* Logo circle area */
.proj-card-logo-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 36px 0;
    flex-shrink: 0;
}
.proj-card-featured .proj-card-logo-wrap {
    padding: 0 0 0 48px;
    align-self: center;
}
.proj-logo-circle {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    background: rgba(255,255,255,0.85);
    border: 2px solid rgba(255,255,255,0.9);
    box-shadow: 0 8px 32px rgba(99,102,241,0.18), 0 0 0 6px rgba(99,102,241,0.07), inset 0 1.5px 0 rgba(255,255,255,1);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.6rem;
    transition: transform 0.35s cubic-bezier(0.22,1,0.36,1), box-shadow 0.35s;
    flex-shrink: 0;
    overflow: hidden;
}
.proj-card:hover .proj-logo-circle {
    transform: scale(1.10) rotate(-4deg);
    box-shadow: 0 16px 48px rgba(99,102,241,0.28), 0 0 0 8px rgba(99,102,241,0.10), inset 0 1.5px 0 rgba(255,255,255,1);
}
.proj-logo-circle img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    border-radius: 50%;
}

/* Body */
.proj-card-body {
    padding: 32px 36px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    flex: 1;
    position: relative;
}
.proj-card-body::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.9), transparent);
}
.proj-card-featured .proj-card-body::before { top: 0; left: 0; width: 1px; height: 100%; background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.9), transparent); }

.proj-card-top {
    display: flex;
    align-items: center;
    gap: 12px;
}
.proj-number {
    font-family: var(--font-display);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 2px;
    color: var(--c-indigo);
    opacity: 0.5;
}
.proj-badge {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--c-indigo);
    background: var(--c-indigo-soft);
    border: 1px solid rgba(99,102,241,0.18);
    border-radius: 50px;
    padding: 3px 12px;
}
.proj-title {
    font-family: var(--font-display);
    font-size: 1.6rem;
    font-weight: 800;
    letter-spacing: -0.5px;
    color: var(--text-dark);
    line-height: 1.1;
}
.proj-card:not(.proj-card-featured) .proj-title { font-size: 1.2rem; }
.proj-desc {
    font-size: 0.93rem;
    line-height: 1.7;
    color: var(--text-mid);
    flex: 1;
}
.proj-tags { display: flex; flex-wrap: wrap; gap: 7px; }
.proj-links { display: flex; gap: 10px; align-items: center; margin-top: 4px; }
.proj-link-btn {
    text-decoration: none;
    background: var(--c-indigo);
    color: #fff;
    padding: 9px 22px;
    border-radius: 50px;
    font-size: 0.84rem;
    font-weight: 700;
    box-shadow: 0 4px 16px rgba(99,102,241,0.30);
    transition: background 0.2s, transform 0.2s;
}
.proj-link-btn:hover { background: #4f52e0; transform: translateY(-2px); }
.proj-link-ghost {
    text-decoration: none;
    color: var(--text-mid);
    font-size: 0.84rem;
    font-weight: 600;
    padding: 9px 18px;
    border-radius: 50px;
    border: 1.5px solid rgba(99,102,241,0.18);
    transition: border-color 0.2s, color 0.2s;
}
.proj-link-ghost:hover { border-color: var(--c-indigo); color: var(--c-indigo); }

@media(max-width:1024px) {
    .proj-card-featured { flex-direction: column; grid-column: span 3; }
    .proj-card-featured .proj-card-logo-wrap { padding: 32px 36px 0; align-self: auto; }
    .proj-card-featured .proj-card-body::before { top: 0; left: 0; right: 0; width: 100%; height: 1px; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.9), transparent); }
}
@media(max-width:768px) {
    .section-projects { padding: 70px 0; }
    .proj-grid { grid-template-columns: 1fr; gap: 14px; }
    .proj-card-featured { grid-column: span 1; flex-direction: column; }
    .proj-title { font-size: 1.2rem; }

    /* ── Mobile Accordion ── */
    /* Hide logo wrap & body by default; show toggle header */
    .proj-card-logo-wrap { display: none !important; }
    .proj-card-body {
        max-height: 0;
        overflow: hidden;
        padding-top: 0 !important;
        padding-bottom: 0 !important;
        transition: max-height 0.42s cubic-bezier(0.22,1,0.36,1), padding 0.3s;
    }
    .proj-card.proj-expanded .proj-card-body {
        max-height: 700px;
        padding-top: 0 !important;
        padding-bottom: 22px !important;
    }
    .proj-card-toggle {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        padding: 16px 20px;
        cursor: pointer;
        background: none;
        border: none;
        width: 100%;
        text-align: left;
    }
    .proj-toggle-left {
        display: flex;
        align-items: center;
        gap: 12px;
        flex: 1;
        min-width: 0;
    }
    .proj-toggle-logo {
        width: 42px;
        height: 42px;
        border-radius: 50%;
        background: rgba(255,255,255,0.85);
        border: 1.5px solid rgba(255,255,255,0.9);
        box-shadow: 0 4px 14px rgba(99,102,241,0.14);
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        overflow: hidden;
    }
    .proj-toggle-logo img {
        width: 100%; height: 100%;
        object-fit: cover; border-radius: 50%;
    }
    .proj-toggle-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
    .proj-toggle-name {
        font-family: var(--font-display);
        font-size: 1rem;
        font-weight: 800;
        color: var(--text-dark);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .proj-toggle-badge {
        font-size: 0.65rem;
        font-weight: 700;
        letter-spacing: 0.8px;
        text-transform: uppercase;
        color: var(--c-indigo);
    }
    .proj-toggle-chevron {
        width: 28px; height: 28px;
        border-radius: 50%;
        background: var(--c-indigo-soft);
        border: 1px solid rgba(99,102,241,0.18);
        display: flex; align-items: center; justify-content: center;
        flex-shrink: 0;
        color: var(--c-indigo);
        transition: transform 0.35s cubic-bezier(0.22,1,0.36,1), background 0.2s, color 0.2s;
    }
    .proj-card.proj-expanded .proj-toggle-chevron {
        transform: rotate(180deg);
        background: var(--c-indigo);
        color: #fff;
    }
    /* Body padding when expanded */
    .proj-card.proj-expanded .proj-card-body {
        padding-left: 20px !important;
        padding-right: 20px !important;
    }
    .proj-links { flex-wrap: wrap; gap: 8px; margin-top: 8px; }
    .proj-link-btn, .proj-link-ghost { font-size: 0.86rem; padding: 9px 18px; }
}
@media(min-width:769px) {
    .proj-card-toggle { display: none; }
}
@media(max-width:480px) {
    .proj-card-body { padding: 20px 18px; }
    .proj-card:not(.proj-card-featured) .proj-card-img { height: 180px; }
    .blog-read { font-size: 0.85rem; padding: 7px 14px; }
}

/* ===================== MOBILE SCROLL PERFORMANCE ===================== */
@media(max-width:768px){
    /* Kill canvas cloud — biggest GPU drain on mobile */
    #cloud-canvas{display:none !important;}
    /* Kill floating orbs */
    .hero-bg-orb{display:none !important;}
    /* Kill heavy looping CSS animations */
    .orb-1,.orb-2{animation:none !important;}
    .nav-container::before{animation:none !important;}
    .badge-1,.badge-2{animation:none !important;}
    .pill-badge::after{animation:none !important;}
    .vision-fab-pulse{animation:none !important;}
    .edu-badge-current{animation:none !important;}
    .rm-node.state-active .rm-bubble{animation:none !important;}
    /* Remove backdrop-filter blur from all glass elements — #1 scroll jank cause on mobile */
    .glass-card,.about-glass,.masonry-item,.info-card,.timeline-card,.blog-card,
    .skills-glass-wrap,.rm-panel-inner,.rm-bubble,.edu-content,.proj-card,
    .nav-container,.mobile-menu,.contact-form-container,.vision-panel,
    .vision-fab-inner,.vision-chip,.vision-input,.sg-pill,.skill-chip,.csoc-btn,
    .hero-float-badge,.form-group input,.form-group textarea{
        backdrop-filter:none !important;
        -webkit-backdrop-filter:none !important;
    }
    /* Snappy scroll reveal — elements already get .visible immediately on mobile via JS */
    .fade-in,.slide-left,.slide-right,.scale-in{
        transition:opacity 0.2s ease,transform 0.2s ease !important;
        will-change:opacity,transform;
    }
    .fade-in.visible,.slide-left.visible,.slide-right.visible,.scale-in.visible{
        will-change:auto;
    }
}
