@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap";html{scroll-behavior:smooth}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;color-scheme:light dark;--primary-hue: 220;--accent-hue: 200;--background: linear-gradient( 135deg, hsl(220, 60%, 98%) 0%, hsl(210, 70%, 96%) 25%, hsl(200, 60%, 97%) 50%, hsl(215, 65%, 95%) 75%, hsl(225, 55%, 98%) 100% );--text-primary: hsl(220, 30%, 12%);--text-secondary: hsl(220, 15%, 35%);--text-tertiary: hsl(220, 10%, 50%);--accent-primary: hsl(210, 100%, 52%);--accent-secondary: hsl(200, 100%, 45%);--accent-tertiary: hsl(190, 95%, 50%);--accent-glow: hsla(210, 100%, 52%, .3);--success: hsl(145, 80%, 42%);--warning: hsl(38, 95%, 55%);--error: hsl(350, 85%, 55%);--glass-bg: rgba(255, 255, 255, .75);--glass-bg-light: rgba(255, 255, 255, .55);--glass-bg-heavy: rgba(255, 255, 255, .9);--glass-border: rgba(255, 255, 255, .85);--glass-border-subtle: rgba(255, 255, 255, .4);--glass-tint: hsla(210, 100%, 52%, .04);--glass-shadow: rgba(0, 0, 0, .05);--blur-xs: blur(4px);--blur-sm: blur(8px);--blur-md: blur(16px);--blur-lg: blur(24px);--blur-xl: blur(32px);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .05), 0 1px 3px rgba(0, 0, 0, .07);--shadow-md: 0 4px 16px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .09);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .09), 0 4px 8px rgba(0, 0, 0, .11);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .12), 0 8px 16px rgba(0, 0, 0, .14);--shadow-2xl: 0 24px 64px rgba(0, 0, 0, .15), 0 12px 24px rgba(0, 0, 0, .17);--shadow-glow: 0 0 20px var(--accent-glow), 0 0 40px var(--accent-glow);--shadow-glow-sm: 0 0 10px var(--accent-glow), 0 0 20px var(--accent-glow);--gradient-primary: linear-gradient(135deg, hsl(210, 100%, 52%) 0%, hsl(220, 95%, 48%) 100%);--gradient-accent: linear-gradient(135deg, hsl(190, 100%, 50%) 0%, hsl(210, 100%, 52%) 100%);--gradient-vibrant: linear-gradient(135deg, hsl(280, 85%, 60%) 0%, hsl(210, 100%, 52%) 50%, hsl(190, 95%, 50%) 100%);--gradient-glass: linear-gradient( 135deg, rgba(255, 255, 255, .95) 0%, rgba(255, 255, 255, .65) 100% );--gradient-text: linear-gradient(135deg, hsl(210, 100%, 52%) 0%, hsl(280, 85%, 60%) 50%, hsl(190, 95%, 50%) 100%);--mesh-bg: radial-gradient(at 0% 0%, hsla(210, 100%, 60%, .08) 0px, transparent 50%), radial-gradient(at 50% 0%, hsla(190, 100%, 60%, .08) 0px, transparent 50%), radial-gradient(at 100% 0%, hsla(280, 100%, 65%, .08) 0px, transparent 50%), radial-gradient(at 0% 100%, hsla(200, 100%, 60%, .08) 0px, transparent 50%), radial-gradient(at 100% 100%, hsla(220, 100%, 60%, .08) 0px, transparent 50%);--tech-bg: hsla(210, 100%, 52%, .1);--tech-border: hsla(210, 100%, 52%, .25);--tech-text: hsl(210, 100%, 40%);--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 32px;--radius-full: 9999px;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .35s;--duration-slower: .5s;--ease-spring: cubic-bezier(.68, -.55, .265, 1.55);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);color:var(--text-primary);background:var(--background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body.dark-mode{--background: linear-gradient( 135deg, hsl(220, 40%, 8%) 0%, hsl(215, 35%, 10%) 25%, hsl(220, 38%, 9%) 50%, hsl(210, 40%, 8%) 75%, hsl(225, 35%, 9%) 100% );--text-primary: hsla(0, 0%, 100%, .95);--text-secondary: hsla(0, 0%, 100%, .7);--text-tertiary: hsla(0, 0%, 100%, .5);--accent-primary: hsl(210, 100%, 60%);--accent-secondary: hsl(200, 100%, 55%);--accent-tertiary: hsl(190, 95%, 60%);--accent-glow: hsla(210, 100%, 60%, .4);--glass-bg: rgba(15, 20, 30, .75);--glass-bg-light: rgba(15, 20, 30, .55);--glass-bg-heavy: rgba(15, 20, 30, .9);--glass-border: rgba(255, 255, 255, .12);--glass-border-subtle: rgba(255, 255, 255, .06);--glass-tint: hsla(210, 100%, 60%, .06);--glass-shadow: rgba(0, 0, 0, .3);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .35), 0 1px 3px rgba(0, 0, 0, .45);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45), 0 2px 4px rgba(0, 0, 0, .55);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .55), 0 4px 8px rgba(0, 0, 0, .65);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .65), 0 8px 16px rgba(0, 0, 0, .75);--shadow-2xl: 0 24px 64px rgba(0, 0, 0, .75), 0 12px 24px rgba(0, 0, 0, .85);--gradient-primary: linear-gradient(135deg, hsl(210, 100%, 60%) 0%, hsl(220, 95%, 55%) 100%);--gradient-accent: linear-gradient(135deg, hsl(190, 100%, 60%) 0%, hsl(210, 100%, 60%) 100%);--gradient-vibrant: linear-gradient(135deg, hsl(280, 85%, 65%) 0%, hsl(210, 100%, 60%) 50%, hsl(190, 95%, 60%) 100%);--gradient-glass: linear-gradient( 135deg, rgba(15, 20, 30, .95) 0%, rgba(15, 20, 30, .65) 100% );--mesh-bg: radial-gradient(at 0% 0%, hsla(210, 100%, 45%, .12) 0px, transparent 50%), radial-gradient(at 50% 0%, hsla(190, 100%, 45%, .12) 0px, transparent 50%), radial-gradient(at 100% 0%, hsla(280, 100%, 50%, .12) 0px, transparent 50%), radial-gradient(at 0% 100%, hsla(200, 100%, 45%, .12) 0px, transparent 50%), radial-gradient(at 100% 100%, hsla(220, 100%, 45%, .12) 0px, transparent 50%);--tech-bg: hsla(210, 100%, 60%, .15);--tech-border: hsla(210, 100%, 60%, .35);--tech-text: hsl(210, 100%, 70%)}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:var(--background);background-attachment:fixed;color:var(--text-primary);position:relative}body:before{content:"";position:fixed;inset:0;background:var(--mesh-bg);z-index:0;pointer-events:none}h1,h2,h3,h4,h5,h6{font-family:Space Grotesk,Inter,sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.2}h1{font-size:clamp(2.5rem,5vw,4rem);line-height:1.1}h2{font-size:clamp(2rem,4vw,3rem)}h3{font-size:clamp(1.5rem,3vw,2rem)}a{font-weight:500;color:var(--accent-primary);text-decoration:none;transition:all var(--duration-normal) var(--ease-smooth);position:relative}a:hover{color:var(--accent-secondary);text-decoration:none}a:focus-visible{outline:2px solid var(--accent-primary);outline-offset:4px;border-radius:var(--radius-sm)}button{border-radius:var(--radius-md);border:1px solid transparent;padding:var(--spacing-sm) var(--spacing-lg);font-size:1em;font-weight:600;font-family:inherit;background:var(--glass-bg);color:var(--text-primary);cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);box-shadow:var(--shadow-sm);backdrop-filter:var(--blur-md);-webkit-backdrop-filter:var(--blur-md)}button:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow-sm)}button:active{transform:translateY(0)}button:focus,button:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.glass{background:var(--glass-bg);backdrop-filter:var(--blur-md);-webkit-backdrop-filter:var(--blur-md);border-radius:var(--radius-lg);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);position:relative}.glass:before{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--glass-tint);pointer-events:none}.glass-light{background:var(--glass-bg-light);backdrop-filter:var(--blur-sm);-webkit-backdrop-filter:var(--blur-sm)}.glass-heavy{background:var(--glass-bg-heavy);backdrop-filter:var(--blur-lg);-webkit-backdrop-filter:var(--blur-lg)}.gradient-text{background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradient-shift 8s ease infinite;background-size:200% 200%}@keyframes gradient-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.hover-lift{transition:transform var(--duration-normal) var(--ease-smooth),box-shadow var(--duration-normal) var(--ease-smooth)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.fade-section{opacity:0;transform:translateY(30px);transition:opacity var(--duration-slow) var(--ease-smooth),transform var(--duration-slow) var(--ease-smooth)}.section-heading{font-size:clamp(2rem,4vw,2.5rem);text-align:center;margin-bottom:var(--spacing-2xl);position:relative;display:inline-block;width:100%}.section-heading:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:60px;height:4px;background:var(--gradient-primary);border-radius:var(--radius-full)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.text-center{text-align:center}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}*{transition-timing-function:var(--ease-smooth)}::selection{background:var(--accent-primary);color:#fff}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--glass-bg-light)}::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--accent-secondary)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}*:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:var(--radius-sm)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.App{width:100%;max-width:100%;min-height:100vh;position:relative;z-index:1}.fade-section{opacity:0;transform:translateY(40px);transition:opacity var(--duration-slower) var(--ease-smooth),transform var(--duration-slower) var(--ease-smooth)}.fade-section.in-view{opacity:1;transform:translateY(0)}html{scroll-behavior:smooth;scroll-padding-top:80px}a{color:inherit;text-decoration:none}#root{width:100%;min-height:100vh}.navbar{height:var(--nav-height, 70px);display:flex;justify-content:space-between;align-items:center;padding:0 var(--spacing-xl);position:sticky;top:0;z-index:999;background:var(--glass-bg-heavy);backdrop-filter:var(--blur-xl);-webkit-backdrop-filter:var(--blur-xl);border-bottom:1px solid var(--glass-border);box-shadow:var(--shadow-lg);transition:all var(--duration-normal) var(--ease-smooth)}.navbar:before{content:"";position:absolute;inset:0;background:var(--glass-tint);pointer-events:none}.scroll-progress{position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);transform-origin:0%;z-index:10;box-shadow:var(--shadow-glow-sm)}.logo-container a{display:flex;align-items:center;text-decoration:none;position:relative;z-index:1}.logo-img{height:40px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:transform var(--duration-normal) var(--ease-spring)}.logo-img:hover{transform:scale(1.08)}.nav-controls{display:flex;align-items:center;gap:var(--spacing-lg);position:relative;z-index:1}.nav-links{list-style:none;display:flex;gap:var(--spacing-lg);padding:0;margin:0;align-items:center;position:relative;z-index:1}.nav-links li a{font-weight:600;color:var(--text-secondary);text-decoration:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);position:relative;transition:all var(--duration-normal) var(--ease-smooth);display:block}.nav-links li a:before{content:"";position:absolute;inset:0;background:var(--tech-bg);border-radius:var(--radius-md);opacity:0;transition:opacity var(--duration-normal) var(--ease-smooth);z-index:-1}.nav-links li a:hover{color:var(--accent-primary)}.nav-links li a:hover:before{opacity:1}.nav-links li a.active{color:var(--accent-primary);background:var(--tech-bg);border:1px solid var(--tech-border)}.theme-toggle-desktop{display:block}.theme-toggle-mobile{display:none}.hamburger{display:none;flex-direction:column;justify-content:space-around;width:26px;height:24px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001;position:relative}.hamburger span{width:100%;height:3px;background:var(--text-primary);border-radius:var(--radius-full);transition:all var(--duration-normal) var(--ease-smooth);position:relative}.hamburger.open span:nth-child(1){transform:rotate(45deg);top:9px}.hamburger.open span:nth-child(2){opacity:0;transform:translate(20px)}.hamburger.open span:nth-child(3){transform:rotate(-45deg);top:-9px}@media(max-width:768px){.navbar{padding:0 var(--spacing-md)}.nav-links{display:none}.hamburger{display:flex}.theme-toggle-desktop{display:none}.theme-toggle-mobile{display:block}.nav-links.open{display:flex;flex-direction:column;position:fixed;top:0;right:0;height:100vh;width:280px;padding:var(--spacing-3xl) var(--spacing-xl);gap:var(--spacing-md);background:var(--glass-bg-heavy);backdrop-filter:var(--blur-xl);-webkit-backdrop-filter:var(--blur-xl);box-shadow:var(--shadow-2xl);border-left:1px solid var(--glass-border);animation:slideIn .3s var(--ease-smooth);z-index:1000}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.nav-links.open li{width:100%}.nav-links.open li a{font-size:1.1rem;padding:var(--spacing-md) var(--spacing-lg);width:100%;text-align:left}.nav-links.open .theme-toggle-desktop{display:block;margin-top:var(--spacing-lg)}}.overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:var(--blur-sm);-webkit-backdrop-filter:var(--blur-sm);z-index:999;animation:fadeIn .3s var(--ease-smooth)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}body.dark-mode .navbar{box-shadow:var(--shadow-lg),0 0 0 1px #ffffff0d}body.dark-mode .scroll-progress{box-shadow:var(--shadow-glow-sm)}body.dark-mode .overlay{background:#000000b3}.theme-toggle{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:0;color:var(--text-primary)}.hero-bg{display:flex;align-items:center;justify-content:center;min-height:100vh;text-align:left;position:relative;overflow:hidden;padding:var(--spacing-xl) var(--spacing-lg)}.hero-shapes{position:absolute;inset:0;z-index:0;overflow:hidden;opacity:.6}.shape{position:absolute;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;filter:blur(60px);opacity:.4}.shape-1{width:400px;height:400px;background:linear-gradient(135deg,#39f,#bf5af2);top:10%;left:10%}.shape-2{width:350px;height:350px;background:linear-gradient(135deg,#38dafa,#39f);bottom:15%;right:10%}.shape-3{width:300px;height:300px;background:linear-gradient(135deg,#bf5af2,#3bf);top:50%;right:30%}.hero-content{width:100%;max-width:900px;z-index:1;position:relative}.hero-greeting{font-size:clamp(1.1rem,2vw,1.3rem);color:var(--text-secondary);margin-bottom:var(--spacing-sm);font-weight:500;letter-spacing:.5px}.hero-content h1{font-size:clamp(2.5rem,7vw,5rem);font-weight:900;margin-bottom:var(--spacing-md);line-height:1.1;letter-spacing:-.03em}.hero-name{display:inline-block;position:relative;background:var(--gradient-text);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-role{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:700;margin-bottom:var(--spacing-lg);min-height:60px;font-family:Space Grotesk,sans-serif}.typing-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}.hero-description{font-size:clamp(1.1rem,2vw,1.35rem);color:var(--text-secondary);margin-bottom:var(--spacing-2xl);line-height:1.7;max-width:700px;font-weight:400}.hero-buttons{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.hero-btn{padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-weight:600;font-size:1.05rem;text-decoration:none;transition:all var(--duration-normal) var(--ease-smooth);display:inline-flex;align-items:center;gap:var(--spacing-sm);position:relative;overflow:hidden;border:2px solid transparent}.hero-btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-lg),0 8px 20px var(--accent-glow)}.hero-btn-primary:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 50%);opacity:0;transition:opacity var(--duration-normal) var(--ease-smooth)}.hero-btn-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-xl),var(--shadow-glow)}.hero-btn-primary:hover:before{opacity:1}.hero-btn-primary:active{transform:translateY(-1px)}.hero-btn-primary svg{transition:transform var(--duration-normal) var(--ease-spring)}.hero-btn-primary:hover svg{transform:translateY(2px)}.hero-btn-secondary{background:var(--glass-bg);backdrop-filter:var(--blur-md);-webkit-backdrop-filter:var(--blur-md);color:var(--text-primary);border-color:var(--glass-border);box-shadow:var(--shadow-md)}.hero-btn-secondary:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent-primary);background:var(--glass-bg-heavy)}.hero-btn-secondary:active{transform:translateY(-1px)}.scroll-indicator{position:absolute;bottom:var(--spacing-2xl);left:50%;transform:translate(-50%);background:var(--glass-bg);backdrop-filter:var(--blur-md);-webkit-backdrop-filter:var(--blur-md);border:1px solid var(--glass-border);width:48px;height:48px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--accent-primary);cursor:pointer;box-shadow:var(--shadow-md);transition:all var(--duration-normal) var(--ease-smooth);z-index:2;padding:0}.scroll-indicator:hover{background:var(--glass-bg-heavy);box-shadow:var(--shadow-lg),var(--shadow-glow-sm);transform:translate(-50%) scale(1.1)}@media(max-width:768px){.hero-bg{padding:var(--spacing-lg) var(--spacing-md);text-align:center}.hero-content{text-align:center}.hero-description{max-width:100%}.hero-buttons{justify-content:center}.hero-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:1rem}.shape{filter:blur(40px);opacity:.3}.shape-1{width:250px;height:250px}.shape-2{width:220px;height:220px}.shape-3{width:200px;height:200px;top:40%;right:20%}.scroll-indicator{bottom:var(--spacing-xl);width:40px;height:40px}}@media(max-width:480px){.hero-greeting{font-size:1rem}.hero-role{min-height:50px}.hero-buttons{flex-direction:column;gap:var(--spacing-md);width:100%}.hero-btn{width:100%;justify-content:center}}body.dark-mode .shape{opacity:.3}body.dark-mode .scroll-indicator:hover{box-shadow:var(--shadow-lg),var(--shadow-glow-sm)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:var(--spacing-xl);padding:0;margin-bottom:var(--spacing-3xl)}@media(min-width:768px){.projects-grid{grid-template-columns:repeat(2,1fr)}.project-card.featured{grid-column:1 / -1}}.project-card{padding:var(--spacing-xl);transition:all var(--duration-slow) var(--ease-smooth);outline:none;position:relative;display:flex;flex-direction:column;min-height:280px;background:var(--glass-bg);backdrop-filter:var(--blur-lg);-webkit-backdrop-filter:var(--blur-lg);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg);overflow:hidden;cursor:pointer}.project-card:before{content:"";position:absolute;inset:0;background:var(--glass-tint);pointer-events:none;transition:opacity var(--duration-normal) var(--ease-smooth);opacity:.5}.project-card:after{content:"";position:absolute;inset:-2px;background:var(--gradient-accent);border-radius:var(--radius-xl);opacity:0;z-index:-1;transition:opacity var(--duration-slow) var(--ease-smooth)}.project-card:hover:before{opacity:1}.project-card:hover:after{opacity:.15}.project-card:hover{box-shadow:var(--shadow-2xl);border-color:var(--accent-primary)}.project-card:focus-visible{outline:2px solid var(--accent-primary);outline-offset:4px}.featured-badge{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:var(--gradient-primary);color:#fff;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:700;box-shadow:var(--shadow-md),var(--shadow-glow-sm);z-index:2;letter-spacing:.5px}.project-content{display:flex;flex-direction:column;justify-content:flex-start;flex-grow:1;position:relative;z-index:1}.project-card h3{margin-bottom:var(--spacing-md);font-size:clamp(1.25rem,2vw,1.5rem);color:var(--accent-primary);font-weight:700;letter-spacing:-.01em;position:relative;z-index:1;transition:color var(--duration-normal) var(--ease-smooth)}.project-card:hover h3{color:var(--accent-secondary)}.project-description{font-size:1.05rem;margin-bottom:var(--spacing-lg);color:var(--text-secondary);line-height:1.7;position:relative;z-index:1}.tech-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding:0;list-style:none;align-items:center;position:relative;z-index:1}.tech-list li{background:var(--tech-bg);color:var(--tech-text);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;-webkit-user-select:none;user-select:none;border:1px solid var(--tech-border);letter-spacing:.01em;margin-bottom:0;display:flex;align-items:center;transition:all var(--duration-normal) var(--ease-spring);backdrop-filter:var(--blur-sm);-webkit-backdrop-filter:var(--blur-sm);cursor:pointer}.tech-list li:hover{transform:scale(1.05);box-shadow:var(--shadow-md);border-color:var(--accent-primary);background:var(--tech-bg)}.project-links{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-top:auto;align-items:flex-start;position:relative;z-index:1}.project-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-weight:600;color:var(--accent-primary);text-decoration:none;font-size:1rem;transition:all var(--duration-normal) var(--ease-smooth);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);position:relative}.project-link:before{content:"";position:absolute;inset:0;background:var(--tech-bg);border-radius:inherit;opacity:0;transition:opacity var(--duration-normal) var(--ease-smooth);z-index:-1}.project-link:hover:before{opacity:1}.project-link svg{transition:transform var(--duration-normal) var(--ease-spring)}.project-link:hover{color:var(--accent-secondary);transform:translate(4px)}.project-link:hover svg{transform:scale(1.2)}.project-link:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.project-card.featured{background:var(--glass-bg-heavy);border-width:2px;min-height:320px}.project-card.featured:before{opacity:.7}.project-card.featured .project-description{max-width:900px}@media(min-width:768px){.project-card.featured{padding:var(--spacing-2xl)}.project-card.featured h3{font-size:1.75rem}.project-card.featured .project-description{font-size:1.15rem}.project-card.featured .tech-list{gap:var(--spacing-md)}.project-card.featured .tech-list li{padding:var(--spacing-sm) var(--spacing-lg);font-size:.95rem}}@media(max-width:768px){.projects-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}.project-card{padding:var(--spacing-lg);min-height:240px}.featured-badge{font-size:.8rem;padding:4px var(--spacing-sm)}}@media(max-width:480px){.project-card h3{font-size:1.2rem}.project-description{font-size:.95rem}.tech-list{gap:.5rem}.tech-list li{font-size:.8rem;padding:.4rem .75rem}.project-links{flex-direction:column;gap:var(--spacing-sm)}.project-link{width:100%}}body.dark-mode .project-card{box-shadow:var(--shadow-lg),0 0 0 1px #ffffff0d}body.dark-mode .project-card:hover{box-shadow:var(--shadow-2xl),0 0 40px var(--accent-glow)}body.dark-mode .featured-badge{box-shadow:var(--shadow-lg),var(--shadow-glow-sm)}.contact-intro{max-width:700px;margin:0 auto var(--spacing-3xl);text-align:center}.contact-intro p{font-size:1.2rem;line-height:1.7;color:var(--text-secondary);margin-bottom:var(--spacing-lg)}.availability-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);background:var(--glass-bg);backdrop-filter:var(--blur-md);-webkit-backdrop-filter:var(--blur-md);border:1px solid var(--glass-border);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-weight:600;color:var(--success);box-shadow:var(--shadow-md)}.status-indicator{width:10px;height:10px;background:var(--success);border-radius:var(--radius-full);box-shadow:0 0 10px var(--success);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.message-composer{max-width:900px;margin:0 auto var(--spacing-3xl);padding:var(--spacing-2xl);border-radius:var(--radius-xl);transition:all var(--duration-normal) var(--ease-smooth)}.message-composer:hover{box-shadow:var(--shadow-2xl);border-color:var(--accent-primary)}.message-composer h3{font-size:1.8rem;font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-xl) 0;letter-spacing:-.02em}.composer-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.subject-input,.message-input{width:90%;padding:var(--spacing-md) var(--spacing-lg);background:var(--tech-bg);border:2px solid var(--tech-border);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;color:var(--text-primary);transition:all var(--duration-normal) var(--ease-smooth);resize:vertical}.subject-input:focus,.message-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px var(--accent-glow)}.subject-input::placeholder,.message-input::placeholder{color:var(--text-tertiary)}.message-input{min-height:150px;line-height:1.6}.send-options{display:flex;flex-direction:column;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--glass-border)}.send-label{font-size:1rem;font-weight:600;color:var(--text-secondary);margin:0}.platform-buttons{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.platform-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-size:1rem;font-weight:600;color:#fff;border:none;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.platform-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.platform-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow-sm)}.platform-btn:not(:disabled):active{transform:translateY(0)}.platform-btn svg{width:20px;height:20px}.email-btn{background:linear-gradient(135deg,#f06e42,#f48c25)}.email-btn:not(:disabled):hover{background:linear-gradient(135deg,#f67e55,#fa9938)}.linkedin-btn{background:linear-gradient(135deg,#0da6f2,#1a79ff)}.linkedin-btn:not(:disabled):hover{background:linear-gradient(135deg,#1fb1f9,#38f)}.github-btn{background:linear-gradient(135deg,#3d475c,#263140)}.github-btn:not(:disabled):hover{background:linear-gradient(135deg,#47536b,#303d50)}body.dark-mode .github-btn{background:linear-gradient(135deg,#d3d7de,#b3bdcc);color:#29303d}body.dark-mode .github-btn:not(:disabled):hover{background:linear-gradient(135deg,#e2e4e9,#c2cad6)}.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-xl);max-width:1000px;margin:0 auto}.contact-card{padding:var(--spacing-2xl);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--spacing-lg);transition:all var(--duration-normal) var(--ease-smooth);position:relative;min-height:240px}.contact-card:hover{box-shadow:var(--shadow-2xl);border-color:var(--accent-primary)}.contact-icon{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-lg),var(--shadow-glow-sm);transition:all var(--duration-normal) var(--ease-spring)}.contact-card:hover .contact-icon{transform:scale(1.1) rotate(5deg)}.contact-icon svg{width:32px;height:32px}.email-icon{background:linear-gradient(135deg,#f06e42,#f48c25)}.linkedin-icon{background:linear-gradient(135deg,#0da6f2,#1a79ff)}.github-icon{background:linear-gradient(135deg,#3d475c,#263140)}body.dark-mode .github-icon{background:linear-gradient(135deg,#d3d7de,#b3bdcc)}.contact-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.contact-card h3{font-size:1.5rem;color:var(--text-primary);font-weight:700;margin:0;letter-spacing:-.01em}.contact-card a{color:var(--text-secondary);font-size:1rem;margin-bottom:var(--spacing-md);word-break:break-word;transition:color var(--duration-normal) var(--ease-smooth)}.contact-card a:hover{color:var(--accent-primary)}.copy-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--tech-bg);border:1px solid var(--tech-border);color:var(--accent-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);align-self:flex-start}.copy-btn:hover{background:var(--accent-primary);color:#fff;transform:translateY(0);box-shadow:var(--shadow-md);border-color:var(--accent-primary)}.copy-btn svg{width:16px;height:16px}.contact-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--gradient-primary);color:#fff!important;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-size:1rem;font-weight:600;text-decoration:none;transition:all var(--duration-normal) var(--ease-smooth);align-self:flex-start;box-shadow:var(--shadow-md),var(--shadow-glow-sm);margin-top:auto}.contact-btn:hover{transform:translate(4px);box-shadow:var(--shadow-lg),var(--shadow-glow);color:#fff!important}@media(max-width:768px){.message-composer{padding:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.message-composer h3{font-size:1.5rem}.platform-buttons{flex-direction:column}.platform-btn{width:100%;justify-content:center}.contact-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}.contact-card{padding:var(--spacing-xl)}.contact-icon{width:56px;height:56px}.contact-icon svg{width:28px;height:28px}.contact-card h3{font-size:1.3rem}}@media(max-width:480px){.message-composer{padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.message-composer h3{font-size:1.3rem}.subject-input,.message-input{padding:var(--spacing-sm) var(--spacing-md);font-size:.95rem}.message-input{min-height:120px}.send-label{font-size:.95rem}.platform-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:.95rem}.contact-intro p{font-size:1.05rem}.availability-badge{font-size:.9rem;padding:var(--spacing-xs) var(--spacing-md)}.contact-card{padding:var(--spacing-lg);min-height:200px}.contact-icon{width:48px;height:48px}.contact-icon svg{width:24px;height:24px}.contact-card h3{font-size:1.2rem}.contact-card a{font-size:.95rem}}body.dark-mode .contact-card:hover{box-shadow:var(--shadow-2xl),0 0 40px var(--accent-glow)}body.dark-mode .contact-icon{box-shadow:var(--shadow-lg),var(--shadow-glow-sm)}body.dark-mode .contact-btn{box-shadow:var(--shadow-md),var(--shadow-glow-sm)}body.dark-mode .contact-btn:hover{box-shadow:var(--shadow-lg),var(--shadow-glow)}.timeline{position:relative;max-width:1000px;margin:0 auto;padding:var(--spacing-xl) 0}.timeline:before{content:"";position:absolute;left:30px;top:0;bottom:0;width:3px;background:var(--gradient-primary);border-radius:var(--radius-full);opacity:.3}.timeline-item{position:relative;padding-left:80px;padding-bottom:var(--spacing-3xl);display:flex;align-items:flex-start;gap:var(--spacing-lg)}.timeline-item:last-child{padding-bottom:0}.timeline-dot-wrapper{position:absolute;left:0;top:0;z-index:2}.timeline-dot{width:60px;height:60px;background:var(--gradient-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-lg),var(--shadow-glow-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);position:relative}.timeline-dot:before{content:"";position:absolute;inset:-4px;border-radius:inherit;background:var(--gradient-accent);opacity:0;z-index:-1;transition:opacity var(--duration-normal) var(--ease-smooth)}.timeline-dot:hover:before{opacity:.3}.timeline-dot svg{width:24px;height:24px}.timeline-content{flex:1;padding:var(--spacing-xl);border-radius:var(--radius-lg);transition:all var(--duration-normal) var(--ease-smooth);position:relative}.timeline-content:hover{box-shadow:var(--shadow-xl);border-color:var(--accent-primary)}.experience-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.timeline-content h3{font-size:clamp(1.25rem,2vw,1.5rem);color:var(--accent-primary);margin:0 0 var(--spacing-xs) 0;font-weight:700;letter-spacing:-.01em;line-height:1.3}.company{font-size:1.1rem;color:var(--text-secondary);font-weight:600;margin:0}.date-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--tech-bg);border:1px solid var(--tech-border);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:600;color:var(--tech-text);white-space:nowrap;backdrop-filter:var(--blur-sm);-webkit-backdrop-filter:var(--blur-sm)}.experience-details{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.experience-details li{display:flex;gap:var(--spacing-md);align-items:flex-start;color:var(--text-secondary);line-height:1.7;font-size:1.05rem}.experience-details .bullet{color:var(--accent-primary);font-weight:700;font-size:1.2rem;flex-shrink:0;margin-top:2px}.experience-details li span:last-child{flex:1}.experience-details li:hover{color:var(--text-primary)}@media(max-width:768px){.timeline:before{left:20px}.timeline-item{padding-left:60px;padding-bottom:var(--spacing-2xl)}.timeline-dot{width:40px;height:40px}.timeline-dot svg{width:18px;height:18px}.timeline-content{padding:var(--spacing-lg)}.experience-header{flex-direction:column;gap:var(--spacing-sm)}.timeline-content h3{font-size:1.2rem}.company{font-size:1rem}.date-badge{font-size:.8rem;padding:4px var(--spacing-sm)}.experience-details li{font-size:.95rem;gap:var(--spacing-sm)}.experience-details .bullet{font-size:1rem}}@media(max-width:480px){.timeline:before{left:15px}.timeline-item{padding-left:50px}.timeline-dot{width:30px;height:30px}.timeline-dot svg{width:14px;height:14px}.timeline-content h3{font-size:1.1rem}.company{font-size:.95rem}.experience-details li{font-size:.9rem}}body.dark-mode .timeline:before{opacity:.4}body.dark-mode .timeline-dot{box-shadow:var(--shadow-md),var(--shadow-glow-sm)}body.dark-mode .timeline-content:hover{box-shadow:var(--shadow-xl),0 0 30px var(--accent-glow)}.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-xl);max-width:1000px;margin:0 auto}.cert-card{padding:var(--spacing-xl);border-radius:var(--radius-lg);position:relative;display:flex;flex-direction:column;gap:var(--spacing-md);transition:all var(--duration-normal) var(--ease-smooth);text-decoration:none;cursor:pointer;min-height:200px}.cert-card:hover{box-shadow:var(--shadow-xl);border-color:var(--accent-primary)}.cert-icon{width:56px;height:56px;background:var(--gradient-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow-sm);transition:all var(--duration-normal) var(--ease-spring)}.cert-card:hover .cert-icon{transform:rotate(5deg) scale(1.1)}.cert-icon svg{width:28px;height:28px}.cert-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.cert-card h3{font-size:1.25rem;color:var(--text-primary);font-weight:700;margin:0;line-height:1.3;letter-spacing:-.01em}.cert-issuer-badge{display:inline-block;background:color-mix(in srgb,var(--badge-color, hsl(210, 100%, 55%)) 15%,transparent);border:1px solid color-mix(in srgb,var(--badge-color, hsl(210, 100%, 55%)) 30%,transparent);color:var(--badge-color, hsl(210, 100%, 55%));padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:600;align-self:flex-start;backdrop-filter:var(--blur-sm);-webkit-backdrop-filter:var(--blur-sm)}.cert-date{font-size:.95rem;color:var(--text-tertiary);margin:0;font-weight:500}.cert-link-icon{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:32px;height:32px;background:var(--glass-bg-light);backdrop-filter:var(--blur-sm);-webkit-backdrop-filter:var(--blur-sm);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--accent-primary);opacity:0;transition:all var(--duration-normal) var(--ease-smooth)}.cert-card:hover .cert-link-icon{opacity:1;transform:translate(2px,-2px)}.cert-link-icon svg{width:16px;height:16px}@media(max-width:768px){.cert-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}.cert-card{padding:var(--spacing-lg)}.cert-icon{width:48px;height:48px}.cert-icon svg{width:24px;height:24px}.cert-card h3{font-size:1.15rem}.cert-link-icon{opacity:1}}@media(max-width:480px){.cert-card h3{font-size:1.1rem}.cert-issuer-badge{font-size:.8rem}.cert-date{font-size:.875rem}}body.dark-mode .cert-card:hover{box-shadow:var(--shadow-xl),0 0 30px var(--accent-glow)}body.dark-mode .cert-icon{box-shadow:var(--shadow-md),var(--shadow-glow-sm)}.section{width:100%;padding:4rem 2rem;box-sizing:border-box}.section-inner{max-width:1200px;margin:0 auto;width:100%}
