@font-face{font-family:'SY';font-weight:800;src:url('/assets/fonts/syne-extrabold.woff2')format('woff2');font-display:swap}@font-face{font-family:'OR';src:url('/assets/fonts/orbitron.woff2')format('woff2');font-display:swap}@font-face{font-family:'Inter';font-weight:400;src:url('/assets/fonts/inter-400.woff2')format('woff2');font-display:swap}@font-face{font-family:'Inter';font-weight:600;src:url('/assets/fonts/inter-600.woff2')format('woff2');font-display:swap}@font-face{font-family:'Inter';font-weight:500;src:url('/assets/fonts/inter-500.woff2')format('woff2');font-display:swap}@font-face{font-family:'Inter';font-weight:700;src:url('/assets/fonts/inter-700.woff2')format('woff2');font-display:swap}body:not(.lang-active-en) .lang-en{display:none !important}body.lang-active-en .lang-de{display:none !important}.stat-icon{display:inline-block;vertical-align:middle;margin-right:6px;flex-shrink:0}.dot-red{background:#ff5f57}.dot-yellow{background:#febc2e}.dot-green{background:#28c840}.mono-label{font-size:10px;color:var(--white);font-family:'OR',monospace}.mono-mini{font-size:8px;letter-spacing:1px;color:var(--d2)}.col-stack{display:flex;flex-direction:column;gap:7px}:root{--font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--fs-body:clamp(17px,0.7rem + 0.9vw,20px);--fs-body-sm:clamp(14px,0.6rem + 0.5vw,16px);--bg:#04060f;--s1:#070a16;--s2:#0d1220;--b1:#182035;--b2:#223050;--b3:#5a6c94;--d1:#6a82a8;--d2:#96aac8;--d3:#c4d4e8;--teal1:#009e8e;--teal2:#00ccb8;--teal3:#00eedc;--pink:#f0a;--pink-a11y:#ff66c2;--purple:#73b;--white:#fff;--term-green:#0e8;--nav-h:70px;--fs-xs:11px;--fs-sm:13px;--fs-md:16px;--fs-lg:20px;--fs-xl:24px;--fs-2xl:44px;--fs-3xl:56px;--lh-tight:1.1;--lh-normal:1.5;--lh-loose:1.8;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:24px;--sp-6:32px;--sp-7:48px;--sp-8:64px;--sp-9:96px;--r-none:0;--r-sm:2px;--r-md:6px;--r-lg:20px;--z-base:1;--z-dropdown:10;--z-sticky:100;--z-overlay:1000;--z-modal:2000;--z-toast:3000;--z-cursor:99999;--t-fast:150ms;--t-med:250ms;--t-slow:500ms}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 16px)}body{background:var(--bg);color:var(--white);font-family:'OR',monospace;overflow-x:hidden}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}#scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:200;background:linear-gradient(90deg,var(--teal1),var(--purple),var(--pink));transition:width .1s linear}#matrix-canvas.matrix-active{opacity:.18}@media(hover:hover) and (pointer:fine){html.custom-cursor-ready *{cursor:none !important}html.custom-cursor-ready input,html.custom-cursor-ready textarea,html.custom-cursor-ready [contenteditable="true"]{cursor:text !important}}@media(hover:none),(pointer:coarse){#cursor-dot,#cursor-ring{display:none !important}*{cursor:auto !important}}@media(prefers-reduced-motion:reduce){*,html.custom-cursor-ready *{cursor:auto !important}#cursor-dot,#cursor-ring,.slash-trail{display:none !important}#matrix-canvas{display:none !important}*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}.blink,.avail-dot,.scroll-hint svg,.term-cursor,.hero-glow,.slash-pulse,.back-to-top-bg,.ticker-blink,.tl-end-icon,.tl-line::after,.tl-line::before,.envelope-svg,.envelope-status-dot,.envelope-flap,.envelope-seal{animation:none !important}.process-grid .process-step.reveal{opacity:1 !important;transform:none !important}#hero *{opacity:1 !important;transform:none !important}}:focus-visible{outline:2px solid var(--teal2);outline-offset:3px;border-radius:2px}.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-link:focus,.skip-link:focus-visible{position:fixed;top:10px;left:10px;z-index:9999;width:auto;height:auto;padding:10px 20px;background:var(--teal1);color:var(--bg);border-radius:3px;font-family:'OR',monospace;font-size:11px;letter-spacing:2px;text-decoration:none;outline:2px solid var(--teal3);outline-offset:2px}.btn-primary:focus-visible,.form-submit:focus-visible{outline:2px solid var(--white);outline-offset:3px;box-shadow:0 0 0 5px var(--teal2)}.lang-btn:focus-visible,.filter-btn:focus-visible,.form-check:focus-within{outline:2px solid var(--teal2);outline-offset:2px}#cursor-dot{position:fixed;width:8px;height:8px;border-radius:50%;background:var(--teal2);pointer-events:none;z-index:var(--z-cursor);transform:translate(-50%,-50%);will-change:transform,left,top;box-shadow:0 0 8px rgba(0,204,184,0.6);transition:background .2s,transform .1s,box-shadow .2s}#cursor-ring{position:fixed;width:32px;height:32px;border-radius:50%;border:1px solid rgba(0,204,184,0.4);pointer-events:none;z-index:calc(var(--z-cursor) - 1);transform:translate(-50%,-50%);will-change:transform,left,top;transition:width .2s,height .2s,border-color .2s}.cursor-hover #cursor-dot{background:var(--pink);box-shadow:0 0 12px rgba(255,0,170,0.7);transform:translate(-50%,-50%) scale(1.5)}.cursor-hover #cursor-ring{border-color:rgba(255,0,170,0.4);width:46px;height:46px}.slash-trail{position:fixed;pointer-events:none;z-index:calc(var(--z-cursor) - 2);width:1.5px;border-radius:1px;background:linear-gradient(to bottom,var(--teal2),var(--pink));opacity:0;transition:opacity .5s ease;transform-origin:top center}body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background-image:radial-gradient(circle,rgba(255,255,255,0.025) 1px,transparent 1px);background-size:28px 28px}#back-top{position:fixed;bottom:32px;right:32px;z-index:90;width:52px;height:52px;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px) scale(.92);transition:opacity .4s ease,transform .4s cubic-bezier(.4,1.4,.6,1);text-decoration:none;background:radial-gradient(circle at center,rgba(4,6,15,0.85) 0,rgba(4,6,15,0.65) 70%,rgba(4,6,15,0) 100%);border-radius:50%}#back-top.visible{opacity:1;transform:translateY(0) scale(1)}#back-top:hover{transform:translateY(-3px) scale(1.05)}#back-top .bt-ring{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg);pointer-events:none}#back-top .bt-ring-track{fill:none;stroke:rgba(150,170,200,0.18);stroke-width:2}#back-top .bt-ring-progress{fill:none;stroke:url(#bt-gradient);stroke-width:2;stroke-linecap:round;stroke-dasharray:100;stroke-dashoffset:calc(100 - var(--bt-progress, 0) * 1);transition:stroke-dashoffset .15s linear;filter:drop-shadow(0 0 4px rgba(0,204,184,0.4))}#back-top .bt-arrow{width:22px;height:22px;position:relative;z-index:2;transition:transform .35s cubic-bezier(.4,1.4,.6,1)}#back-top:hover .bt-arrow{transform:translateY(-2px)}#back-top .bt-arrow-teal{stroke:var(--teal2);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;fill:none}#back-top .bt-arrow-pink{stroke:var(--pink);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;fill:none}#back-top .bt-slash{stroke:rgba(119,51,187,0.6);stroke-width:1.2;stroke-linecap:round;opacity:0;transition:opacity .3s}#back-top:hover .bt-slash{opacity:.75}#back-top::before{content:"";position:absolute;inset:-4px;border-radius:50%;background:radial-gradient(circle,rgba(0,204,184,0.3) 0,rgba(255,0,170,0.2) 50%,transparent 70%);opacity:0;transition:opacity .3s;pointer-events:none;z-index:0}#back-top:hover::before{opacity:1}#back-top::after{content:"↑";position:absolute;font-size:10px;color:var(--teal2);opacity:0;bottom:100%;left:50%;transform:translateX(-50%) translateY(0);pointer-events:none;transition:opacity .3s;text-shadow:0 0 6px rgba(0,204,184,0.8)}#back-top:hover::after{animation:btThrust 1.2s ease-out infinite}@keyframes btThrust{0%{opacity:0;transform:translateX(-50%) translateY(0)}20%{opacity:1}100%{opacity:0;transform:translateX(-50%) translateY(-18px)}}#bt-gradient-def{position:absolute;width:0;height:0;overflow:hidden}nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,5vw,80px);background:rgba(4,6,15,0.9);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .3s}nav.scrolled{border-bottom-color:var(--b1)}.nav-links{display:flex;gap:clamp(16px,2.5vw,36px);align-items:center;list-style:none}.nav-links a{font-size:11px;letter-spacing:3px;color:var(--d2);text-transform:uppercase;text-decoration:none;transition:color .2s;position:relative;padding-bottom:3px}.nav-links a::after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--teal2);transform:scaleX(0);transition:transform .25s ease;transform-origin:left}.nav-links a:hover,.nav-links a.active{color:var(--white)}.nav-links a.active::after,.nav-links a:hover::after{transform:scaleX(1)}.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;min-width:44px;min-height:44px;align-items:center;justify-content:center;box-sizing:border-box}.hamburger span{display:block;width:22px;height:1.5px;background:var(--d2);transition:all .3s}.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}.mobile-menu{position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(4,6,15,0.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--b1);z-index:99;display:none;flex-direction:column;padding:24px clamp(20px,5vw,80px)}.mobile-menu.open{display:flex}.mobile-menu a{font-size:13px;letter-spacing:4px;color:var(--d2);text-transform:uppercase;text-decoration:none;padding:16px 0;border-bottom:1px solid var(--b1);transition:color .2s}.mobile-menu a:last-child{border-bottom:0}.mobile-menu a:hover{color:var(--white)}.nav-right{display:flex;align-items:center;gap:12px}.nav-lang{display:flex;gap:4px}.lang-btn{font-size:9px;letter-spacing:2px;padding:5px 12px;border-radius:20px;border:1px solid var(--b2);background:transparent;color:var(--d2);transition:color .2s,border-color .2s,background .2s;font-family:'OR',monospace}.lang-btn.active-de{background:var(--teal1);border-color:var(--teal1);color:var(--bg)}.lang-btn.active-en{background:var(--pink);border-color:var(--pink);color:var(--bg)}.lang-btn:hover:not(.active-de):not(.active-en){border-color:var(--d2);color:var(--white)}#hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:calc(var(--nav-h)+40px) clamp(20px,5vw,80px) 80px;overflow:hidden;text-align:center}.hero-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 75% 60% at 5% 50%,rgba(0,204,184,0.1) 0,transparent 55%),radial-gradient(ellipse 60% 55% at 95% 40%,rgba(255,0,170,0.08) 0,transparent 55%)}.hero-slash{position:absolute;top:0;bottom:0;width:2px;transform:rotate(12deg);transform-origin:50% 0;background:linear-gradient(to bottom,transparent 0,rgba(0,238,220,0.25) 25%,rgba(119,51,187,0.42) 55%,rgba(255,0,170,0.25) 80%,transparent 100%);animation:slashPulse 4s ease-in-out infinite}.hero-slash:nth-child(1){left:28%;animation-delay:0s}.hero-slash:nth-child(2){left:33%;width:1px;opacity:.3;animation-delay:.8s}.hero-slash:nth-child(3){right:26%;animation-delay:1.6s}.hero-slash:nth-child(4){right:21%;width:1px;opacity:.28;animation-delay:2.4s}@keyframes slashPulse{0%,100%{opacity:.4}50%{opacity:1}}.hero-logo{width:min(680px,88vw);height:auto;animation:heroGlow 4s ease-in-out infinite,fadeUp .8s ease both}@keyframes glitch{0%{clip-path:inset(0 0 95% 0);transform:translate(-4px,0);filter:hue-rotate(90deg)}10%{clip-path:inset(30% 0 50% 0);transform:translate(4px,0)}20%{clip-path:inset(60% 0 20% 0);transform:translate(-3px,0);filter:hue-rotate(-90deg)}30%{clip-path:inset(80% 0 5% 0);transform:translate(3px,0)}40%{clip-path:inset(10% 0 70% 0);transform:translate(-2px,0)}50%{clip-path:inset(45% 0 35% 0);transform:translate(2px,0);filter:hue-rotate(45deg)}60%{clip-path:inset(70% 0 15% 0);transform:translate(-4px,0)}70%{clip-path:inset(20% 0 60% 0);transform:translate(4px,0)}80%{clip-path:inset(55% 0 30% 0);transform:translate(-1px,0)}90%{clip-path:inset(5% 0 85% 0);transform:translate(1px,0)}99%{clip-path:inset(0 0 0 0);transform:translate(0,0);filter:none}100%{clip-path:none;transform:translate(0,0);filter:none}}@keyframes heroGlow{0%,100%{filter:drop-shadow(0 0 10px rgba(0,204,184,0.32)) drop-shadow(0 0 24px rgba(255,0,170,0.14))}50%{filter:drop-shadow(0 0 18px rgba(0,204,184,0.5)) drop-shadow(0 0 44px rgba(255,0,170,0.25))}}.avail-badge{display:inline-flex;align-items:center;gap:10px;margin-top:22px;padding:7px 16px;border-radius:3px;border:1px solid rgba(0,204,184,0.4);background:rgba(0,204,184,0.04);font-size:10px;letter-spacing:3px;color:var(--teal2);text-transform:uppercase;font-family:'OR',monospace;animation:fadeUp .8s ease .15s both;position:relative}.avail-badge::after{content:"▊";margin-left:4px;color:var(--pink-a11y);animation:termBlink .9s step-end infinite;font-size:11px;line-height:1}.avail-dot{width:7px;height:7px;border-radius:50%;background:var(--pink);box-shadow:0 0 6px rgba(255,0,170,0.6);animation:blink 2s ease-in-out infinite}@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}.hero-tagline{font-family:'SY',sans-serif;font-weight:800;font-size:clamp(17px,2.5vw,24px);color:var(--d3);letter-spacing:1px;margin-top:24px;min-height:1.4em;animation:fadeUp .8s ease .25s both}.t-pink{color:var(--pink)}.t-teal{color:var(--teal2)}.typing-cursor{display:inline-block;width:2px;height:1em;background:var(--teal2);margin-left:3px;vertical-align:middle;animation:cursorBlink .75s ease-in-out infinite}@keyframes cursorBlink{0%,100%{opacity:1}50%{opacity:0}}.hero-sub{font-size:12px;letter-spacing:4px;color:var(--d1);text-transform:uppercase;margin-top:22px;animation:fadeUp .8s ease .35s both}.hero-promise{font-size:clamp(15px,1.7vw,18px);color:var(--white);letter-spacing:.5px;line-height:1.4;margin-top:30px;max-width:560px;font-weight:400;animation:fadeUp .9s ease 1.0s both}.hero-ctas{display:flex;gap:16px;margin-top:40px;flex-wrap:wrap;justify-content:center;animation:fadeUp .8s ease .5s both}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:15px 34px;border-radius:3px;background:linear-gradient(90deg,var(--teal1),var(--teal2));color:var(--bg);font-family:'OR',monospace;font-size:11px;letter-spacing:3px;text-transform:uppercase;text-decoration:none;font-weight:600;border:0;transition:transform .25s,box-shadow .25s,background .25s}.btn-primary:hover{background:linear-gradient(90deg,var(--teal2),var(--teal3));transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,204,184,0.3)}.btn-primary:active{transform:translateY(0);box-shadow:0 4px 12px rgba(0,204,184,0.4);transition-duration:80ms}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 34px;border-radius:3px;background:transparent;color:var(--d3);font-family:'OR',monospace;font-size:11px;letter-spacing:3px;text-transform:uppercase;text-decoration:none;border:1.5px solid var(--teal2);transition:border-color .3s,color .3s,transform .3s,box-shadow .3s,background .3s}.btn-secondary:hover{border-color:var(--pink);color:var(--white);transform:translateY(-2px);background:rgba(255,0,170,0.08);box-shadow:0 0 0 1px rgba(255,0,170,0.3),0 0 20px rgba(255,0,170,0.25),0 0 40px rgba(255,0,170,0.12)}.btn-secondary:active{transform:translateY(0);background:rgba(255,0,170,0.14);transition-duration:80ms}.scroll-hint{position:absolute;bottom:28px;left:0;right:0;margin-inline:auto;width:fit-content;display:flex;flex-direction:column;align-items:center;gap:8px;animation:fadeUp .8s ease .8s both;pointer-events:none}.scroll-hint span{font-size:9px;letter-spacing:4px;color:var(--d1);text-transform:uppercase}.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--b2),transparent);animation:scrollDrop 2s ease-in-out infinite;transform-origin:center top}@keyframes scrollDrop{0%{transform:scaleY(0);transform-origin:top;opacity:1}50%{transform:scaleY(1);transform-origin:top;opacity:1}100%{transform:scaleY(1);transform-origin:bottom;opacity:0}}.sec-wrap{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:110px clamp(20px,5vw,80px)}.sec-wrap::before,.sec-wrap::after{content:"";position:absolute;width:18px;height:18px;pointer-events:none;opacity:.4;transition:opacity .6s ease}.sec-wrap::before{top:60px;left:clamp(12px,3vw,40px);border-top:1.5px solid var(--teal2);border-left:1.5px solid var(--teal2)}.sec-wrap::after{bottom:60px;right:clamp(12px,3vw,40px);border-bottom:1.5px solid var(--teal2);border-right:1.5px solid var(--teal2)}.sec-wrap:hover::before,.sec-wrap:hover::after{opacity:.7}@media(max-width:640px){.sec-wrap::before{top:40px;left:12px}.sec-wrap::after{bottom:40px;right:12px}.sec-wrap::before,.sec-wrap::after{width:14px;height:14px}}.sec-divider{width:100%;height:1px;max-width:1200px;margin:0 auto;background:linear-gradient(to right,transparent,var(--b1) 20%,var(--b1) 80%,transparent)}.sec-tag{display:flex;align-items:center;gap:16px;font-size:10px;letter-spacing:7px;color:var(--d2);text-transform:uppercase;margin-bottom:52px}.sec-tag-num{color:var(--teal2);letter-spacing:2px;font-size:11px}.sec-tag::after{content:"";flex:1;height:1px;background:var(--b1)}.sec-subtitle{font-family:var(--font-body);font-size:var(--fs-body);color:var(--d2);line-height:1.6;letter-spacing:0;margin:-32px 0 52px;max-width:560px}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}.about-headline{font-family:'SY',sans-serif;font-weight:800;font-size:clamp(34px,4vw,54px);line-height:1.1;letter-spacing:-1px}.about-headline .hl-teal{color:var(--teal2)}.about-headline .hl-pink{color:var(--pink)}.about-body{font-family:var(--font-body);font-size:var(--fs-body);line-height:1.7;color:var(--d3);letter-spacing:0;margin-top:22px}.about-location{display:inline-flex;align-items:center;gap:9px;margin-top:20px;font-size:11px;letter-spacing:3px;color:var(--d2);text-transform:uppercase}.loc-dot{width:7px;height:7px;border-radius:50%;background:var(--teal2);box-shadow:0 0 6px var(--teal2);flex-shrink:0}.skills-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px;list-style:none;padding:0}.skills-grid li{display:contents}.skill-tag{font-size:10px;letter-spacing:2px;text-transform:uppercase;padding:8px 16px;border-radius:2px;border:1px solid rgba(0,204,184,0.22);background:rgba(0,204,184,0.04);color:var(--teal2);transition:all .25s;cursor:default}.skill-tag:hover{border-color:var(--teal2);background:rgba(0,204,184,0.1);box-shadow:0 0 16px rgba(0,204,184,0.25)}.skill-tag.pink{border-color:rgba(255,0,170,0.22);background:rgba(255,0,170,0.04);color:var(--pink-a11y)}.skill-tag.pink:hover{border-color:var(--pink);background:rgba(255,0,170,0.1);box-shadow:0 0 16px rgba(255,0,170,0.25)}.about-card{background:#020508;border:1px solid #0d2010;border-radius:6px;padding:28px 28px;position:relative;overflow:visible;font-family:'OR',monospace}.about-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--teal1),var(--purple),var(--pink))}.about-card .term-bar{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#030a05;margin:-28px -28px 20px -28px;border-bottom:1px solid #0d2010;border-radius:6px 6px 0 0}.term-dot{width:10px;height:10px;border-radius:50%}.term-title{font-size:9px;letter-spacing:3px;color:#2a5a30;text-transform:uppercase;margin-left:8px}.about-card .stat-label{font-size:10px;letter-spacing:2px;color:#2a7a40;font-family:'OR',monospace;display:inline-flex;align-items:center}.about-card .stat-label::before{content:"";display:none}.about-card .stat-value{font-family:'OR',monospace;font-weight:400;font-size:15px;color:var(--term-green);letter-spacing:1px}.about-card .stat-value.pink{color:#f4c}.term-cursor{display:inline-block;width:8px;height:14px;background:var(--term-green);margin-left:4px;vertical-align:middle;animation:termBlink .8s step-end infinite}@keyframes termBlink{0%,100%{opacity:1}50%{opacity:0}}.stat-row{display:flex;flex-direction:column;gap:22px}.stat-item{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:18px;border-bottom:1px solid var(--b1)}.about-card .stat-item{border-bottom-color:#0d2010}.stat-item:last-child{border-bottom:0;padding-bottom:0}#portfolio .stat-label,#services .stat-label,#contact .stat-label{font-size:10px;letter-spacing:3px;color:var(--d2);text-transform:uppercase}#portfolio .stat-value,#services .stat-value,#contact .stat-value{font-family:'SY',sans-serif;font-weight:800;font-size:22px;color:var(--teal2);letter-spacing:-.5px}#portfolio .stat-value.pink,#services .stat-value.pink,#contact .stat-value.pink{color:var(--pink)}.portfolio-filter{display:flex;gap:8px;margin-bottom:36px;flex-wrap:wrap}.filter-btn{font-size:10px;letter-spacing:3px;padding:8px 20px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:2px;border:1px solid var(--b2);background:transparent;color:var(--d3);font-family:'OR',monospace;text-transform:uppercase;transition:color .2s,border-color .2s,background .2s}.filter-btn.active{background:var(--teal1);border-color:var(--teal1);color:var(--bg)}.filter-btn.active-art{background:var(--pink);border-color:var(--pink);color:var(--white)}.filter-btn:hover:not(.active):not(.active-art)[data-filter="code"]{border-color:var(--teal2);color:var(--teal2)}.filter-btn:hover:not(.active):not(.active-art)[data-filter="design"]{border-color:var(--pink-a11y);color:var(--pink)}.filter-btn:hover:not(.active):not(.active-art)[data-filter="all"]{border-color:var(--d2);color:var(--white)}.portfolio-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:1100px;margin:0 auto}@media(max-width:768px){.portfolio-grid{grid-template-columns:1fr}}.proj-card{position:relative;background:var(--s1);border:1px solid var(--b1);border-radius:4px;overflow:hidden;transition:opacity .3s ease,transform .35s cubic-bezier(.4,.8,.3,1),border-color .25s,box-shadow .25s,background-color .25s;display:flex;flex-direction:column}.proj-card[data-accent="teal"]{--card-accent:var(--teal2);--card-rgb:0,204,184}.proj-card[data-accent="pink"]{--card-accent:var(--pink);--card-rgb:255,0,170}.proj-card[data-accent="gold"]{--card-accent:#c88600;--card-rgb:200,134,0}.proj-card::after{content:"";position:absolute;bottom:10px;left:10px;width:14px;height:14px;border-bottom:1px solid var(--card-accent,var(--teal2));border-left:1px solid var(--card-accent,var(--teal2));opacity:0;transition:opacity .35s,width .35s,height .35s;z-index:3;pointer-events:none}.proj-card:hover{border-color:var(--card-accent,var(--b2));transform:translateY(-5px);box-shadow:0 20px 48px rgba(0,0,0,0.45),0 0 30px -12px rgba(var(--card-rgb,0,204,184),0.45),0 0 0 1px rgba(var(--card-rgb,0,204,184),0.12)}.proj-card:hover::after{opacity:.9;width:20px;height:20px}.proj-thumb{height:190px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--s2)}.proj-thumb-inner{font-family:'SY',sans-serif;font-weight:800;font-size:44px;letter-spacing:-1px;opacity:.14;user-select:none}.proj-thumb-badge{position:absolute;top:12px;right:12px;font-size:8px;letter-spacing:3px;text-transform:uppercase;padding:4px 10px;border-radius:2px}.badge-wip{background:rgba(255,0,170,0.18);color:var(--pink-a11y);border:1px solid rgba(255,0,170,0.3)}.badge-code{background:rgba(0,204,184,0.18);color:var(--teal2);border:1px solid rgba(0,204,184,0.3)}.badge-done{background:rgba(0,238,136,0.18);color:var(--term-green);border:1px solid rgba(0,238,136,0.3)}.badge-wip{background:rgba(255,0,170,0.15);color:var(--pink-a11y);border:1px solid rgba(255,0,170,0.3)}.badge-gold{background:rgba(200,134,0,0.15);color:#c88600;border:1px solid rgba(200,134,0,0.3)}.proj-body{padding:24px 24px 26px;flex:1;display:flex;flex-direction:column}.proj-tags{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}.proj-tag{font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:4px 9px;border-radius:2px;border:1px solid var(--b2);color:var(--d2)}.proj-title{font-family:'SY',sans-serif;font-weight:800;font-size:20px;color:var(--white);letter-spacing:-.3px;margin-bottom:10px;overflow-wrap:break-word;hyphens:auto}.proj-desc{font-family:var(--font-body);font-size:var(--fs-body-sm);color:var(--d3);line-height:1.6;letter-spacing:0;flex:1}.proj-footer{margin-top:20px;padding-top:16px;border-top:1px solid var(--b1);display:flex;justify-content:space-between;align-items:center}.proj-status{font-size:9px;letter-spacing:2px;color:var(--d2);text-transform:uppercase}.proj-arrow-wrap{display:inline-flex;align-items:center;gap:6px}.proj-arrow-label{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--card-accent,var(--teal2));opacity:0;transform:translateX(8px);transition:opacity .3s ease,transform .3s ease;pointer-events:none;white-space:nowrap}.proj-card:hover .proj-arrow-label{opacity:1;transform:translateX(0)}.proj-arrow{font-size:16px;color:var(--d2);transition:all .2s}.proj-card:hover .proj-arrow{color:var(--card-accent,var(--teal2));transform:translateX(5px)}.proj-scan-line{display:none}.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.svc-icon svg{width:20px;height:20px;fill:none;stroke-width:1.5;stroke:var(--teal2)}.svc-card.svc-art .svc-icon svg{stroke:var(--pink)}.svc-title{font-family:'SY',sans-serif;font-weight:800;font-size:19px;color:var(--white);letter-spacing:-.3px;margin-bottom:12px}.svc-desc{font-size:13px;color:var(--d3);line-height:1.55;letter-spacing:.3px}.legal-overlay{position:fixed;inset:0;z-index:var(--z-modal);background:rgba(4,6,15,0.94);backdrop-filter:blur(12px);display:flex;align-items:flex-end;justify-content:center;padding:0;opacity:0;pointer-events:none;transition:opacity .3s ease}.legal-overlay.open{opacity:1;pointer-events:all}.legal-sheet{background:var(--s1);border:1px solid var(--b2);border-radius:12px 12px 0 0;width:100%;max-width:760px;max-height:80vh;overflow-y:auto;padding:32px 36px 40px;transform:translateY(40px);transition:transform .35s cubic-bezier(.22,1,.36,1)}.legal-overlay.open .legal-sheet{transform:translateY(0)}.legal-sheet::-webkit-scrollbar{width:3px}.legal-sheet::-webkit-scrollbar-thumb{background:var(--b2)}.legal-close{float:right;width:44px;height:44px;border-radius:50%;background:var(--s2);border:1px solid var(--b2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--d2);font-size:14px;transition:all .2s}.legal-close:hover{background:var(--b2);color:var(--white)}.legal-title{font-family:'SY',sans-serif;font-weight:800;font-size:20px;color:var(--white);margin:0 0 20px 0;line-height:1.2}.legal-body{font-family:var(--font-body);font-size:var(--fs-body-sm);color:var(--d3);line-height:1.7;letter-spacing:0}.legal-body h3{font-size:11px;letter-spacing:3px;color:var(--d2);text-transform:uppercase;margin:20px 0 8px;font-weight:normal}.legal-body a{color:var(--teal2);text-decoration:none}.legal-body a:hover{text-decoration:underline}.form-group{margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:0}.form-label{font-size:9px;letter-spacing:3px;color:var(--d2);text-transform:uppercase;margin-bottom:8px;display:block}.form-input{width:100%;background:var(--s2);border:1px solid var(--b3);border-radius:4px;padding:12px 14px;font-family:'OR',monospace;font-size:12px;color:var(--white);letter-spacing:.5px;outline:0;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none}.form-input::placeholder{color:var(--d1)}.form-input:focus{border-color:var(--teal2);box-shadow:0 0 0 3px rgba(0,204,184,0.1)}.form-textarea{resize:vertical;min-height:100px;line-height:1.6}.form-checks{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.form-check{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:3px;border:1px solid var(--b2);background:var(--s2);cursor:pointer;transition:all .2s;font-size:10px;letter-spacing:1px;color:var(--d2)}.form-check input{display:none}.check-box{width:14px;height:14px;border-radius:2px;border:1px solid var(--b2);background:var(--s1);flex-shrink:0;position:relative;transition:all .2s}.check-box::after{content:"";position:absolute;top:2px;left:4px;width:4px;height:7px;border:1.5px solid transparent;border-top:0;border-left:0;transform:rotate(45deg);transition:border-color .15s}.form-check.teal input:checked ~ .check-box{background:var(--teal1);border-color:var(--teal2)}.form-check.teal input:checked ~ .check-box::after{border-color:var(--bg)}.form-check.pink input:checked ~ .check-box{background:var(--pink);border-color:var(--pink)}.form-check.pink input:checked ~ .check-box::after{border-color:var(--white)}.form-check input:checked ~ .check-box{background:var(--d2);border-color:var(--d2)}.form-check input:checked ~ .check-box::after{border-color:var(--white)}.form-check.teal:has(input:checked){border-color:rgba(0,204,184,0.4);color:var(--teal2);background:rgba(0,204,184,0.06)}.form-check.pink:has(input:checked){border-color:rgba(255,0,170,0.4);color:var(--pink-a11y);background:rgba(255,0,170,0.06)}.form-check:has(input:checked){border-color:var(--d2);color:var(--white)}.form-check:hover{border-color:var(--b2);color:var(--white)}.form-privacy{font-size:10px;color:var(--d1);line-height:1.7;letter-spacing:.3px;margin-bottom:14px}.form-submit{width:100%;padding:14px;border-radius:4px;background:linear-gradient(90deg,var(--teal1),var(--teal2));border:0;color:var(--bg);font-family:'OR',monospace;font-size:11px;letter-spacing:3px;text-transform:uppercase;cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center;gap:10px}.form-submit:hover{background:linear-gradient(90deg,var(--teal2),var(--teal3));transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,204,184,0.25)}.form-submit:active:not(:disabled){transform:translateY(0);box-shadow:0 3px 10px rgba(0,204,184,0.35);transition-duration:80ms}.form-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-success-msg{font-size:12px;color:var(--teal2);letter-spacing:1px;padding:14px 16px;text-align:center;background:rgba(0,204,184,0.08);border:1px solid rgba(0,204,184,0.25);border-radius:4px}.form-success-main{font-size:13px;font-weight:600;margin-bottom:6px}.form-success-sub{font-size:11px;letter-spacing:.5px;opacity:.75;font-weight:400;text-transform:none}.form-error-msg{font-size:12px;color:var(--pink-a11y);letter-spacing:1px;padding:14px 16px;text-align:center;background:rgba(255,102,194,0.08);border:1px solid rgba(255,102,194,0.35);border-radius:4px}@media(max-width:520px){.form-row{grid-template-columns:1fr}}.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}.contact-headline{font-family:'SY',sans-serif;font-weight:800;font-size:clamp(30px,3.8vw,48px);line-height:1.15;letter-spacing:-1px;margin-bottom:20px}.contact-sub{font-family:var(--font-body);font-size:var(--fs-body);color:var(--d3);line-height:1.7;letter-spacing:0}.contact-card{background:var(--s1);border:1px solid var(--b1);border-radius:6px;padding:40px 36px;position:relative;overflow:hidden}.contact-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--teal1),var(--purple),var(--pink))}footer{position:relative;z-index:1;border-top:1px solid var(--b1);padding:28px clamp(16px,5vw,80px);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px}.footer-copy{justify-self:center;text-align:center}.footer-links{justify-self:end}.footer-copy{font-size:10px;letter-spacing:1px;color:var(--d2);text-transform:uppercase}.brand-name{text-transform:none;letter-spacing:0}.coords-wrap{position:relative;white-space:nowrap}.coords-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--s1);border:1px solid var(--teal2);color:var(--teal2);font-size:10px;letter-spacing:3px;text-transform:uppercase;padding:5px 12px;border-radius:3px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease}.coords-tooltip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--teal2)}.coords-wrap:hover .coords-tooltip{opacity:1;transform:translateX(-50%) translateY(0)}.about-card .coords-tooltip::after{border-top-color:var(--term-green)}.footer-links{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.footer-links a{font-size:11px;letter-spacing:2px;color:var(--d2);text-transform:uppercase;text-decoration:none;transition:color .2s;font-family:'OR',monospace;display:inline-flex;align-items:center;min-height:44px}.footer-links a:hover{color:var(--teal2)}.footer-links .footer-email{color:var(--teal2);text-transform:none;letter-spacing:1px}.footer-links .footer-email:hover{color:var(--teal3);text-shadow:0 0 12px rgba(0,238,220,0.4)}.footer-sep{color:var(--b2);font-size:10px;line-height:1}@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease}.reveal.visible{opacity:1;transform:translateY(0)}.proj-modal-overlay{position:fixed;inset:0;z-index:var(--z-modal);background:rgba(4,6,15,0.94);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .35s ease}.proj-modal-overlay.open{opacity:1;pointer-events:all}.proj-modal{background:var(--s1);border:1px solid var(--b2);border-radius:10px;width:100%;max-width:940px;max-height:90vh;overflow-y:auto;position:relative;transform:translateY(28px) scale(0.98);transition:transform .35s cubic-bezier(.22,1,.36,1);box-shadow:0 40px 80px rgba(0,0,0,0.6),0 0 0 1px rgba(0,204,184,0.06)}.proj-modal-overlay.open .proj-modal{transform:translateY(0) scale(1)}.proj-modal::-webkit-scrollbar{width:3px}.proj-modal::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:28px 32px 24px;border-bottom:1px solid var(--b1);position:sticky;top:0;background:linear-gradient(to bottom,var(--s1) 85%,transparent);z-index:10;gap:20px}.modal-header-left{flex:1}.modal-header-top{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.modal-title{font-family:'SY',sans-serif;font-weight:800;font-size:24px;letter-spacing:-.5px;color:var(--white);margin:0;line-height:1.2}.modal-wip-badge{font-size:8px;letter-spacing:3px;text-transform:uppercase;padding:4px 10px;border-radius:20px;background:rgba(0,204,184,0.12);color:var(--teal2);border:1px solid rgba(0,204,184,0.3);display:inline-flex;align-items:center;gap:6px}.modal-wip-dot{width:5px;height:5px;border-radius:50%;background:var(--teal2);animation:blink 2s infinite}.modal-subtitle{font-family:var(--font-body);font-size:var(--fs-body);color:var(--d3);line-height:1.7;letter-spacing:0;max-width:560px}.modal-close{width:44px;height:44px;border-radius:50%;flex-shrink:0;background:var(--s2);border:1px solid var(--b2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--d2);font-size:16px;transition:all .2s;margin-top:2px}.modal-close:hover{background:rgba(255,0,170,0.15);border-color:var(--pink);color:var(--pink-a11y)}.modal-body{padding:28px 32px 32px}.modal-tags{display:flex;gap:8px;margin-bottom:32px;flex-wrap:wrap}.modal-tag{font-size:9px;letter-spacing:3px;text-transform:uppercase;padding:5px 12px;border-radius:2px;border:1px solid var(--b2);color:var(--d2);transition:all .2s}.modal-tag.teal{color:var(--teal2);border-color:rgba(0,204,184,0.3);background:rgba(0,204,184,0.05)}.modal-tag.pink{color:var(--pink-a11y);border-color:rgba(255,0,170,0.3);background:rgba(255,0,170,0.05)}.modal-section-title{font-size:10px;letter-spacing:5px;color:var(--d1);text-transform:uppercase;margin-bottom:20px;display:flex;align-items:center;gap:14px}.modal-section-title::after{content:"";flex:1;height:1px;background:var(--b1)}.mockup-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:36px;align-items:end}.mockup-wrap{display:flex;flex-direction:column;align-items:center;gap:0;opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}.mockup-wrap.visible{opacity:1;transform:translateY(0)}.mockup-wrap:nth-child(2){transition-delay:.1s}.mockup-wrap:nth-child(3){transition-delay:.2s}.phone-frame{position:relative;background:#0a0c10;border-radius:28px;border:2px solid #1a1e28;box-shadow:0 0 0 1px #0d1018,inset 0 0 0 1px #252a36,0 24px 48px rgba(0,0,0,0.5);overflow:hidden;width:100%;padding-top:0}.phone-frame::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:36%;height:6px;background:#0a0c10;border-radius:0 0 10px 10px;border:1px solid #1a1e28;border-top:0;z-index:10}.phone-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.03) 0,transparent 50%);pointer-events:none;z-index:9;border-radius:26px}.phone-screen{border-radius:26px;overflow:hidden;display:block;width:100%}.mockup-num{font-size:9px;letter-spacing:3px;color:var(--teal2);text-transform:uppercase;margin-top:14px;margin-bottom:4px}.mockup-label{font-size:10px;color:var(--d3);letter-spacing:.5px;text-align:center}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:28px}.feature-item{background:var(--s2);border:1px solid var(--b1);border-radius:6px;padding:16px 16px 18px;transition:border-color .25s,transform .25s;position:relative;overflow:hidden}.feature-item::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--b1);transition:background .25s}.feature-item:hover{border-color:var(--b2);transform:translateY(-2px)}.feature-item:hover::before{background:linear-gradient(90deg,var(--teal1),var(--purple),var(--pink))}.feature-item.art:hover::before{background:linear-gradient(90deg,var(--pink),var(--purple))}.feature-icon{width:36px;height:36px;border-radius:8px;background:var(--s1);border:1px solid var(--b2);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.feature-icon svg{width:17px;height:17px;fill:none;stroke-width:1.5}.feature-name{font-size:12px;font-weight:600;color:var(--white);margin-bottom:6px;letter-spacing:.2px}.feature-desc{font-family:var(--font-body);font-size:var(--fs-body-sm);color:var(--d2);line-height:1.65;letter-spacing:0}.modal-footer{margin-top:4px;padding:18px 20px;background:var(--s2);border:1px solid var(--b1);border-radius:6px;display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:12px}.modal-status-dot{width:7px;height:7px;border-radius:50%;background:var(--teal2);box-shadow:0 0 6px rgba(0,204,184,0.5);animation:blink 2s infinite}.modal-status-right{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--d2);letter-spacing:1px}@media(max-width:700px){.mockup-row{grid-template-columns:1fr}.feature-grid{grid-template-columns:1fr 1fr}.modal-body{padding:20px 16px 24px}.modal-header{padding:20px 16px}.modal-title{font-size:22px;word-break:break-word;overflow-wrap:break-word;hyphens:auto;line-height:1.15}.modal-subtitle{max-width:100%;overflow-wrap:break-word}.proj-modal-content{overflow-x:hidden}.feature-item{min-width:0;overflow:hidden}.feature-desc{overflow-wrap:break-word;word-wrap:break-word}}@media(max-width:480px){.feature-grid{grid-template-columns:1fr}.modal-title{font-size:20px}}.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.process-arrow{position:absolute;top:50%;right:-12px;transform:translateY(-50%);width:24px;height:24px;display:flex;align-items:center;justify-content:center;z-index:2;font-size:14px;color:var(--b2)}.process-step:last-child .process-arrow{display:none}@media(max-width:900px){.process-grid{grid-template-columns:1fr 1fr;gap:14px}.process-step:nth-child(2) .process-arrow,.process-step:last-child .process-arrow{display:none}}@media(max-width:520px){.process-grid{grid-template-columns:1fr;gap:12px}.process-arrow{display:none}}@media(max-width:768px){.nav-links{display:none}.hamburger{display:flex}footer{grid-template-columns:1fr;gap:10px;padding:20px clamp(16px,5vw,40px)}.footer-copy{justify-self:start;text-align:left}.footer-links{justify-self:start}.footer-links{gap:10px}.footer-copy{font-size:9px}.about-grid,.contact-wrap{grid-template-columns:1fr;gap:36px}.hero-logo{width:82vw}.hero-promise{font-size:14px;max-width:88vw}#hero{overflow-x:hidden}.portfolio-grid,.services-grid{grid-template-columns:1fr}@media(max-width:1100px) and (min-width:769px){.services-grid{grid-template-columns:repeat(2,1fr)}}#back-top{bottom:20px;right:20px}.footer-links{padding-right:54px}}body.party-mode{animation:partyBg 3s infinite}@keyframes partyBg{0%{background:var(--bg)}25%{background:#0a0620}50%{background:#120418}75%{background:#061a20}100%{background:var(--bg)}}body.party-mode .nav-logo svg{animation:partyLogo 1.5s infinite}@keyframes partyLogo{0%{transform:rotate(0)}25%{transform:rotate(5deg) scale(1.05)}50%{transform:rotate(-5deg) scale(1)}75%{transform:rotate(3deg) scale(1.03)}100%{transform:rotate(0)}}body.party-mode .hero-title-text{animation:partyHue 2s infinite}@keyframes partyHue{0%{filter:hue-rotate(0)}100%{filter:hue-rotate(360deg)}}body.party-mode .sec-tag-num,body.party-mode .filter-btn.active,body.party-mode .service-num{animation:partyHue 1.5s infinite}#party-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.5);background:linear-gradient(135deg,rgba(0,204,184,0.95),rgba(119,51,187,0.95),rgba(255,0,170,0.95));color:var(--white);padding:24px 36px;border-radius:8px;font-family:'SY',sans-serif;font-weight:800;font-size:18px;letter-spacing:2px;text-align:center;box-shadow:0 20px 60px rgba(119,51,187,0.5),0 0 0 1px rgba(255,255,255,0.1) inset;opacity:0;transition:all .4s cubic-bezier(.4,.8,.3,1.4);z-index:99999;pointer-events:none}#party-toast.visible{opacity:1;transform:translate(-50%,-50%) scale(1)}.nav-logo{position:relative;display:inline-block;cursor:pointer}.nav-logo svg{transition:transform .2s}.nav-logo-mark{display:none}@media(max-width:640px){.nav-logo-full{display:none}.nav-logo-mark{display:inline-block}}.nav-logo.chopping svg{animation:chopGlitch .55s cubic-bezier(.3,.8,.4,1.3)}@keyframes chopGlitch{0%{transform:translate(0,0) skewX(0)}15%{transform:translate(-3px,1px) skewX(-2deg);filter:drop-shadow(3px 0 0 rgba(255,0,170,0.8)) drop-shadow(-3px 0 0 rgba(0,204,184,0.8))}30%{transform:translate(2px,-1px) skewX(2deg);filter:drop-shadow(-2px 0 0 rgba(255,0,170,0.8)) drop-shadow(2px 0 0 rgba(0,204,184,0.8))}45%{transform:translate(-1px,0) skewX(-1deg) scale(1.04);filter:drop-shadow(0 0 12px rgba(119,51,187,0.6))}60%{transform:translate(1px,-1px) skewX(1deg) scale(1.02);filter:drop-shadow(0 0 8px rgba(255,0,170,0.4))}100%{transform:translate(0,0) skewX(0) scale(1);filter:none}}.nav-logo.chopping::after{content:"";position:absolute;top:50%;left:-8px;right:-8px;height:2px;background:linear-gradient(90deg,transparent 0,var(--purple) 20%,var(--pink) 50%,var(--teal2) 80%,transparent 100%);transform:translateY(-50%) scaleX(0);transform-origin:left;animation:chopLine .45s ease-out;pointer-events:none}@keyframes chopLine{0%{transform:translateY(-50%) scaleX(0) translateX(0);opacity:0}40%{transform:translateY(-50%) scaleX(1) translateX(0);opacity:1}100%{transform:translateY(-50%) scaleX(1) translateX(100%);opacity:0}}.svc-card{position:relative;min-width:0;display:grid;perspective:1600px;cursor:pointer;transition:all .35s cubic-bezier(.4,.8,.3,1)}.svc-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--svc-accent,var(--teal2));transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.4,.8,.3,1)}.svc-card[data-accent="grad-pink"]{--svc-accent:var(--pink);--svc-accent-text:var(--pink-a11y);--svc-accent-dim:rgba(255,0,170,0.15);--svc-accent-glow:rgba(255,0,170,0.3)}.svc-card[data-accent="grad-mix-pp"]{--svc-accent:#a422b5;--svc-accent-text:#c860d4;--svc-accent-dim:rgba(164,34,181,0.15);--svc-accent-glow:rgba(164,34,181,0.3)}.svc-card[data-accent="grad-mix-tp"]{--svc-accent:#4f57ac;--svc-accent-text:#7b85d4;--svc-accent-dim:rgba(79,87,172,0.15);--svc-accent-glow:rgba(79,87,172,0.3)}.svc-card[data-accent="grad-teal"]{--svc-accent:var(--teal1);--svc-accent-text:var(--teal2);--svc-accent-dim:rgba(0,158,142,0.15);--svc-accent-glow:rgba(0,158,142,0.3)}.svc-card:hover{transform:translateY(-4px)}.svc-card:hover::before{transform:scaleX(1)}.svc-corner{position:absolute;top:10px;right:10px;width:16px;height:16px;border-top:1px solid var(--svc-accent);border-right:1px solid var(--svc-accent);opacity:.35;transition:all .35s}.svc-card:hover .svc-corner{opacity:1;width:24px;height:24px}.svc-num{font-family:'OR',monospace;font-size:10px;color:var(--svc-accent-text);letter-spacing:3px;opacity:.55;transition:opacity .3s}.svc-card:hover .svc-num{opacity:1}.svc-icon{width:44px;height:44px;border:1px solid var(--b1);border-radius:4px;background:rgba(255,255,255,0.02);display:flex;align-items:center;justify-content:center;transition:all .35s cubic-bezier(.4,.8,.3,1.4)}.svc-icon svg{width:22px;height:22px;fill:none;stroke:var(--svc-accent);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;transition:transform .4s cubic-bezier(.4,.8,.3,1.4)}.svc-card:hover .svc-icon{border-color:var(--svc-accent);background:var(--svc-accent-dim);box-shadow:0 0 20px var(--svc-accent-glow);transform:rotate(-6deg) scale(1.05)}.svc-title{font-family:'SY',sans-serif;font-weight:800;font-size:clamp(17px,2vw,20px);line-height:1.1;color:var(--white);letter-spacing:-.3px;overflow-wrap:break-word;word-wrap:break-word;hyphens:auto}.svc-tagline{font-family:var(--font-body);font-size:var(--fs-body-sm);color:var(--svc-accent-text);line-height:1.45;letter-spacing:0;margin:0;opacity:.9}.svc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;flex:1}.svc-list li{position:relative;padding-left:18px;font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.5;color:var(--d1)}.svc-list li::before{content:"";position:absolute;left:0;top:8px;width:8px;height:1px;background:var(--svc-accent);opacity:.7;transition:width .3s}.svc-card:hover .svc-list li::before{width:12px;opacity:1}.svc-example{font-family:'OR',monospace;font-size:10px;color:var(--d2);font-style:italic;letter-spacing:.3px;padding-top:12px;border-top:1px dashed var(--b1);margin-top:auto;transition:border-color .3s,color .3s}.svc-card:hover .svc-example{border-top-color:var(--svc-accent);color:var(--svc-accent);opacity:.8}.svc-desc,.svc-art{display:none}.contact-left{position:relative}.contact-watermark{position:absolute;top:50%;left:-40px;transform:translateY(-50%);width:560px;height:560px;pointer-events:none;z-index:0;opacity:.06;filter:blur(0.3px)}.contact-watermark svg{width:100%;height:100%;display:block}.contact-left>*:not(.contact-watermark){position:relative;z-index:1}#contact:hover .contact-watermark{opacity:.09}.contact-watermark{transition:opacity .8s ease}@media(max-width:900px){.contact-watermark{display:none}}.stat-ticker{display:inline-block;position:relative;transition:opacity .25s ease}.stat-ticker.rotating{opacity:0}@keyframes tickerBlink{0%,100%{opacity:1}50%{opacity:.4}}.process-timeline{display:flex !important;flex-direction:row !important;align-items:center !important;gap:14px;margin:0 auto 28px !important;width:100%;max-width:100%;height:auto !important;padding:0 4px;position:relative;z-index:2;pointer-events:auto}.tl-start,.tl-end{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0}.tl-label{font-family:'OR',monospace;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;white-space:nowrap}.tl-label-start{color:var(--d2)}.tl-label-end{color:var(--teal2)}.tl-start-icon{position:relative;width:34px;height:34px;border:1px solid var(--b1);border-radius:50%;background:var(--s1);display:flex;align-items:center;justify-content:center;color:var(--d1);cursor:pointer;text-decoration:none;transition:border-color .3s,color .3s,box-shadow .3s,transform .3s}.tl-start-icon:focus-visible{outline:2px solid var(--teal2);outline-offset:3px}.tl-start-icon svg{position:absolute;inset:0;margin:auto;transition:opacity .5s ease,transform .5s ease}.tl-start-icon .tl-icon-mail{opacity:1;transform:scale(1)}.tl-start-icon .tl-icon-phone{opacity:0;transform:scale(.7)}.tl-start-icon[data-icon="phone"] .tl-icon-mail{opacity:0;transform:scale(.7)}.tl-start-icon[data-icon="phone"] .tl-icon-phone{opacity:1;transform:scale(1)}.process-timeline:hover .tl-start-icon{border-color:var(--teal2);color:var(--teal2);box-shadow:0 0 14px rgba(0,204,184,0.25)}.tl-start-icon:hover,.tl-start-icon:focus-visible{border-color:var(--teal2);color:var(--teal2);box-shadow:0 0 20px rgba(0,204,184,0.5);transform:scale(1.1)}.tl-end-icon{width:30px;height:30px;border-radius:50%;background:var(--teal2);color:var(--bg);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 0 rgba(0,204,184,0.55);animation:tlEndPulse 2.4s ease-out infinite}@keyframes tlEndPulse{0%{box-shadow:0 0 0 0 rgba(0,204,184,0.55),0 0 10px rgba(0,204,184,0.4)}70%{box-shadow:0 0 0 12px rgba(0,204,184,0),0 0 18px rgba(0,204,184,0.5)}100%{box-shadow:0 0 0 0 rgba(0,204,184,0),0 0 10px rgba(0,204,184,0.4)}}.tl-track{position:relative;flex:1;height:34px;display:flex;align-items:center}.tl-line{position:absolute;left:0;right:0;top:50%;height:8px;transform:translateY(-50%);background:linear-gradient(90deg,rgba(0,204,184,0.5) 0,rgba(77,166,200,0.6) 33%,rgba(179,102,221,0.6) 66%,rgba(255,0,170,0.5) 100%);background-size:100% 1px;background-repeat:no-repeat;background-position:center;overflow:hidden}.tl-line::after{content:"";position:absolute;top:50%;left:0;width:140px;height:3px;margin-left:-140px;border-radius:3px;transform:translateY(-50%);background:linear-gradient(90deg,rgba(255,255,255,0) 0,rgba(255,255,255,0.4) 30%,rgba(255,255,255,0.95) 75%,rgba(255,255,255,1) 95%,rgba(255,255,255,0) 100%);filter:blur(1px);opacity:0;pointer-events:none}.process-timeline.is-playing .tl-line::after{animation:tlPulse 6s linear forwards}@keyframes tlPulse{0%{left:0;opacity:1}90%{opacity:1}100%{left:100%;opacity:0}}.tl-line::before{content:"";position:absolute;top:50%;left:0;width:100px;height:1px;margin-left:-50px;transform:translateY(-50%);background:linear-gradient(90deg,rgba(255,255,255,0) 0,rgba(255,255,255,0.5) 50%,rgba(255,255,255,0) 100%);opacity:0;pointer-events:none}.process-timeline.is-idle-shimmer .tl-line::before{animation:tlShimmer 7s ease-in-out infinite;animation-delay:1.5s}@keyframes tlShimmer{0%{left:0;opacity:0}15%{opacity:.55}85%{opacity:.55}100%{left:100%;opacity:0}}.tl-dot.is-pulsing{animation:tlDotPulse 1s ease-out}@keyframes tlDotPulse{0%{transform:translate(-50%,-50%) scale(1);box-shadow:0 0 0 3px var(--bg),0 0 8px var(--dot-c)}40%{transform:translate(-50%,-50%) scale(1.7);box-shadow:0 0 0 3px var(--bg),0 0 22px var(--dot-c),0 0 36px var(--dot-c)}100%{transform:translate(-50%,-50%) scale(1);box-shadow:0 0 0 3px var(--bg),0 0 8px var(--dot-c)}}.process-grid .process-step.reveal{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s cubic-bezier(.4,.8,.3,1)}.process-grid .process-step.reveal.is-revealed{opacity:1;transform:translateY(0)}.process-grid .process-step.reveal.visible{opacity:1;transform:translateY(0)}.tl-end-icon.is-burst{animation:tlEndBurst 1.4s ease-out,tlEndPulse 2.4s ease-out infinite 1.4s}@keyframes tlEndBurst{0%{transform:scale(1);box-shadow:0 0 0 0 rgba(0,204,184,0.8),0 0 10px rgba(0,204,184,0.4)}35%{transform:scale(1.4);box-shadow:0 0 0 18px rgba(0,204,184,0),0 0 40px rgba(0,204,184,0.9),0 0 60px rgba(0,204,184,0.5)}100%{transform:scale(1);box-shadow:0 0 0 0 rgba(0,204,184,0),0 0 10px rgba(0,204,184,0.4)}}.tl-dot{position:absolute;top:50%;width:10px;height:10px;border-radius:50%;transform:translate(-50%,-50%) scale(1);background:var(--bg);border:2px solid var(--dot-c,var(--teal2));box-shadow:0 0 0 3px var(--bg),0 0 8px var(--dot-c,var(--teal2));cursor:pointer;pointer-events:auto;transition:transform .25s cubic-bezier(.4,.8,.3,1.4),box-shadow .25s ease}.tl-dot::before{content:"";position:absolute;inset:-10px;border-radius:50%}.tl-dot:hover,.tl-dot.is-card-hover{transform:translate(-50%,-50%) scale(1.5);box-shadow:0 0 0 3px var(--bg),0 0 16px var(--dot-c,var(--teal2)),0 0 28px var(--dot-c,var(--teal2))}@media(max-width:1000px){.process-timeline{display:none}}.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;z-index:1}@media(max-width:1000px){.process-grid{grid-template-columns:repeat(2,1fr);gap:16px}}@media(max-width:640px){.process-grid{grid-template-columns:1fr}}.process-step{position:relative;background:var(--s1);border:1px solid var(--b1);border-radius:4px;padding:28px 22px 22px;overflow:visible;transition:all .3s cubic-bezier(.4,.8,.3,1);display:flex;flex-direction:column;min-height:340px}.process-step[data-step="1"]{--step-color:var(--teal1);--step-color-text:var(--teal2);--step-rgb:0,158,142}.process-step[data-step="2"]{--step-color:#4f57ac;--step-color-text:#7b85d4;--step-rgb:79,87,172}.process-step[data-step="3"]{--step-color:#a422b5;--step-color-text:#c860d4;--step-rgb:164,34,181}.process-step[data-step="4"]{--step-color:var(--pink);--step-color-text:var(--pink-a11y);--step-rgb:255,0,170}.process-step::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--step-color)}.process-step:hover,.process-step.is-tl-hover{border-color:var(--step-color);background:linear-gradient(180deg,rgba(var(--step-rgb),0.06) 0,var(--s1) 50%);transform:translateY(-4px);box-shadow:0 8px 30px -10px rgba(var(--step-rgb),0.35)}.process-num{position:absolute;top:14px;right:16px;font-family:'SY',sans-serif;font-weight:800;font-size:54px;line-height:1;color:var(--step-color);opacity:.08;letter-spacing:-2px;transition:opacity .3s}.process-step:hover .process-num,.process-step.is-tl-hover .process-num{opacity:.16}.process-label{font-family:'OR',monospace;font-size:9px;letter-spacing:3px;color:var(--step-color-text);text-transform:uppercase;opacity:.7;margin-bottom:18px}.process-icon{width:38px;height:38px;border:1px solid var(--b1);border-radius:4px;background:rgba(255,255,255,0.02);display:flex;align-items:center;justify-content:center;margin-bottom:14px;transition:all .3s cubic-bezier(.4,.8,.3,1.4)}.process-icon svg{stroke:var(--step-color)}.process-step:hover .process-icon,.process-step.is-tl-hover .process-icon{border-color:var(--step-color);background:rgba(var(--step-rgb),0.1);box-shadow:0 0 18px rgba(var(--step-rgb),0.3);transform:rotate(-6deg) scale(1.05)}.process-title{font-family:'SY',sans-serif;font-weight:800;font-size:clamp(18px,2.2vw,22px);color:var(--white);margin-bottom:10px;letter-spacing:-.3px;overflow-wrap:break-word;word-wrap:break-word;hyphens:auto}.process-desc{font-family:var(--font-body);font-size:var(--fs-body-sm);line-height:1.6;color:var(--d1);margin-bottom:18px;flex:1}.process-meta{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px dashed var(--b1);transition:border-color .3s;margin-top:auto}.process-step:hover .process-meta,.process-step.is-tl-hover .process-meta{border-top-color:var(--step-color)}.meta-duration{display:inline-flex;align-items:center;gap:5px;font-family:'OR',monospace;font-size:9px;letter-spacing:1.5px;color:var(--d2);text-transform:uppercase}.meta-duration svg{stroke:var(--step-color);opacity:.8}.meta-keyword{font-family:'OR',monospace;font-size:9px;letter-spacing:2px;color:var(--step-color-text);padding:3px 8px;border:1px solid rgba(var(--step-rgb),0.3);border-radius:2px;background:rgba(var(--step-rgb),0.05);text-transform:lowercase}.browser-frame{width:100%;max-width:100%;background:var(--bg);border-radius:8px;border:1px solid #1c2840;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.03) inset}.browser-bar{display:flex;align-items:center;gap:6px;padding:9px 12px;background:#0a0f1a;border-bottom:1px solid #1c2840}.browser-dot{width:10px;height:10px;border-radius:50%;opacity:.7;flex-shrink:0}.browser-url{flex:1;margin-left:12px;padding:4px 12px;background:var(--bg);border-radius:4px;font-family:'OR',monospace;font-size:10px;color:#4a5f88;text-align:center;border:1px solid var(--b1)}.browser-screen{display:block;width:100%;height:auto;aspect-ratio:720/460}.mockup-row-desktop{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}.mockup-row-desktop .mockup-wrap-desktop{grid-column:span 1}.mockup-row-desktop .mockup-wrap-mobile-centered{grid-column:span 2;justify-self:center;max-width:280px}@media(max-width:700px){.mockup-row-desktop{grid-template-columns:1fr}.mockup-row-desktop .mockup-wrap-desktop,.mockup-row-desktop .mockup-wrap-mobile-centered{grid-column:span 1;justify-self:stretch;max-width:100%}}.form-hint{font-size:10px;color:var(--d2);letter-spacing:1px;text-align:right;margin-top:4px;font-family:'OR',monospace;opacity:.6;transition:color .2s,opacity .2s}.form-hint.warning{color:#c88600;opacity:1}.form-hint.danger{color:var(--pink-a11y);opacity:1}.form-consent{margin-top:18px;padding-top:18px;border-top:1px dashed var(--b1)}.consent-check{display:flex !important;align-items:flex-start !important;gap:10px;cursor:pointer;padding:0 !important;border:none !important;background:transparent !important}.consent-check .check-box{flex-shrink:0;margin-top:2px}.consent-check>span:not(.check-box){font-size:var(--fs-body-sm);line-height:1.55;color:var(--d2);font-family:var(--font-body);letter-spacing:0}.consent-link{color:var(--teal2);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.consent-link:hover{color:var(--pink-a11y)}.form-error-inline{display:none;margin-top:8px;padding:8px 12px;background:rgba(255,102,194,0.08);border:1px solid rgba(255,102,194,0.4);border-radius:3px;font-size:11px;color:var(--pink-a11y);letter-spacing:.5px;font-family:'OR',monospace}.form-error-inline.show{display:block}.form-input.error{border-color:var(--pink-a11y) !important;box-shadow:0 0 0 3px rgba(255,102,194,0.15) !important}.form-input.error+.form-hint{color:var(--pink-a11y);opacity:1}.form-submit:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.form-submit:disabled:hover{transform:none;background:var(--teal1)}.form-submit-hint{display:block;text-align:center;font-size:10px;color:var(--d2);margin-top:6px;letter-spacing:1px;font-family:'OR',monospace;font-style:italic;opacity:0;transition:opacity .25s;height:0;overflow:hidden}.form-submit:disabled+.form-submit-hint{opacity:.7;height:auto;margin-top:8px}fieldset.form-group{border:0;padding:0;margin:0;min-width:0}fieldset.form-group legend.form-label{padding:0;display:block;margin-bottom:10px}.contact-card{position:relative;overflow:visible}.contact-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--teal2) 0,var(--purple) 50%,var(--pink) 100%);border-radius:6px 6px 0 0}.form-header{display:flex;align-items:center;gap:14px;padding-bottom:20px;margin-bottom:24px;border-bottom:1px solid var(--b1)}.form-header-icon{width:40px;height:40px;flex-shrink:0;border:1px solid var(--b2);border-radius:4px;background:rgba(0,204,184,0.06);display:flex;align-items:center;justify-content:center;color:var(--teal2);transition:all .3s cubic-bezier(.4,.8,.3,1.4)}.contact-card:hover .form-header-icon{border-color:var(--teal2);background:rgba(0,204,184,0.12);box-shadow:0 0 18px rgba(0,204,184,0.25);transform:rotate(-8deg)}.form-header-text{flex:1}.form-header-label{font-family:'OR',monospace;font-size:13px;letter-spacing:3px;color:var(--white);font-weight:700;text-transform:uppercase}.form-header-sub{font-family:'OR',monospace;font-size:10px;letter-spacing:1.5px;color:var(--d2);margin-top:4px;text-transform:lowercase;font-style:italic}.form-section{position:relative}.form-section-collapsible{border:1px solid var(--b1);border-radius:4px;padding:0;margin-bottom:0;background:rgba(7,10,22,0.4);transition:border-color .25s,background .25s}.form-section-collapsible:hover{border-color:var(--b2)}.form-section-collapsible[open]{border-color:rgba(0,204,184,0.25);background:rgba(0,204,184,0.02)}.form-section-collapsible>summary{cursor:pointer;padding:14px 16px;margin:0;list-style:none;user-select:none}.form-section-collapsible>summary::-webkit-details-marker{display:none}.form-section-collapsible>summary::marker{display:none}.form-section-chevron{margin-left:auto;font-size:18px;color:var(--teal2);line-height:1;transition:transform .25s ease;display:inline-block}.form-section-collapsible[open] .form-section-chevron{transform:rotate(90deg)}.form-section-collapsible>.form-group{padding:0 16px 16px}.form-section-label{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-family:'OR',monospace;font-size:11px;letter-spacing:2.5px;color:var(--d2);text-transform:uppercase}.form-section-collapsible>.form-section-label{margin-bottom:0}.form-section-num{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;background:rgba(0,204,184,0.1);border:1px solid rgba(0,204,184,0.3);border-radius:2px;color:var(--teal2);font-size:9px;font-weight:700;letter-spacing:1px}.form-section-optional{margin-left:auto;font-size:9px;letter-spacing:1.5px;color:var(--d2);font-style:italic;opacity:.7;text-transform:lowercase}.form-divider{height:1px;background:linear-gradient(90deg,transparent 0,var(--b1) 30%,var(--b1) 70%,transparent 100%);margin:22px 0}.visually-hidden{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.form-section .form-group{margin-bottom:0}.form-section .form-row{margin-bottom:0}.form-section .form-row .form-group:not(:last-child){margin-bottom:0}.form-submit{position:relative;overflow:hidden;background:linear-gradient(90deg,var(--teal2) 0,var(--teal2) 50%,var(--pink) 200%);background-size:200% 100%;background-position:0 0;transition:all .4s cubic-bezier(.4,.8,.3,1)}.form-submit:not(:disabled):hover{background-position:100% 0;box-shadow:0 0 28px rgba(0,204,184,0.35),0 0 40px rgba(255,0,170,0.2);transform:translateY(-1px)}.form-consent{margin-top:24px;padding:16px;background:rgba(0,204,184,0.025);border:1px solid var(--b1);border-radius:4px;border-top-color:rgba(0,204,184,0.2)}@media(max-width:380px){.portfolio-filter{gap:6px}.filter-btn{padding:7px 14px;font-size:9px;letter-spacing:2px}}.proj-card.filtered-out{opacity:0;transform:scale(0.95);pointer-events:none}@media(hover:none){.proj-card:active{transform:scale(0.98);transition:transform .15s ease}.filter-btn:active{opacity:.75}}@media(max-width:520px){.lang-btn,.scroll-hint span,.proj-tag,.proj-status,.form-label,.modal-tag,.mockup-num,.process-label{font-size:10px}}@media print{#matrix-canvas,#cursor-dot,#cursor-ring,.slash-trail,#back-top,.hamburger,.mobile-menu,.scroll-hint,#scroll-progress,.hero-bg,.hero-slash{display:none !important}html,body{background:var(--white) !important;color:#000 !important;font-family:Georgia,'Times New Roman',serif !important}*{color:#000 !important;background:transparent !important;box-shadow:none !important;text-shadow:none !important;border-color:#888 !important}nav,.lang-switch{display:none !important}a[href^="http"]::after,a[href^="mailto:"]::after{content:" (" attr(href) ")";font-size:90%;color:#555 !important}a[href^="#"]::after{content:""}.proj-modal-overlay,.legal-overlay{display:none !important}.proj-modal-overlay.open,.legal-overlay.open{display:block !important;position:static !important}section.sec-wrap{page-break-inside:avoid;padding:20px 0 !important}h1,h2,h3{page-break-after:avoid}}.contact-toggle{position:relative;width:100%;min-height:480px}.envelope-trigger{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;width:100%;min-height:460px;padding:40px 20px;background:transparent;border:0;cursor:pointer;font-family:'OR',monospace;transition:opacity .35s ease,transform .45s cubic-bezier(.4,.8,.3,1);opacity:1;transform:scale(1)}.envelope-svg{width:320px;max-width:80%;height:auto;display:block;animation:env-float 4s ease-in-out infinite;filter:drop-shadow(0 12px 28px rgba(0,204,184,0.18));transition:filter .35s ease,transform .35s cubic-bezier(.4,1.4,.6,1)}@keyframes env-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}.envelope-trigger:hover .envelope-svg,.envelope-trigger:focus-visible .envelope-svg{filter:drop-shadow(0 16px 36px rgba(255,0,170,0.32));transform:translateY(-4px) scale(1.02)}.envelope-flap{transition:transform .4s cubic-bezier(.4,1.4,.6,1);transform-box:fill-box;transform-origin:center top}.envelope-trigger:hover .envelope-flap,.envelope-trigger:focus-visible .envelope-flap{transform:rotateX(28deg)}.envelope-seal{transition:transform .35s cubic-bezier(.4,1.4,.6,1);transform-origin:160px 130px}.envelope-trigger:hover .envelope-seal,.envelope-trigger:focus-visible .envelope-seal{transform:scale(1.08) rotate(-3deg)}.envelope-status-dot{animation:env-status-pulse 1.6s ease-in-out infinite;transform-origin:282px 40px;transform-box:fill-box}@keyframes env-status-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(0.7)}}.envelope-status-label,.envelope-status-label-hover{transition:opacity .35s ease}.envelope-trigger:hover .envelope-status-label,.envelope-trigger:focus-visible .envelope-status-label{opacity:0}.envelope-trigger:hover .envelope-status-label-hover,.envelope-trigger:focus-visible .envelope-status-label-hover{opacity:1}.envelope-hint{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--d2);opacity:.7;transition:opacity .3s ease,color .3s ease,letter-spacing .3s ease;margin-top:8px}.envelope-trigger:hover .envelope-hint,.envelope-trigger:focus-visible .envelope-hint{opacity:1;color:var(--teal2);letter-spacing:4px}.envelope-trigger:focus-visible{outline:2px solid var(--teal2);outline-offset:8px;border-radius:6px}.contact-toggle.opening .envelope-trigger{transform:scale(1.15);opacity:0;pointer-events:none}.contact-toggle.opened .envelope-trigger{display:none}.contact-toggle.opened .contact-card{animation:form-morph-in .55s cubic-bezier(.4,.8,.3,1) both}@keyframes form-morph-in{0%{opacity:0;transform:scale(1.04);filter:blur(6px)}60%{opacity:1;filter:blur(0)}100%{opacity:1;transform:scale(1);filter:blur(0)}}.form-back-btn{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--b1);border-radius:4px;color:var(--d2);cursor:pointer;transition:border-color .2s,color .2s,background .2s;z-index:2}.form-back-btn:hover,.form-back-btn:focus-visible{border-color:var(--pink);color:var(--pink-a11y);background:rgba(255,0,170,0.05)}.form-back-btn:focus-visible{outline:2px solid var(--pink);outline-offset:2px}.contact-card{position:relative}@media(prefers-reduced-motion:reduce){.envelope-svg,.envelope-flap,.envelope-seal,.envelope-hint,.envelope-status-dot,.envelope-status-label,.envelope-status-label-hover{animation:none !important;transition:none !important}.contact-toggle.opening .envelope-trigger,.contact-toggle.opened .contact-card{animation:none !important;transition:opacity .15s linear !important}}@media(max-width:640px){.envelope-trigger{min-height:360px;padding:24px 16px}.envelope-svg{width:240px}.contact-toggle{min-height:380px}}.hero-logo-wrap{position:relative;display:inline-block;line-height:0}.hero-logo-wrap .hero-logo{animation:heroScanReveal 3.0s .3s cubic-bezier(0.5,0,0.5,1) both,heroGlow 4s ease-in-out 3.4s infinite,fadeUp .8s ease both}.hero-logo-wrap.scan-done .hero-logo{animation:heroGlow 4s ease-in-out infinite}.hero-logo-wrap.scan-done .hero-logo.glitching,.hero-logo-wrap.scan-done .hero-logo.glitching{animation:heroGlow 4s ease-in-out infinite,glitch .3s steps(2) both}.hero-logo-wrap::before{content:'';position:absolute;top:-12%;bottom:-12%;width:3px;background:linear-gradient(to bottom,transparent 0,var(--teal3) 50%,transparent 100%);box-shadow:0 0 14px var(--teal3),0 0 28px rgba(0,238,220,0.7);left:0;opacity:0;pointer-events:none;z-index:5;animation:heroScanLine 3.0s .3s forwards cubic-bezier(0.5,0,0.5,1)}.hero-logo-wrap.scan-done::before{animation:none;opacity:0}@keyframes heroScanReveal{0%{clip-path:inset(0 100% 0 0)}99%{clip-path:inset(0 0 0 0)}100%{clip-path:none}}@keyframes heroScanLine{0%{left:0;opacity:0}10%,90%{opacity:1}100%{left:100%;opacity:0}}.nav-logo::before,.nav-logo::after{content:'';position:absolute;width:14px;height:14px;border:2px solid var(--teal3);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}.nav-logo::before{top:-8px;left:-8px;border-right:0;border-bottom:0;transform:translate(8px,8px)}.nav-logo::after{bottom:-8px;right:-8px;border-left:0;border-top:0;transform:translate(-8px,-8px)}.nav-logo:hover svg{filter:drop-shadow(0 0 6px rgba(0,238,220,0.55))}.nav-logo:hover::before,.nav-logo:hover::after{opacity:1;transform:translate(0,0)}.nav-logo.chopping::before,.nav-logo.chopping::after{opacity:0}.footer-logo{display:inline-flex;align-items:center;text-decoration:none;cursor:pointer;transition:transform .25s,filter .25s}.footer-logo svg{height:30px;width:auto;opacity:.65;transition:opacity .25s}.footer-logo:hover svg{opacity:1;filter:drop-shadow(0 0 6px rgba(0,238,220,0.45))}.footer-logo:hover{transform:translateY(-2px)}.footer-logo:focus-visible{outline:2px solid var(--teal2);outline-offset:4px;border-radius:2px}.modal-body>.modal-subtitle{margin-top:0;margin-bottom:24px}/* === review v3.22.5: collapsible modal sections + mobile bottom-sheet & mockup carousel === */.modal-body>.modal-subtitle{margin-top:0;margin-bottom:24px}details.modal-collapsible{margin-bottom:28px;border:1px solid var(--b1);border-radius:6px;background:rgba(13,18,32,0.5);transition:border-color .25s,background .25s}details.modal-collapsible:hover{border-color:var(--b2)}details.modal-collapsible[open]{border-color:rgba(0,204,184,0.28);background:rgba(0,204,184,0.03)}details.modal-collapsible>summary{cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none;padding:16px 18px;margin-bottom:0;color:var(--d2)}details.modal-collapsible>summary::-webkit-details-marker{display:none}details.modal-collapsible>summary::marker{content:""}details.modal-collapsible>summary::after{content:none}details.modal-collapsible:hover>summary,details.modal-collapsible[open]>summary{color:var(--d3)}.modal-collapsible-chevron{margin-left:auto;font-size:20px;line-height:1;color:var(--teal2);transition:transform .25s ease,color .2s ease;display:inline-block}details.modal-collapsible:hover .modal-collapsible-chevron{color:var(--teal3)}details.modal-collapsible[open]>summary .modal-collapsible-chevron{transform:rotate(90deg)}details.modal-collapsible>.feature-grid{margin-bottom:0;padding:0 18px 18px}details.modal-collapsible:not([open])>.feature-grid{display:none}@media(max-width:640px){details.modal-collapsible>summary{padding:14px}details.modal-collapsible>.feature-grid{padding:0 14px 14px}.proj-modal-overlay{align-items:flex-end;padding:0}.proj-modal{max-width:100%;width:100%;max-height:92vh;border-radius:18px 18px 0 0;border-left:0;border-right:0;border-bottom:0;transform:translateY(100%) scale(1)}.proj-modal-overlay.open .proj-modal{transform:translateY(0) scale(1)}.modal-header{padding:24px 16px 14px;border-radius:18px 18px 0 0}.modal-header::before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);width:38px;height:4px;border-radius:2px;background:var(--b2);z-index:11}.mockup-row,.mockup-row-desktop{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:12px;margin:0 -16px;padding:4px 16px 10px;scroll-padding-left:16px;scrollbar-width:none}.mockup-row-desktop{align-items:center}.mockup-row::-webkit-scrollbar,.mockup-row-desktop::-webkit-scrollbar{display:none}.mockup-wrap,.mockup-wrap-desktop{flex:0 0 82%;scroll-snap-align:start;grid-column:auto}.mockup-row-desktop .phone-frame{max-width:66vw}}/* === service-card flip (v3.22.7) === */.svc-flip{position:relative;display:grid;width:100%;transform-style:preserve-3d;transition:transform .9s cubic-bezier(.22,1,.36,1)}.svc-card.flipped .svc-flip{transform:rotateY(180deg)}.svc-front,.svc-back{grid-area:1/1;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:var(--s1);border:1px solid var(--b1);border-radius:4px;overflow:hidden}.svc-front{position:relative;padding:30px 24px 24px;display:flex;flex-direction:column;gap:14px;min-height:420px;transition:border-color .35s,background .35s,box-shadow .35s}.svc-back{transform:rotateY(180deg);padding:15px 15px 13px;display:flex;flex-direction:column;background:var(--bg)}.svc-card:hover .svc-front{border-color:var(--svc-accent);background:linear-gradient(180deg,var(--svc-accent-dim) 0,var(--s1) 40%);box-shadow:0 8px 30px -10px var(--svc-accent-glow),0 0 0 1px var(--svc-accent-dim)}.svc-card.flipped .svc-back{border-color:var(--svc-accent)}.svc-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:12px;border-top:1px dashed var(--b1);transition:border-color .3s}.svc-card:hover .svc-foot{border-top-color:var(--svc-accent)}.svc-foot .svc-example{margin-top:0;padding-top:0;border-top:0}.svc-flip-hint{flex-shrink:0;display:inline-flex;align-items:center;gap:5px;font-family:'OR',monospace;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--svc-accent-text);opacity:.7;transition:opacity .3s}.svc-card:hover .svc-flip-hint{opacity:1}.svc-flip-ico{width:12px;height:12px;flex-shrink:0}.svc-back-head,.svc-back-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;font-family:'OR',monospace;font-size:9px;letter-spacing:1.5px;color:var(--d1)}.svc-back-foot{padding-top:8px;border-top:1px dashed var(--b1)}.svc-back-tag{color:var(--svc-accent-text)}.svc-back-return{color:var(--d2)}.svc-bp{flex:1;width:100%;min-height:0;display:block;margin:6px 0}.svc-draw{stroke-dasharray:100;stroke-dashoffset:100}.svc-fx{opacity:0}.svc-card.flipped .svc-draw{animation:svcDraw 1.1s ease var(--dl,.5s) forwards}.svc-card.flipped .svc-fx{animation:svcFade .8s ease var(--dl,.5s) forwards}@keyframes svcDraw{to{stroke-dashoffset:0}}@keyframes svcFade{to{opacity:1}}@media(prefers-reduced-motion:reduce){.svc-flip{transition:none}.svc-draw{stroke-dashoffset:0}.svc-fx{opacity:1}}/* === animated process section (v3.22.8) === */.process-anim-wrap{position:relative;width:min(1280px,100vw);margin-top:var(--sp-6,32px);margin-left:50%;margin-right:0;transform:translateX(-50%);aspect-ratio:16/9;overflow:hidden;background:var(--bg)}.process-anim-frame{width:1280px;height:720px;border:0;display:block;background:var(--bg);transform-origin:top left}@media(max-width:720px){.process-anim-wrap{aspect-ratio:9/16;width:min(460px,100vw)}.process-anim-frame{width:720px;height:1280px}}
/* ════════════════════════════════════════════════════
   Portfolio card hover animations
   ════════════════════════════════════════════════════ */
[class*="anim-c"] { transform-box: fill-box; }

@media (prefers-reduced-motion: reduce) {
  [class*="anim-c"] { animation: none !important; }
}

/* ── CARD 1 · Schichtplanungs-App ────────────────── */
.anim-c1-stat, .anim-c1-cal-rect, .anim-c1-cal-num,
.anim-c1-streak-num, .anim-c1-streak-fire, .anim-c1-bar-sara,
.anim-c1-row { transform-origin: center; }
.anim-c1-bar-sara { transform-origin: left center; }
.anim-c1-plus { opacity: 0; }

@keyframes c1-idle {
  0%, 92%, 100% { fill: #ff00aa; transform: scale(1); }
  94% { fill: #ff66c2; transform: scale(1.08); }
  96% { fill: #ff00aa; transform: scale(1); }
}
.proj-card:not(:hover) .anim-c1-stat {
  animation: c1-idle 8s ease-in-out infinite;
}
@keyframes c1-stat-pulse {
  0% { transform: scale(1); fill: #ff00aa; }
  40% { transform: scale(1.22); fill: #ff66c2;
        filter: drop-shadow(0 0 6px rgba(255,0,170,0.7)); }
  100% { transform: scale(1); fill: #ff00aa; filter: none; }
}
.proj-card:hover .anim-c1-stat {
  animation: c1-stat-pulse 0.7s cubic-bezier(.4,.8,.3,1.4) 0.2s 1;
}
@keyframes c1-plus {
  0% { opacity: 0; transform: translate(0, 0); }
  20% { opacity: 1; transform: translate(0, -2px); }
  60% { opacity: 1; transform: translate(0, -10px); }
  100% { opacity: 0; transform: translate(0, -16px); }
}
.proj-card:hover .anim-c1-plus {
  animation: c1-plus 1.1s ease-out 0.3s 1 forwards;
}
@keyframes c1-cal-rect {
  0% { fill: rgba(255,0,170,0); }
  50% { fill: rgba(255,0,170,0.4); }
  100% { fill: rgba(255,0,170,0); }
}
@keyframes c1-cal-scale {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.18);
        filter: drop-shadow(0 0 8px rgba(255,0,170,0.8)); }
}
.proj-card:hover .anim-c1-cal-rect { animation: c1-cal-rect 0.6s ease-out 0.45s 1; }
.proj-card:hover .anim-c1-cal-num { animation: c1-cal-scale 0.6s ease-out 0.45s 1; }
@keyframes c1-streak-num {
  0% { opacity: 1; transform: translateY(0); }
  40% { opacity: 0; transform: translateY(-4px); }
  60% { opacity: 0; transform: translateY(4px); }
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes c1-fire {
  0%, 100% { transform: scale(1); filter: none; }
  50% { transform: scale(1.4) rotate(-6deg);
        filter: drop-shadow(0 0 8px rgba(255,153,0,0.9))
                drop-shadow(0 0 14px rgba(255,0,170,0.6)); }
}
@keyframes c1-bar {
  0% { transform: scaleX(0.9); }
  50% { transform: scaleX(1.05); }
  100% { transform: scaleX(1); }
}
.proj-card:hover .anim-c1-streak-num { animation: c1-streak-num 0.55s ease 0.75s 1; }
.proj-card:hover .anim-c1-streak-fire { animation: c1-fire 0.7s ease 0.85s 1; }
.proj-card:hover .anim-c1-bar-sara { animation: c1-bar 0.6s ease 0.8s 1; }

/* ── CARD 2 · Brand Identity ─────────────────────── */
.anim-c2-swatch, .anim-c2-title { transform-origin: center; }
.anim-c2-label-bar { transform-origin: left center; }

@keyframes c2-swatch-pulse {
  0%, 100% { transform: scale(1); filter: none; }
  50% { transform: scale(1.18);
        filter: drop-shadow(0 0 6px currentColor); }
}
.proj-card:hover .anim-c2-swatch-1 { animation: c2-swatch-pulse .45s ease .20s 1; }
.proj-card:hover .anim-c2-swatch-2 { animation: c2-swatch-pulse .45s ease .30s 1; }
.proj-card:hover .anim-c2-swatch-3 { animation: c2-swatch-pulse .45s ease .40s 1; }
.proj-card:hover .anim-c2-swatch-4 { animation: c2-swatch-pulse .45s ease .50s 1; }
.proj-card:hover .anim-c2-swatch-5 { animation: c2-swatch-pulse .45s ease .60s 1; }

@keyframes c2-label-bar {
  0%, 100% { transform: scaleY(1); filter: none; }
  50% { transform: scaleY(2.4); filter: drop-shadow(0 0 6px #ff00aa); }
}
.proj-card:hover .anim-c2-label-bar { animation: c2-label-bar 0.6s ease 0.95s 1; }

@keyframes c2-title-glow {
  0%, 100% { fill: #00ccb8; filter: none; }
  50% { fill: #00eedc; filter: drop-shadow(0 0 8px rgba(0,204,184,0.8)); }
}
.proj-card:hover .anim-c2-title { animation: c2-title-glow 0.6s ease 1.0s 1; }

@keyframes c2-idle {
  0%, 92%, 100% { transform: scale(1); }
  94% { transform: scale(1.08); } 96% { transform: scale(1); }
}
.proj-card:not(:hover) .anim-c2-swatch-3 {
  animation: c2-idle 8s ease-in-out infinite;
}

/* ── CARD 3 · PL Tool ────────────────────────────── */
.anim-c3-row-beta { transform-origin: left center; }
.anim-c3-status-bg, .anim-c3-status-text, .anim-c3-output-num { transform-origin: center; }
.anim-c3-output-new { opacity: 0; }

@keyframes c3-row-glow {
  0%, 100% { stroke: #182035; stroke-width: 1; }
  50% { stroke: #00ccb8; stroke-width: 1.5; }
}
.proj-card:hover .anim-c3-row-beta { animation: c3-row-glow 0.8s ease 0.3s 1; }

@keyframes c3-status-flash {
  0%, 100% { fill: rgba(255,0,170,0.15); stroke: rgba(255,0,170,0.3); }
  50% { fill: rgba(0,204,184,0.25); stroke: rgba(0,204,184,0.7); }
}
.proj-card:hover .anim-c3-status-bg { animation: c3-status-flash 0.9s ease 0.4s 1; }

@keyframes c3-status-text {
  0% { opacity: 1; }
  30% { opacity: 0; transform: translateY(-3px); }
  50% { opacity: 0; transform: translateY(3px); }
  100% { opacity: 1; transform: translateY(0); }
}
.proj-card:hover .anim-c3-status-text { animation: c3-status-text 0.9s ease 0.4s 1; }

@keyframes c3-output-pulse {
  0%, 100% { transform: scale(1); fill: #00ee88; filter: none; }
  50% { transform: scale(1.25); fill: #66ffaa;
        filter: drop-shadow(0 0 6px rgba(0,238,136,0.7)); }
}
.proj-card:hover .anim-c3-output-num {
  animation: c3-output-pulse 0.6s cubic-bezier(.4,.8,.3,1.4) 0.7s 1;
}
@keyframes c3-output-new {
  0% { opacity: 0; transform: translate(0, 8px); }
  30%, 70% { opacity: 1; transform: translate(0, 0); }
  100% { opacity: 0; transform: translate(0, -6px); }
}
.proj-card:hover .anim-c3-output-new {
  animation: c3-output-new 1.2s ease-out 0.8s 1 forwards;
}
@keyframes c3-idle {
  0%, 92%, 100% { fill: #00ee88; transform: scale(1); }
  94% { fill: #66ffaa; transform: scale(1.05); }
  96% { fill: #00ee88; transform: scale(1); }
}
.proj-card:not(:hover) .anim-c3-output-num {
  animation: c3-idle 8s ease-in-out infinite;
}

/* ── CARD 4 · Gastro Betrieb ─────────────────────── */
.anim-c4-cta { transform-origin: center; }
.anim-c4-notif { opacity: 0; }
.anim-c4-tile-mid { transform-origin: center; }

@keyframes c4-cta-glow {
  0%, 100% { transform: scale(1); filter: none; }
  50% { transform: scale(1.06);
        filter: drop-shadow(0 0 10px rgba(200,134,0,0.9))
                drop-shadow(0 0 20px rgba(200,134,0,0.4)); }
}
.proj-card:hover .anim-c4-cta { animation: c4-cta-glow 0.8s ease 0.2s 1; }

@keyframes c4-notif {
  0% { opacity: 0; transform: translate(20px, 0); }
  15%, 80% { opacity: 1; transform: translate(0, 0); }
  100% { opacity: 0; transform: translate(-4px, 0); }
}
.proj-card:hover .anim-c4-notif {
  animation: c4-notif 1.6s ease-out 0.5s 1 forwards;
}

@keyframes c4-tile-pulse {
  0%, 92%, 100% { transform: scale(1); }
  94% { transform: scale(1.06); } 96% { transform: scale(1); }
}
.proj-card:not(:hover) .anim-c4-tile-mid {
  animation: c4-tile-pulse 8s ease-in-out infinite;
}
