@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg: #0c1017;--bg-alt: #0f1624;--card: #111927;--text: #e5e7eb;--muted: #9aa0ad;--accent: #7b7b7b;--surface: #161f2e;--border: rgba(255, 255, 255, .06);--pill: #1f2937}body{margin:0;width:100%;overflow-x:hidden;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;transition:background .3s ease,color .3s ease}body.theme-light{--bg: linear-gradient(135deg, #F3F3F3 0%, #F8F8F8 100%);--bg-alt: #ffffff;--card: #f5f5f7;--text: #1a1a1a;--muted: #4a4a4a;--accent: #7b7b7b;--surface: #ffffff;--border: rgba(0, 0, 0, .05);--pill: #f0f2f5}body.theme-dark{background:radial-gradient(circle at 20% 20%,rgba(62,83,119,.18),transparent 35%),radial-gradient(circle at 80% 0%,rgba(72,207,173,.12),transparent 30%),#0c1017}*{box-sizing:border-box}a{color:inherit;text-decoration:none}.app-shell{display:flex;min-height:100vh;background:transparent;gap:0}.main-content{flex:1;padding:32px 48px 64px;max-width:1400px;margin:0 auto;min-width:0}.section{padding:80px 0;scroll-margin-top:96px}.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:var(--pill);color:var(--text);border:1px solid var(--border);font-weight:600;font-size:.9rem}.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}.skills-wall{margin-top:48px;padding:24px;border-radius:18px;background:var(--surface);border:1px solid var(--border);display:grid;grid-template-columns:repeat(auto-fit,minmax(62px,1fr));gap:16px}.skill-chip{height:60px;border-radius:14px;background:linear-gradient(135deg,#ffffff0a,#ffffff05);border:1px solid var(--border);display:grid;place-items:center;font-weight:700;color:var(--text);letter-spacing:.3px;box-shadow:inset 0 1px #ffffff0a}.theme-toggle{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.theme-toggle:hover{transform:translateY(-2px);box-shadow:0 10px 30px #00000026}.content-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:28px;box-shadow:0 20px 70px #00000047}body.theme-dark .about-section,body.theme-dark #portfolio,body.theme-dark .section.contact{background:var(--bg-alt);color:var(--text)}body.theme-dark .about-section h1,body.theme-dark .about-section h2,body.theme-dark .about-section h3,body.theme-dark .timeline-header h2,body.theme-dark .timeline-title,body.theme-dark .featured-title h1,body.theme-dark .section.contact h2{color:var(--text)}body.theme-dark .desc,body.theme-dark .desc h2,body.theme-dark .timeline-description,body.theme-dark .timeline-company,body.theme-dark .timeline-period,body.theme-dark .cv-description,body.theme-dark .cv-company,body.theme-dark .featured-proj .MuiTypography-body2{color:var(--muted)!important}body.theme-dark .cv-section,body.theme-dark .timeline-section,body.theme-dark .cv-tab,body.theme-dark .timeline-tab,body.theme-dark .cv-item,body.theme-dark .timeline-content,body.theme-dark .skill-items{background:var(--surface)!important;border-color:var(--border)!important;box-shadow:none!important}body.theme-dark .cv-tab.active,body.theme-dark .timeline-tab.active,body.theme-dark .timeline-dot{background:#1f2937!important;color:var(--text)!important}body.theme-dark .featured-proj .MuiCard-root{background:var(--surface);border-color:var(--border)}body.theme-dark .featured-proj h2,body.theme-dark .featured-proj .MuiTypography-h5{color:var(--text)!important}body.theme-dark .featured-proj:hover h2,body.theme-dark .featured-proj:hover .MuiTypography-h5{color:#a9b2ff!important}body.theme-dark .featured-proj .MuiChip-root{background:#304ffe!important}body.theme-dark .section.contact{border-top:1px solid var(--border)}body.theme-light .sidebar-shell{background:#fff;border-right:1px solid var(--border);box-shadow:12px 0 30px #00000014}body.theme-light .profile-card,body.theme-light .nav-link{background:#fff;border:1px solid var(--border)}body.theme-light .nav-link.active{background:#e5e7eb;color:#111;border-color:#0000000f}body.theme-light .chat-cta{border-color:#0000000f}body.theme-light .grid-overlay{background-image:linear-gradient(rgba(255,255,255,.35) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.35) 1px,transparent 1px)}body.theme-light .section.contact{background:#fff;color:#111}body.theme-light .contact-form{background:#00000008;border:1px solid rgba(0,0,0,.06)}body.theme-light .contact-form input,body.theme-light .contact-form textarea{background:#fff;color:#111;border:1px solid rgba(0,0,0,.12)}body.theme-light .contact-icon{background:#0000000a;border:1px solid rgba(0,0,0,.08);color:#111}body.theme-light .contact-icon .tooltip{background:#fff;color:#111;border:1px solid rgba(0,0,0,.08)}body.theme-light .contact-form button{background:#111;color:#fff}@media (max-width: 1024px){.app-shell{flex-direction:column}.main-content{padding:24px 22px 48px}.hero-grid{grid-template-columns:1fr}.skills-wall{grid-template-columns:repeat(auto-fit,minmax(54px,1fr))}}@media (max-width: 768px){.main-content{padding:20px 16px 40px}.section{padding:60px 0}}@media (max-width: 480px){.main-content{padding:16px 12px 32px}.section{padding:40px 0}}.landing{position:relative;scroll-margin-top:96px}.grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}.hero-grid{position:relative;z-index:1}.text-stack{display:flex;flex-direction:column;gap:18px}.eyebrow{color:var(--muted);font-weight:600;letter-spacing:.4px;margin-bottom:-1rem}.display-name{font-size:clamp(4.8rem,5vw,3.8rem);line-height:1.1;margin:0;color:var(--text)}.meta-row{display:flex;flex-wrap:wrap;gap:12px}.lede{color:var(--muted);line-height:1.6;font-size:1.02rem;margin:10px 0 6px}.action-buttons{display:flex;gap:16px;margin-top:24px;margin-bottom:6px}.btn-resume{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 28px;background:#ff6b35;color:#fff;text-decoration:none;border-radius:12px;font-weight:600;font-size:1rem;transition:all .3s ease;border:none;cursor:pointer;box-shadow:0 4px 12px #ff6b3533}.btn-resume:hover{background:#e55a2b;transform:translateY(-2px);box-shadow:0 6px 20px #ff6b3566}.social-row{display:flex;gap:14px;margin-top:6px}.social-row svg{color:var(--text);padding:10px;border-radius:12px;border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.social-row svg:hover{transform:translateY(-3px);box-shadow:0 12px 30px #0003;background:linear-gradient(135deg,#ffffff0d,#ffffff05)}.portrait-wrapper{position:relative;display:flex;justify-content:center}.glow{position:absolute;width:320px;height:420px;background:radial-gradient(circle at 30% 30%,rgba(74,222,128,.12),transparent 55%),radial-gradient(circle at 70% 60%,rgba(59,130,246,.12),transparent 60%);filter:blur(10px);top:-20px;z-index:0}.photo-container{width:360px;height:420px;border-radius:20px;overflow:hidden;position:relative;border:1px solid var(--border);background:linear-gradient(135deg,#ffffff0a,#ffffff05);box-shadow:0 20px 50px #00000059;z-index:1}.portrait{width:100%;height:100%;object-fit:cover;display:block}@media (max-width: 1024px){.photo-container{width:100%;max-width:340px;height:380px}}@media (max-width: 768px){.hero-grid{gap:32px}.meta-row{flex-direction:column;align-items:flex-start}.text-stack{gap:14px}.display-name{font-size:clamp(2.5rem,8vw,3rem)}.lede{font-size:.95rem}.action-buttons{flex-direction:column;width:100%}.btn-resume{width:100%;justify-content:center}.social-row{flex-wrap:wrap;gap:10px}.social-row svg{size:40px;padding:8px}}@media (max-width: 480px){.display-name{font-size:2rem}.eyebrow{font-size:.9rem}.pill{font-size:.85rem;padding:6px 12px}.social-row svg{size:36px}}.resume-modal-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:10px;animation:fadeIn .3s ease}.resume-modal-content{background:var(--surface);border-radius:16px;width:100%;max-width:1200px;max-height:95vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease;border:1px solid var(--border)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.resume-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.resume-modal-header h2{margin:0;font-size:1.5rem;color:var(--text);font-weight:600}.resume-modal-actions{display:flex;gap:12px;align-items:center}.resume-download-btn,.resume-close-btn{background:transparent;border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.resume-download-btn:hover{background:var(--card);border-color:#ff6b35;color:#ff6b35;transform:translateY(-2px)}.resume-close-btn:hover{background:var(--card);border-color:var(--text);transform:translateY(-2px)}.resume-modal-body{flex:1;overflow:hidden;display:flex;min-height:0}.resume-pdf-embed{width:100%;height:100%;border:none;border-radius:0 0 16px 16px;min-height:800px;display:block}.resume-iframe{width:100%;height:100%;border:none;border-radius:0 0 16px 16px;min-height:600px}.resume-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;color:var(--text);min-height:600px;width:100%}.resume-fallback p{margin-bottom:12px;color:var(--muted);font-size:1.1rem}.resume-fallback-hint{font-size:.9rem!important;color:var(--muted)!important;margin-bottom:24px!important;max-width:400px}@media (max-width: 768px){.resume-modal-overlay{padding:10px}.resume-modal-content{max-height:95vh;border-radius:12px}.resume-modal-header{padding:16px 20px}.resume-modal-header h2{font-size:1.25rem}.resume-iframe{min-height:500px}}@media (max-width: 480px){.resume-modal-overlay{padding:0}.resume-modal-content{max-height:100vh;border-radius:0;height:100vh}.resume-modal-header{padding:12px 16px}.resume-modal-header h2{font-size:1.1rem}.resume-iframe{min-height:calc(100vh - 80px)}.resume-download-btn,.resume-close-btn{padding:6px}}*{font-family:Inter,sans-serif}.about-section{position:relative;overflow:hidden;background-color:#f8f8f8;min-height:auto;padding-top:40px;scroll-margin-top:96px}.background-elements{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.floating-element{position:absolute;background:linear-gradient(45deg,#2222221a,#7b7b7b1a);border-radius:50%;animation:float infinite ease-in-out;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}@keyframes float{0%,to{transform:translateY(0) rotate(0);opacity:.7}50%{transform:translateY(-20px) rotate(180deg);opacity:1}}.gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);animation:pulse 6s ease-in-out infinite}.gradient-orb-1{width:300px;height:300px;background:linear-gradient(45deg,#ff4b4b4d,#ff964b4d);top:10%;right:10%;animation-delay:0s}.gradient-orb-2{width:200px;height:200px;background:linear-gradient(45deg,#4b96ff4d,#964bff4d);bottom:20%;left:15%;animation-delay:2s}.gradient-orb-3{width:150px;height:150px;background:linear-gradient(45deg,#4bff964d,#4bc8ff4d);top:50%;left:50%;animation-delay:4s}@keyframes pulse{0%,to{transform:scale(1) rotate(0);opacity:.5}50%{transform:scale(1.1) rotate(180deg);opacity:.8}}.cursor-follower{position:fixed;width:20px;height:20px;background:radial-gradient(circle,rgba(34,34,34,.3) 0%,transparent 70%);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);transition:transform .1s ease-out;z-index:1}.grid-pattern{position:absolute;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(rgba(34,34,34,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(34,34,34,.05) 1px,transparent 1px);background-size:50px 50px;animation:gridMove 20s linear infinite}@keyframes gridMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.floating-code{position:absolute;font-family:Courier New,monospace;font-weight:600;color:#2222225b;font-size:14px;animation:codeFloat 15s linear infinite}.code-1{top:25%;left:5%;animation-delay:0s}.code-2{top:45%;right:10%;animation-delay:3s}.code-3{top:65%;left:8%;animation-delay:6s}.code-4{top:35%;right:20%;animation-delay:9s}.code-5{top:80%;right:5%;animation-delay:12s}@keyframes codeFloat{0%{transform:translateY(100vh) rotate(0);opacity:0}10%,90%{opacity:1}to{transform:translateY(-100px) rotate(360deg);opacity:0}}.about-container{padding:70px 40px;max-width:1400px;margin:0 auto;min-height:auto;position:relative;z-index:2}.about-head h1{display:flex;justify-content:center;font-size:3.3rem;margin-top:5.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.about-content{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.desc{font-size:1.1rem;color:#7b7b7b;line-height:1.8;margin-top:50px}.desc h2{color:#222;font-size:1.5rem;margin-bottom:20px}.skills{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;margin-top:40px}.skill-items{background:#f8f8f8e6;padding:20px;border-radius:15px;text-align:center;transition:all .3s ease;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-color:transparent;box-shadow:inset 52px 55px 76px -51px #4e4d4d1a,38px 30px 75px 6px #5c58581a}.skill-items:hover{background-color:#222;color:#f2f2f2}.skill-items:hover svg{margin-bottom:10px;color:#fff}.cv-section{padding:48px 32px;border-radius:25px;position:relative;overflow:hidden;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);margin-top:80px}.cv-header{text-align:center;margin-bottom:40px}.cv-header h2{font-size:2.5rem;color:#222;margin-bottom:10px;position:relative}.cv-header p{font-size:1.1rem;color:#7b7b7b;font-style:italic}.cv-tabs{display:flex;justify-content:center;gap:20px;margin-bottom:50px;flex-wrap:wrap}.cv-tab{background:#ffffffe6;border:2px solid rgba(240,240,240,.5);padding:15px 25px;border-radius:50px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;display:flex;align-items:center;gap:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-color:transparent;box-shadow:inset 52px 55px 76px -51px #4e4d4d1a,38px 30px 75px 6px #5c58581a}.cv-tab:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);transition:left .5s ease}.cv-tab:hover:before{left:100%}.cv-tab:hover{border-color:#222;transform:translateY(-2px);box-shadow:0 5px 15px #0000001a}.cv-tab.active{background:#222;color:#fff;border-color:#222;transform:translateY(-2px);box-shadow:0 5px 15px #0003}.cv-content{max-width:800px;margin:0 auto}.cv-item{background:#ffffffe6;padding:30px;border-radius:20px;margin-bottom:25px;border-left:4px solid #222222;transition:all .3s ease;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-color:transparent;box-shadow:inset 52px 55px 76px -51px #4e4d4d1a,38px 30px 75px 6px #5c58581a}.cv-item:hover{transform:translate(10px);box-shadow:0 10px 25px #0000001a}.cv-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;flex-wrap:wrap;gap:10px}.cv-item h3{color:#222;font-size:1.3rem;font-weight:600;margin:0}.cv-period{background:#f0f0f0cc;padding:5px 15px;border-radius:20px;font-size:.9rem;color:#666;font-weight:500;white-space:nowrap;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.cv-company{color:#7b7b7b;font-size:1.1rem;font-weight:500;margin:5px 0 15px}.cv-description{color:#7b7b7b;line-height:1.6;margin:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.timeline-section{margin-top:60px;padding:48px 32px;border-radius:25px;position:relative;overflow:hidden;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.timeline-header{text-align:center;margin-bottom:40px}.timeline-header h2{font-size:2.5rem;color:#222;margin-bottom:10px;position:relative}.timeline-header p{font-size:1.1rem;color:#7b7b7b;font-style:italic}.timeline-tabs{display:flex;justify-content:center;gap:20px;margin-bottom:50px;flex-wrap:wrap}.timeline-tab{background:#ffffffe6;border:2px solid rgba(240,240,240,.5);padding:15px 25px;border-radius:50px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;display:flex;align-items:center;gap:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-color:transparent;box-shadow:inset 52px 55px 76px -51px #4e4d4d1a,38px 30px 75px 6px #5c58581a}.timeline-tab:hover{border-color:#222;transform:translateY(-2px);box-shadow:0 5px 15px #0000001a}.timeline-tab.active{background:#222;color:#fff;border-color:#222;transform:translateY(-2px);box-shadow:0 5px 15px #0003}.timeline-container{position:relative;max-width:1000px;margin:0 auto;padding:20px 0}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:4px;background:linear-gradient(to bottom,#222,#7b7b7b);transform:translate(-50%);border-radius:2px}.timeline-item{position:relative;margin:32px 0;display:flex;align-items:center;animation:fadeInUp .6s ease-out forwards;opacity:0}.timeline-item:nth-child(1){animation-delay:.1s}.timeline-item:nth-child(2){animation-delay:.3s}.timeline-item:nth-child(3){animation-delay:.5s}.timeline-item:nth-child(4){animation-delay:.7s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.timeline-item.left{justify-content:flex-end;padding-right:calc(50% + 40px)}.timeline-item.right{justify-content:flex-start;padding-left:calc(50% + 40px)}.timeline-dot{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:50px;height:50px;background:#222;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;z-index:10;border-color:transparent;box-shadow:inset 52px 55px 76px -51px #4e4d4d1a,38px 30px 75px 6px #5c58581a;transition:all .3s ease}.timeline-item:hover .timeline-dot{transform:translate(-50%,-50%) scale(1.1);box-shadow:0 0 0 12px #f8f8f8e6,0 0 30px #2226}.timeline-content{background:#fffffff2;padding:30px;border-radius:20px;max-width:400px;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-color:transparent;box-shadow:inset 52px 55px 76px -51px #4e4d4d1a,38px 30px 75px 6px #5c58581a;transition:all .3s ease}.timeline-content:hover{transform:translateY(-5px);box-shadow:0 20px 40px #00000026}.timeline-content:before{content:"";position:absolute;top:50%;width:0;height:0;border:15px solid transparent}.timeline-item.left .timeline-content:before{right:-30px;border-left-color:#fffffff2;transform:translateY(-50%)}.timeline-item.right .timeline-content:before{left:-30px;border-right-color:#fffffff2;transform:translateY(-50%)}.timeline-period{background:#fff;color:#222;padding:8px 16px;border-radius:20px;font-size:.85rem;font-weight:600;display:inline-block;margin-bottom:15px;letter-spacing:.5px;border-color:transparent;box-shadow:12px 10px 25px 6px #0000001a}.timeline-title{color:#222;font-size:1.3rem;font-weight:600;margin-bottom:8px;line-height:1.3}.timeline-company{color:#7b7b7b;font-size:1rem;font-weight:500;margin-bottom:12px;font-style:italic}.timeline-description{color:#666;line-height:1.6;font-size:.95rem}.fade-in{animation:fadeIn 1s ease-in-out}@media (max-width: 768px){.about-section{padding-top:20px}.about-container{padding:40px 20px}.about-head h1{font-size:2.5rem;margin-top:2rem}.about-content{grid-template-columns:1fr;gap:40px}.desc{font-size:1rem;margin-top:30px}.desc h2{font-size:1.3rem}.skills{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px;margin-top:30px}.skill-items{padding:16px}.cv-section{margin-top:60px;padding:30px 20px;border-radius:20px}.cv-header h2{font-size:2rem}.cv-tabs{flex-direction:column;align-items:center;gap:12px}.cv-tab{width:100%;max-width:250px;text-align:center;padding:12px 20px}.cv-item{padding:20px}.cv-item-header{flex-direction:column;align-items:flex-start}.cv-item:hover{transform:translateY(-5px)}.timeline-section{padding:30px 20px;margin-top:40px}.timeline-header h2{font-size:2rem}.timeline-tabs{flex-direction:column;align-items:center;gap:12px}.timeline-tab{width:100%;max-width:250px;padding:12px 20px}.timeline-line{left:20px}.timeline-item.left,.timeline-item.right{padding-left:60px;padding-right:0;justify-content:flex-start}.timeline-dot{left:20px}.timeline-content{max-width:100%}.timeline-content:before{display:none}.floating-code{font-size:12px}.gradient-orb-1{width:200px;height:200px}.gradient-orb-2{width:150px;height:150px}.gradient-orb-3{width:100px;height:100px}}@media (max-width: 480px){.about-head h1{font-size:2rem}.cv-header h2,.timeline-header h2{font-size:1.75rem}.skills{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}}.projects-section{background:#0c1017;color:#e5e7eb;padding:80px 24px;min-height:100vh}.tab-toggle-container{display:flex;justify-content:center;margin-bottom:60px}.tab-toggle{display:flex;background-color:#ffffff0d;border-radius:20px;padding:4px;position:relative;max-width:600px;width:100%}.tab-button{flex:1;padding:12px 24px;border:none;background:transparent;border-radius:16px;cursor:pointer;font-weight:600;font-size:1rem;color:#fff9;transition:color .3s ease;z-index:1;position:relative}.tab-button.active{color:#fff}.tab-indicator{position:absolute;top:4px;width:calc(50% - 4px);height:calc(100% - 8px);background:#ff6b35;border-radius:16px;z-index:0}.projects-header{text-align:center;margin-bottom:60px}.projects-title{font-size:3.5rem;font-weight:700;color:#fff;margin:0 0 20px;font-family:Inter,system-ui,-apple-system,sans-serif}.projects-header-decoration{display:flex;flex-direction:column;align-items:center;gap:0}.decoration-dot{width:12px;height:12px;background:#ff6b35;border-radius:50%;margin-bottom:8px}.decoration-line{width:2px;height:40px;background:#ff6b35}.projects-container{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:80px}.project-card{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:40px 0}.project-card.layout-left .project-content{order:1}.project-card.layout-left .project-visual,.project-card.layout-right .project-content{order:2}.project-card.layout-right .project-visual{order:1}.project-content{display:flex;flex-direction:column;gap:24px}.project-title{font-size:2.5rem;font-weight:700;color:#fff;margin:0;font-family:Inter,system-ui,-apple-system,sans-serif}.project-tech-tags{display:flex;flex-wrap:wrap;gap:12px}.tech-tag{display:inline-block;padding:8px 20px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:20px;color:#e5e7eb;font-size:.9rem;font-weight:500;transition:all .3s ease}.tech-tag:hover{border-color:#ff6b35;color:#ff6b35}.project-description{font-size:1.1rem;line-height:1.7;color:#9aa0ad;margin:0}.project-buttons{display:flex;gap:16px;margin-top:8px}.btn-github{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;background:#ff6b35;color:#fff;text-decoration:none;border-radius:6px;font-weight:600;font-size:1rem;transition:all .3s ease;border:none;cursor:pointer}.btn-github:hover{background:#e55a2b;transform:translateY(-2px);box-shadow:0 4px 12px #ff6b354d}.btn-project{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:#1f2937;color:#fff;text-decoration:none;border-radius:6px;font-weight:600;font-size:1rem;transition:all .3s ease;border:1px solid rgba(255,255,255,.1)}.btn-project:hover{background:#374151;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.project-visual{display:flex;align-items:center;justify-content:center}.terminal-output{background:#1a1a1a;border-radius:8px;overflow:hidden;width:100%;max-width:500px;box-shadow:0 8px 24px #0006}.terminal-header{background:#2d2d2d;padding:12px 16px;display:flex;align-items:center}.terminal-dots{display:flex;gap:8px}.terminal-dots span{width:12px;height:12px;border-radius:50%;background:#555}.terminal-dots span:nth-child(1){background:#ff5f56}.terminal-dots span:nth-child(2){background:#ffbd2e}.terminal-dots span:nth-child(3){background:#27c93f}.terminal-content{padding:20px;font-family:Courier New,monospace;font-size:.9rem;line-height:1.6;color:#e5e7eb}.terminal-line{margin-bottom:8px;white-space:pre-wrap}.code-snippet{background:#1a1a1a;border-radius:8px;padding:24px;width:100%;max-width:500px;box-shadow:0 8px 24px #0006;overflow-x:auto}.code-snippet pre{margin:0;font-family:Courier New,monospace;font-size:.85rem;line-height:1.6;color:#e5e7eb}.code-snippet code{color:#e5e7eb;white-space:pre}.project-image-wrapper{width:100%;max-width:500px;border-radius:8px;overflow:hidden;box-shadow:0 8px 24px #0006}.project-image{width:100%;height:auto;display:block;object-fit:cover}@media (max-width: 1200px){.project-card{gap:40px}.project-title{font-size:2rem}}@media (max-width: 900px){.projects-section{padding:60px 20px}.projects-title{font-size:2.5rem}.project-card{grid-template-columns:1fr;gap:40px}.project-card.layout-left .project-content,.project-card.layout-left .project-visual,.project-card.layout-right .project-content,.project-card.layout-right .project-visual{order:unset}.project-visual{order:-1}.project-title{font-size:1.8rem}.projects-container{gap:60px}}@media (max-width: 600px){.projects-section{padding:40px 16px}.projects-title{font-size:2rem}.projects-header,.tab-toggle-container{margin-bottom:40px}.project-title{font-size:1.5rem}.project-description{font-size:1rem}.project-buttons{flex-direction:column}.btn-github,.btn-project{width:100%;justify-content:center}.tech-tag{font-size:.8rem;padding:6px 16px}.tab-toggle{max-width:100%}.tab-button{padding:10px 12px;font-size:.85rem}.projects-container{gap:50px}.project-card{padding:20px 0}.code-snippet,.terminal-output{max-width:100%}.code-snippet pre{font-size:.75rem}.terminal-content{padding:16px;font-size:.8rem}}.section.contact{background:#222;color:#f3f3f3;padding:60px 0 40px;text-align:center;scroll-margin-top:96px}.section.contact h2{font-size:3rem;font-weight:700;margin-bottom:24px}.contact-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start;padding:0 24px}.contact-content{text-align:left}.contact-info{display:flex;justify-content:flex-start;gap:18px;flex-wrap:wrap;margin-top:24px}.contact-icon{position:relative;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#f3f3f3;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.contact-icon:hover{transform:translateY(-3px);box-shadow:0 10px 24px #00000040;background:#ffffff1f}.contact-icon .tooltip{pointer-events:none;position:absolute;bottom:110%;left:50%;transform:translate(-50%) translateY(6px);background:#111827;color:#f3f3f3;padding:6px 10px;border-radius:8px;font-size:.85rem;white-space:nowrap;opacity:0;transition:opacity .15s ease,transform .15s ease;border:1px solid rgba(255,255,255,.12);box-shadow:0 10px 30px #00000059;z-index:2}.contact-icon:hover .tooltip{opacity:1;transform:translate(-50%) translateY(0)}.contact-form{background:linear-gradient(135deg,#ffffff0f,#ffffff0a);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:14px;text-align:left}.contact-form label{display:flex;flex-direction:column;gap:6px;color:#e8e8e8;font-weight:600;font-size:.95rem}.contact-form input,.contact-form textarea{width:100%;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#f3f3f3;padding:12px 14px;font-size:.95rem;outline:none;transition:border .2s ease,box-shadow .2s ease}.contact-form input:focus,.contact-form textarea:focus{border-color:#7b7b7b;box-shadow:0 0 0 3px #7b7b7b40}.contact-form textarea{resize:vertical;min-height:140px}.contact-form button{margin-top:6px;border:none;border-radius:10px;padding:12px 16px;background:#7b7b7b;color:#f3f3f3;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.contact-form button:hover{transform:translateY(-2px);box-shadow:0 10px 24px #00000040;background:#8a8a8a}.status-box{background-color:#e0f7ff;color:#007bff;font-weight:700;padding:.5rem 1rem;border-radius:6px;margin-bottom:1rem;text-align:center;box-shadow:0 2px 6px #0000001a}button.btn-disabled{background:#555!important;cursor:not-allowed!important;box-shadow:none!important;transform:none!important}button.btn-enabled{background:#08f!important;cursor:pointer!important}@media (max-width: 768px){.contact-grid{grid-template-columns:1fr;gap:20px;padding:0 16px}.contact-info{gap:30px}.section.contact h2{font-size:2.5rem}}.mobile-menu-toggle{display:none;position:fixed;top:16px;left:16px;z-index:1001;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;color:var(--text);cursor:pointer;box-shadow:0 4px 12px #00000026;transition:all .3s ease}.mobile-menu-toggle:hover{background:var(--card);transform:scale(1.05)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar-shell{width:280px;min-width:260px;flex-shrink:0;position:sticky;top:0;height:100vh;padding:28px 22px;display:flex;flex-direction:column;gap:22px;background:var(--surface);border-right:1px solid var(--border);box-shadow:12px 0 40px #0000002e;transition:transform .3s ease;z-index:1000}.profile-card{padding:18px;text-align:center;display:flex;flex-direction:column;gap:8px}.avatar-ring{width:96px;height:96px;border-radius:50%;margin:0 auto;border:3px solid rgba(255,255,255,.1);padding:4px;background:radial-gradient(circle at 30% 30%,rgba(74,222,128,.18),transparent 60%)}.avatar{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.name-row{display:flex;align-items:center;justify-content:center;gap:6px}.name-row h2{margin:0;font-size:1.2rem;color:var(--text)}.verified{color:#22c55e}.handle,.location{color:var(--muted);font-size:.95rem;margin:0}.status-pill{margin-top:6px;display:inline-flex;align-self:center;padding:8px 12px;border-radius:12px;background:#22c55e26;color:#a7f3d0;border:1px solid rgba(34,197,94,.3);font-weight:600;font-size:.9rem}.sidebar-nav{display:flex;flex-direction:column;gap:10px}.nav-link{width:100%;display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:transparent;border:1px solid var(--border);color:var(--text);cursor:pointer;font-weight:600;transition:transform .2s ease,background .2s ease,box-shadow .2s ease}.nav-link:hover{transform:translate(4px);background:linear-gradient(135deg,#ffffff0d,#ffffff05);box-shadow:0 10px 30px #00000040}.nav-link.active{background:#1f2937;border-color:#ffffff14}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:12px}.theme-toggle{width:100%;justify-content:center}.chat-cta{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;border-radius:14px;border:1px solid var(--border);background:linear-gradient(135deg,#22c55e38,#10b9812e);color:#d1fae5;font-weight:700;transition:transform .2s ease,box-shadow .2s ease}.chat-cta:hover{transform:translateY(-2px);box-shadow:0 12px 30px #00000040}@media (max-width: 1024px){.mobile-menu-toggle{display:block}.sidebar-shell{position:fixed;top:0;left:0;height:100vh;width:280px;min-width:280px;max-width:85vw;transform:translate(-100%);z-index:1000;border-right:1px solid var(--border);overflow-y:auto}.sidebar-shell.open{transform:translate(0)}.sidebar-overlay{display:block}.profile-card{flex-direction:column;text-align:center;gap:8px}.avatar-ring{width:80px;height:80px;margin:0 auto}.name-row{justify-content:center}.name-row h2{font-size:1.1rem}.handle{font-size:.9rem}.status-pill{margin-top:6px;font-size:.85rem;padding:6px 12px}.sidebar-nav{flex-direction:column;gap:10px}.nav-link{padding:12px 14px;font-size:.95rem}.nav-link span{display:inline}.sidebar-footer{flex-direction:column;gap:12px}.theme-toggle{width:100%;justify-content:center}.theme-toggle span,.chat-cta span{display:inline}}@media (max-width: 600px){.mobile-menu-toggle{top:12px;left:12px;padding:10px}.sidebar-shell{width:260px;min-width:260px;padding:24px 20px}.avatar-ring{width:72px;height:72px}.name-row h2{font-size:1rem}.handle{font-size:.85rem}.nav-link{padding:10px 12px;font-size:.9rem}}.chatbot-wrapper{position:fixed;bottom:20px;right:20px;z-index:9999}.chatbot-toggle{position:relative;background:#f2f2f2f2;border:none;outline:none;border-radius:50%;padding:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 12px #00000026}.chatbot-toggle:hover{transform:scale(1.05);background:#333}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:40px 16px;color:#444;font-size:.95rem;opacity:.8;animation:fadeIn .4s ease}.empty-state .avatar{height:48px;width:48px;background:#222;border-radius:50%;display:flex;align-items:center;justify-content:center}.empty-state .avatar svg{height:24px;width:24px;fill:#f8f8f8}.empty-state .empty-text{max-width:280px;line-height:1.5}.chatbot-popup{position:absolute;bottom:20px;right:0;width:400px;height:500px;background:#f8f8f8;border-radius:16px;border:1px solid #7b7b7b;box-shadow:0 10px 25px -5px #2222221a,0 10px 10px -5px #2222220a;display:flex;flex-direction:column;overflow:hidden;z-index:9999}.popup-text{position:absolute;top:-50px;transform:translate(-50%);background:#333;color:#fff;padding:8px 12px;border-radius:8px;white-space:nowrap;font-size:.85rem;font-weight:500;animation:fadeInOut 3s ease-in-out;z-index:1000;box-shadow:0 4px 12px #00000026}.popup-text:after{content:"";position:absolute;top:100%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}.popup-text.right-aligned{top:-50px;right:-110px;left:auto;transform:none}.popup-text.right-aligned:after{right:20px;left:auto;transform:none}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(10px) scale(.9)}10%,90%{opacity:1;transform:translate(-50%) translateY(0) scale(1)}to{opacity:0;transform:translate(-50%) translateY(-5px) scale(.9)}}.chatbot-popup .chat-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:#f8f8f8;border-bottom:1px solid #7b7b7b;flex-shrink:0}.chatbot-popup .header-info{display:flex;gap:12px;align-items:center}.header-info .avatar{height:32px;width:32px;background:#222;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-info .avatar svg{height:18px;width:18px;fill:#f8f8f8}.header-info .logo-text{color:#222;font-size:1.1rem;font-weight:600;letter-spacing:-.025em}.chat-header button{height:32px;width:32px;border:none;outline:none;color:#7b7b7b;font-size:1.2rem;border-radius:8px;background:transparent;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.chat-header button:hover{background:#f3f3f3;color:#222}.chat-body{padding:24px 24px 100px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;flex:1;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.chat-body::-webkit-scrollbar{width:6px}.chat-body::-webkit-scrollbar-track{background:transparent}.chat-body::-webkit-scrollbar-thumb{background:#7b7b7b;border-radius:3px}.chat-body .message{display:flex;align-items:flex-start;gap:12px;max-width:85%}.chat-body .bot-message .avatar{height:28px;width:28px;background:#222;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.chat-body .bot-message svg{height:14px;width:14px;fill:#f8f8f8}.chat-body .message .message-text{padding:12px 16px;font-size:.9rem;line-height:1.5;word-wrap:break-word}.chat-body .bot-message .message-text{background:#f3f3f3;border:1px solid #7b7b7b;border-radius:0 18px 18px;color:#222}.chat-body .user-message{flex-direction:row-reverse;align-self:flex-end}.chat-body .user-message .message-text{color:#f8f8f8;background:#222;border-radius:18px 18px 0;border:none}.chat-footer{position:absolute;bottom:0;left:0;right:0;background:#f8f8f8;padding:12px 24px 24px;border-top:1px solid #7b7b7b;border-radius:0 0 16px 16px}.chat-footer .chat-form{display:flex;align-items:center;gap:8px;background:#f3f3f3;border:1px solid #7b7b7b;padding:4px;width:100%;border-radius:24px;transition:all .2s ease}.chat-footer .chat-form:focus-within{border-color:#222;box-shadow:0 0 0 3px #2222221a}.chat-form input{border:none;outline:none;background:none;padding:12px 16px;width:100%;font-size:.9rem;color:#222;font-family:Aeonik TRIAL,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.chat-form input::placeholder{color:#7b7b7b}.chat-form button{height:36px;width:36px;background:#222;color:#f8f8f8;flex-shrink:0;border-radius:50%;font-size:1.1rem;border:none;outline:none;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all .2s ease}.chat-form button:hover{transform:scale(1.05);background:#7b7b7b;box-shadow:0 4px 12px #2223}.chat-form input:valid+button{display:flex}.status-indicator{height:8px;width:8px;background:#7b7b7b;border-radius:50%;margin-left:4px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.message{animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
