@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a25;--text-primary: #ffffff;--text-secondary: #b8b8c8;--text-muted: #6b6b80;--accent-color: #9b59b6;--accent-primary: #8e44ad;--accent-light: #bb8fce;--accent-glow: rgba(155, 89, 182, .4);--border-color: rgba(155, 89, 182, .2);--border-hover: rgba(155, 89, 182, .5);--gradient-primary: linear-gradient(135deg, #9b59b6 0%, #8e44ad 50%, #6c3483 100%);--gradient-secondary: linear-gradient(135deg, #3498db 0%, #2980b9 100%);--gradient-card: linear-gradient(145deg, rgba(18, 18, 26, .8) 0%, rgba(26, 26, 37, .6) 100%);--gradient-bg: radial-gradient(ellipse at top, rgba(155, 89, 182, .1) 0%, transparent 50%), radial-gradient(ellipse at bottom right, rgba(52, 152, 219, .05) 0%, transparent 50%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .6);--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--section-padding: 5rem 1.5rem;--container-max: 1200px}[data-theme=light]{--bg-primary: #faf8fc;--bg-secondary: #f5f2f8;--bg-tertiary: #ebe7f0;--text-primary: #1a1a2e;--text-secondary: #4a4a5e;--text-muted: #7a7a8e;--accent-color: #7b2cbf;--accent-primary: #9d4edd;--accent-light: #c77dff;--accent-glow: rgba(123, 44, 191, .3);--border-color: rgba(123, 44, 191, .2);--border-hover: rgba(123, 44, 191, .5);--gradient-primary: linear-gradient(135deg, #7b2cbf 0%, #9d4edd 50%, #c77dff 100%);--gradient-card: linear-gradient(145deg, rgba(255, 255, 255, .9) 0%, rgba(245, 242, 248, .8) 100%);--gradient-bg: radial-gradient(ellipse at top, rgba(123, 44, 191, .08) 0%, transparent 50%), radial-gradient(ellipse at bottom right, rgba(157, 78, 221, .05) 0%, transparent 50%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 20px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .12);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden;transition:background-color var(--transition-normal),color var(--transition-normal)}body:before{content:"";position:fixed;inset:0;background:var(--gradient-bg);pointer-events:none;z-index:-1}body:after{content:"";position:fixed;inset:0;background-image:radial-gradient(circle at 20% 30%,var(--accent-glow) 0%,transparent 1px),radial-gradient(circle at 80% 70%,var(--accent-glow) 0%,transparent 1px),radial-gradient(circle at 40% 80%,var(--accent-glow) 0%,transparent 1px),radial-gradient(circle at 60% 20%,var(--accent-glow) 0%,transparent 1px);background-size:300px 300px,400px 400px,250px 250px,350px 350px;animation:particleFloat 20s ease-in-out infinite;pointer-events:none;z-index:-1;opacity:.5}@keyframes particleFloat{0%,to{transform:translate(0)}25%{transform:translate(10px,-10px)}50%{transform:translate(-5px,15px)}75%{transform:translate(15px,5px)}}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;letter-spacing:-.02em}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.75rem,4vw,2.5rem)}h3{font-size:clamp(1.25rem,3vw,1.75rem)}p{color:var(--text-secondary)}a{color:var(--accent-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-color)}.container{max-width:var(--container-max);margin:0 auto;padding:0 1.5rem}section{padding:var(--section-padding);position:relative}@media(min-width:769px){section{padding:6rem 2rem}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.75rem;font-size:1rem;font-weight:500;font-family:inherit;border-radius:12px;border:none;cursor:pointer;transition:all var(--transition-normal);text-decoration:none}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 20px #9b59b666;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 30px #9b59b680}.btn-primary:hover:before{left:100%}.btn-secondary{background:transparent;color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{border-color:var(--accent-primary);background:#9b59b61a}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes pulse{0%,to{opacity:.2}50%{opacity:.4}}@keyframes glow{0%,to{box-shadow:0 0 20px var(--accent-glow);opacity:.8}50%{box-shadow:0 0 40px var(--accent-glow),0 0 60px var(--accent-glow);opacity:1}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.animate-on-scroll.visible{opacity:1;transform:translateY(0)}.stagger-1{transition-delay:.1s}.stagger-2{transition-delay:.2s}.stagger-3{transition-delay:.3s}.stagger-4{transition-delay:.4s}.stagger-5{transition-delay:.5s}.stagger-6{transition-delay:.6s}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}::selection{background:var(--accent-primary);color:#fff}.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}@media(min-width:481px){:root{--section-padding: 4rem 2rem}}@media(min-width:769px){:root{--section-padding: 5rem 2rem;--container-max: 900px}}@media(min-width:1024px){:root{--container-max: 1100px}}@media(min-width:1400px){:root{--container-max: 1300px}}.header{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem 0;transition:all var(--transition-normal)}.header.scrolled{background:#0a0a0fd9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);padding:.75rem 0}[data-theme=light] .header.scrolled{background:#faf8fce6}.header-container{display:flex;align-items:center;justify-content:space-between;max-width:var(--container-max);margin:0 auto;padding:0 1.5rem}.logo{display:flex;align-items:center;gap:.25rem;font-family:JetBrains Mono,monospace;font-weight:600;font-size:1.1rem;color:var(--text-primary);text-decoration:none;transition:all var(--transition-fast)}.logo:hover{color:var(--accent-light)}.logo-code{color:var(--text-secondary)}.logo-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-desktop{display:none;align-items:center;gap:2rem}@media(min-width:769px){.nav-desktop{display:flex}}.nav-link{font-size:.95rem;color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast);position:relative}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--gradient-primary);transition:width var(--transition-fast)}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:after{width:100%}.header-controls{display:flex;align-items:center;gap:.5rem}.control-btn{display:flex;align-items:center;justify-content:center;gap:.35rem;width:40px;height:40px;background:transparent;border:1px solid var(--border-color);border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.control-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#9b59b61a}.lang-indicator{font-size:.75rem;font-weight:600}.mobile-menu-btn{display:flex;width:40px;height:40px}@media(min-width:769px){.mobile-menu-btn{display:none}}.nav-mobile{position:fixed;inset:0;background:var(--bg-primary);z-index:99;padding:6rem 1.5rem 2rem;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto}.nav-link-mobile{display:block;padding:1rem 1.5rem;font-size:1.25rem;color:var(--text-primary);text-decoration:none;border-radius:12px;transition:all var(--transition-fast)}.nav-link-mobile:hover{background:#9b59b61a;color:var(--accent-light)}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:6rem 0 4rem}.hero-bg{position:absolute;inset:0;z-index:-1}.floating-elements{position:absolute;inset:0;pointer-events:none}.floating-code{position:absolute;font-family:JetBrains Mono,Fira Code,monospace;font-size:1.5rem;font-weight:600;color:var(--accent-primary);opacity:.2;text-shadow:0 0 20px var(--accent-glow)}.code-1{top:15%;left:10%}.code-2{top:25%;right:15%}.code-3{bottom:30%;left:20%}.code-4{bottom:20%;right:10%}@media(max-width:768px){.floating-code{font-size:1rem}.code-1{top:10%;left:5%}.code-2{top:20%;right:5%}.code-3{bottom:25%;left:10%}.code-4{bottom:15%;right:5%}}.hero-content{text-align:center;max-width:800px;z-index:1}.hero-title{margin:1.5rem 0;display:flex;flex-direction:column;align-items:center;gap:.5rem}.hero-title-text{font-family:JetBrains Mono,Fira Code,monospace;font-size:clamp(2.5rem,8vw,5rem);font-weight:700;color:var(--text-primary)}.title-highlight{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.title-line{display:flex;align-items:center;justify-content:center}.title-icon{color:var(--accent-primary);margin-bottom:.5rem;filter:drop-shadow(0 0 20px var(--accent-glow))}@media(min-width:769px){.title-icon{width:64px;height:64px}}.hero-title-text{font-family:JetBrains Mono,Fira Code,monospace;font-size:clamp(2rem,6vw,4rem);font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.title-highlight{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 3s ease infinite;background-size:200% 200%}.hero-subtitle{font-size:clamp(1.25rem,4vw,2rem);color:var(--text-secondary);margin-bottom:1rem;font-weight:500}.hero-description{font-size:clamp(1rem,2.5vw,1.25rem);color:var(--text-muted);max-width:600px;margin:0 auto 2rem;line-height:1.7}.hero-cta{display:flex;flex-direction:column;align-items:center;gap:1rem}@media(min-width:481px){.hero-cta{flex-direction:row;justify-content:center}}.terminal-decoration{position:absolute;right:3%;bottom:15%;width:320px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-lg);display:none;z-index:10}@media(min-width:1400px){.terminal-decoration{display:block}}.terminal-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.terminal-dot{width:12px;height:12px;border-radius:50%}.terminal-dot.red{background:#ff5f56}.terminal-dot.yellow{background:#ffbd2e}.terminal-dot.green{background:#27ca40}.terminal-title{margin-left:auto;font-size:.8rem;color:var(--text-muted);font-family:JetBrains Mono,monospace}.terminal-body{padding:1rem;font-family:JetBrains Mono,monospace;font-size:.85rem;line-height:1.6}.terminal-line{display:flex;gap:.5rem;margin-bottom:.5rem}.prompt{color:var(--accent-primary)}.command{color:var(--text-primary)}.terminal-output{color:var(--text-muted);margin-bottom:.25rem;display:flex;gap:.5rem}.success{color:#27ca40}.accent{color:var(--accent-light)}.terminal-cursor{display:inline-block;color:var(--accent-primary);animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}.hero [style*=transform]{will-change:transform}.services{position:relative;background:var(--bg-secondary)}.section-title{margin-bottom:1rem}.section-subtitle{font-size:clamp(1rem,2.5vw,1.25rem);color:var(--text-muted);max-width:600px;margin:0 auto}.services-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:481px){.services-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.services-grid{grid-template-columns:repeat(3,1fr)}}.service-card{position:relative;background:var(--gradient-card);border:1px solid var(--border-color);border-radius:20px;padding:2rem;cursor:pointer;overflow:hidden;transition:all var(--transition-normal)}.service-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--accent-color),transparent);opacity:0;transition:opacity var(--transition-normal)}.service-card:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);transition:left .5s ease}.service-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg),0 0 40px #9b59b626;transform:translateY(-5px)}.service-card:hover:before{opacity:1}.service-card:hover:after{left:100%}.service-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,var(--accent-color),var(--accent-primary));border-radius:14px;margin-bottom:1.25rem;color:#fff;box-shadow:0 4px 15px #0003;transition:transform var(--transition-fast)}.service-card:hover .service-icon{transform:scale(1.1) rotate(5deg)}.service-title{font-size:1.25rem;margin-bottom:.75rem;color:var(--text-primary)}.service-description{font-size:.95rem;color:var(--text-secondary);line-height:1.6}.tech-stack{position:relative;background:var(--bg-primary);overflow:hidden}.tech-categories{display:flex;flex-direction:column;gap:1rem;max-width:800px;margin:0 auto}.tech-category{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;transition:all var(--transition-normal)}.tech-category.open{border-color:var(--category-color);box-shadow:var(--shadow-md)}.category-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1.25rem 1.5rem;background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast)}.category-header:hover{background:var(--accent-glow)}.category-title{display:flex;align-items:center;gap:.75rem;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.category-icon{color:var(--category-color)}.category-chevron{color:var(--text-muted);transition:color var(--transition-fast)}.tech-category.open .category-chevron{color:var(--category-color)}.category-content{overflow:hidden}.tech-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;padding:1rem 1.5rem 1.5rem}@media(min-width:481px){.tech-grid{grid-template-columns:repeat(4,1fr)}}.tech-item{display:flex;align-items:center;gap:.5rem;padding:1.25rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all var(--transition-fast)}.tech-item:hover{border-color:var(--tech-color);background:var(--bg-card);transform:translateY(-2px)}.tech-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.tech-name{font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:color var(--transition-fast)}.tech-item:hover .tech-name{color:var(--text-primary)}.roadmap{position:relative;background:var(--bg-primary);overflow:hidden}.roadmap:before{content:"";position:absolute;top:50%;left:50%;width:600px;height:600px;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);transform:translate(-50%,-50%);opacity:.3;pointer-events:none}.section-header{text-align:center;margin-bottom:4rem}.roadmap-timeline{display:none;position:relative;max-width:900px;margin:0 auto;padding:2rem 0}@media(min-width:769px){.roadmap-timeline{display:block}}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent 0%,var(--accent-primary) 10%,var(--accent-primary) 90%,transparent 100%);transform:translate(-50%)}.timeline-line-progress{position:absolute;top:0;left:0;width:100%;height:0%;background:var(--gradient-primary);transition:height .5s ease}.timeline-step{position:relative;display:flex;align-items:flex-start;gap:2rem;margin-bottom:3rem}.timeline-step:last-child{margin-bottom:0}.timeline-step.left{flex-direction:row}.timeline-step.right{flex-direction:row-reverse}.timeline-step.left .step-content{text-align:right}.timeline-step.right .step-content{text-align:left}.step-content{flex:1;max-width:350px;background:var(--gradient-card);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;transition:all var(--transition-normal)}.step-content:hover,.step-content.active{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-4px)}.step-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.timeline-step.left .step-header{flex-direction:row-reverse}.step-number{font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:600;color:var(--accent-primary);opacity:.7;flex-shrink:0}.step-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;background:#9b59b626;border-radius:12px;color:var(--step-color, var(--accent-primary));transition:all var(--transition-fast);flex-shrink:0}.step-content:hover .step-icon,.step-content.active .step-icon{background:var(--step-color, var(--accent-primary));color:#fff;transform:scale(1.1)}.step-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.step-description{font-size:.95rem;color:var(--text-secondary);line-height:1.6}.step-details{margin-top:1rem;overflow:hidden}.step-checklist{display:flex;flex-direction:column;gap:.5rem}.checklist-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-muted)}.timeline-step.left .checklist-item{justify-content:flex-end}.timeline-step.right .checklist-item{justify-content:flex-start}.checklist-item svg{color:var(--accent-primary);flex-shrink:0}.step-connector{position:absolute;left:50%;top:1.5rem;transform:translate(-50%);z-index:2}.step-dot{width:16px;height:16px;background:var(--step-color, var(--accent-primary));border-radius:50%;border:3px solid var(--bg-primary);box-shadow:0 0 20px var(--accent-glow);transition:all var(--transition-fast)}.step-content:hover~.step-connector .step-dot,.step-content.active~.step-connector .step-dot{transform:scale(1.3);box-shadow:0 0 30px var(--accent-glow)}.step-arrow{position:absolute;left:50%;bottom:-1.5rem;transform:translate(-50%) rotate(90deg);color:var(--text-muted);opacity:.5}.timeline-step:last-child .step-arrow{display:none}.roadmap-mobile{display:flex;flex-direction:column;gap:1.5rem;padding-left:2rem;position:relative}@media(min-width:769px){.roadmap-mobile{display:none}}.roadmap-mobile:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent 0%,var(--accent-primary) 10%,var(--accent-primary) 90%,transparent 100%)}.mobile-step{position:relative;background:var(--gradient-card);border:1px solid var(--border-color);border-radius:16px;padding:1.25rem;transition:all var(--transition-normal)}.mobile-step:before{content:"";position:absolute;left:-2rem;top:1.5rem;width:12px;height:12px;background:var(--accent-primary);border-radius:50%;border:2px solid var(--bg-primary);transform:translate(-50%)}.mobile-step:hover{border-color:var(--border-hover);transform:translate(4px)}.mobile-step-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.mobile-step-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#9b59b626;border-radius:10px;color:var(--step-color, var(--accent-primary))}.mobile-step-number{font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:600;color:var(--accent-primary);opacity:.7}.mobile-step-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.35rem}.mobile-step-description{font-size:.9rem;color:var(--text-secondary);line-height:1.5}[data-theme=light] .step-icon,[data-theme=light] .mobile-step-icon{background:#7b2cbf1f}.portfolio{position:relative;background:var(--bg-secondary)}.portfolio-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:769px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}.portfolio-card:first-child{grid-column:span 2}}@media(min-width:1200px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}.portfolio-card:first-child{grid-column:span 1}}.portfolio-card{position:relative;background:var(--gradient-card);border:1px solid var(--border-color);border-radius:20px;overflow:hidden;transition:all var(--transition-normal);display:flex;flex-direction:column;min-height:320px}.portfolio-card:hover{border-color:var(--border-hover);transform:translateY(-8px);box-shadow:var(--shadow-xl),0 0 50px #9b59b633}.portfolio-image{position:relative;height:180px;overflow:hidden}.portfolio-gradient{position:absolute;inset:0;transition:transform var(--transition-slow)}.portfolio-card:hover .portfolio-gradient{transform:scale(1.05)}.gradient-purple{background:linear-gradient(135deg,#9b59b6,#6c3483,#4a235a)}.gradient-blue{background:linear-gradient(135deg,#3498db,#2980b9,#1a5276)}.gradient-orange{background:linear-gradient(135deg,#e67e22,#d35400,#a04000)}.portfolio-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#ffffffe6;filter:drop-shadow(0 4px 20px rgba(0,0,0,.3))}.portfolio-content{padding:1.5rem;flex:1;display:flex;flex-direction:column}.portfolio-title{font-size:1.35rem;margin-bottom:.75rem;color:var(--text-primary)}.portfolio-description{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1rem;flex:1}.portfolio-tags{display:flex;flex-wrap:wrap;gap:.5rem}.portfolio-tag{padding:.35rem .75rem;background:#9b59b626;border:1px solid rgba(155,89,182,.3);border-radius:20px;font-size:.8rem;color:var(--accent-primary);transition:all var(--transition-fast)}.portfolio-tag:hover{background:#9b59b640;border-color:var(--accent-primary)}[data-theme=light] .portfolio-tag{background:#7b2cbf1a;border-color:#7b2cbf4d;color:var(--accent-primary)}[data-theme=light] .portfolio-tag:hover{background:#7b2cbf33}.contact{position:relative;background:var(--bg-secondary);overflow:hidden}.contact:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-primary),transparent)}.section-title{font-size:clamp(2rem,5vw,2.75rem);font-weight:700;margin-bottom:1rem}.section-subtitle{font-size:1.1rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.contact-methods-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:900px;margin:0 auto}@media(min-width:769px){.contact-methods-grid{grid-template-columns:repeat(3,1fr)}}.contact-method-card{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--gradient-card);border:1px solid var(--border-color);border-radius:20px;padding:2rem 1.5rem;text-decoration:none;transition:all var(--transition-normal);overflow:hidden}.contact-method-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);transform:scaleX(0);transition:transform var(--transition-normal)}.contact-method-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg),0 0 40px #9b59b626}.contact-method-card:hover:before{transform:scaleX(1)}.method-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,var(--method-color, var(--accent-primary)),var(--accent-primary));border-radius:16px;margin-bottom:1.25rem;color:#fff;box-shadow:0 4px 15px #0003;transition:transform var(--transition-fast)}.contact-method-card:hover .method-icon{transform:scale(1.1)}.method-info{display:flex;flex-direction:column;gap:.35rem}.method-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.method-value{font-size:1.1rem;font-weight:500;color:var(--text-primary);word-break:break-word}[data-theme=light] .contact-method-card{background:#fffc}[data-theme=light] .method-icon{box-shadow:0 4px 15px #7b2cbf33}.footer{position:relative;background:var(--bg-primary);border-top:1px solid var(--border-color);padding:3rem 1.5rem 2rem}.footer-content{max-width:var(--container-max);margin:0 auto}.footer-main{display:flex;flex-direction:column;align-items:center;gap:2rem;margin-bottom:2rem}@media(min-width:769px){.footer-main{flex-direction:row;justify-content:space-between;align-items:flex-start}}.footer-brand{text-align:center}@media(min-width:769px){.footer-brand{text-align:left}}.footer-logo{display:flex;align-items:center;justify-content:center;gap:.75rem;font-family:JetBrains Mono,monospace;font-weight:600;font-size:1.1rem;color:var(--text-primary);margin-bottom:.75rem}@media(min-width:769px){.footer-logo{justify-content:flex-start}}.footer-logo-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--gradient-primary);border-radius:8px;color:#fff}.footer-tagline{font-size:.95rem;color:var(--text-muted)}.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem}@media(min-width:769px){.footer-links{justify-content:flex-end}}.footer-link{font-size:.95rem;color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast)}.footer-link:hover{color:var(--accent-primary)}.footer-bottom{display:flex;flex-direction:column;align-items:center;gap:1rem;padding-top:2rem;border-top:1px solid var(--border-color)}@media(min-width:769px){.footer-bottom{flex-direction:row;justify-content:space-between}}.footer-copyright{font-size:.85rem;color:var(--text-muted)}.footer-social{display:flex;gap:.75rem}.social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid var(--border-color);border-radius:10px;color:var(--text-secondary);transition:all var(--transition-fast)}.social-link:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#9b59b61a;transform:translateY(-2px)}[data-theme=light] .social-link:hover{background:#7b2cbf1a}.app{min-height:100vh;display:flex;flex-direction:column}.section-header{text-align:center;margin-bottom:3rem}.section-title{margin-bottom:.75rem;position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:60px;height:3px;background:var(--gradient-primary);border-radius:2px}.section-subtitle{font-size:clamp(1rem,2.5vw,1.15rem);color:var(--text-muted);max-width:600px;margin:0 auto;line-height:1.6}section[id]{scroll-margin-top:80px}main{flex:1}.fade-in{animation:fadeIn .6s ease forwards}.slide-up{animation:slideUp .6s ease forwards}.scale-in{animation:scaleIn .5s ease forwards}.hover-lift{transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.hover-lift:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glass{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}[data-theme=light] .glass{background:#ffffffb3;border:1px solid rgba(0,0,0,.1)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
