body{-moz-osx-font-smoothing:grayscale;color:#ffffffeb}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0a0a0a}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#00ff884d}::selection{background:#0f83;color:#fff}:root{--bg:#0a0a0a;--bg-2:#0d0d0d;--surface:#ffffff08;--surface-2:hsla(0,0%,100%,.055);--border:#ffffff12;--border-hover:#ffffff29;--green:#0f8;--blue:#0af;--green-dim:#00ff881f;--blue-dim:#00aaff1f;--text-1:#ffffffed;--text-2:#ffffff8c;--text-3:#ffffff47;--font-display:"Syne",sans-serif;--font-body:"Outfit",sans-serif;--font-mono:"DM Mono",monospace;--radius:16px;--radius-sm:8px;--ease:cubic-bezier(0.4,0,0.2,1);--ease-out:cubic-bezier(0.16,1,0.3,1);--ease-bounce:cubic-bezier(0.34,1.56,0.64,1);--nav-h:72px;--section-pad:clamp(80px,12vw,140px)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;background:#0a0a0a;background:var(--bg);color:#ffffffed;color:var(--text-1);font-family:Outfit,sans-serif;font-family:var(--font-body);overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}img{display:block;max-width:100%}.app{min-height:100vh}.app,.section{position:relative}.section{padding:clamp(80px,12vw,140px) clamp(16px,6vw,80px);padding:var(--section-pad) clamp(16px,6vw,80px);z-index:1}.section-inner{margin:0 auto;max-width:1160px}.section-label{align-items:center;color:#ffffff47;color:var(--text-3);display:flex;font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:11px;gap:12px;letter-spacing:.18em;margin-bottom:20px;text-transform:uppercase}.section-label:before{background:linear-gradient(90deg,#0000,#0f8);background:linear-gradient(90deg,#0000,var(--green));content:"";height:1px;width:28px}.section-label span{color:#0f8;color:var(--green)}.section-title{color:#ffffffed;color:var(--text-1);font-family:Syne,sans-serif;font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;letter-spacing:-.03em;line-height:1.05;margin-bottom:16px}.section-title .gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0f8,#0af);background:linear-gradient(135deg,var(--green),var(--blue));-webkit-background-clip:text;background-clip:text}.section-desc{color:#ffffff8c;color:var(--text-2);font-size:clamp(.95rem,2vw,1.05rem);line-height:1.75;margin-bottom:60px;max-width:520px}.glass-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff08;background:var(--surface);border:1px solid #ffffff12;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius);transition:border-color .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1),background .3s cubic-bezier(.4,0,.2,1);transition:border-color .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease)}.glass-card:hover{background:hsla(0,0%,100%,.055);background:var(--surface-2);border-color:#ffffff29;border-color:var(--border-hover);box-shadow:0 20px 60px #00000040}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0f8,#0af);background:linear-gradient(135deg,var(--green),var(--blue));-webkit-background-clip:text;background-clip:text}.btn-primary{align-items:center;background:linear-gradient(135deg,#0f8,#0af);background:linear-gradient(135deg,var(--green),var(--blue));border:none;border-radius:100px;color:#000;display:inline-flex;font-family:Outfit,sans-serif;font-family:var(--font-body);font-size:.88rem;font-weight:600;gap:8px;padding:12px 26px;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s cubic-bezier(.4,0,.2,1);transition:transform .25s var(--ease-bounce),box-shadow .25s var(--ease)}.btn-primary:hover{box-shadow:0 12px 32px #00ff884d;transform:translateY(-3px)}.btn-secondary{align-items:center;background:#0000;border:1px solid #ffffff12;border:1px solid var(--border);border-radius:100px;color:#ffffff8c;color:var(--text-2);display:inline-flex;font-family:Outfit,sans-serif;font-family:var(--font-body);font-size:.88rem;font-weight:500;gap:8px;padding:12px 26px;transition:all .25s cubic-bezier(.4,0,.2,1);transition:all .25s var(--ease)}.btn-secondary:hover{border-color:#0f8;border-color:var(--green);color:#0f8;color:var(--green);transform:translateY(-2px)}.dot-pulse{animation:dotPulse 2.5s ease-in-out infinite;background:#0f8;background:var(--green);border-radius:50%;display:inline-block;height:7px;width:7px}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.6)}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;transition-duration:.01ms!important}}.nav{border-bottom:1px solid #0000;height:var(--nav-h);left:0;padding:0 clamp(16px,5vw,60px);position:fixed;right:0;top:0;transition:background .4s var(--ease),border-color .4s var(--ease),-webkit-backdrop-filter .4s var(--ease);transition:background .4s var(--ease),border-color .4s var(--ease),backdrop-filter .4s var(--ease);transition:background .4s var(--ease),border-color .4s var(--ease),backdrop-filter .4s var(--ease),-webkit-backdrop-filter .4s var(--ease);z-index:100}.nav.scrolled{-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#0a0a0ad9;border-bottom-color:var(--border)}.nav-inner{gap:40px;height:100%;margin:0 auto;max-width:1200px}.nav-inner,.nav-logo{align-items:center;display:flex}.nav-logo{background:none;border:none;color:var(--text-1);cursor:pointer;flex-shrink:0;font-family:var(--font-mono);font-size:1rem;font-weight:500;gap:4px;transition:color .2s}.logo-bracket,.nav-logo:hover .logo-name{color:var(--green)}.logo-bracket{font-size:1.1rem}.logo-name{letter-spacing:.05em}.logo-dot{margin-left:6px}.nav-links{align-items:center;display:flex;flex:1 1;gap:4px;justify-content:center;list-style:none}@media (max-width:900px){.nav-links{display:none}}.nav-link{background:none;border:none;border-radius:100px;color:var(--text-2);cursor:pointer;font-family:var(--font-body);font-size:.85rem;padding:6px 14px;position:relative;transition:color .2s,background .2s;white-space:nowrap}.nav-link:hover{background:var(--surface)}.nav-link.active,.nav-link:hover{color:var(--text-1)}.nav-link-indicator{background:linear-gradient(90deg,var(--green),var(--blue));border-radius:2px;bottom:2px;height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:width .3s var(--ease-out);width:0}.nav-link.active .nav-link-indicator{width:20px}.nav-cta{flex-shrink:0;font-size:.82rem;padding:9px 20px}@media (max-width:900px){.nav-cta{display:none}}.nav-burger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;margin-left:auto;padding:8px}@media (max-width:900px){.nav-burger{display:flex}}.nav-burger span{background:var(--text-1);border-radius:2px;display:block;height:1.5px;transform-origin:center;transition:transform .3s var(--ease),opacity .3s var(--ease);width:22px}.nav-burger.open span:first-child{transform:translateY(6.5px) rotate(45deg)}.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.mobile-menu{inset:0;pointer-events:none;position:fixed;z-index:99}.mobile-menu.open{pointer-events:all}.mobile-menu-bg{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;inset:0;opacity:0;position:absolute;transition:opacity .3s var(--ease)}.mobile-menu.open .mobile-menu-bg{opacity:1}.mobile-menu-panel{background:#111;border-left:1px solid var(--border);bottom:0;display:flex;flex-direction:column;gap:32px;padding:100px 32px 40px;position:absolute;right:0;top:0;transform:translateX(100%);transition:transform .4s var(--ease-out);width:min(320px,85vw)}.mobile-menu.open .mobile-menu-panel{transform:translateX(0)}.mobile-menu-panel ul{display:flex;flex-direction:column;gap:4px;list-style:none}.mobile-menu-panel li{opacity:0;transform:translateX(20px);transition:opacity .3s var(--ease-out) calc(var(--i)*50ms + .1s),transform .3s var(--ease-out) calc(var(--i)*50ms + .1s)}.mobile-menu.open .mobile-menu-panel li{opacity:1;transform:translateX(0)}.mobile-link{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-2);cursor:pointer;display:flex;font-family:var(--font-body);font-size:1.05rem;gap:14px;padding:12px 16px;text-align:left;transition:color .2s,background .2s;width:100%}.mobile-link.active,.mobile-link:hover{background:var(--surface);color:var(--text-1)}.mobile-link-icon,.mobile-link.active{color:var(--green)}.mobile-link-icon{font-size:14px;text-align:center;width:20px}.mobile-cta{font-size:.8rem;justify-content:center;width:100%;word-break:break-all}.hero-section{align-items:center;display:flex;min-height:100vh;overflow:hidden;padding-bottom:80px;padding-top:calc(var(--nav-h) + 40px)}.hero-orbs{inset:0;transition:transform .8s cubic-bezier(.4,0,.2,1)}.hero-orb,.hero-orbs{pointer-events:none;position:absolute}.hero-orb{border-radius:50%;filter:blur(100px)}.hero-orb-1{animation:orbDrift1 18s ease-in-out infinite;background:radial-gradient(circle,#00ff8824,#0000 70%);height:700px;left:-150px;top:-200px;width:700px}.hero-orb-2{animation:orbDrift2 22s ease-in-out infinite;background:radial-gradient(circle,#00aaff1f,#0000 70%);bottom:-100px;height:500px;right:-50px;width:500px}@keyframes orbDrift1{0%,to{transform:translate(0)}50%{transform:translate(40px,-60px)}}@keyframes orbDrift2{0%,to{transform:translate(0)}50%{transform:translate(-30px,40px)}}.hero-content{max-width:760px;opacity:0;position:relative;transform:translateY(40px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out);z-index:1}.hero-content.visible{opacity:1;transform:translateY(0)}.hero-eyebrow{align-items:center;animation:fadeSlideUp .7s var(--ease-out) .2s both;background:#00ff880f;border:1px solid #00ff8840;border-radius:100px;color:var(--green);display:inline-flex;font-family:var(--font-mono);font-size:.75rem;gap:10px;letter-spacing:.05em;margin-bottom:32px;padding:8px 16px}.hero-name{display:flex;flex-direction:column;font-family:var(--font-display);font-size:clamp(4rem,10vw,8rem);font-weight:800;letter-spacing:-.04em;line-height:.95;margin-bottom:24px}.hero-name-line{animation:fadeSlideUp .8s var(--ease-out) .3s both;display:block}.hero-name-accent{animation-delay:.45s}.hero-role{animation:fadeSlideUp .7s var(--ease-out) .6s both;color:var(--text-2);font-family:var(--font-mono);font-size:clamp(1rem,2.5vw,1.25rem);margin-bottom:28px;min-height:2em}.hero-role-text{color:var(--blue)}.hero-cursor{animation:blink 1s step-end infinite;color:var(--green);display:inline-block;margin-left:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-desc{animation:fadeSlideUp .7s var(--ease-out) .7s both;color:var(--text-2);font-size:clamp(.95rem,2vw,1.05rem);line-height:1.8;margin-bottom:40px;max-width:600px}.hero-desc strong{color:var(--text-1);font-weight:600}.hero-actions{animation:fadeSlideUp .7s var(--ease-out) .85s both;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:36px}.hero-socials{animation:fadeSlideUp .7s var(--ease-out) .95s both;display:flex;gap:8px;margin-bottom:64px}.hero-social{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:50%;color:var(--text-2);display:flex;height:40px;justify-content:center;transition:color .2s,border-color .2s,background .2s,transform .2s var(--ease-bounce);width:40px}.hero-social:hover{background:#00ff8814;border-color:#0f86;color:var(--green);transform:translateY(-3px)}.hero-scroll{align-items:center;animation:fadeSlideUp .7s var(--ease-out) 1.1s both;background:none;border:none;color:var(--text-3);cursor:pointer;display:flex;flex-direction:column;gap:8px;transition:color .2s}.hero-scroll:hover{color:var(--text-2)}.scroll-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase}.scroll-line{background:linear-gradient(180deg,var(--border),#0000);height:40px;overflow:hidden;position:relative;width:1px}.scroll-dot{animation:scrollDrop 2s ease-in-out infinite;background:var(--green);height:12px;position:absolute;top:-12px;width:1px}@keyframes scrollDrop{0%{opacity:0;top:-12px}20%{opacity:1}80%{opacity:1}to{opacity:0;top:40px}}.hero-badges{display:flex;flex-direction:column;gap:16px;opacity:0;pointer-events:none;position:absolute;right:clamp(0px,5vw,60px);top:50%;transform:translateY(-50%);transition:opacity 1s var(--ease-out) 1.2s}.hero-badges.visible{opacity:1;pointer-events:all}@media (max-width:1024px){.hero-badges{display:none}}.hero-badge{align-items:center;animation:badgeFloat 6s ease-in-out infinite;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius);display:flex;gap:12px;padding:14px 18px;white-space:nowrap}.badge-1{animation-delay:0s}.badge-2{animation-delay:-2s}.badge-3{animation-delay:-4s}@keyframes badgeFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.badge-icon{font-size:1.4rem}.badge-title{color:var(--text-1);font-size:.82rem;font-weight:600}.badge-sub{color:var(--text-3);font-family:var(--font-mono);font-size:.7rem}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.about-inner{grid-gap:64px;align-items:start;display:grid;gap:64px;grid-template-columns:1fr 1fr;opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.about-inner.visible{opacity:1;transform:translateY(0)}@media (max-width:900px){.about-inner{gap:40px;grid-template-columns:1fr}}.about-text{color:var(--text-2);font-size:.97rem;line-height:1.85;margin-bottom:20px}.about-text strong{color:var(--text-1);font-weight:600}.about-langs{margin-top:40px}.about-sub-title{color:var(--text-3);font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}.about-sub-title,.lang-row{margin-bottom:16px}.lang-header{display:flex;justify-content:space-between;margin-bottom:6px}.lang-name{color:var(--text-1);font-size:.9rem;font-weight:500}.lang-level{color:var(--green);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em}.lang-bar{background:var(--surface-2);border-radius:4px;height:4px;overflow:hidden}.lang-fill{background:linear-gradient(90deg,var(--green),var(--blue));border-radius:4px;height:100%;transition:width 1.2s var(--ease-out) 0s;transition:width 1.2s var(--ease-out) var(--transitionDelay,0s);width:0}.about-inner.visible .lang-fill{width:var(--pct)}.about-right{display:flex;flex-direction:column;gap:16px}.about-card{padding:24px}.about-card-title{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:20px}.passions-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.passion-item{align-items:center;background:var(--surface);border-radius:var(--radius-sm);color:var(--text-2);display:flex;font-size:.85rem;gap:10px;padding:10px 12px;transition:background .2s,color .2s}.passion-item:hover{background:var(--surface-2);color:var(--text-1)}.passion-icon{font-size:1.1rem}.qualities-list{display:flex;flex-direction:column;gap:8px}.quality-item{align-items:center;border-bottom:1px solid var(--border);color:var(--text-2);display:flex;font-size:.88rem;gap:12px;padding:6px 0}.quality-item:last-child{border-bottom:none}.quality-check{color:var(--green);flex-shrink:0;font-family:var(--font-mono);font-size:.8rem;width:20px}.info-row{align-items:center;border-bottom:1px solid var(--border);color:var(--text-2);display:flex;font-size:.88rem;gap:12px;padding:8px 0}.info-row:last-child{border-bottom:none}.info-row a{color:var(--text-2);transition:color .2s}.info-row a:hover{color:var(--green)}.info-icon{font-size:1rem;text-align:center;width:24px}.skills-section .section-inner{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.skills-section .section-inner.visible{opacity:1;transform:translateY(0)}.skills-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:60px}.skill-group{opacity:0;padding:28px;transform:translateY(20px);transition:opacity .6s var(--ease-out) 0ms,transform .6s var(--ease-out) 0ms,border-color .3s var(--ease),box-shadow .3s var(--ease);transition:opacity .6s var(--ease-out) var(--delay,0ms),transform .6s var(--ease-out) var(--delay,0ms),border-color .3s var(--ease),box-shadow .3s var(--ease)}.visible .skill-group{opacity:1;transform:translateY(0)}.skill-group:hover{border-color:color-mix(in srgb,var(--group-color) 30%,#0000)!important;box-shadow:0 0 40px color-mix(in srgb,var(--group-color) 8%,#0000)!important}.skill-group-header{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:12px;margin-bottom:24px;padding-bottom:16px}.skill-group-icon{font-size:1.2rem}.skill-group-title{color:var(--text-1);font-family:var(--font-display);font-size:1rem;font-weight:700}.skill-bars{display:flex;flex-direction:column;gap:14px}.skill-bar-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.skill-bar-name{color:var(--text-2);font-size:.85rem}.skill-bar-pct{color:var(--green);color:var(--group-color,var(--green));font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em}.skill-bar-track{background:var(--surface-2);border-radius:4px;height:4px;overflow:hidden}.skill-bar-fill{background:linear-gradient(90deg,var(--green),color-mix(in srgb,var(--group-color) 60%,var(--blue)));background:linear-gradient(90deg,var(--group-color,var(--green)),color-mix(in srgb,var(--group-color) 60%,var(--blue)));border-radius:4px;height:100%;transition:width 1s var(--ease-out) 0ms;transition:width 1s var(--ease-out) var(--transitionDelay,0ms);width:0}.visible .skill-bar-fill{width:var(--level)}.tech-cloud{text-align:center}.tech-cloud-label{color:var(--text-3);font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;margin-bottom:20px;text-transform:uppercase}.tech-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.tech-tag{background:var(--surface);border:1px solid var(--border);border-radius:100px;color:var(--text-2);cursor:default;font-family:var(--font-mono);font-size:.78rem;opacity:0;padding:6px 14px;transform:scale(.9);transition:opacity .4s var(--ease-out) calc(var(--ti)*25ms + .3s),transform .4s var(--ease-bounce) calc(var(--ti)*25ms + .3s),border-color .2s,color .2s,background .2s}.visible .tech-tag{opacity:1;transform:scale(1)}.tech-tag:hover{background:#00ff880f;border-color:#00ff8859;color:var(--green)}.projects-section .section-inner{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.projects-section .section-inner.visible{opacity:1;transform:translateY(0)}.proj-filters{background:var(--surface);border:1px solid var(--border);border-radius:100px;display:flex;gap:4px;margin-bottom:40px;padding:4px;position:relative;width:fit-content}.proj-filter-indicator{background:linear-gradient(135deg,#00ff8826,#00aaff26);border:1px solid #00ff8840;border-radius:100px;height:calc(100% - 8px);pointer-events:none;position:absolute;top:4px;transition:left .35s var(--ease),width .35s var(--ease)}.proj-filter-btn{align-items:center;background:none;border:none;border-radius:100px;color:var(--text-3);cursor:pointer;display:flex;font-size:.82rem;gap:6px;padding:8px 16px;position:relative;transition:color .2s;white-space:nowrap}.proj-filter-btn:hover{color:var(--text-2)}.proj-filter-btn.active{color:var(--text-1)}.proj-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.proj-card-wrapper{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease-out) 0ms,transform .6s var(--ease-out) 0ms;transition:opacity .6s var(--ease-out) var(--delay,0ms),transform .6s var(--ease-out) var(--delay,0ms)}.proj-card-wrapper.revealed{opacity:1;transform:translateY(0)}@media (min-width:1024px){.proj-card-wrapper.featured:first-child{grid-column:span 2}}.proj-card{cursor:pointer;display:flex;flex-direction:column;gap:14px;height:100%;overflow:hidden;padding:24px;position:relative;transition:border-color .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease)!important;will-change:transform}.proj-card.hovered{border-color:var(--border-hover)!important}.proj-card:focus-visible{outline:2px solid var(--green);outline-offset:2px}.proj-card-glow{background:radial-gradient(400px circle at 50% 50%,#00ff880a,#0000 60%);background:radial-gradient(400px circle at var(--mx,50%) var(--my,50%),#00ff880a,#0000 60%);inset:0;pointer-events:none;position:absolute}.proj-card-top{align-items:center;display:flex;justify-content:space-between}.proj-year{color:var(--text-3);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em}.proj-status{align-items:center;color:var(--green);color:var(--status-color,var(--green));display:flex;font-size:.7rem;gap:5px}.proj-status-dot{animation:dotPulse 2.5s ease-in-out infinite;background:currentColor;border-radius:50%;height:5px;width:5px}.proj-visual{justify-content:space-between}.proj-icon-ring,.proj-visual{align-items:center;display:flex}.proj-icon-ring{background:linear-gradient(135deg,color-mix(in srgb,var(--card-color) 15%,#0000),color-mix(in srgb,var(--card-accent) 10%,#0000));border:1px solid color-mix(in srgb,var(--card-color) 25%,#0000);border-radius:12px;height:48px;justify-content:center;transition:transform .4s var(--ease-bounce);width:48px}.proj-card.hovered .proj-icon-ring{transform:scale(1.1) rotate(6deg)}.proj-icon{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--card-color),var(--card-accent));-webkit-background-clip:text;background-clip:text;font-size:20px}.proj-featured{background:#00ff880f;border:1px solid #00ff8840;border-radius:100px;color:var(--green);font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;padding:3px 10px;text-transform:uppercase}.proj-content{flex:1 1}.proj-subtitle{color:var(--text-3);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;margin-bottom:4px;text-transform:uppercase}.proj-title{color:var(--text-1);font-family:var(--font-display);font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin-bottom:10px;transition:color .3s}.proj-card.hovered .proj-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--card-color),var(--card-accent));-webkit-background-clip:text;background-clip:text}.proj-desc{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:var(--text-2);display:-webkit-box;font-size:.85rem;line-height:1.65;overflow:hidden}.proj-tags{display:flex;flex-wrap:wrap;gap:5px}.proj-tag{background:var(--surface);border:1px solid var(--border);border-radius:100px;color:var(--text-3);font-family:var(--font-mono);font-size:.68rem;padding:3px 9px;transition:border-color .2s,color .2s}.proj-card.hovered .proj-tag{border-color:color-mix(in srgb,var(--card-color) 25%,#0000);color:var(--text-2)}.proj-metrics{grid-gap:1px;background:var(--border);border-radius:var(--radius-sm);display:grid;gap:1px;grid-template-columns:repeat(3,1fr);overflow:hidden}.proj-metric{align-items:center;background:var(--bg);display:flex;flex-direction:column;gap:2px;padding:8px}.proj-metric-val{color:var(--text-1);font-family:var(--font-mono);font-size:.82rem;font-weight:600}.proj-metric-label{color:var(--text-3);font-size:.62rem;text-align:center}.proj-cta{align-items:center;color:var(--green);color:var(--card-color,var(--green));display:flex;font-size:.78rem;justify-content:space-between;opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s}.proj-card.hovered .proj-cta{opacity:1;transform:translateY(0)}.proj-border-line{background:linear-gradient(90deg,var(--card-color),var(--card-accent));bottom:0;height:2px;left:0;position:absolute;transition:width .5s var(--ease);width:0}.proj-card.hovered .proj-border-line{width:100%}.proj-modal-overlay{align-items:flex-end;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000bf;display:flex;inset:0;justify-content:center;opacity:0;position:fixed;transition:opacity .3s var(--ease);z-index:200}.proj-modal-overlay.visible{opacity:1}@media (min-width:640px){.proj-modal-overlay{align-items:center;padding:24px}}.proj-modal{background:#111;border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;max-height:85vh;max-width:560px;overflow:hidden;position:relative;transform:translateY(40px);transition:transform .35s var(--ease-out);width:100%}.proj-modal-overlay.visible .proj-modal{transform:translateY(0)}@media (min-width:640px){.proj-modal{border-radius:var(--radius)}}.proj-modal:before{background:linear-gradient(90deg,var(--card-color),var(--card-accent));content:"";height:2px;left:0;position:absolute;right:0;top:0}.proj-modal-scroll{max-height:85vh;overflow-y:auto;padding:40px 32px}.proj-modal-close{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:50%;color:var(--text-2);cursor:pointer;display:flex;height:34px;justify-content:center;position:absolute;right:14px;top:14px;transition:background .2s,color .2s;width:34px;z-index:10}.proj-modal-close:hover{background:var(--surface-2);color:var(--text-1)}.proj-modal-header{align-items:center;display:flex;gap:16px;margin-bottom:24px}.proj-modal-icon{align-items:center;background:linear-gradient(135deg,color-mix(in srgb,var(--card-color) 12%,#0000),color-mix(in srgb,var(--card-accent) 12%,#0000));-webkit-background-clip:text;background-clip:text;border:1px solid color-mix(in srgb,var(--card-color) 25%,#0000);border-radius:14px;display:flex;flex-shrink:0;font-size:22px;height:52px;justify-content:center;width:52px}.proj-modal-subtitle{color:var(--text-3);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;margin-bottom:4px;text-transform:uppercase}.proj-modal-title{color:var(--text-1);font-family:var(--font-display);font-size:1.6rem;font-weight:700}.proj-modal-metrics{grid-gap:1px;background:var(--border);border-radius:var(--radius-sm);display:grid;gap:1px;grid-template-columns:repeat(3,1fr);margin-bottom:24px;overflow:hidden}.proj-modal-metric{align-items:center;background:#ffffff05;display:flex;flex-direction:column;gap:4px;padding:14px 10px}.proj-modal-metric-val{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--card-color),var(--card-accent));-webkit-background-clip:text;background-clip:text;font-family:var(--font-mono);font-size:1rem;font-weight:700}.proj-modal-metric-label{color:var(--text-3);font-size:.65rem}.proj-modal-desc{color:var(--text-2);font-size:.9rem;line-height:1.75;margin-bottom:20px}.proj-modal-tags{display:flex;flex-wrap:wrap;gap:8px}.proj-modal-tag{background:var(--surface);border:1px solid var(--border);border-radius:100px;color:var(--text-2);font-family:var(--font-mono);font-size:.75rem;padding:5px 12px}.proj-modal-links{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:32px}.proj-modal-link{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text-2);display:flex;font-family:var(--font-mono);font-size:.85rem;gap:8px;padding:10px 16px;text-decoration:none;transition:all .25s var(--ease)}.proj-modal-link:hover{background:linear-gradient(135deg,color-mix(in srgb,var(--card-color) 15%,#0000),color-mix(in srgb,var(--card-accent) 10%,#0000));border-color:color-mix(in srgb,var(--card-color) 25%,#0000);color:var(--card-color);transform:translateY(-2px)}.proj-modal-carousel{margin-top:24px;position:relative}.carousel-container{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;position:relative;width:100%}.carousel-images{align-items:center;display:flex;height:300px;justify-content:center;position:relative;width:100%}.carousel-images.mobile-format{background:#0000;height:600px;margin:0 auto;max-width:320px;position:relative}.carousel-images.mobile-format:before{background:#000;border-radius:36px;box-shadow:0 0 0 8px #1a1a1a,0 0 0 10px #2a2a2a,0 8px 24px #0000004d,0 16px 48px #0003;height:100%;top:0;width:100%;z-index:0}.carousel-images.mobile-format:after,.carousel-images.mobile-format:before{content:"";left:50%;pointer-events:none;position:absolute;transform:translateX(-50%)}.carousel-images.mobile-format:after{background:#1a1a1a;border-radius:12px;height:20px;top:8px;width:100px;z-index:2}.carousel-image{height:100%;object-fit:cover;opacity:0;position:absolute;transition:opacity .5s var(--ease);width:100%}.carousel-image.active{opacity:1}.carousel-images.mobile-format .carousel-image{background:#0000!important;border-radius:32px!important;box-shadow:none!important;box-sizing:border-box!important;display:none!important;height:100%!important;object-fit:cover!important;opacity:1!important;padding:35px 4px 4px!important;position:relative!important;width:100%!important;z-index:1!important}.carousel-images.mobile-format .carousel-image.active{display:block!important;opacity:1!important}.carousel-btn{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .25s var(--ease);width:40px;z-index:10}.carousel-btn:hover{background:#000000e6;transform:translateY(-50%) scale(1.1)}.carousel-btn-prev{left:12px}.carousel-btn-next{right:12px}.carousel-dots{bottom:12px;display:flex;gap:8px;left:50%;position:absolute;transform:translateX(-50%);z-index:10}.carousel-dot{background:#fff6;border:none;border-radius:50%;cursor:pointer;height:8px;transition:all .25s var(--ease);width:8px}.carousel-dot.active{background:var(--green);background:var(--card-color,var(--green));transform:scale(1.2)}.carousel-dot:hover{background:#fff9}.experience-section .section-inner{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.experience-section .section-inner.visible{opacity:1;transform:translateY(0)}.exp-tabs{background:var(--surface);border:1px solid var(--border);border-radius:100px;display:flex;gap:4px;margin-bottom:48px;padding:4px;width:fit-content}.exp-tab{background:none;border:none;border-radius:100px;color:var(--text-2);cursor:pointer;font-family:var(--font-body);font-size:.85rem;padding:8px 20px;transition:all .25s var(--ease)}.exp-tab.active{background:linear-gradient(135deg,#00ff8826,#00aaff26);border:1px solid #00ff8840;color:var(--text-1)}.timeline{padding-left:32px;position:relative}.timeline:before{background:linear-gradient(180deg,var(--green),var(--blue) 60%,#0000);bottom:0;content:"";left:8px;opacity:.3;position:absolute;top:8px;width:1px}.timeline-item{margin-bottom:28px;opacity:0;position:relative;transform:translateX(-20px);transition:opacity .6s var(--ease-out) 0ms,transform .6s var(--ease-out) 0ms;transition:opacity .6s var(--ease-out) var(--delay,0ms),transform .6s var(--ease-out) var(--delay,0ms)}.timeline-item.revealed{opacity:1;transform:translateX(0)}.timeline-dot{align-items:center;background:var(--bg);border:2px solid var(--dot-color,var(--text-3));border-radius:50%;display:flex;height:16px;justify-content:center;left:-32px;position:absolute;top:20px;transition:transform .2s var(--ease-bounce);width:16px}.timeline-item:hover .timeline-dot{transform:scale(1.3)}.timeline-dot-inner{background:var(--text-3);background:var(--dot-color,var(--text-3));border-radius:50%;height:6px;width:6px}.timeline-card{padding:24px 28px}.timeline-card-top{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:10px}.timeline-period{color:var(--text-3);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em}.timeline-badge{align-items:center;border-radius:100px;display:flex;font-family:var(--font-mono);font-size:.68rem;gap:6px;letter-spacing:.08em;padding:3px 10px;text-transform:uppercase}.timeline-badge-current{background:#00ff8814;border:1px solid #0f83;color:var(--green)}.timeline-badge-upcoming{background:#00aaff14;border:1px solid #0af3;color:var(--blue)}.timeline-title{color:var(--text-1);font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin-bottom:4px}.timeline-company{color:var(--green);font-family:var(--font-mono);font-size:.82rem;margin-bottom:12px}.timeline-desc{color:var(--text-2);font-size:.88rem;line-height:1.7;margin-bottom:16px}.timeline-tags{display:flex;flex-wrap:wrap;gap:6px}.timeline-tag{background:var(--surface);border:1px solid var(--border);border-radius:100px;color:var(--text-3);cursor:default;font-family:var(--font-mono);font-size:.7rem;padding:3px 10px;transition:all .25s var(--ease)}.timeline-tag:hover{background:#00ff8814;border:1px solid #0f83;color:var(--green);transform:translateY(-1px)}.lab-section .section-inner{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.lab-section .section-inner.visible{opacity:1;transform:translateY(0)}.lab-banner{align-items:flex-start;background:#00aaff0a!important;border-color:#0af3!important;display:flex;gap:20px;margin-bottom:40px;padding:20px 24px}.lab-banner-icon{color:var(--blue);flex-shrink:0;font-size:1.4rem;margin-top:2px}.lab-banner-title{color:var(--text-1);font-size:.9rem;font-weight:600;margin-bottom:4px}.lab-banner-desc{color:var(--text-2);font-size:.82rem;line-height:1.65}.lab-banner-desc code{background:#00aaff1a;border-radius:4px;color:var(--blue);font-family:var(--font-mono);font-size:.78rem;padding:1px 6px}.scenes-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.scene-card{opacity:0;overflow:hidden;position:relative;transform:translateY(24px);transition:opacity .6s var(--ease-out) 0ms,transform .6s var(--ease-out) 0ms;transition:opacity .6s var(--ease-out) var(--delay,0ms),transform .6s var(--ease-out) var(--delay,0ms)}.scene-card.revealed{opacity:1;transform:translateY(0)}.scene-card:hover{border-color:color-mix(in srgb,var(--scene-color) 35%,#0000)!important;box-shadow:0 20px 60px color-mix(in srgb,var(--scene-color) 10%,#0000)!important}.scene-visual{background:#080808;border-radius:var(--radius) var(--radius) 0 0;height:180px;overflow:hidden;position:relative}.scene-canvas{display:block;height:180px;object-fit:cover;width:100%}.scene-visual-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;border:1px solid #ffffff1a;border-radius:10px;color:var(--scene-color);display:flex;font-size:14px;height:36px;justify-content:center;position:absolute;right:12px;top:12px;width:36px}.scene-content{padding:24px}.scene-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:14px}.scene-subtitle{color:var(--text-3);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;margin-bottom:4px;text-transform:uppercase}.scene-title{color:var(--text-1);font-family:var(--font-display);font-size:1.2rem;font-weight:700}.scene-id{background:color-mix(in srgb,var(--scene-color) 8%,#0000);border:1px solid color-mix(in srgb,var(--scene-color) 30%,#0000);border-radius:100px;color:var(--scene-color);flex-shrink:0;font-family:var(--font-mono);font-size:.7rem;padding:3px 10px;white-space:nowrap}.scene-desc{color:var(--text-2);font-size:.87rem;line-height:1.7;margin-bottom:20px}.scene-details{margin-bottom:0;max-height:0;overflow:hidden;transition:max-height .4s var(--ease-out)}.scene-details.open{margin-bottom:16px;max-height:300px}.scene-details-title{color:var(--text-3);font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;margin-bottom:10px;text-transform:uppercase}.scene-features{display:flex;flex-direction:column;gap:6px;list-style:none}.scene-feature{align-items:baseline;color:var(--text-2);display:flex;font-size:.83rem;gap:10px}.feature-dot{color:var(--scene-color);flex-shrink:0;font-size:10px}.scene-tech{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.scene-tech-tag{background:var(--surface);border:1px solid var(--border);border-radius:100px;color:var(--text-3);font-family:var(--font-mono);font-size:.68rem;padding:3px 10px;transition:border-color .2s,color .2s}.scene-card:hover .scene-tech-tag{border-color:color-mix(in srgb,var(--scene-color) 25%,#0000);color:var(--text-2)}.scene-expand{align-items:center;background:none;border:none;color:var(--scene-color);cursor:pointer;display:flex;font-family:var(--font-body);font-size:.8rem;gap:6px;opacity:.8;padding:0;transition:opacity .2s}.scene-expand:hover{opacity:1}.scene-border-line{background:linear-gradient(90deg,var(--scene-color),var(--blue));background:linear-gradient(90deg,var(--scene-color),var(--scene-accent,var(--blue)));bottom:0;height:2px;left:0;position:absolute;transition:width .5s var(--ease-out);width:0}.scene-card:hover .scene-border-line{width:100%}@media (max-width:768px){.scenes-grid{grid-template-columns:1fr}}.scene-canvas-wrap{border-radius:var(--radius) var(--radius) 0 0;cursor:pointer;height:280px;overflow:hidden;position:relative}.scene-canvas-wrap canvas{display:block;height:100%!important;width:100%!important}.scene-canvas-wrap.active{cursor:grab}.scene-canvas-wrap.active:active{cursor:grabbing}.scene-canvas-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000059;display:flex;flex-direction:column;gap:12px;inset:0;justify-content:center;position:absolute;transition:opacity .3s;z-index:10}.scene-play-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:100px;color:#fff;display:flex;font-family:var(--font-body);font-size:.88rem;font-weight:500;gap:8px;padding:10px 22px;transition:background .2s,border-color .2s,transform .2s var(--ease-bounce)}.scene-canvas-wrap:hover .scene-play-btn{background:#ffffff2e;border-color:#fff6;border-color:var(--scene-color,#fff6);color:#fff;color:var(--scene-color,#fff);transform:scale(1.05)}.scene-hint{color:#ffffff80;font-size:.75rem}.scene-hint,.scene-loading{font-family:var(--font-mono)}.scene-loading{align-items:center;color:var(--text-3);display:flex;flex-direction:column;font-size:.8rem;gap:12px;inset:0;justify-content:center;position:absolute}.scene-loading-ring{animation:spin .8s linear infinite;border:2px solid var(--border);border-radius:50%;border-top-color:var(--green);height:28px;width:28px}@keyframes spin{to{transform:rotate(1turn)}}.scene-id-badge{background:color-mix(in srgb,var(--scene-color) 8%,#0000);border:1px solid color-mix(in srgb,var(--scene-color) 30%,#0000);border-radius:100px;color:var(--scene-color);flex-shrink:0;font-family:var(--font-mono);font-size:.7rem;padding:3px 10px;white-space:nowrap}.dataia-section .section-inner{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.dataia-section .section-inner.visible{opacity:1;transform:translateY(0)}.dataia-viz-block{margin:52px 0 76px}.viz-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.viz-tab{background:var(--surface);border:1px solid var(--border);border-radius:100px;color:var(--text-2);cursor:pointer;font-family:var(--font-mono);font-size:.77rem;letter-spacing:.04em;padding:9px 20px;transition:all .2s var(--ease);white-space:nowrap}.viz-tab:hover{border-color:#00ff884d;color:var(--text-1)}.viz-tab.active{background:#00ff881a;border-color:#00ff8873;color:var(--green)}.viz-canvas-wrap{border-radius:var(--radius);height:400px;overflow:hidden;padding:0;position:relative;transition:height .4s var(--ease-out);width:100%}.viz-canvas-wrap.mcd-active{height:540px}.viz-slot{inset:0;position:absolute}.viz-canvas-el{display:block}.viz-live-badge{animation:livePulse 2.2s ease-in-out infinite;background:#00ff8814;border:1px solid #00ff8838;border-radius:100px;color:var(--green);font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;padding:4px 12px;pointer-events:none;position:absolute;right:14px;top:14px;z-index:3}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.4}}.viz-legend{align-items:center;bottom:13px;color:#ffffff80;display:flex;font-family:var(--font-mono);font-size:10px;gap:7px;left:14px;letter-spacing:.05em;pointer-events:none;position:absolute;z-index:3}.legend-dot{background:var(--green);border-radius:50%;box-shadow:0 0 6px var(--green);flex-shrink:0;height:6px;width:6px}.legend-sep{color:#ffffff2e}.legend-sub{color:#ffffff47}.ai-cases-header{margin-bottom:28px}.ai-cases-title{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2.1rem);font-weight:800;line-height:1.1;margin-bottom:8px}.ai-cases-sub{color:var(--text-2);font-size:.88rem}.ai-cases-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));margin-bottom:60px}.ai-case-card{opacity:0;overflow:hidden;padding:22px;position:relative;transform:translateY(18px);transition:opacity .5s var(--ease-out) 0ms,transform .5s var(--ease-out) 0ms,border-color .25s,box-shadow .25s;transition:opacity .5s var(--ease-out) var(--delay,0ms),transform .5s var(--ease-out) var(--delay,0ms),border-color .25s,box-shadow .25s}.ai-case-card.visible{opacity:1;transform:translateY(0)}.ai-case-card:hover{border-color:color-mix(in srgb,var(--color) 28%,#0000)!important;box-shadow:0 0 36px color-mix(in srgb,var(--color) 7%,#0000)!important}.ai-case-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:14px}.ai-case-icon{font-size:1.35rem;line-height:1}.ai-case-metric{text-align:right}.ai-case-metric-value{display:block;font-family:var(--font-display);font-size:1.45rem;font-weight:800;line-height:1}.ai-case-metric-label{color:var(--text-3);font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase}.ai-case-title{font-family:var(--font-display);font-size:.97rem;font-weight:700;margin-bottom:9px}.ai-case-desc{color:var(--text-2);font-size:.82rem;line-height:1.6;margin-bottom:16px}.ai-case-tags{display:flex;flex-wrap:wrap;gap:5px}.ai-case-tag{background:color-mix(in srgb,var(--color) 9%,#0000);border:1px solid color-mix(in srgb,var(--color) 22%,#0000);border-radius:100px;color:var(--color);font-family:var(--font-mono);font-size:.66rem;letter-spacing:.05em;padding:3px 9px}.ai-case-bar{background:linear-gradient(90deg,#0000,var(--color),#0000);bottom:0;height:2px;left:0;opacity:0;position:absolute;right:0;transition:opacity .3s}.ai-case-card:hover .ai-case-bar{opacity:.55}.dataia-cta{align-items:center;background:linear-gradient(135deg,#00ff880d,#00aaff08);border:1px solid #00ff8821;border-radius:var(--radius);display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;padding:28px 36px}.dataia-cta-text{font-family:var(--font-display);font-size:clamp(.95rem,2vw,1.2rem);font-weight:600}.btn-primary-dark{align-items:center;background:var(--green);border-radius:100px;color:#000;display:inline-flex;font-family:var(--font-display);font-size:.88rem;font-weight:700;gap:8px;padding:11px 22px;text-decoration:none;transition:all .2s var(--ease);white-space:nowrap}.btn-primary-dark:hover{background:#fff;box-shadow:0 8px 28px #00ff8847;transform:translateY(-2px)}@media (max-width:900px){.viz-canvas-wrap.mcd-active{height:440px}}@media (max-width:768px){.viz-canvas-wrap{height:320px}.viz-canvas-wrap.mcd-active{height:380px}.ai-cases-grid{grid-template-columns:1fr 1fr}.dataia-cta{align-items:flex-start;flex-direction:column}}@media (max-width:520px){.viz-canvas-wrap{height:260px}.viz-canvas-wrap.mcd-active{height:320px}.ai-cases-grid{grid-template-columns:1fr}.viz-tab{font-size:.71rem;padding:7px 13px}}.viz-canvas-wrap.sql-active{height:520px}.viz-canvas-wrap.ml-active{height:540px}.viz-canvas-wrap.kmeans-active{height:460px}.viz-canvas-wrap.reco-active{height:520px}@media (max-width:900px){.viz-canvas-wrap.sql-active{height:600px}.viz-canvas-wrap.ml-active{height:580px}.viz-canvas-wrap.kmeans-active{height:420px}.viz-canvas-wrap.reco-active{height:560px}}@media (max-width:768px){.viz-canvas-wrap.sql-active{height:680px}.viz-canvas-wrap.ml-active{height:640px}.viz-canvas-wrap.kmeans-active{height:380px}.viz-canvas-wrap.reco-active{height:600px}}@media (max-width:520px){.viz-canvas-wrap.sql-active{height:740px}.viz-canvas-wrap.ml-active{height:700px}.viz-canvas-wrap.kmeans-active{height:320px}.viz-canvas-wrap.reco-active{height:640px}}.lab-block{margin-bottom:0}.lab-block-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:18px}.lab-block-badge{align-items:center;background:#00ff8814;border:1px solid #00ff884d;border-radius:100px;color:var(--green);display:inline-flex;flex-shrink:0;font-family:var(--font-mono);font-size:.75rem;font-weight:700;gap:7px;letter-spacing:.08em;padding:6px 14px}.lab-block-badge--ia{background:#a064ff14;border-color:#a064ff4d;color:#a064ff}.lab-block-badge-dot{animation:livePulse 2s ease-in-out infinite;background:var(--green);border-radius:50%;box-shadow:0 0 6px var(--green);height:6px;width:6px}.lab-block-badge-dot--ia{background:#a064ff;box-shadow:0 0 6px #a064ffcc}.lab-block-desc{color:var(--text-2);font-size:.83rem;margin:0}.lab-separator{align-items:center;display:flex;gap:16px;margin:56px 0 48px}.lab-separator--cases{margin:64px 0 32px}.lab-separator-line{background:linear-gradient(90deg,#0000,#ffffff14,#0000);flex:1 1;height:1px}.lab-separator-label{align-items:center;color:#ffffff47;display:flex;font-family:var(--font-mono);font-size:.7rem;gap:10px;letter-spacing:.18em;text-transform:uppercase;white-space:nowrap}.lab-separator-icon{color:#ffffff2e;font-size:.65rem}.viz-tab-wrap{align-items:center;display:inline-flex;gap:0}.viz-tab-info{align-items:center;background:#ffffff0a;border:1px solid #ffffff24;border-radius:50%;color:#ffffff59;cursor:pointer;display:flex;flex-shrink:0;font-family:var(--font-mono);font-size:9px;font-weight:700;height:18px;justify-content:center;margin-left:4px;margin-right:4px;transition:all .2s;width:18px}.viz-tab-info:hover{background:#00ff881a;border-color:#00ff8873;color:var(--green)}.info-panel-overlay{align-items:center;animation:overlayIn .2s ease-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000059;display:flex;inset:0;justify-content:flex-end;padding:20px;position:fixed;z-index:100}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.info-panel{animation:panelIn .25s cubic-bezier(.34,1.56,.64,1);background:#070c0afa!important;border-color:var(--panel-border)!important;max-height:88vh;max-width:420px;overflow-y:auto;padding:24px;scrollbar-color:#ffffff1a #0000;scrollbar-width:thin;width:100%}@keyframes panelIn{0%{opacity:0;transform:translateX(32px)}to{opacity:1;transform:translateX(0)}}.info-panel-header{align-items:center;display:flex;gap:10px;margin-bottom:16px}.info-panel-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.info-panel-title{color:var(--text-1);flex:1 1;font-family:var(--font-display);font-size:1rem;font-weight:700;margin:0}.info-panel-close{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;color:#ffffff73;cursor:pointer;display:flex;flex-shrink:0;font-size:11px;height:28px;justify-content:center;transition:all .15s;width:28px}.info-panel-close:hover{background:#ff4b4b26;border-color:#ff4b4b4d;color:#ff4b4be6}.info-panel-desc{color:var(--text-2);font-size:.85rem;line-height:1.7;margin-bottom:20px}.info-panel-section-label{color:#ffffff47;font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;margin-bottom:12px;text-transform:uppercase}.info-panel-steps{margin-bottom:20px}.info-step{align-items:flex-start;display:flex;gap:12px;margin-bottom:12px}.info-step-num{align-items:center;border-radius:6px;display:flex;flex-shrink:0;font-size:10px;height:24px;justify-content:center;margin-top:1px;width:24px}.info-step-label,.info-step-num{font-family:var(--font-mono);font-weight:700}.info-step-label{color:var(--text-1);font-size:11px;margin-bottom:3px}.info-step-desc{color:var(--text-2);font-size:.8rem;line-height:1.6}.info-panel-limits{margin-bottom:20px}.info-panel-limits-text{background:#ff96280f;border:1px solid #ff96282e;border-radius:8px;color:#ff9628cc;font-size:.82rem;line-height:1.6;margin:0;padding:10px 12px}.info-panel-tags{display:flex;flex-wrap:wrap;gap:6px}.info-panel-tag{border-radius:100px;font-family:var(--font-mono);font-size:.7rem;padding:4px 10px}@media (max-width:768px){.lab-separator{margin:40px 0 32px}.info-panel{max-width:100%}.info-panel-overlay{align-items:flex-end;padding:12px}.info-panel{max-height:80vh}}@media (max-width:520px){.lab-block-header{gap:10px}.viz-tab-info{font-size:8px;height:16px;width:16px}}.info-panel-analogy{align-items:flex-start;border:1px solid;border-radius:10px;display:flex;gap:10px;margin-bottom:20px;padding:12px 14px}.info-panel-analogy-icon{flex-shrink:0;font-size:1.2rem;margin-top:1px}.info-panel-analogy-text{color:#d7e8e0bf;font-size:.82rem;font-style:italic;line-height:1.65;margin:0}.contact-inner{grid-gap:64px;align-items:start;display:grid;gap:64px;grid-template-columns:1fr 1fr;opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.contact-inner.visible{opacity:1;transform:translateY(0)}@media (max-width:900px){.contact-inner{gap:40px;grid-template-columns:1fr}}.contact-desc{color:var(--text-2);font-size:.97rem;line-height:1.8;margin-bottom:20px}.contact-desc strong{color:var(--text-1);font-weight:600}.contact-email-block{margin:32px 0}.contact-email-btn{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;display:flex;gap:16px;justify-content:space-between;padding:16px 20px;text-align:left;transition:border-color .2s,background .2s,box-shadow .2s;width:100%}.contact-email-btn:hover{background:#00ff880a;border-color:#0f86;box-shadow:0 0 30px #00ff8814}.contact-email-text{color:var(--text-1);font-family:var(--font-mono);font-size:.9rem;word-break:break-all}.contact-email-action{align-items:center;color:var(--green);display:flex;flex-shrink:0;font-family:var(--font-mono);font-size:.78rem;gap:6px;white-space:nowrap}.contact-alternance{background:#00ff8808!important;border-color:#00ff8826!important;padding:20px 24px}.alternance-header{align-items:center;display:flex;gap:10px;margin-bottom:16px}.alternance-title{color:var(--text-1);font-size:.88rem;font-weight:600}.alternance-details{display:flex;flex-direction:column;gap:10px}.alternance-row{align-items:flex-start;color:var(--text-2);display:flex;font-size:.85rem;gap:10px;line-height:1.5}.alternance-row strong{color:var(--text-1);font-weight:600}.alternance-icon{flex-shrink:0;font-size:1rem;margin-top:1px;width:22px}.contact-right{display:flex;flex-direction:column;gap:12px}.contact-link-card{align-items:center;border-radius:var(--radius);display:flex;gap:16px;opacity:0;padding:18px 20px;text-decoration:none;transform:translateX(20px);transition:opacity .5s var(--ease-out) 0ms,transform .5s var(--ease-out) 0ms,border-color .2s,background .2s,box-shadow .2s;transition:opacity .5s var(--ease-out) var(--delay,0ms),transform .5s var(--ease-out) var(--delay,0ms),border-color .2s,background .2s,box-shadow .2s}.contact-inner.visible .contact-link-card{opacity:1;transform:translateX(0)}.contact-link-card:hover{background:color-mix(in srgb,var(--link-color) 4%,#0000)!important;border-color:color-mix(in srgb,var(--link-color) 30%,#0000)!important;box-shadow:0 8px 30px color-mix(in srgb,var(--link-color) 10%,#0000)!important}.contact-link-icon{align-items:center;background:color-mix(in srgb,var(--link-color) 10%,#0000);border:1px solid color-mix(in srgb,var(--link-color) 20%,#0000);border-radius:12px;display:flex;flex-shrink:0;font-size:1.4rem;font-style:normal;height:44px;justify-content:center;width:44px}.contact-link-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.contact-link-label{color:var(--text-3);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase}.contact-link-value{color:var(--text-1);font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-link-arrow{color:var(--text-3);flex-shrink:0;font-size:1rem;transition:transform .2s var(--ease-bounce),color .2s}.contact-link-card:hover .contact-link-arrow{color:var(--link-color);transform:translateX(4px)}.contact-cv-btn{align-items:center;border-radius:var(--radius);display:flex;font-size:.9rem;gap:8px;justify-content:center;margin-top:8px;padding:14px 24px;text-decoration:none}.footer{border-top:1px solid var(--border);padding:24px clamp(16px,6vw,80px);position:relative;z-index:1}.footer-inner{flex-wrap:wrap;justify-content:space-between;margin:0 auto;max-width:1160px}.footer-inner,.footer-left{align-items:center;display:flex;gap:16px}.footer-logo{color:var(--text-2);font-family:var(--font-mono);font-size:.9rem}.footer-logo-bracket{color:var(--green)}.footer-copy{color:var(--text-3);font-size:.78rem}.footer-built{color:var(--text-3);letter-spacing:.04em}.footer-built,.footer-scroll-top{font-family:var(--font-mono);font-size:.72rem}.footer-scroll-top{align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:100px;color:var(--text-2);cursor:pointer;display:flex;gap:6px;padding:7px 14px;transition:border-color .2s,color .2s,background .2s}.footer-scroll-top:hover{background:#00ff880a;border-color:var(--green);color:var(--green)}@media (max-width:600px){.footer-inner{flex-direction:column;gap:12px;justify-content:center;text-align:center}}
/*# sourceMappingURL=main.a888d18e.css.map*/