@keyframes aurora1{0%{transform:translate(0,0) rotate(0deg) scale(1)}33%{transform:translate(5%,-3%) rotate(2deg) scale(1.05)}66%{transform:translate(-3%,5%) rotate(-1deg) scale(.98)}to{transform:translate(2%,-2%) rotate(1deg) scale(1.02)}}@keyframes aurora2{0%{transform:translate(0,0) rotate(0deg) scale(1)}33%{transform:translate(-4%,3%) rotate(-2deg) scale(1.03)}66%{transform:translate(3%,-4%) rotate(1deg) scale(.97)}to{transform:translate(-1%,2%) rotate(-1deg) scale(1.01)}}@keyframes gradient-shift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}@keyframes scrollBounce{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}@keyframes contact-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.6}}@keyframes breathing{0%,to{opacity:1}50%{opacity:.6}}:root{--color-bg:#0A0E14;--color-surface:#111820;--color-surface-hover:#161D28;--color-accent:#2DD4A0;--color-accent-dark:#1A9E74;--color-accent-bright:#5EEBC0;--color-blue:#3B82F6;--color-purple:#8B5CF6;--color-text:#F0F2F5;--color-text-secondary:#9CA3AF;--color-text-dim:#7C8491;--color-border:rgba(45, 212, 160, 0.12);--color-border-hover:rgba(45, 212, 160, 0.3);--container-max:1200px;--container-narrow:800px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--space-4xl:80px;--space-5xl:128px;--text-xs:11px;--text-sm:13px;--text-base:16px;--text-lg:18px;--text-xl:20px;--text-2xl:24px;--text-3xl:32px;--text-4xl:40px;--text-5xl:48px;--ease-out:cubic-bezier(0.16, 1, 0.3, 1);--ease-in-out:cubic-bezier(0.65, 0, 0.35, 1);--duration-fast:150ms;--duration-normal:300ms;--duration-slow:600ms;--shadow-card:0 4px 24px rgba(0, 0, 0, 0.2);--shadow-card-hover:0 8px 40px rgba(0, 0, 0, 0.3), 0 0 60px rgba(45, 212, 160, 0.04);--shadow-glow:0 0 30px rgba(45, 212, 160, 0.15);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px}@property --border-angle{syntax:"<angle>";initial-value:0deg;inherits:false}*,::after,::before{margin:0;padding:0;box-sizing:border-box}html{scroll-padding-top:56px;font-size:16px}body{font-family:"Inter","Helvetica Neue",Arial,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.page-grain,.page-vignette{position:fixed;inset:0;pointer-events:none}.page-grain{z-index:10000;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:256px 256px}.page-vignette{z-index:9999;background:radial-gradient(ellipse at 50% 50%,transparent 60%,rgba(10,14,20,.3) 100%)}::selection{background:rgba(45,212,160,.25);color:var(--color-text)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:rgba(45,212,160,.2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(45,212,160,.4)}a{color:inherit;text-decoration:none}ul{list-style:none}.skip-to-content{position:absolute;top:-100%;left:16px;z-index:9999;padding:12px 24px;background:var(--color-accent);color:var(--color-bg);font-weight:500;font-size:14px;border-radius:0 0 8px 8px;transition:top .2s ease;clip:rect(0,0,0,0);overflow:hidden}.skip-to-content:focus{top:0;clip:auto;overflow:visible}:focus-visible,a:focus-visible,button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}a:focus-visible,button:focus-visible{border-radius:4px}.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-lg)}.btn{display:inline-flex;align-items:center;gap:8px;font-family:"Inter",sans-serif;font-weight:500;border-radius:var(--radius-sm);transition:all var(--duration-normal) var(--ease-out);cursor:pointer;border:0;text-decoration:none;letter-spacing:.3px}.btn-ghost,.btn-primary{padding:14px 32px;font-size:15px}.btn-primary{color:var(--color-bg);background:linear-gradient(135deg,var(--color-accent),var(--color-accent-bright));box-shadow:0 2px 16px rgba(45,212,160,.2)}.btn-primary:hover{box-shadow:0 4px 30px rgba(45,212,160,.3),0 0 60px rgba(45,212,160,.1);transform:translateY(-2px)}.btn-ghost{color:var(--color-accent);background:0 0;border:1px solid rgba(45,212,160,.3)}.btn-ghost:hover{background:rgba(45,212,160,.08);border-color:rgba(45,212,160,.5);transform:translateY(-2px)}.btn-sm{padding:8px 20px;font-size:13px}.bracket,.nav-links a::after{transition:transform var(--duration-normal) var(--ease-out)}.bracket{color:var(--color-accent);font-family:"JetBrains Mono",monospace;display:inline-block}.bracket-open{margin-right:2px}.bracket-close{margin-left:-2px}.logo-text,.section-label{color:var(--color-text);font-family:"JetBrains Mono",monospace;letter-spacing:4px}.section-label{font-size:var(--text-sm);font-weight:500;color:var(--color-accent);letter-spacing:3px;text-transform:uppercase;margin-bottom:var(--space-md)}.comment-slash{color:rgba(45,212,160,.5);text-shadow:0 0 10px rgba(45,212,160,.3)}.section-heading{font-family:"Inter",sans-serif;font-size:var(--text-3xl);font-weight:600;color:var(--color-text);line-height:1.2;margin-bottom:var(--space-2xl)}.cursor-glow{position:fixed;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(45,212,160,.06)0,transparent 70%);pointer-events:none;z-index:9996;transform:translate(-50%,-50%);will-change:transform;opacity:0;transition:opacity .5s ease}.cursor-glow.active{opacity:1}.hamburger span,.navbar{transition:all var(--duration-normal) ease}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0}.navbar.scrolled{background:rgba(10,14,20,.85);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);padding:14px 0;border-bottom:1px solid rgba(45,212,160,.08)}.nav-container{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-lg);display:flex;align-items:center;justify-content:space-between}.nav-logo{font-size:18px;font-weight:500;transition:opacity var(--duration-normal) ease}.nav-logo:hover{opacity:.8}.nav-logo:hover .bracket-open{transform:translateX(-3px)}.nav-logo:hover .bracket-close{transform:translateX(3px)}.nav-links{display:flex;gap:var(--space-xl);align-items:center}.nav-links a{font-size:14px;color:var(--color-text-secondary);transition:color var(--duration-normal) ease;position:relative}.nav-links a::after{content:"";position:absolute;bottom:-6px;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--color-accent),rgba(45,212,160,.3));transform:scaleX(0);transform-origin:left}.nav-links a.active,.nav-links a:hover{color:var(--color-text)}.nav-links a.active::after,.nav-links a:hover::after{transform:scaleX(1)}.nav-cta{margin-left:var(--space-md)}.hamburger{display:none;flex-direction:column;gap:5px;background:0 0;border:0;cursor:pointer;padding:4px}.hamburger span{display:block;width:22px;height:2px;background:var(--color-text);border-radius:2px}.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.hero{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:100px 24px;overflow:hidden}.hero::after,.hero::before{content:"";position:absolute;inset:-50%;z-index:0}.hero::before{background:radial-gradient(ellipse 80% 50%at 20% 60%,rgba(45,212,160,.07)0,transparent 60%),radial-gradient(ellipse 60% 80%at 80% 30%,rgba(30,100,180,.06)0,transparent 60%),radial-gradient(ellipse 50% 60%at 50% 80%,rgba(139,92,246,.04)0,transparent 60%);animation:aurora1 15s ease-in-out infinite alternate}.hero::after{background:radial-gradient(ellipse 70% 60%at 70% 70%,rgba(45,212,160,.05)0,transparent 60%),radial-gradient(ellipse 50% 70%at 30% 40%,rgba(59,130,246,.05)0,transparent 60%);animation:aurora2 20s ease-in-out infinite alternate-reverse}.hero-grid{position:absolute;inset:0;z-index:1;background:radial-gradient(circle,rgba(45,212,160,.15) 1px,transparent 1px);background-size:32px 32px;mask-image:radial-gradient(ellipse 60% 50%at 50% 50%,#000 20%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 60% 50%at 50% 50%,#000 20%,transparent 70%)}.hero-content{position:relative;z-index:2;opacity:0;transform:translateY(20px);animation:fadeInUp .8s ease forwards;animation-delay:.2s}.hero-logo{font-size:var(--text-5xl);font-weight:400;margin-bottom:2px}.hero-logo .bracket{text-shadow:0 0 30px rgba(45,212,160,.4),0 0 60px rgba(45,212,160,.1)}.hero-tagline-wrapper{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:40px}.hero-tagline-line{flex:0 1 80px;height:1px;background:linear-gradient(90deg,transparent,rgba(45,212,160,.3),transparent)}.hero-tagline{font-family:"Inter",sans-serif;font-size:12px;letter-spacing:5px;background:linear-gradient(90deg,var(--color-accent),var(--color-text-dim),var(--color-accent));background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradient-shift 8s ease infinite}.hero-description{font-size:var(--text-base);color:var(--color-text-secondary);max-width:480px;margin:0 auto;line-height:1.7}.hero-ctas,.hero-tech{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}.hero-ctas{gap:var(--space-md);margin-top:40px}.hero-tech{gap:var(--space-lg);margin-top:var(--space-3xl)}.hero-tech span{font-family:"JetBrains Mono",monospace;font-size:var(--text-sm);color:var(--color-text-dim);opacity:0;animation:fadeInUp .5s ease forwards;letter-spacing:1px}.hero-tech span:nth-child(1){animation-delay:1.2s}.hero-tech span:nth-child(2){animation-delay:1.3s}.hero-tech span:nth-child(3){animation-delay:1.4s}.hero-tech span:nth-child(4){animation-delay:1.5s}.hero-tech span:nth-child(5){animation-delay:1.6s}.hero-tech span:nth-child(6){animation-delay:1.7s}.hero-tech span:nth-child(7){animation-delay:1.8s}.hero-tech span:nth-child(8){animation-delay:1.9s}.hero-tech span:nth-child(9){animation-delay:2s}.hero-tech span:nth-child(10){animation-delay:2.1s}.hero-tech span:nth-child(11){animation-delay:2.2s}.hero-tech span:nth-child(12){animation-delay:2.3s}.hero-tech span:nth-child(13){animation-delay:2.4s}.hero-tech span:nth-child(14){animation-delay:2.5s}.hero-tech span:nth-child(15){animation-delay:2.6s}.hero-tech .separator{color:rgba(45,212,160,.2)}.scroll-indicator,.section::before{position:absolute;left:50%;transform:translateX(-50%)}.scroll-indicator{bottom:40px;z-index:2;opacity:.4;animation:scrollBounce 2s ease-in-out infinite;transition:opacity var(--duration-normal) ease}.card-icon svg,.scroll-indicator svg{width:24px;height:24px;stroke:var(--color-accent);fill:none;stroke-width:2}.section{padding:var(--space-5xl)0;position:relative}.section::before{content:"";top:0;width:min(100%,var(--container-max));height:1px;background:linear-gradient(90deg,transparent,rgba(45,212,160,.15),transparent);transition:background var(--duration-slow) ease}.section.glow-border::before{background:linear-gradient(90deg,transparent 10%,rgba(45,212,160,.5) 50%,transparent 90%)}.reveal{opacity:0;transform:translateY(30px);filter:blur(4px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out),filter .8s var(--ease-out)}.reveal.visible{filter:blur(0)}.stagger-item{opacity:0;transform:translateY(20px);transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out)}.reveal.visible,.stagger-item.stagger-visible{opacity:1;transform:translateY(0)}.services-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.card{position:relative;background:linear-gradient(135deg,rgba(45,212,160,.04),rgba(45,212,160,.01));border:.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2xl);transition:all var(--duration-normal) var(--ease-out);overflow:hidden}.card::before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(45,212,160,.08),transparent 40%);opacity:0;transition:opacity var(--duration-normal) ease;pointer-events:none;z-index:1}.card::after,.tag::before{content:"";position:absolute;top:0}.card::after{left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--color-accent),transparent);opacity:0;transition:opacity var(--duration-normal) ease}@media (hover:hover){.card:hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02));transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}.card:hover::after,.card:hover::before{opacity:1}}.card.hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02))}.card-icon,.card-title{position:relative;z-index:2}.card-icon{width:48px;height:48px;border-radius:50%;background:rgba(45,212,160,.1);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-lg)}.card-icon svg{stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.card-title{font-family:"Inter",sans-serif;font-size:var(--text-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-sm)}.card-description{font-size:14px;color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--space-md);position:relative;z-index:2}.card-tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);z-index:2}.card-tags,.tag,.timeline{position:relative}.tag{font-family:"JetBrains Mono",monospace;font-size:var(--text-xs);color:var(--color-accent);background:rgba(45,212,160,.06);border:.5px solid var(--color-border);padding:4px 10px;border-radius:4px;overflow:hidden}.tag::before{left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(45,212,160,.15),transparent);transition:left .5s ease}@media (hover:hover){.card:hover .tag::before,.process-step:hover .tag::before,.reference-card:hover .tag::before{left:100%}}.timeline{padding-left:80px}.timeline-line{position:absolute;top:0;bottom:0;left:31px;width:2px;background:linear-gradient(to bottom,var(--color-accent),rgba(45,212,160,.1));transform:scaleY(0);transform-origin:top;transition:transform 1.2s var(--ease-out)}.reveal.visible .timeline-line{transform:scaleY(1)}.timeline-step{position:relative;margin-bottom:var(--space-2xl);padding:var(--space-lg) var(--space-xl);background:linear-gradient(135deg,rgba(45,212,160,.04),rgba(45,212,160,.01));border:.5px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--duration-normal) var(--ease-out);overflow:hidden}.timeline-step::before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(45,212,160,.08),transparent 40%);opacity:0;transition:opacity var(--duration-normal) ease;pointer-events:none}.timeline-step:last-child{margin-bottom:0}@media (hover:hover){.timeline-step:hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02));transform:translateX(4px);box-shadow:var(--shadow-card)}.timeline-step:hover::before{opacity:1}}.timeline-step.hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02))}.step-node{position:absolute;left:-80px;top:var(--space-lg);width:48px;height:48px;border-radius:50%;border:2px solid var(--color-accent);display:flex;align-items:center;justify-content:center;background:var(--color-bg);z-index:2}.step-number,.step-title{font-size:var(--text-base)}.step-number{font-family:"JetBrains Mono",monospace;font-weight:700;color:var(--color-accent);line-height:1;text-shadow:0 0 20px rgba(45,212,160,.3)}@media (hover:hover){.timeline-step:hover .step-number{text-shadow:0 0 30px rgba(45,212,160,.5),0 0 60px rgba(45,212,160,.2)}}.step-title{font-family:"Inter",sans-serif;font-weight:600;color:var(--color-text);margin-bottom:6px}.step-description{font-size:14px;color:var(--color-text-secondary);line-height:1.7}.references{display:flex;flex-direction:column;gap:var(--space-3xl)}.reference-card{display:flex;gap:var(--space-2xl);align-items:center;background:linear-gradient(135deg,rgba(45,212,160,.04),rgba(45,212,160,.01));border:.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2xl);transition:all var(--duration-normal) var(--ease-out);overflow:hidden;position:relative}.reference-card::before{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(45,212,160,.08),transparent 40%);opacity:0;transition:opacity var(--duration-normal) ease;pointer-events:none;z-index:1}.reference-card:nth-child(even){flex-direction:row-reverse}@media (hover:hover){.reference-card:hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02));box-shadow:var(--shadow-card-hover)}.reference-card:hover::before{opacity:1}}.reference-card.hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02))}.reference-screenshot{flex:0 0 55%;position:relative;z-index:2}.device-frame{background:#1a1f28;border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(255,255,255,.06);box-shadow:var(--shadow-card);transition:all var(--duration-normal) var(--ease-out)}@media (hover:hover){.reference-card:hover .device-frame{box-shadow:0 20px 40px rgba(0,0,0,.3);transform:scale(1.02) rotateX(1deg)}}.device-frame-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#141920;border-bottom:1px solid rgba(255,255,255,.04)}.device-frame-dot{width:8px;height:8px;border-radius:50%}.device-frame-dot:nth-child(1){background:#ff5f57}.device-frame-dot:nth-child(2){background:#ffbd2e}.device-frame-dot:nth-child(3){background:#28ca41}.device-frame .screenshot-img{width:100%;height:auto;display:block}.reference-details{flex:1;position:relative;z-index:2}.reference-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.reference-icon{width:52px;height:52px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-size:var(--text-lg);font-weight:700;flex-shrink:0}.kiertue-icon{background:rgba(45,212,160,.15);color:var(--color-accent)}.pesakirja-icon{background:rgba(59,130,246,.15);color:var(--color-blue)}.reference-name{font-family:"JetBrains Mono",monospace;font-size:15px;font-weight:600;color:var(--color-text);letter-spacing:1px}.footer-links a,.reference-url{font-size:var(--text-sm);color:var(--color-text-dim);transition:color var(--duration-normal) ease}.footer-contact-info a:hover,.footer-links a:hover,.reference-url:hover{color:var(--color-accent)}.reference-description{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--space-lg)}.reference-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--color-accent);padding:10px 24px;border:1px solid rgba(45,212,160,.3);border-radius:var(--radius-sm);margin-top:var(--space-sm);transition:all var(--duration-normal) var(--ease-out)}.reference-link:hover{background:rgba(45,212,160,.08);border-color:rgba(45,212,160,.5);transform:translateY(-2px)}.articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.article-card,.article-tag{border:.5px solid var(--color-border);position:relative}.article-card{display:flex;flex-direction:column;padding:var(--space-xl);background:linear-gradient(135deg,rgba(45,212,160,.04),rgba(45,212,160,.01));border-radius:var(--radius-lg);transition:all var(--duration-normal) var(--ease-out);text-decoration:none;overflow:hidden}.article-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--color-accent),transparent);opacity:.5}.article-card::after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(45,212,160,.08),transparent 40%);opacity:0;transition:opacity var(--duration-normal) ease;pointer-events:none}@media (hover:hover){.article-card:hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02));transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}.article-card:hover::after{opacity:1}.article-card:hover .article-card-link{transform:translateX(4px)}}.article-card.hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02))}.article-tag{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:var(--text-xs);color:var(--color-accent);background:rgba(45,212,160,.06);padding:3px 10px;border-radius:4px;margin-bottom:12px;letter-spacing:.5px;z-index:2}.article-card-title{font-family:"Inter",sans-serif;font-size:var(--text-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-sm);line-height:1.4;position:relative;z-index:2;flex-grow:1}.article-card-excerpt{font-size:15px;color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-md);position:relative;z-index:2}.article-card-link{font-size:14px;color:var(--color-accent);transition:all var(--duration-normal) var(--ease-out);position:relative;z-index:2;display:inline-block}.articles-all{text-align:center;margin-top:var(--space-2xl)}.section-contact{background:linear-gradient(135deg,rgba(45,212,160,.04),rgba(59,130,246,.03))}.contact-content{text-align:center}.contact-intro{font-size:var(--text-lg);color:var(--color-text-secondary);margin-bottom:var(--space-xl)}.contact-email-btn{display:inline-flex;align-items:center;gap:8px;font-family:"Inter",sans-serif;font-size:var(--text-base);font-weight:500;color:var(--color-bg);background:linear-gradient(135deg,var(--color-accent),var(--color-accent-bright));padding:16px 40px;border-radius:var(--radius-sm);border:0;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);box-shadow:0 2px 16px rgba(45,212,160,.2);position:relative;text-decoration:none}.contact-email-btn:hover{box-shadow:0 4px 30px rgba(45,212,160,.3),0 0 60px rgba(45,212,160,.1);transform:translateY(-2px)}.contact-glow{position:relative;display:inline-block}.contact-glow::after{content:"";position:absolute;inset:-20px;border-radius:50%;background:radial-gradient(ellipse,rgba(45,212,160,.08)0,transparent 70%);z-index:-1;animation:contact-pulse 3s ease-in-out infinite}.contact-email-text{font-size:14px;color:var(--color-text-dim);margin-top:var(--space-md)}.footer{position:relative;padding:var(--space-3xl)0 var(--space-2xl)}.footer::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(100%,var(--container-max));height:1px;background:linear-gradient(90deg,transparent,rgba(45,212,160,.2),transparent)}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--space-2xl);margin-bottom:var(--space-2xl)}.footer-brand .footer-logo{font-size:var(--text-base);display:block;margin-bottom:var(--space-sm)}.footer-brand .footer-logo .bracket{animation:breathing 4s ease-in-out infinite}.footer-brand .footer-logo .bracket-close{animation-delay:.2s}.footer-brand-desc{font-size:var(--text-sm);color:var(--color-text-dim);line-height:1.6;max-width:300px}.footer-heading{font-family:"JetBrains Mono",monospace;font-size:var(--text-xs);font-weight:500;color:var(--color-accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:var(--space-md)}.footer-links{display:flex;flex-direction:column;gap:var(--space-sm)}.footer-contact-info p{line-height:1.8}.footer-contact-info a{transition:color var(--duration-normal) ease}.footer-bottom{padding-top:var(--space-lg);border-top:1px solid rgba(45,212,160,.06);text-align:center}.footer-contact-info p,.footer-copy{font-size:var(--text-sm);color:var(--color-text-dim)}.blog-header{padding:20px 0;border-bottom:1px solid rgba(45,212,160,.08)}.blog-nav{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-lg);display:flex;align-items:center;justify-content:space-between}.blog-back{font-size:14px;color:var(--color-text-secondary);transition:color var(--duration-normal) ease}.blog-back:hover,.blog-cta a{color:var(--color-accent)}.blog-content{max-width:680px;margin:0 auto;padding:120px 24px 80px}.blog-body h2,.blog-title{font-family:"Inter",sans-serif;margin-bottom:var(--space-md)}.blog-title{font-size:var(--text-4xl);font-weight:600;color:var(--color-text);line-height:1.2}.blog-meta{font-size:14px;color:var(--color-text-dim);margin-bottom:var(--space-2xl)}.blog-body h2{font-size:var(--text-xl);margin-top:var(--space-2xl)}.blog-body p{line-height:1.8;margin-bottom:20px}.blog-body ul{list-style:disc;padding-left:24px;margin-bottom:20px}.blog-body li,.blog-body p,.blog-cta p{font-size:var(--text-base);color:var(--color-text-secondary)}.blog-body li{line-height:1.8;margin-bottom:8px}.blog-body h2,.blog-body strong{color:var(--color-text);font-weight:600}.blog-cta{margin-top:var(--space-3xl);padding:var(--space-xl);background:linear-gradient(135deg,rgba(45,212,160,.04),rgba(45,212,160,.01));border:.5px solid var(--color-border);border-radius:var(--radius-lg);text-align:center}.blog-cta p{margin-bottom:12px}.blog-cta a{font-weight:500;font-size:var(--text-lg);transition:opacity var(--duration-normal) ease}.blog-cta a:hover{opacity:.8}.blog-list{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.blog-list-item{display:block;padding:var(--space-xl);background:linear-gradient(135deg,rgba(45,212,160,.04),rgba(45,212,160,.01));border:.5px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.blog-list-item::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--color-accent),transparent);opacity:.5}@media (hover:hover){.blog-list-item:hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02));transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}}.blog-list-item.hover{border-color:var(--color-border-hover);background:linear-gradient(135deg,rgba(45,212,160,.06),rgba(45,212,160,.02))}.blog-list-title{font-family:"Inter",sans-serif;font-size:var(--text-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-sm)}.blog-list-excerpt{font-size:15px;color:var(--color-text-secondary);line-height:1.6}.blog-list-date{font-size:var(--text-sm);color:var(--color-text-dim);margin-top:12px}@media (max-width:1024px){.articles-grid{grid-template-columns:1fr 1fr}.reference-card,.reference-card:nth-child(even){flex-direction:column}.reference-screenshot{flex:none;width:100%}.footer-grid{grid-template-columns:1fr 1fr}.section-heading{font-size:var(--text-2xl)}}@media (max-width:768px){body,html{overflow-x:hidden}.hamburger{display:flex;z-index:1002;position:relative}.nav-links{position:fixed;top:0;right:-100%;width:70%;max-width:280px;height:100vh;height:100dvh;background:var(--color-surface);flex-direction:column;padding:80px 32px 32px;gap:24px;transition:right var(--duration-normal) ease;border-left:1px solid var(--color-border);z-index:1001}.nav-links.open{right:0}.nav-cta{display:none}.nav-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1000}.nav-overlay.open{display:block}.nav-links a{font-size:16px}.hero-logo{font-size:var(--text-3xl)}.hero-tagline{font-size:11px;letter-spacing:4px}.hero-tagline-line{flex:0 1 40px}.hero-tech{gap:var(--space-md)}.hero-tech span{font-size:var(--text-xs)}.services-grid{grid-template-columns:1fr}.section{padding:var(--space-4xl)0}.section-heading{font-size:var(--text-xl)}.card{padding:var(--space-xl)}.timeline{padding-left:56px}.timeline-line{left:19px}.step-node{width:36px;height:36px;left:-56px}.step-number{font-size:14px}.timeline-step{padding:var(--space-lg)}.hero-ctas{flex-direction:column;gap:12px}.btn-ghost,.btn-primary{width:100%;justify-content:center}.screenshot-placeholder{height:150px}.blog-title{font-size:var(--text-2xl)}.blog-content{padding:120px 16px 48px}.blog-logo-banner{padding:16px 20px;gap:14px}.blog-logo-banner img{width:40px;height:40px}.blog-logo-banner-text h3{font-size:17px}.blog-logo-banner-text p{font-size:var(--text-sm)}.blog-highlight-box{padding:18px 20px}.blog-image,.blog-image-full{margin:24px 0;border-radius:var(--radius-sm)}.blog-image-caption{margin-top:-14px;margin-bottom:24px;font-size:12px}.articles-grid{grid-template-columns:1fr}.article-card{padding:20px}.article-card-title{font-size:var(--text-base)}.blog-list{grid-template-columns:1fr}.blog-list-item{padding:20px}.blog-list-title{font-size:var(--text-base)}.footer-grid{grid-template-columns:1fr;gap:var(--space-xl)}.cookie-content{flex-direction:column;text-align:center;gap:12px}.scroll-indicator{bottom:24px}}.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:2000;background:var(--color-surface);border-top:1px solid rgba(45,212,160,.15);padding:20px 24px;transition:transform .4s ease}.cookie-banner.visible{transform:translateY(0)}.cookie-banner,.cookie-banner.hidden{transform:translateY(100%)}.cookie-content{max-width:var(--container-max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}.blog-logo-banner-text p,.cookie-text{font-size:14px;color:var(--color-text-secondary)}.cookie-text{line-height:1.5}.cookie-actions{display:flex;gap:10px;flex-shrink:0}.cookie-btn{font-family:"Inter",sans-serif;font-size:var(--text-sm);font-weight:500;padding:8px 20px;border-radius:6px;border:0;cursor:pointer;transition:all var(--duration-normal) ease}.cookie-btn-accept{background:var(--color-accent);color:var(--color-bg)}.cookie-btn-accept:hover{background:var(--color-accent-dark)}.cookie-btn-decline{background:0 0;color:var(--color-text-secondary);border:.5px solid rgba(156,163,175,.3)}.cookie-btn-decline:hover{color:var(--color-text);border-color:rgba(156,163,175,.5)}.blog-image{width:100%;max-width:100%;height:auto;border-radius:var(--radius-md);margin:32px 0;border:1px solid rgba(255,255,255,.08);overflow:hidden}.blog-image-caption{text-align:center;font-size:var(--text-sm);color:var(--color-text-dim);margin-top:-20px;margin-bottom:32px;font-style:italic}.blog-image-full{width:100%;max-width:100%;height:auto;border-radius:var(--radius-md);margin:40px 0;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 24px rgba(0,0,0,.3);overflow:hidden}.blog-highlight-box,.blog-logo-banner{border-radius:var(--radius-md);margin:32px 0}.blog-logo-banner{display:flex;align-items:center;gap:20px;padding:24px 32px;background:rgba(37,99,235,.06);border:1px solid rgba(37,99,235,.15)}.blog-logo-banner img{width:56px;height:56px;flex-shrink:0}.blog-logo-banner-text h3{font-family:"Inter",sans-serif;font-size:var(--text-xl);font-weight:700;color:var(--color-text);margin:0 0 4px}.blog-logo-banner-text p{margin:0}.blog-highlight-box{background:rgba(45,212,160,.05);border:1px solid rgba(45,212,160,.15);padding:24px 28px}.blog-highlight-box p{margin:0;color:#d1d5db;font-size:15px;line-height:1.7}.blog-highlight-box strong{color:var(--color-accent)}.koodinorppa-icon{background:rgba(231,176,64,.16);color:#E7B040}
.koodinorppa-showcase{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl) var(--space-lg);background:linear-gradient(135deg,rgba(231,176,64,.10),rgba(231,176,64,.02));border-radius:var(--radius-md);border:1px solid rgba(231,176,64,.18);box-shadow:var(--shadow-card);transition:all var(--duration-normal) var(--ease-out);min-height:300px;position:relative;overflow:hidden}
.koodinorppa-showcase::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(231,176,64,.10),transparent 70%);pointer-events:none}
.koodinorppa-phone{flex:0 0 auto;width:42%;max-width:200px;aspect-ratio:9/19;background:#0A1623;border-radius:24px;border:6px solid #1A3349;overflow:hidden;box-shadow:0 14px 32px rgba(0,0,0,.45);position:relative;z-index:1}
.koodinorppa-phone img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}
.koodinorppa-mascot{flex:0 0 auto;width:44%;max-width:220px;height:auto;position:relative;z-index:1;filter:drop-shadow(0 10px 22px rgba(0,0,0,.35))}
@media (hover:hover){.reference-card:hover .koodinorppa-showcase{box-shadow:0 22px 44px rgba(0,0,0,.32);transform:scale(1.015)}}
@media (max-width:640px){.koodinorppa-showcase{min-height:240px;padding:var(--space-lg) var(--space-md)}.koodinorppa-phone{width:38%}.koodinorppa-mascot{width:46%}}
@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reveal{filter:none}.hero-content,.reveal,.stagger-item{opacity:1;transform:none}.hero-tech span{opacity:1}.timeline-line{transform:scaleY(1)}}