@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Fira+Code:wght@400;500&display=swap";:root{--bg-primary: #0d0d0d;--bg-secondary: #111111;--bg-card: #161616;--bg-card-hover: #1c1c1c;--border: #242424;--border-hover: #3a3a3a;--accent: #7c3aed;--accent-light: #a78bfa;--accent-glow: rgba(124, 58, 237, .25);--accent-2: #22d3ee;--text-primary: #f0f0f0;--text-secondary: #a3a3a3;--text-muted: #525252;--success: #34d399;--radius: 14px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0, 0, 0, .5);--shadow-lg: 0 12px 60px rgba(0, 0, 0, .7);--transition: .3s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}img{max-width:100%}button{cursor:pointer;border:none;background:none;font-family:inherit}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}::selection{background:var(--accent);color:#fff}.container{max-width:1080px;margin:0 auto;padding:0 28px}.section{padding:100px 0}.section-header{margin-bottom:60px}.section-label{font-family:Fira Code,monospace;font-size:.75rem;color:var(--accent-light);letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:10px}.section-label:after{content:"";height:1px;width:48px;background:var(--accent-light);opacity:.4}.section-title{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;color:var(--text-primary);line-height:1.2;letter-spacing:-.02em}.section-title span{color:var(--accent-light)}.gradient-text{background:linear-gradient(135deg,#a78bfa,#22d3ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tag{display:inline-flex;align-items:center;padding:4px 12px;background:#7c3aed1a;border:1px solid rgba(167,139,250,.2);border-radius:999px;font-size:.72rem;font-weight:500;color:var(--accent-light);font-family:Fira Code,monospace;white-space:nowrap}@keyframes fadeInUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.animate-in{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}.animate-in.visible{opacity:1;transform:translateY(0)}.animate-in.delay-1{transition-delay:.1s}.animate-in.delay-2{transition-delay:.2s}.animate-in.delay-3{transition-delay:.3s}.animate-in.delay-4{transition-delay:.4s}@media (max-width: 768px){.section{padding:72px 0}.container{padding:0 20px}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;transition:background var(--transition),border-color var(--transition),padding var(--transition);border-bottom:1px solid transparent}.navbar.scrolled{background:#0d0d0de0;backdrop-filter:blur(16px) saturate(1.5);-webkit-backdrop-filter:blur(16px) saturate(1.5);border-color:var(--border);padding:14px 0}.nav-inner{display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:Fira Code,monospace;font-size:1.15rem;font-weight:500;color:var(--text-primary);transition:opacity var(--transition)}.nav-logo:hover{opacity:.8}.logo-bracket{color:var(--accent-light)}.logo-name{color:var(--text-primary);margin:0 2px}.nav-links{display:flex;align-items:center;gap:4px;list-style:none}.nav-links a{display:inline-block;padding:8px 14px;font-size:.875rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition);position:relative}.nav-links a:hover,.nav-links a.active{color:var(--text-primary);background:#ffffff0d}.nav-links a.active:after{content:"";position:absolute;bottom:3px;left:50%;transform:translate(-50%);width:16px;height:2px;background:var(--accent-light);border-radius:1px}.nav-cta{padding:8px 20px!important;background:#7c3aed26!important;border:1px solid rgba(167,139,250,.3)!important;border-radius:8px!important;color:var(--accent-light)!important;font-weight:600!important;transition:all var(--transition)!important}.nav-cta:hover{background:#7c3aed4d!important;border-color:var(--accent-light)!important;color:#fff!important}.nav-cta.active:after{display:none!important}.lang-toggle{padding:6px 14px;border-radius:999px;font-size:.72rem;font-weight:700;color:var(--text-secondary);background:#ffffff0a;border:1px solid var(--border);font-family:Fira Code,monospace;letter-spacing:.08em;cursor:pointer;transition:all var(--transition)}.lang-toggle:hover{color:var(--accent-light);border-color:#a78bfa4d;background:#7c3aed1a}.nav-controls{display:flex;align-items:center;gap:8px;margin-left:8px}.nav-right-mobile{display:none;align-items:center;gap:8px}.lang-toggle-mobile{display:none}.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;background:none;border:none}.hamburger span{display:block;width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:transform var(--transition),opacity var(--transition)}.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media (max-width: 768px){.hamburger{display:flex;z-index:1001}.nav-right-mobile{display:flex}.lang-toggle-mobile{display:inline-flex}.nav-overlay{display:block}.nav-links{position:fixed;top:0;right:-100%;width:260px;height:100vh;background:#111111fa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid var(--border);flex-direction:column;align-items:flex-start;gap:4px;padding:80px 24px 32px;transition:right var(--transition);z-index:1000}.nav-links.open{right:0}.nav-links li{width:100%}.nav-controls{flex-direction:column;align-items:flex-start;margin-left:0;margin-top:8px;padding-top:16px;border-top:1px solid var(--border);width:100%}.lang-toggle:not(.lang-toggle-mobile){display:none}.nav-links a{width:100%;padding:12px 16px;font-size:1rem}}.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding-top:80px}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(124,58,237,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(124,58,237,.04) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,black 0%,transparent 100%);mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,black 0%,transparent 100%)}.hero-glow{position:absolute;border-radius:50%;filter:blur(80px);animation:float 8s ease-in-out infinite}.hero-glow-1{width:500px;height:500px;background:radial-gradient(circle,rgba(124,58,237,.18) 0%,transparent 70%);top:-100px;left:-100px;animation-delay:0s}.hero-glow-2{width:400px;height:400px;background:radial-gradient(circle,rgba(34,211,238,.1) 0%,transparent 70%);bottom:0;right:-50px;animation-delay:4s}.hero-content{position:relative;z-index:1;padding-top:40px;padding-bottom:40px}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;background:#34d39914;border:1px solid rgba(52,211,153,.2);border-radius:999px;font-size:.8rem;color:var(--success);font-weight:500;margin-bottom:28px}.badge-dot{width:7px;height:7px;background:var(--success);border-radius:50%;box-shadow:0 0 #34d39966;animation:pulse 2.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #34d39966}70%{box-shadow:0 0 0 8px #34d39900}to{box-shadow:0 0 #34d39900}}.hero-name{font-size:clamp(2.8rem,7vw,5rem);font-weight:800;line-height:1.1;letter-spacing:-.03em;margin-bottom:20px;color:var(--text-primary)}.hero-role{font-family:Fira Code,monospace;font-size:clamp(1rem,2.5vw,1.25rem);color:var(--text-secondary);margin-bottom:28px;min-height:1.8em;display:flex;align-items:center;gap:4px}.role-prefix{color:var(--accent-light);opacity:.6}.role-text{color:var(--accent-light)}.cursor{color:var(--accent-light);animation:blink 1s infinite;margin-left:1px;font-weight:300}.hero-desc{max-width:560px;font-size:1.05rem;color:var(--text-secondary);line-height:1.75;margin-bottom:40px}.hero-desc strong{color:var(--text-primary);font-weight:600}.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:52px}.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:10px;font-weight:600;font-size:.95rem;transition:all var(--transition);cursor:pointer}.btn-primary{background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;border:1px solid rgba(167,139,250,.3);box-shadow:0 4px 20px #7c3aed4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px #7c3aed73}.btn-primary svg{transition:transform var(--transition)}.btn-primary:hover svg{transform:translate(4px)}.btn-secondary{background:#ffffff0a;color:var(--text-primary);border:1px solid var(--border-hover)}.btn-secondary:hover{background:#ffffff14;border-color:var(--accent-light);color:var(--accent-light);transform:translateY(-2px)}.hero-stats{display:flex;align-items:center;gap:32px}.stat{display:flex;flex-direction:column;gap:4px}.stat-number{font-size:2rem;font-weight:800;letter-spacing:-.02em;line-height:1}.stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.stat-divider{width:1px;height:40px;background:var(--border)}.scroll-indicator{position:absolute;bottom:36px;left:90%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;animation:float 3s ease-in-out infinite}.scroll-indicator span{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted)}.scroll-mouse{width:22px;height:36px;border:2px solid var(--border-hover);border-radius:11px;display:flex;justify-content:center;padding-top:6px}.scroll-wheel{width:3px;height:6px;background:var(--accent-light);border-radius:3px;animation:scroll-down 2s ease-in-out infinite}@keyframes scroll-down{0%{transform:translateY(0);opacity:1}to{transform:translateY(12px);opacity:0}}@media (max-width: 600px){.hero-stats{gap:20px}.scroll-indicator{display:none}}.about-section{padding-top:72px}.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}.about-text{display:flex;flex-direction:column;gap:20px}.about-text p{font-size:1.05rem;color:var(--text-secondary);line-height:1.8}.about-values{display:grid;grid-template-columns:1fr 1fr;gap:14px}.value-card{display:flex;align-items:flex-start;gap:14px;padding:18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition)}.value-card:hover{border-color:#a78bfa33;transform:translateY(-2px)}.value-icon{font-size:1.4rem;flex-shrink:0;line-height:1;margin-top:2px}.value-label{font-size:.88rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.value-desc{font-size:.78rem;color:var(--text-muted);line-height:1.5}@media (max-width: 900px){.about-layout{grid-template-columns:1fr;gap:32px}}@media (max-width: 480px){.about-values{grid-template-columns:1fr}}.skills-header{margin-bottom:48px}.fs-domains{display:flex;align-items:center;flex-wrap:wrap;gap:4px;margin-top:14px}.fs-domain-pill{font-family:Fira Code,monospace;font-size:.82rem;color:var(--text-muted);display:flex;align-items:center}.fs-sep{color:var(--accent);margin:0 4px;opacity:.6}.skills-cats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.skill-group{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:22px 20px;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);display:flex;flex-direction:column;gap:16px}.skill-group:hover{border-color:#a78bfa40;transform:translateY(-3px);box-shadow:0 8px 32px #7c3aed14}.skill-group-head{display:flex;align-items:center;gap:10px;padding-bottom:14px;border-bottom:1px solid var(--border)}.skill-group-icon{font-size:1.25rem;line-height:1}.skill-group-label{font-size:.88rem;font-weight:700;color:var(--text-primary)}.skill-group-tags{display:flex;flex-wrap:wrap;gap:7px}.skill-pill{display:inline-block;padding:5px 11px;border-radius:999px;font-size:.76rem;font-weight:500;color:var(--text-secondary);background:#ffffff0a;border:1px solid var(--border);transition:all var(--transition);white-space:nowrap;cursor:default}.skill-pill:hover{color:var(--accent-light);border-color:#a78bfa4d;background:#7c3aed14;transform:translateY(-1px)}@media (max-width: 1000px){.skills-cats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 560px){.skills-cats{grid-template-columns:1fr}}.timeline{display:flex;flex-direction:column;gap:0;position:relative}.timeline-item{display:grid;grid-template-columns:40px 1fr;gap:24px;padding-bottom:40px}.timeline-item:last-child{padding-bottom:0}.timeline-line{display:flex;flex-direction:column;align-items:center;position:relative}.timeline-dot{width:14px;height:14px;border-radius:50%;background:var(--border-hover);border:2px solid var(--bg-card);flex-shrink:0;margin-top:6px;position:relative;z-index:1}.timeline-dot.current{background:var(--accent);border-color:var(--bg-primary);box-shadow:0 0 0 4px #7c3aed33}.dot-ping{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid var(--accent-light);animation:ping 2s ease-in-out infinite}@keyframes ping{0%{transform:scale(1);opacity:.8}to{transform:scale(2.2);opacity:0}}.timeline-line:after{content:"";flex:1;width:1px;background:linear-gradient(to bottom,var(--border),transparent);margin-top:8px}.timeline-item:last-child .timeline-line:after{display:none}.timeline-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.timeline-card:hover{border-color:#a78bfa33;transform:translate(4px);box-shadow:0 8px 32px #7c3aed14}.timeline-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;flex-wrap:wrap}.timeline-role{font-size:1.08rem;font-weight:700;color:var(--text-primary);margin-bottom:6px}.timeline-meta{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-secondary)}.timeline-company{color:var(--accent-light);font-weight:600}.timeline-separator{color:var(--text-muted)}.timeline-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.timeline-period{font-family:Fira Code,monospace;font-size:.78rem;color:var(--text-muted);white-space:nowrap}.timeline-type{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.06em}.type-cdi{background:#34d3991a;border:1px solid rgba(52,211,153,.25);color:var(--success)}.type-stage{background:#22d3ee1a;border:1px solid rgba(34,211,238,.25);color:var(--accent-2)}.type-académique{background:#a78bfa1a;border:1px solid rgba(167,139,250,.25);color:var(--accent-light)}.timeline-bullets{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.timeline-bullets li{display:flex;gap:12px;font-size:.9rem;color:var(--text-secondary);line-height:1.6}.bullet-icon{color:var(--accent-light);flex-shrink:0;font-family:Fira Code,monospace;font-size:.8rem;margin-top:2px}.timeline-tech{display:flex;flex-wrap:wrap;gap:8px}@media (max-width: 600px){.timeline-item{grid-template-columns:28px 1fr;gap:16px}.timeline-header{flex-direction:column}.timeline-right{align-items:flex-start;flex-direction:row;flex-wrap:wrap}}.project-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px}.filter-btn{padding:8px 20px;border-radius:999px;font-size:.85rem;font-weight:500;color:var(--text-secondary);background:#ffffff0a;border:1px solid var(--border);transition:all var(--transition);font-family:Inter,sans-serif}.filter-btn:hover{color:var(--text-primary);border-color:var(--border-hover);background:#ffffff12}.filter-btn.active{color:var(--accent-light);background:#7c3aed1f;border-color:#a78bfa59}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);position:relative;animation:cardAppear .45s cubic-bezier(.4,0,.2,1) both}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--project-accent, var(--accent));opacity:0;transition:opacity var(--transition)}.project-card:hover{border-color:#ffffff14;transform:translateY(-5px);box-shadow:0 16px 48px #0006}.project-card:hover:before{opacity:1}.project-card.featured{border-color:#7c3aed33}.project-card-inner{padding:28px}.project-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.project-icon-wrap{width:48px;height:48px;background:#ffffff0a;border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem}.featured-badge{font-size:.7rem;padding:4px 10px;background:#7c3aed1f;border:1px solid rgba(167,139,250,.2);border-radius:999px;color:var(--accent-light);font-weight:500}.project-category-badge{display:inline-block;font-family:Fira Code,monospace;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:8px}.project-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:6px;line-height:1.3}.project-subtitle{font-size:.82rem;color:var(--text-muted);margin-bottom:20px}.project-problem{margin-bottom:16px}.problem-label,.learned-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:6px;font-weight:600}.project-problem p{font-size:.83rem;color:var(--text-secondary);line-height:1.6}.project-learned{margin-bottom:20px}.project-learned ul{list-style:none;display:flex;flex-direction:column;gap:6px}.project-learned li{display:flex;gap:8px;font-size:.82rem;color:var(--text-secondary);line-height:1.5}.check-icon{color:var(--project-accent, var(--accent-light));flex-shrink:0;font-size:.75rem;margin-top:2px}.project-tech{display:flex;flex-wrap:wrap;gap:6px;padding-top:16px;border-top:1px solid var(--border)}@media (max-width: 1000px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.projects-grid{grid-template-columns:1fr}}.edu-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}.edu-left{display:flex;flex-direction:column;gap:20px}.edu-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;display:flex;gap:20px;transition:border-color var(--transition)}.edu-card:hover{border-color:#a78bfa33}.edu-icon{font-size:2rem;flex-shrink:0;line-height:1;margin-top:2px}.edu-degree{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.edu-school{color:var(--accent-light);font-size:.9rem;font-weight:600;margin-bottom:2px}.edu-period{font-family:Fira Code,monospace;font-size:.75rem;color:var(--text-muted);margin-bottom:16px}.edu-highlights{list-style:none;display:flex;flex-direction:column;gap:8px}.edu-highlights li{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:var(--text-secondary);line-height:1.5}.highlight-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0;margin-top:6px}.languages-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.lang-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:20px}.languages{display:flex;flex-direction:column;gap:16px}.lang-item{display:flex;flex-direction:column;gap:8px}.lang-header{display:flex;justify-content:space-between;align-items:center}.lang-name{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:500;color:var(--text-primary)}.lang-level{font-size:.75rem;color:var(--text-muted);font-family:Fira Code,monospace}.lang-track{height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden}.lang-fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:2px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.visible .lang-fill{width:var(--target)}.distinctions-col{display:flex;flex-direction:column;gap:16px}.distinctions-title{margin-bottom:4px}.distinctions-list{display:flex;flex-direction:column;gap:14px}.distinction-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;gap:14px;transition:all var(--transition)}.distinction-card:hover{border-color:#a78bfa33;transform:translate(3px)}.distinction-icon{font-size:1.5rem;flex-shrink:0;line-height:1}.distinction-title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:3px}.distinction-subtitle{font-size:.78rem;color:var(--accent-light);font-weight:500;margin-bottom:6px}.distinction-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.55}@media (max-width: 900px){.edu-layout{grid-template-columns:1fr}}@media (max-width: 600px){.edu-card{flex-direction:column;gap:12px}}.contact-intro{max-width:520px;color:var(--text-secondary);font-size:1rem;margin-top:12px;line-height:1.7}.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:28px;align-items:start}.contact-info{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px}.contact-info-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin-bottom:24px}.contact-links{display:flex;flex-direction:column;gap:6px;margin-bottom:28px}.contact-link,.contact-link-static{display:flex;align-items:flex-start;gap:14px;padding:12px;border-radius:var(--radius-sm);transition:background var(--transition)}.contact-link{text-decoration:none;color:inherit}.contact-link:hover{background:#ffffff0a}.contact-link-icon{color:var(--accent-light);flex-shrink:0;margin-top:1px;display:flex;align-items:center}.contact-link div{display:flex;flex-direction:column;gap:2px}.contact-link-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:600}.contact-link-value{font-size:.88rem;color:var(--text-secondary);transition:color var(--transition)}.contact-link:hover .contact-link-value{color:var(--text-primary)}.availability-badge{display:flex;gap:12px;align-items:flex-start;padding:16px;background:#34d3990f;border:1px solid rgba(52,211,153,.18);border-radius:var(--radius-sm);margin-top:8px}.availability-badge .badge-dot{width:8px;height:8px;background:var(--success);border-radius:50%;flex-shrink:0;margin-top:5px;box-shadow:0 0 #34d39966;animation:pulse 2.5s infinite}.avail-title{font-size:.85rem;font-weight:600;color:var(--success);margin-bottom:3px}.avail-sub{font-size:.75rem;color:var(--text-muted)}.contact-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.form-group input,.form-group textarea{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-size:.9rem;color:var(--text-primary);font-family:Inter,sans-serif;transition:border-color var(--transition),background var(--transition);resize:none;outline:none;width:100%}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group textarea:focus{border-color:#a78bfa66;background:#7c3aed0d}.submit-btn{width:100%;justify-content:center;font-size:.95rem;padding:14px 28px;transition:all var(--transition)}.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none!important}.submit-btn.sent{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 20px #0596694d}.submit-btn.error{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 20px #dc26264d}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.emailjs-note{margin-top:16px;padding:10px 14px;background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-sm);font-size:.75rem;color:#f59e0bcc;line-height:1.5;font-family:Fira Code,monospace}@media (max-width: 900px){.contact-layout{grid-template-columns:1fr}}@media (max-width: 600px){.form-row{grid-template-columns:1fr}.contact-info,.contact-form{padding:24px}}.footer{border-top:1px solid var(--border);padding:32px 0;background:var(--bg-secondary)}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.footer-logo{font-family:Fira Code,monospace;font-size:1rem;font-weight:500;color:var(--text-secondary);transition:color var(--transition)}.footer-logo:hover{color:var(--text-primary)}.footer-copy{font-size:.82rem;color:var(--text-muted)}.footer-links{display:flex;gap:20px}.footer-links a{font-size:.82rem;color:var(--text-muted);transition:color var(--transition)}.footer-links a:hover{color:var(--accent-light)}@media (max-width: 600px){.footer-inner{flex-direction:column;text-align:center;gap:12px}}#root{min-height:100vh}main{position:relative}
