:root{--primary: #10B981;--primary-dark: #059669;--primary-deep: #064E3B;--primary-muted: rgba(16, 185, 129, .08);--bg: #080C10;--surface: #0D1117;--surface-elevated: #161B22;--text-primary: #E6EDF3;--text-secondary: #8B949E;--border-subtle: rgba(16, 185, 129, .1);--border-hover: rgba(16, 185, 129, .25);--radius: 12px;--radius-lg: 20px;--radius-pill: 999px;--transition: all .2s ease;--transition-slow: all .35s cubic-bezier(.4, 0, .2, 1);--font-heading: "Sora", "Outfit", sans-serif;--font-body: "Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{overflow-x:hidden}img,video,svg{max-width:100%;height:auto}a{color:var(--primary);text-decoration:none;transition:var(--transition)}a:hover{color:var(--primary-dark)}::selection{background:#10b9812e;color:var(--text-primary)}@media(hover:none){.cursor-dot,.cursor-ring{display:none!important}}.scroll-progress{position:fixed;top:0;left:0;height:2px;background:var(--primary);z-index:10000;transform-origin:left;will-change:transform}.section{padding:clamp(80px,10vw,140px) 24px;max-width:1200px;margin:0 auto}.section--wide{max-width:1400px}.section--narrow{max-width:900px}.section-header{margin-bottom:3rem;position:relative}.section-number{font-family:var(--font-mono);color:var(--primary);font-size:.85rem;font-weight:500;letter-spacing:.05em;display:block;margin-bottom:.75rem;opacity:.7}.section-title{font-family:var(--font-heading);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:700;color:var(--text-primary);letter-spacing:-.03em;margin:0;line-height:1.2}.section-subtitle{font-size:1.1rem;color:var(--text-secondary);margin-top:.75rem;line-height:1.7;max-width:600px}.floating-nav{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:1000;background:#0d111799;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-pill);padding:14px 20px;display:flex;align-items:center;gap:6px;transition:var(--transition-slow)}.floating-nav.scrolled{background:#0d1117eb;border-color:var(--border-subtle);box-shadow:0 8px 32px #0006}.nav-link{position:relative;font-family:"Inter",var(--font-body);font-size:1.05rem;font-weight:500;color:var(--text-secondary);padding:12px 24px;border-radius:var(--radius-pill);transition:color .2s ease;white-space:nowrap;border:none;background:none;text-decoration:none;letter-spacing:-.01em}.nav-link:hover{color:var(--text-primary)}.nav-link.active{color:var(--primary)}.nav-link.active:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:3px;height:3px;background:var(--primary);border-radius:50%}.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text-primary);margin:5px 0;transition:var(--transition);border-radius:2px}.nav-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.nav-hamburger.open span:nth-child(2){opacity:0}.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.nav-mobile-overlay{position:fixed;inset:0;background:#080c10fa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;opacity:0;pointer-events:none;transition:opacity .3s ease}.nav-mobile-overlay.open{opacity:1;pointer-events:all}.nav-mobile-overlay .mobile-nav-link{font-family:var(--font-heading);font-size:1.6rem;font-weight:600;color:var(--text-secondary);transition:var(--transition);text-decoration:none;padding:8px 24px;border-radius:var(--radius-pill)}.nav-mobile-overlay .mobile-nav-link:hover,.nav-mobile-overlay .mobile-nav-link.active{color:var(--primary)}@media(max-width:768px){.floating-nav .nav-links{display:none}.nav-hamburger{display:block}.floating-nav{padding:10px 16px}}.nav-links{display:flex;align-items:center;gap:2px}.hero{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:100px 24px 40px;background:radial-gradient(ellipse 60% 50% at 50% 40%,rgba(16,185,129,.03) 0%,transparent 70%)}.hero-canvas{position:absolute;inset:0;z-index:0;pointer-events:auto}.hero-content{position:relative;z-index:2;text-align:center;max-width:900px;display:flex;flex-direction:column;align-items:center}.hero-name{font-family:var(--font-heading);font-size:clamp(56px,9vw,120px);font-weight:800;color:var(--text-primary);letter-spacing:-.04em;line-height:1;margin-bottom:1.5rem}.hero-headline{font-family:var(--font-heading);font-size:clamp(1.3rem,3vw,2rem);font-weight:500;color:var(--text-secondary);line-height:1.4;margin-bottom:1.5rem;letter-spacing:-.01em}.hero-headline .text-gradient{background:linear-gradient(135deg,var(--primary),#34D399);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:600}.hero-bio{font-family:var(--font-body);font-size:clamp(1rem,1.8vw,1.2rem);color:var(--text-secondary);line-height:1.7;margin-bottom:2.5rem;max-width:640px;opacity:.8}.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}.btn-primary{font-family:var(--font-body);font-weight:600;font-size:1rem;color:var(--bg);background:var(--primary);border:none;padding:14px 32px;border-radius:var(--radius-pill);transition:var(--transition-slow);text-decoration:none;display:inline-block}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 24px #10b98133;color:var(--bg)}.btn-ghost{font-family:var(--font-body);font-weight:600;font-size:1rem;color:var(--text-secondary);background:transparent;border:1px solid rgba(255,255,255,.12);padding:14px 32px;border-radius:var(--radius-pill);transition:var(--transition-slow);text-decoration:none;display:inline-block}.btn-ghost:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}@media(max-width:768px){.hero-ctas{flex-wrap:wrap;justify-content:center}}.scroll-indicator{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-secondary);opacity:.4;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase}.scroll-indicator-line{width:1px;height:32px;background:linear-gradient(to bottom,var(--text-secondary),transparent);animation:scrollPulse 2s ease-in-out infinite}@keyframes scrollPulse{0%,to{opacity:.3;transform:scaleY(1)}50%{opacity:.7;transform:scaleY(1.2)}}.about-section{padding:clamp(80px,10vw,140px) 24px}.about-container{max-width:1200px;margin:0 auto;padding-left:2rem;display:grid;grid-template-columns:280px 1fr;gap:4rem;align-items:start}.about-photo-container{position:relative;width:240px;height:240px;margin:0 auto}.about-photo-inner{position:relative;width:100%;height:100%;border-radius:24px;overflow:hidden;z-index:1;background:var(--surface);box-shadow:0 4px 24px #0000004d}.about-photo-inner img{width:100%;height:100%;object-fit:cover;display:block}.about-text-content{padding-top:.5rem}.about-text-content p{font-size:1.15rem;color:var(--text-secondary);line-height:1.8;margin-bottom:1rem;font-weight:300}.stats-strip{display:flex;align-items:center;gap:2.5rem;margin-top:2.5rem;padding:1.5rem 0;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}.stat-item{display:flex;align-items:baseline;gap:.5rem}.stat-number{font-family:var(--font-mono);font-size:1.5rem;font-weight:600;color:var(--primary);line-height:1}.stat-label{font-size:.85rem;color:var(--text-secondary);opacity:.7;text-transform:capitalize}.stat-divider{width:1px;background:#ffffff14;align-self:stretch}.tech-clusters{display:flex;flex-direction:column;gap:1rem;margin-top:2.5rem}.tech-cluster{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap}.tech-cluster-label{font-family:var(--font-mono);font-size:.75rem;color:var(--primary);opacity:.6;min-width:80px;text-transform:uppercase;letter-spacing:.05em}.tech-cluster-items{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary);line-height:1.8;letter-spacing:.02em;word-spacing:.15em}@media(max-width:768px){.about-container{grid-template-columns:1fr;gap:2rem;text-align:center;padding-left:0}.about-photo-container{width:200px;height:200px}.stats-strip{flex-wrap:wrap;justify-content:center}.tech-clusters{align-items:center}.tech-cluster{flex-direction:column;align-items:center;gap:.25rem}}.projects-section{padding:clamp(80px,10vw,140px) 24px;max-width:1200px;margin:0 auto}.project-featured{display:grid;grid-template-columns:1.2fr 1fr;gap:2.5rem;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:2rem;margin-bottom:3rem;transition:var(--transition-slow);align-items:center}.project-featured:hover{border-color:var(--border-hover)}.project-featured-media{border-radius:var(--radius);overflow:hidden;cursor:pointer;position:relative;aspect-ratio:16/10}.project-featured-media img,.project-featured-media video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.project-featured-media:hover img,.project-featured-media:hover video{transform:scale(1.02)}.project-featured-badge{font-family:var(--font-mono);font-size:.7rem;font-weight:500;padding:4px 12px;border-radius:var(--radius-pill);background:var(--primary-muted);color:var(--primary);border:1px solid var(--border-subtle);display:inline-block;margin-bottom:.75rem}.project-featured-title{font-family:var(--font-heading);font-size:clamp(1.4rem,2.5vw,1.8rem);font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.3;margin-bottom:.75rem}.project-featured-desc{font-size:1.05rem;color:var(--text-secondary);line-height:1.7;margin-bottom:1.25rem;font-weight:300}@media(max-width:768px){.project-featured{grid-template-columns:1fr;padding:1.25rem}}.project-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-top:2rem}.project-card{background:var(--surface);border:1px solid rgba(255,255,255,.04);border-radius:var(--radius);padding:1.75rem;transition:var(--transition-slow);display:flex;flex-direction:column;position:relative}.project-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:0 12px 32px #0000004d}.project-card[data-type=contractor]{border-left:2px solid var(--primary)}.project-card[data-type=fullstack]{border-left:2px solid #34D399}.project-card[data-type=main]{border-left:2px solid var(--text-secondary)}.project-card-title{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.6rem;letter-spacing:-.01em;line-height:1.3}.project-card-desc{font-size:1rem;color:var(--text-secondary);line-height:1.65;margin-bottom:1.25rem;flex-grow:1;font-weight:300}.project-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1rem}.project-tag{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);opacity:.7;padding:2px 0}.project-tag:not(:last-child):after{content:" ·";opacity:.4}.project-card-links{display:flex;gap:1rem;margin-top:auto;padding-top:1rem;border-top:1px solid rgba(255,255,255,.04)}.project-link{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;color:var(--text-secondary);transition:var(--transition)}.project-link:hover{color:var(--primary)}.project-link svg{width:15px;height:15px}.project-gallery-preview{margin-bottom:1rem;border-radius:8px;overflow:hidden;cursor:pointer;position:relative}.project-gallery-preview img{width:100%;height:180px;object-fit:cover;display:block;transition:transform .4s ease}.project-gallery-preview:hover img{transform:scale(1.03)}.gallery-count{position:absolute;bottom:8px;right:8px;font-family:var(--font-mono);font-size:.7rem;background:#000000b3;color:var(--text-primary);padding:3px 8px;border-radius:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.view-all-btn{display:inline-flex;align-items:center;gap:8px;margin-top:2.5rem;font-family:var(--font-body);font-weight:600;font-size:1rem;color:var(--text-secondary);background:transparent;border:1px solid rgba(255,255,255,.1);padding:12px 28px;border-radius:var(--radius-pill);cursor:pointer;transition:var(--transition-slow);text-decoration:none}.view-all-btn:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}.text-center{text-align:center}@media(max-width:768px){.project-grid{grid-template-columns:1fr}}.experience-section{padding:clamp(80px,10vw,140px) 24px;max-width:1200px;margin:0 auto}.experience-cards{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.experience-card{background:var(--surface);border:1px solid rgba(255,255,255,.04);border-radius:var(--radius);padding:1.75rem 2rem;transition:var(--transition-slow);display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:start}.experience-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 8px 24px #0003}.experience-card-main{display:flex;flex-direction:column;gap:.25rem}.experience-company{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.experience-role{font-size:1rem;color:var(--text-secondary);margin-bottom:.5rem}.experience-desc{font-size:.95rem;color:var(--text-secondary);line-height:1.7;opacity:.8;font-weight:300}.experience-date{font-family:var(--font-mono);font-size:.8rem;color:var(--primary);opacity:.7;white-space:nowrap}@media(max-width:600px){.experience-card{grid-template-columns:1fr;padding:1.5rem}.experience-date{order:-1}}.skills-section{padding:clamp(80px,10vw,140px) 24px;max-width:1200px;margin:0 auto}.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}.bento-card{background:var(--surface);border:1px solid rgba(255,255,255,.04);border-radius:var(--radius);padding:1.5rem;transition:var(--transition-slow);display:flex;flex-direction:column;gap:.75rem}.bento-card:hover{border-color:var(--border-hover);background:#10b98108}.bento-card.span-2{grid-column:span 2}.bento-card.anchor{grid-column:span 2;border-left:2px solid var(--primary)}.bento-card-label{font-family:var(--font-mono);font-size:.7rem;font-weight:500;color:var(--primary);letter-spacing:.08em;text-transform:uppercase;opacity:.7}.bento-card-title{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--text-primary)}.bento-card-skills{display:flex;flex-wrap:wrap;gap:6px}.bento-skill{font-family:var(--font-mono);font-size:.8rem;color:var(--text-secondary);background:var(--surface-elevated);padding:4px 10px;border-radius:6px;transition:var(--transition)}.bento-skill:hover{color:var(--primary);background:#10b9810f}@media(max-width:1024px){.bento-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.bento-grid{grid-template-columns:1fr}.bento-card.span-2,.bento-card.anchor{grid-column:span 1}}.testimonials-section{padding:clamp(80px,10vw,140px) 24px;max-width:1200px;margin:0 auto}.testimonials-wall{display:flex;flex-direction:column;gap:4rem;margin-top:2rem;max-width:900px}.testimonial-item{position:relative;padding-left:2rem;border-left:2px solid rgba(16,185,129,.15)}.testimonial-text{font-size:1.15rem;color:var(--text-secondary);line-height:1.8;font-weight:300;font-style:italic}.testimonial-text p{margin-bottom:.75rem}.testimonial-text p:last-child{margin-bottom:0}.testimonial-author{display:flex;flex-direction:column;gap:.15rem;margin-top:1.25rem}.testimonial-name{font-family:var(--font-heading);font-weight:600;color:var(--text-primary);font-size:1rem;font-style:normal}.testimonial-role{font-size:.85rem;color:var(--text-secondary);opacity:.7;font-style:normal}.testimonial-date{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);opacity:.4;font-style:normal}.education-section{padding:clamp(60px,8vw,100px) 24px;max-width:1200px;margin:0 auto}.education-row{display:flex;gap:1.25rem;margin-top:2rem;flex-wrap:wrap}.education-card{background:var(--surface);border:1px solid rgba(255,255,255,.04);border-radius:var(--radius);padding:1.5rem;transition:var(--transition-slow);text-decoration:none;display:block;flex:1;min-width:240px}.education-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.education-card h3{font-family:var(--font-heading);font-size:1.05rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.education-card .school{font-size:.9rem;color:var(--text-secondary);display:block;margin-bottom:.2rem}.education-card .period{font-family:var(--font-mono);font-size:.8rem;color:var(--primary);opacity:.6}.certification-compact{display:flex;gap:1.25rem;margin-bottom:1.5rem;flex-wrap:wrap}.certification-card{background:var(--surface);border:1px solid rgba(255,255,255,.04);border-radius:var(--radius);padding:1.5rem;display:flex;align-items:center;gap:1.25rem;transition:var(--transition-slow);flex:1;min-width:300px}.certification-card:hover{border-color:var(--border-hover)}.certification-card img{width:80px;height:auto;border-radius:8px;flex-shrink:0}.cert-info{display:flex;flex-direction:column;gap:.5rem}.cert-title{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.3;margin:0}.cert-verify-btn{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:500;color:var(--primary);transition:var(--transition);text-decoration:none}.cert-verify-btn:hover{color:var(--primary-dark)}@media(max-width:600px){.certification-card{flex-direction:column;text-align:center}.certification-card img{width:100px}}.contact-section{padding:clamp(100px,12vw,160px) 24px;text-align:center;position:relative}.contact-content{position:relative;z-index:1;max-width:560px;margin:0 auto}.contact-heading{font-family:var(--font-heading);font-size:clamp(2rem,4.5vw,3rem);font-weight:700;color:var(--text-primary);letter-spacing:-.03em;margin-bottom:1rem;line-height:1.2}.contact-subtext{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2.5rem;font-weight:300;line-height:1.6}.contact-email-btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-body);font-weight:600;font-size:1.1rem;color:var(--bg);background:var(--primary);padding:16px 40px;border-radius:var(--radius-pill);text-decoration:none;transition:var(--transition-slow);margin-bottom:2rem}.contact-email-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 24px #10b98133;color:var(--bg)}.contact-secondary-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}.contact-whatsapp-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:500;font-size:.95rem;color:var(--text-secondary);background:transparent;border:1px solid rgba(255,255,255,.08);padding:10px 22px;border-radius:var(--radius-pill);text-decoration:none;transition:var(--transition-slow)}.contact-whatsapp-btn:hover{border-color:var(--primary);color:var(--primary)}.contact-cv-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:500;font-size:.95rem;color:var(--text-secondary);background:transparent;border:1px solid rgba(255,255,255,.08);padding:10px 22px;border-radius:var(--radius-pill);text-decoration:none;transition:var(--transition-slow)}.contact-cv-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.contact-socials{display:flex;gap:.75rem;justify-content:center;margin-top:1.5rem}.contact-social-link{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.06);color:var(--text-secondary);transition:var(--transition);background:transparent}.contact-social-link:hover{border-color:var(--primary);color:var(--primary)}.contact-social-link svg{width:20px;height:20px}.cursor-dot{position:fixed;width:6px;height:6px;background:var(--primary);border-radius:50%;pointer-events:none;z-index:9999;transition:width .2s ease,height .2s ease,margin .2s ease;margin-left:-3px;margin-top:-3px;will-change:transform;opacity:.8}.cursor-dot.hovering{width:20px;height:20px;margin-left:-10px;margin-top:-10px;mix-blend-mode:difference;opacity:.6}.cursor-ring{position:fixed;width:28px;height:28px;border:1px solid rgba(16,185,129,.25);border-radius:50%;pointer-events:none;z-index:9998;transition:opacity .2s ease;margin-left:-14px;margin-top:-14px;will-change:transform}.cursor-ring.hovering{opacity:0}.footer{text-align:center;padding:2rem 24px;border-top:1px solid rgba(255,255,255,.04)}.footer-back-to-top{display:inline-block;font-family:var(--font-mono);font-size:.8rem;color:var(--text-secondary);text-decoration:none;padding:8px 20px;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-pill);margin-bottom:1rem;transition:var(--transition);opacity:.6}.footer-back-to-top:hover{border-color:var(--primary);color:var(--primary);opacity:1}.footer-copy{font-size:.8rem;color:var(--text-secondary);margin:0;opacity:.5}.gallery-modal-overlay{position:fixed;inset:0;background:#000000eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.gallery-modal-overlay.closing{animation:fadeOut .2s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.gallery-modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center;animation:modalScaleIn .3s ease}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.gallery-modal-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:8px}.modal-close{position:absolute;top:-40px;right:0;background:none;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;padding:8px;transition:var(--transition);z-index:10}.modal-close:hover{color:var(--primary)}.modal-nav{position:absolute;top:50%;transform:translateY(-50%);background:#00000080;border:1px solid rgba(255,255,255,.1);color:var(--text-primary);font-size:2rem;cursor:pointer;padding:8px 14px;border-radius:8px;transition:var(--transition);line-height:1}.modal-nav:hover{background:#10b9811a;border-color:var(--primary);color:var(--primary)}.modal-nav-prev{left:-60px}.modal-nav-next{right:-60px}.modal-dots{position:absolute;bottom:-30px;left:50%;transform:translate(-50%);display:flex;gap:8px}.modal-dot{width:6px;height:6px;border-radius:50%;background:#fff3;border:none;cursor:pointer;transition:var(--transition);padding:0}.modal-dot.active{background:var(--primary)}.modal-counter{position:absolute;bottom:-30px;right:0;font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);opacity:.6}@media(max-width:768px){.modal-nav-prev{left:8px}.modal-nav-next{right:8px}.modal-close{top:8px;right:8px}}.video-modal-content{width:min(90vw,960px);max-height:90vh;flex-direction:column}.video-modal-player{width:100%;max-height:80vh;border-radius:8px;display:block;background:#000;outline:none}.project-video-preview{position:relative}.project-video-preview video.video-thumbnail{width:100%;height:180px;object-fit:cover;display:block;transition:transform .4s ease;pointer-events:none}.project-video-preview:hover video.video-thumbnail{transform:scale(1.03)}.video-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;pointer-events:none;transition:transform .2s ease}.project-video-preview:hover .video-play-btn{transform:translate(-50%,-50%) scale(1.1)}.section-divider{width:100%;max-width:80px;height:1px;margin:0 auto;background:#ffffff0d}.section-divider--none{display:none}.text-gradient{background:linear-gradient(135deg,var(--primary),#34D399);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}html{font-size:17px}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;line-height:1.8;color:var(--text-primary);background:var(--bg);margin:0;font-weight:300;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:Sora,Outfit,sans-serif;font-weight:700;letter-spacing:-.03em;color:var(--text-primary);margin-top:0;margin-bottom:.5em}h1{font-size:clamp(3.8rem,7vw,6rem)}h2{font-size:clamp(1.8rem,3.5vw,2.6rem)}h3{font-size:clamp(1.2rem,2vw,1.6rem)}.mono{font-family:JetBrains Mono,Fira Code,monospace}
