*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}:root{--accent: #6366f1;--accent-light: #818cf8;--accent-dark: #4f46e5;--accent-dim: rgba(99, 102, 241, .1);--accent-glow: rgba(99, 102, 241, .2);--gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--bg-primary: #ffffff;--bg-secondary: #f8f9ff;--bg-card: #ffffff;--header-bg: rgba(255, 255, 255, .85);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border-color: rgba(0, 0, 0, .08);--border-hover: rgba(99, 102, 241, .3);--shadow: 0 1px 3px rgba(0,0,0,.04), 0 4px 16px rgba(0,0,0,.06);--shadow-hover: 0 8px 32px rgba(99, 102, 241, .18);--shadow-lg: 0 20px 48px rgba(0, 0, 0, .1);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 4rem;--spacing-xxl: 6rem;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 2rem;--font-4xl: 2.75rem;--font-5xl: 3.5rem}body[data-page-theme=dark]{--accent: #818cf8;--accent-light: #a5b4fc;--accent-dark: #6366f1;--accent-dim: rgba(129, 140, 248, .1);--accent-glow: rgba(129, 140, 248, .2);--gradient: linear-gradient(135deg, #818cf8 0%, #a78bfa 100%);--bg-primary: #080c14;--bg-secondary: #0d1526;--bg-card: #111827;--header-bg: rgba(8, 12, 20, .85);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: rgba(255, 255, 255, .07);--border-hover: rgba(129, 140, 248, .35);--shadow: 0 1px 3px rgba(0,0,0,.3), 0 4px 16px rgba(0,0,0,.35);--shadow-hover: 0 8px 32px rgba(129, 140, 248, .2);--shadow-lg: 0 20px 48px rgba(0, 0, 0, .5)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;font-size:var(--font-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}h1{font-size:var(--font-4xl);font-weight:800;line-height:1.15;letter-spacing:-.03em}h2{font-size:var(--font-3xl);font-weight:700;line-height:1.25;letter-spacing:-.02em}h3{font-size:var(--font-xl);font-weight:600;line-height:1.4}p{color:var(--text-secondary);line-height:1.7}a{text-decoration:none;color:var(--accent);transition:color .2s ease,opacity .2s ease}a:hover{opacity:.85}img{max-width:100%;height:auto;display:block}.container{width:100%;max-width:1160px;margin:0 auto;padding:0 var(--spacing-md)}section{padding:var(--spacing-xl) 0;background-color:var(--bg-primary);transition:background-color .3s ease}section:nth-child(2n){background-color:var(--bg-secondary)}.section-label{display:inline-block;font-size:var(--font-sm);font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.6rem;padding:.25rem .75rem;background:var(--accent-dim);border-radius:100px}.section-title{font-size:clamp(1.75rem,3.5vw,var(--font-3xl));font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:.5rem}.section-subtitle{font-size:var(--font-lg);color:var(--text-secondary);max-width:560px;margin-bottom:var(--spacing-xl)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);border-color:var(--border-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1.35rem;border-radius:var(--radius-md);font-family:Inter,sans-serif;font-size:var(--font-sm);font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-primary{background:var(--gradient);color:#fff;box-shadow:0 4px 14px var(--accent-glow)}.btn-primary:hover{opacity:.92;transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.btn-outline{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}.btn-outline:hover{background:var(--accent-dim);transform:translateY(-2px)}.gradient-text{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grid{display:grid;gap:var(--spacing-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}@media (max-width: 1024px){:root{--spacing-xl: 3rem;--spacing-xxl: 4rem;--font-4xl: 2.25rem;--font-5xl: 3rem}.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){:root{--spacing-lg: 1.5rem;--spacing-xl: 2.5rem;--font-3xl: 1.75rem;--font-4xl: 2rem}.grid-2,.grid-3{grid-template-columns:1fr}section{padding:var(--spacing-lg) 0}}@media (max-width: 480px){:root{--spacing-md: 1.25rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-base: .9375rem;--font-3xl: 1.5rem;--font-4xl: 1.875rem}.container{padding:0 var(--spacing-sm)}}button:focus-visible,a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;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}}@media print{*{background:transparent!important;color:#000!important;box-shadow:none!important}.no-print{display:none!important}}.back-to-top{position:fixed;right:clamp(16px,2.5vw,28px);bottom:clamp(16px,2.5vw,28px);width:44px;height:44px;border-radius:50%;border:1px solid var(--border-color);background:var(--bg-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-secondary);font-size:1rem;display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow);opacity:0;transform:translateY(10px) scale(.9);pointer-events:none;transition:opacity .25s ease,transform .25s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease;z-index:2000}.back-to-top:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-2px) scale(1)}.back-to-top.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}@media (prefers-reduced-motion: reduce){.back-to-top{transition:none}}html,body{overflow-x:hidden}.header{position:sticky;top:0;z-index:1000;background:var(--header-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-color);box-shadow:0 1px 0 var(--border-color);transition:background-color .3s ease,border-color .3s ease}.header-grid{display:grid;grid-template-columns:auto 1fr auto;align-items:center;min-height:64px;gap:clamp(8px,2vw,24px);max-width:1160px;margin:0 auto;padding:0 clamp(12px,2.5vw,24px)}.site-title{display:inline-flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}.logo-icon{width:52px;height:auto;aspect-ratio:3 / 2;object-fit:contain;border-radius:10px;transition:opacity .2s ease}.logo-icon:hover{opacity:.85}@media (max-width: 640px){.logo-icon{width:40px}}.brand-text{font-weight:700;font-size:clamp(.95rem,2vw,1.35rem);color:var(--text-primary);letter-spacing:-.01em;transition:color .2s ease}.site-title:hover .brand-text{color:var(--accent)}.nav-links{display:flex;justify-content:center;align-items:center;gap:clamp(4px,1.5vw,8px);min-width:0;flex-wrap:nowrap}.nav-links a{color:var(--text-secondary);font-weight:500;font-size:clamp(.85rem,1.2vw,.975rem);text-decoration:none;padding:.4rem .75rem;border-radius:8px;white-space:nowrap;transition:color .2s ease,background-color .2s ease}.nav-links a:hover{color:var(--text-primary);background-color:var(--accent-dim)}.header-nav-btn{display:inline-flex;align-items:center;padding:.4rem 1rem!important;background:var(--gradient)!important;color:#fff!important;border-radius:100px!important;font-weight:600!important;font-size:.875rem!important;box-shadow:0 2px 10px var(--accent-glow);transition:opacity .2s ease,transform .2s ease,box-shadow .2s ease!important}.header-nav-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)!important;background-color:transparent!important}.header-actions{display:flex;align-items:center;gap:8px}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);font-size:1rem;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .3s ease}.theme-toggle:hover{border-color:var(--accent);background:var(--accent-dim);transform:rotate(20deg) scale(1.08)}.theme-toggle-desktop{display:inline-flex}.mobile-menu-toggle{display:none;position:relative;background:none;border:none;color:var(--text-primary);width:40px;height:40px;cursor:pointer;padding:0;border-radius:8px;-webkit-tap-highlight-color:transparent}.mobile-menu-toggle span,.mobile-menu-toggle:before,.mobile-menu-toggle:after{content:"";position:absolute;left:50%;width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:transform .28s ease,opacity .2s ease}.mobile-menu-toggle span{top:50%;transform:translate(-50%,-50%)}.mobile-menu-toggle:before{top:50%;transform:translate(-50%,calc(-50% - 7px))}.mobile-menu-toggle:after{top:50%;transform:translate(-50%,calc(-50% + 7px))}.mobile-menu-toggle.open span{opacity:0}.mobile-menu-toggle.open:before{transform:translate(-50%,-50%) rotate(45deg)}.mobile-menu-toggle.open:after{transform:translate(-50%,-50%) rotate(-45deg)}.mobile-nav-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999}.mobile-nav-overlay.open{display:block}.mobile-nav-menu{position:fixed;top:0;right:-100%;width:min(88vw,340px);height:100dvh;background:var(--bg-card);border-left:1px solid var(--border-color);box-shadow:-8px 0 32px #0003;transition:right .3s cubic-bezier(.4,0,.2,1);z-index:1001;padding:20px}.mobile-nav-menu.open{right:0}.mobile-nav-close{background:none;border:none;color:var(--text-secondary);font-size:1.75rem;cursor:pointer;float:right;line-height:1;padding:4px 6px;transition:color .2s ease}.mobile-nav-close:hover{color:var(--text-primary)}.mobile-nav-links{display:flex;flex-direction:column;gap:4px;margin-top:56px;clear:both}.mobile-nav-links a{color:var(--text-secondary);font-weight:500;font-size:1rem;padding:12px 16px;border-radius:10px;text-decoration:none;transition:color .2s ease,background-color .2s ease}.mobile-nav-links a:hover{color:var(--text-primary);background:var(--accent-dim)}.mobile-theme-wrap{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.mobile-theme-wrap .theme-toggle{width:100%;height:44px;border-radius:10px;font-size:.9rem;gap:8px}@media (max-width: 900px){.nav-links a{font-size:clamp(.8rem,1.5vw,.925rem)}}@media (max-width: 640px){.nav-links{display:none}.header-actions{margin-left:auto}.mobile-menu-toggle{display:inline-flex}.theme-toggle-desktop{display:none}}@media (max-width: 360px){.brand-text{font-size:.95rem}.logo-icon{width:34px}}@media (prefers-reduced-motion: reduce){.theme-toggle,.mobile-nav-menu,.nav-links a,.mobile-menu-toggle,.mobile-menu-toggle:before,.mobile-menu-toggle:after,.mobile-menu-toggle span{transition:none}}.hero{position:relative;min-height:92vh;display:flex;align-items:center;justify-content:center;overflow:hidden;isolation:isolate;background:var(--bg-primary);padding:var(--spacing-xl) 0 var(--spacing-lg)}.hero-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-2;background-image:radial-gradient(circle,var(--border-color) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 40%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 40%,transparent 100%);opacity:.6}.hero-glow{position:absolute;top:-10%;right:-5%;bottom:-10%;left:-5%;z-index:-1;pointer-events:none;background:radial-gradient(ellipse 900px 500px at 30% 110%,color-mix(in oklab,var(--accent) 22%,transparent) 0%,transparent 65%),radial-gradient(ellipse 700px 400px at 80% 108%,color-mix(in oklab,var(--accent) 14%,transparent) 0%,transparent 60%);filter:blur(48px);opacity:.8}body[data-page-theme=dark] .hero-glow{opacity:1;background:radial-gradient(ellipse 1000px 560px at 25% 115%,color-mix(in oklab,var(--accent) 30%,#080c14) 0%,transparent 70%),radial-gradient(ellipse 800px 420px at 82% 110%,color-mix(in oklab,var(--accent) 18%,transparent) 0%,transparent 65%)}@media (prefers-reduced-motion: no-preference){.hero-glow{animation:heroGlow 12s ease-in-out infinite alternate}@keyframes heroGlow{0%{transform:translateY(0) translate(0)}to{transform:translateY(10px) translate(-8px)}}}.hero-container{width:100%;max-width:1160px;padding:0 var(--spacing-md);margin:0 auto}.hero-content{display:flex;flex-direction:column;align-items:flex-start;max-width:760px}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:.35rem .85rem;background:var(--accent-dim);border:1px solid var(--border-hover);border-radius:100px;font-size:var(--font-sm);font-weight:500;color:var(--accent);margin-bottom:1.5rem}.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #22c55e40;animation:pulse 2.5s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 2px #22c55e40}50%{box-shadow:0 0 0 5px #22c55e1f}}.hero-title{font-size:clamp(2.2rem,5.5vw,3.75rem);font-weight:800;line-height:1.12;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:1rem}.hero-role{font-size:clamp(1rem,1.8vw,1.15rem);font-weight:500;color:var(--text-secondary);margin-bottom:1.25rem;line-height:1.5}.hero-role-sep{color:var(--text-muted);margin:0 .1rem}.hero-company-link{color:var(--accent);font-weight:600;text-decoration:none;border-bottom:1.5px solid var(--accent-dim);transition:border-color .2s ease}.hero-company-link:hover{border-color:var(--accent);opacity:1}.hero-description{font-size:clamp(.975rem,1.5vw,1.075rem);color:var(--text-secondary);max-width:640px;line-height:1.75;margin-bottom:2rem}.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:3rem}.hero-cta-primary{padding:.75rem 1.6rem;font-size:var(--font-base);border-radius:var(--radius-md)}.hero-cta-ghost{padding:.7rem 1.4rem;font-size:var(--font-base);background:transparent;color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s ease}.hero-cta-ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:translateY(-2px);opacity:1}.hero-stats{display:flex;align-items:center;gap:1.5rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.hero-stat{display:flex;flex-direction:column;gap:.15rem}.hero-stat-value{font-size:1.4rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;line-height:1}.hero-stat-label{font-size:var(--font-xs);color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.hero-stat-divider{width:1px;height:36px;background:var(--border-color)}@media (max-width: 768px){.hero{min-height:80vh;padding:var(--spacing-xl) 0 var(--spacing-md);align-items:flex-start;padding-top:5rem}.hero-content{align-items:center;text-align:center}.hero-description{text-align:center}.hero-cta{justify-content:center}.hero-stats{justify-content:center;gap:1.25rem}}@media (max-width: 480px){.hero-title{font-size:clamp(1.9rem,8vw,2.5rem)}.hero-cta{flex-direction:column;width:100%}.hero-cta-primary,.hero-cta-ghost{width:100%;justify-content:center}.hero-stats{gap:1rem}.hero-stat-value{font-size:1.25rem}}.about-section{padding:var(--spacing-xl) 0;background:var(--bg-secondary)}.about-container{max-width:1160px;margin:0 auto;padding:0 var(--spacing-md);display:grid;grid-template-columns:1.1fr .9fr;gap:4rem;align-items:center}.about-header{margin-bottom:1.5rem}.about-text{font-size:clamp(.95rem,1.3vw,1.02rem);line-height:1.8;color:var(--text-secondary);margin-bottom:1rem}.about-text a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--accent-dim);transition:text-decoration-color .2s ease}.about-text a:hover{text-decoration-color:var(--accent);opacity:1}.about-skills{margin-top:1.75rem;display:flex;flex-wrap:wrap;gap:.5rem}.skill-chip{display:inline-block;padding:.3rem .75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:100px;font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);transition:border-color .2s ease,color .2s ease,background-color .2s ease}.skill-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.about-text-col{display:flex;flex-direction:column}.about-image-col{display:flex;justify-content:center}.about-image{width:100%;max-width:340px;aspect-ratio:4 / 5;object-fit:cover;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-color);transition:transform .3s ease,box-shadow .3s ease;will-change:opacity,transform}.about-image:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 24px 56px #0003}@media (max-width: 980px){.about-container{grid-template-columns:1fr;gap:2.5rem;text-align:left}.about-image-col{order:-1}.about-image{max-width:240px}}@media (max-width: 520px){.about-section{padding:var(--spacing-lg) 0}.about-image{max-width:200px}}@media (prefers-reduced-motion: reduce){.about-image,.skill-chip{transition:none!important}}.projects-section{padding:var(--spacing-xl) 0;background:var(--bg-primary)}.projects-container{max-width:1160px;margin:0 auto;padding:0 var(--spacing-md)}.projects-header{margin-bottom:var(--spacing-xl)}.projects-header .section-subtitle{margin-top:.5rem;margin-bottom:0}.projects-featured-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.project-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.project-card:hover{box-shadow:var(--shadow-hover);border-color:var(--border-hover)}.project-image-wrap{position:relative;width:100%;overflow:hidden;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.project-image-wrap:before{content:"";display:block;padding-top:56.25%}.project-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .4s ease}.project-card:hover .project-image{transform:scale(1.04)}.project-image-placeholder{display:grid;place-items:center}.project-image-placeholder .placeholder-emoji{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:3rem;opacity:.35}body[data-page-theme=dark] .project-image-wrap{background:rgba(255,255,255,.03);border-bottom-color:var(--border-color)}.project-content{display:flex;flex-direction:column;flex:1;padding:1.4rem 1.5rem 1.5rem;gap:.5rem}.project-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.project-tag{display:inline-block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);background:var(--accent-dim);padding:.2rem .6rem;border-radius:100px}.project-title{font-size:var(--font-lg);font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em;line-height:1.35}.project-description{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.65;margin:0;flex:1}.tech-stack{margin-top:.5rem}.tech-stack-icons{height:30px;width:auto;display:block;opacity:.85;transition:opacity .2s ease}.project-card:hover .tech-stack-icons{opacity:1}body[data-page-theme=dark] .tech-stack-icons{opacity:.9;filter:brightness(1.1)}.project-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.75rem}.project-actions .btn{font-size:.82rem;padding:.5rem 1rem}@media (max-width: 1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.projects-featured-grid,.projects-grid{grid-template-columns:1fr}}@media (max-width: 480px){.project-content{padding:1.1rem 1.15rem 1.25rem}.project-actions .btn{width:100%;justify-content:center}.tech-stack-icons{height:26px}}@media (prefers-reduced-motion: reduce){.project-card,.project-image,.tech-stack-icons{transition:none!important}}.achievements-section{padding:var(--spacing-xl) 0;background:var(--bg-secondary);overflow:hidden}.achievements-container{max-width:1160px;margin:0 auto;padding:0 var(--spacing-md)}.achievements-header{margin-bottom:var(--spacing-xl)}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--spacing-lg)}.ach-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.ach-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient);opacity:0;transition:opacity .3s ease}.ach-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);border-color:var(--border-hover)}.ach-card:hover:before{opacity:1}.ach-card-title{font-size:var(--font-lg);font-weight:700;color:var(--accent);margin-bottom:1rem;letter-spacing:-.01em}.ach-card-text{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.75;margin-bottom:1.25rem}.cert-list{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.65rem}.cert-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.8rem 1rem;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.cert-row:hover{border-color:var(--border-hover);transform:translate(4px);box-shadow:0 2px 10px var(--accent-glow)}.cert-name{color:var(--text-primary);font-weight:500;font-size:var(--font-sm);transition:color .2s ease}.cert-row:hover .cert-name{color:var(--accent)}.cert-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex-shrink:0}.cert-actions .btn{font-size:.8rem;padding:.4rem .85rem;white-space:nowrap}@media (max-width: 768px){.achievements-grid{grid-template-columns:1fr}.cert-row{flex-direction:column;align-items:flex-start}.cert-actions{width:100%}}@media (prefers-reduced-motion: reduce){.ach-card,.cert-row{transition:none!important;transform:none!important}.ach-card:before{display:none}}body[data-page-theme=dark] .ach-card:hover{box-shadow:0 8px 32px #818cf833}.journey-section{padding:var(--spacing-xl) 0;background:var(--bg-primary);overflow:hidden}.journey-container{max-width:840px;margin:0 auto;padding:0 var(--spacing-md)}.journey-header{text-align:center;margin-bottom:var(--spacing-xl)}.journey-header .section-label,.journey-header .section-title{display:block;text-align:center}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:7px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--accent) 0%,var(--accent-light) 60%,transparent 100%);border-radius:2px}.timeline-item{position:relative;margin-bottom:2rem;padding-left:1.25rem}.timeline-item:last-child{margin-bottom:0}.timeline-marker{position:absolute;left:-1.75rem;top:.3rem;width:14px;height:14px;border-radius:50%;background:var(--bg-primary);border:2.5px solid var(--accent);box-shadow:0 0 0 3px var(--accent-dim);transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease}.timeline-item:hover .timeline-marker{background:var(--accent);transform:scale(1.25);box-shadow:0 0 0 5px var(--accent-dim)}.timeline-year{font-weight:700;font-size:var(--font-base);color:var(--accent);margin-bottom:.4rem;letter-spacing:.01em}.timeline-text{font-size:var(--font-sm);color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem 1.1rem;line-height:1.7;box-shadow:var(--shadow);transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.timeline-item:hover .timeline-text{border-color:var(--border-hover);box-shadow:0 4px 20px var(--accent-glow);transform:translate(4px)}@media (max-width: 768px){.timeline{padding-left:1.5rem}.timeline-item{padding-left:1rem}.timeline-marker{left:-1.35rem}.timeline-item:hover .timeline-text{transform:translate(2px)}}@media (prefers-reduced-motion: reduce){.timeline-item:hover .timeline-marker,.timeline-item:hover .timeline-text{transition:none;transform:none}}body[data-page-theme=dark] .timeline-marker{background:var(--bg-primary)}body[data-page-theme=dark] .timeline-item:hover .timeline-text{box-shadow:0 4px 20px #818cf826}.contact-section{padding:var(--spacing-xl) 0;background:var(--bg-secondary)}.contact-inner{max-width:680px;margin:0 auto;padding:0 var(--spacing-md)}.contact-header{text-align:center;margin-bottom:var(--spacing-lg)}.contact-header .section-label,.contact-header .section-title{display:block;text-align:center}.contact-header .section-subtitle{text-align:center;margin:.5rem auto 0;max-width:480px}.contact-links{display:flex;justify-content:center;gap:.75rem;margin-bottom:var(--spacing-lg);flex-wrap:wrap}.contact-link{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);text-decoration:none;font-weight:500;font-size:var(--font-sm);transition:all .2s ease}.contact-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:translateY(-2px);box-shadow:0 4px 12px var(--accent-glow);opacity:1}.contact-icon{width:18px;height:18px;object-fit:contain;border-radius:3px}.contact-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column}.form-input,.form-textarea{padding:.8rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-base);font-family:Inter,sans-serif;transition:border-color .2s ease,box-shadow .2s ease;outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-textarea{resize:vertical;min-height:120px;line-height:1.6}.form-button{width:100%;padding:.85rem;background:var(--gradient);color:#fff;border:none;border-radius:var(--radius-md);font-family:Inter,sans-serif;font-size:var(--font-base);font-weight:600;cursor:pointer;transition:opacity .2s ease,transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 14px var(--accent-glow)}.form-button:hover:not(:disabled){opacity:.92;transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}.form-button:disabled{opacity:.6;cursor:not-allowed}.success-message,.error-message{padding:.85rem 1rem;border-radius:var(--radius-md);font-weight:500;font-size:var(--font-sm);text-align:center}.success-message{background:rgba(34,197,94,.08);color:#16a34a;border:1px solid rgba(34,197,94,.25)}.error-message{background:rgba(239,68,68,.08);color:#dc2626;border:1px solid rgba(239,68,68,.25)}body[data-page-theme=dark] .success-message{background:rgba(34,197,94,.1);color:#4ade80;border-color:#22c55e33}body[data-page-theme=dark] .error-message{background:rgba(239,68,68,.1);color:#f87171;border-color:#ef444433}@media (max-width: 600px){.contact-form{padding:var(--spacing-md)}.contact-links{gap:.5rem}.contact-link{padding:.5rem .85rem;font-size:.82rem}}@media (prefers-reduced-motion: reduce){.contact-link,.form-input,.form-textarea,.form-button{transition:none!important}}.footer{padding:2rem var(--spacing-md);background:var(--bg-secondary);border-top:1px solid var(--border-color)}.footer-inner{max-width:1160px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.footer-copy{font-size:var(--font-sm);color:var(--text-muted);margin:0}.footer-name{color:var(--text-secondary);font-weight:600}.footer-links{display:flex;gap:1.25rem}.footer-links a{font-size:var(--font-sm);color:var(--text-muted);text-decoration:none;font-weight:500;transition:color .2s ease}.footer-links a:hover{color:var(--accent);opacity:1}@media (max-width: 480px){.footer-inner{flex-direction:column;text-align:center}}body{margin:0}
