*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#000;--bg-secondary:#0a0a0a;--bg-card:#111;--bg-card-hover:#1a1a1a;--text-primary:#e5e5e5;--text-secondary:#a3a3a3;--text-muted:#525252;--accent:#fff;--accent-hover:#d4d4d4;--accent-glow:#ffffff0f;--accent-purple:#525252;--accent-purple-glow:#52525226;--border:#1f1f1f;--gradient-1:linear-gradient(135deg, #fff 0%, #737373 100%);--gradient-2:linear-gradient(135deg, #e5e5e5 0%, #a3a3a3 100%);--amber:#a3a3a3;--font-heading:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"Fira Code", "Consolas", monospace}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-heading);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent);color:var(--bg-primary)}body.custom-cursor-active,body.custom-cursor-active a,body.custom-cursor-active button{cursor:none}.navbar{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a0a0fcc;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:1rem 2rem;transition:border-color .3s,background .3s;display:flex;position:fixed;top:0;left:0;right:0}.navbar.scrolled{border-bottom-color:var(--border);background:#0a0a0ff2}.navbar-logo{font-family:var(--font-mono);color:var(--text-primary);cursor:pointer;font-size:1.4rem;font-weight:700}.logo-dot{color:var(--accent-purple)}.navbar-links{gap:2rem;list-style:none;display:flex}.navbar-links a{color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:color .2s;position:relative}.navbar-links a:hover{color:var(--text-primary)}.navbar-links a:after{content:"";background:var(--accent);width:0;height:2px;transition:width .3s;position:absolute;bottom:-4px;left:0}.navbar-links a:hover:after{width:100%}.menu-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:none}.menu-toggle span{background:var(--text-primary);border-radius:2px;width:24px;height:2px;transition:transform .3s,opacity .3s}.hero{z-index:1;flex-direction:column;justify-content:center;min-height:100vh;padding:6rem 2rem 4rem;display:flex;position:relative;overflow:hidden}.hero:before{content:"";z-index:-1;background:radial-gradient(circle at 30% 40%,#ffffff08 0%,#0000 50%),radial-gradient(circle at 70% 60%,#ffffff05 0%,#0000 50%);width:200%;height:200%;animation:8s ease-in-out infinite alternate heroGlow;position:absolute;top:-50%;left:-50%}@keyframes heroGlow{0%{transform:translate(0)}to{transform:translate(-2%,-2%)}}.hero-inner{grid-template-columns:1fr auto 1.8fr;align-items:center;gap:2rem;width:100%;max-width:1600px;margin:0 auto;display:grid}.hero-left{flex-direction:column;gap:1.5rem;display:flex}.hero-tag{font-family:var(--font-mono);color:var(--accent);background:var(--accent-glow);border-radius:20px;align-items:center;gap:.5rem;width:fit-content;padding:.4rem 1rem;font-size:.8rem;font-weight:500;display:inline-flex}.tag-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.hero-title{font-size:clamp(3rem,7vw,5rem);font-weight:700;line-height:1.05}.hero-firstname{color:var(--text-primary)}.hero-lastname{color:#0000;-webkit-text-stroke:2px var(--text-primary)}.hero-description{color:var(--text-secondary);max-width:500px;font-size:1.1rem;line-height:1.7}.hero-about{color:var(--text-muted);border-top:1px solid var(--border);max-width:500px;padding-top:1rem;scroll-margin-top:5rem;font-size:.95rem;line-height:1.7}.hero-buttons{flex-wrap:nowrap;gap:.75rem;display:flex}.btn-primary{background:var(--accent);color:#000;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.85rem 2rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:background .2s,transform .2s,box-shadow .2s;display:inline-flex}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 20px #ffffff1a}.btn-secondary{color:var(--text-primary);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:.5rem;padding:.85rem 2rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:border-color .2s,transform .2s;display:inline-flex}.btn-secondary:hover{border-color:var(--accent);transform:translateY(-2px)}.btn-compact{gap:.35rem;padding:.65rem 1rem;font-size:.8rem}.btn-linkedin{color:#fff;background:#0a66c2}.btn-linkedin:hover{background:#004182;box-shadow:0 4px 20px #0a66c24d}.hero-stats{flex-wrap:wrap;gap:2rem;display:flex}.stat{flex-direction:column;display:flex}.stat-number{font-family:var(--font-mono);color:var(--accent);font-size:1.5rem;font-weight:700}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:.8rem}.hero-connector{background:linear-gradient(to bottom, transparent, var(--border), transparent);align-self:center;width:1px;height:300px}.hero-right{flex-direction:row;gap:.75rem;display:flex}.panel-preview{border:1px solid #ffffff0a;border-radius:6px;margin-bottom:.75rem;overflow:hidden}.panel-preview svg{width:100%;height:auto;display:block}.panel-preview-img{object-fit:cover;object-position:center;width:100%;height:150px;display:block}.hero-panel-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex:1 1 0;min-width:0;padding:1rem;transition:border-color .3s,box-shadow .3s,transform .3s}.hero-panel-card:hover{border-color:var(--accent);box-shadow:0 0 30px var(--accent-glow);transform:translateY(-4px)}.hero-panel-card--business{background:linear-gradient(145deg, #eab3080f, var(--bg-card));border-color:#eab3084d}.hero-panel-card--business:hover{border-color:#eab30899;box-shadow:0 0 30px #eab30826}.business-badge{color:#eab308;background:#eab3081a;border:1px solid #eab30833}.panel-badge{font-family:var(--font-mono);border-radius:20px;align-items:center;gap:.4rem;margin-bottom:.75rem;padding:.25rem .6rem;font-size:.7rem;font-weight:600;display:inline-flex}.green-badge{color:var(--text-secondary);background:#ffffff0f}.badge-dot{background:var(--text-secondary);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}.wip-badge{color:var(--text-muted);background:#ffffff0a}.amber-dot{background:var(--text-muted)}.panel-title{margin-bottom:.4rem;font-size:1.05rem;font-weight:700}.panel-desc{color:var(--text-secondary);margin-bottom:.6rem;font-size:.8rem;line-height:1.5}.panel-tags{flex-wrap:wrap;gap:.5rem;display:flex}.panel-tag{font-family:var(--font-mono);color:var(--accent);background:var(--accent-glow);border-radius:4px;padding:.25rem .6rem;font-size:.7rem}.panel-links{align-items:center;gap:1rem;margin-top:.75rem;display:flex}.panel-site-link{color:var(--text-secondary);align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;transition:color .2s;display:inline-flex}.panel-site-link:hover{color:var(--text-primary)}.panel-view-link{color:var(--accent);align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;transition:gap .2s;display:inline-flex}.hero-panel-card:hover .panel-view-link{gap:.7rem}.wip-progress{background:var(--bg-primary);border-radius:3px;width:100%;height:6px;margin-bottom:.4rem;overflow:hidden}.wip-progress-bar{background:linear-gradient(90deg,#525252,#a3a3a3);border-radius:3px;height:100%;transition:width 1s}.wip-progress-label{font-family:var(--font-mono);color:var(--text-muted);font-size:.7rem}.scroll-indicator{flex-direction:column;align-items:center;gap:.5rem;display:flex;position:absolute;bottom:2rem;left:2rem}.scroll-text{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;writing-mode:vertical-rl;font-size:.7rem}.scroll-line{background:var(--text-muted);width:1px;height:40px;animation:2s ease-in-out infinite scrollPulse}@keyframes scrollPulse{0%,to{opacity:.3;height:40px}50%{opacity:1;height:60px}}.section{z-index:1;max-width:1100px;margin:0 auto;padding:6rem 2rem;position:relative}.section-container{max-width:1100px;margin:0 auto}.section-header{align-items:center;gap:1rem;margin-bottom:3rem;display:flex}.section-number{font-family:var(--font-mono);color:var(--accent);font-size:1rem;font-weight:600}.section-header-title{white-space:nowrap;font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700}.section-header-line{background:var(--border);flex:1;height:1px}.projects-section{background:var(--bg-secondary);z-index:1;max-width:100%;padding:6rem 2rem;position:relative}.marquee-wrapper{width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 5% 95%,#0000);mask-image:linear-gradient(90deg,#0000,#000 5% 95%,#0000)}.marquee-track{gap:1.5rem;width:max-content;animation:30s linear infinite marqueeScroll;display:flex}.marquee-wrapper:hover .marquee-track{animation-play-state:paused}@keyframes marqueeScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-shrink:0;width:360px;transition:transform .3s,border-color .3s,box-shadow .3s;overflow:hidden}.project-card:hover{border-color:var(--accent);box-shadow:0 8px 40px var(--accent-glow);transform:translateY(-4px)}.project-image-wrapper{height:220px;position:relative;overflow:hidden}.project-image{object-fit:cover;object-position:top;width:100%;height:100%;display:block}.project-image-overlay{background:linear-gradient(to top, var(--bg-card), transparent);pointer-events:none;height:60%;position:absolute;bottom:0;left:0;right:0}.project-card-body{padding:1.5rem}.project-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.project-tag{font-family:var(--font-mono);color:var(--accent);background:var(--accent-glow);border-radius:4px;padding:.25rem .6rem;font-size:.7rem;font-weight:500}.project-card h3{margin-bottom:.5rem;font-size:1.15rem;font-weight:700}.project-card p{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem;line-height:1.6}.project-view-link{color:var(--accent);align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;transition:gap .2s;display:inline-flex}.project-view-link:hover{gap:.7rem}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;background:#000000d9;justify-content:center;align-items:center;padding:2rem;animation:.2s modalFadeIn;display:flex;position:fixed;inset:0}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:580px;max-height:85vh;animation:.25s modalSlideIn;position:relative;overflow-y:auto}.modal-close{border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;z-index:2;background:#0009;border-radius:50%;justify-content:center;align-items:center;transition:border-color .2s,color .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{border-color:var(--text-primary);color:var(--text-primary)}.modal-image{background:#0a0a0a;border-radius:16px 16px 0 0;width:100%;overflow:hidden}.modal-image img{object-fit:contain;width:100%;max-height:400px;display:block}.modal-body{padding:1.75rem}.modal-body .project-tags{margin-bottom:.75rem}.modal-body h2{margin:.5rem 0 .75rem;font-size:1.5rem;font-weight:700}.modal-body>p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.95rem;line-height:1.7}.modal-features{flex-direction:column;gap:.6rem;margin:0 0 1.5rem;padding:0;list-style:none;display:flex}.modal-features li{color:var(--text-secondary);padding-left:1.25rem;font-size:.9rem;line-height:1.5;position:relative}.modal-features li:before{content:"";background:var(--text-muted);border-radius:50%;width:6px;height:6px;position:absolute;top:.55em;left:0}.modal-body .btn-primary{justify-content:center;width:100%}.modal-videos{flex-direction:column;gap:1rem;margin-bottom:1.5rem;display:flex}.modal-video{border:1px solid var(--border);border-radius:8px;width:100%}.modal-content::-webkit-scrollbar{width:4px}.modal-content::-webkit-scrollbar-track{background:0 0}.modal-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@media (width<=768px){.modal-overlay{align-items:flex-end;padding:1rem}.modal-content{border-radius:16px 16px 0 0;max-height:90vh}}.skills-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.skills-category{flex-direction:column;gap:1rem;display:flex}.skills-category-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-size:.8rem;font-weight:600}.skills-tags{flex-wrap:wrap;gap:.6rem;display:flex}.skill-chip{border:1px solid var(--border);background:var(--bg-card);cursor:default;border-radius:8px;align-items:center;gap:.4rem;padding:.5rem 1rem;transition:border-color .2s,background .2s,opacity .2s;display:inline-flex;position:relative}.skill-chip:hover,.skill-chip--active{border-color:var(--accent);background:#ffffff0f}.skill-chip--dimmed{opacity:.3}.skill-chip__name{font-family:var(--font-mono);color:var(--text-secondary);font-size:.8rem;font-weight:500;transition:color .2s}.skill-chip:hover .skill-chip__name,.skill-chip--active .skill-chip__name{color:var(--text-primary)}.skill-chip__count{font-family:var(--font-mono);color:var(--accent);background:var(--accent-glow);border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;font-weight:600;display:flex}.skill-tooltip{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;font-family:var(--font-mono);color:#a3a3a3;z-index:20;pointer-events:none;background:#111111f2;border:1px solid #ffffff1a;border-radius:6px;padding:.4rem .75rem;font-size:.7rem;animation:.15s skill-tooltip-in;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}@keyframes skill-tooltip-in{0%{opacity:0;transform:translate(-50%)translateY(4px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (width<=768px){.skills-grid{grid-template-columns:1fr}}.contact-section{background:var(--bg-secondary);z-index:1;max-width:100%;padding:6rem 2rem;position:relative}.contact-section .section-container{max-width:600px}.contact-wrapper{text-align:center}.contact-text{color:var(--text-secondary);margin-bottom:2rem;font-size:1.05rem;line-height:1.7}.contact-email-btn{margin-bottom:2rem}.contact-socials{justify-content:center;gap:1rem;display:flex}.social-circle{border:1px solid var(--border);width:48px;height:48px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;transition:border-color .2s,color .2s,transform .2s,box-shadow .2s;display:flex}.social-circle:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 20px var(--accent-glow);transform:translateY(-2px)}.footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);z-index:1;padding:2rem;font-size:.85rem;position:relative}.fade-in{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.fade-in.visible{opacity:1;transform:translateY(0)}@media (width<=1024px){.hero-inner{text-align:center;grid-template-columns:1fr}.hero-connector{display:none}.hero-left{align-items:center}.hero-about,.hero-description{margin-left:auto;margin-right:auto}.hero-stats{justify-content:center}.hero-buttons{flex-wrap:wrap;justify-content:center}.hero-right{grid-template-columns:1fr 1fr;display:grid}.hero-panel-card{min-width:0}.scroll-indicator{display:none}}@media (width<=768px){.navbar{padding:.75rem 1.25rem}.navbar-links{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-direction:column;gap:1rem;padding:1.5rem 2rem;display:none;position:absolute;top:100%;left:0;right:0}.navbar-links.open,.menu-toggle{display:flex}.hero{min-height:auto;padding:5rem 1.25rem 3rem}.hero-title{font-size:clamp(2.5rem,12vw,3.5rem)}.hero-description{font-size:1rem}.hero-buttons{flex-wrap:wrap;gap:.5rem}.btn-primary{padding:.75rem 1.5rem;font-size:.9rem}.btn-compact{padding:.6rem .85rem;font-size:.75rem}.hero-about{font-size:.9rem}.hero-right{grid-template-columns:1fr;gap:.75rem}.hero-panel-card{min-width:0;padding:1.25rem}.panel-preview-img{height:160px}.panel-title{font-size:1.1rem}.panel-desc{font-size:.85rem}.section,.projects-section,.contact-section{padding:3.5rem 1.25rem}.section-header{margin-bottom:2rem}.project-card{width:280px}.project-image-wrapper{height:170px}.project-card-body{padding:1.25rem}.project-card h3{font-size:1.05rem}.project-card p{font-size:.85rem}.modal-overlay{align-items:flex-end;padding:0}.modal-content{border-radius:16px 16px 0 0;max-height:92vh}.modal-body{padding:1.25rem}.modal-body h2{font-size:1.25rem}.skills-grid{grid-template-columns:1fr;gap:1.5rem}.skill-chip{padding:.4rem .75rem}.skill-chip__name{font-size:.75rem}.contact-wrapper{padding:0}.contact-text{font-size:.95rem}.contact-email-btn{justify-content:center;width:100%}}@media (width<=480px){.hero{padding:4.5rem 1rem 2.5rem}.hero-title{font-size:2.5rem}.hero-description{font-size:.9rem}.hero-buttons{width:100%}.hero-buttons .btn-primary{justify-content:center;width:100%}.hero-buttons .btn-compact{flex:1;justify-content:center}.hero-stats{gap:1rem}.stat-number{font-size:1.2rem}.panel-preview-img{height:140px}.project-card{width:250px}.project-image-wrapper{height:150px}.section-header-title{font-size:1.5rem}.modal-image img{max-height:250px}}.cursor-dot{background:var(--accent);pointer-events:none;z-index:9999;will-change:transform;border-radius:50%;width:8px;height:8px;position:fixed;top:-4px;left:-4px}.cursor-ring{border:1.5px solid var(--accent);pointer-events:none;z-index:9998;opacity:.5;will-change:transform;border-radius:50%;width:40px;height:40px;position:fixed;top:-20px;left:-20px}.circuit-bg{z-index:0;pointer-events:none;width:100vw;height:100vh;position:fixed;top:0;left:0}
