:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--primary:#1c1917;--secondary:#44403c;--cta:#c2410c;--background:#fafaf9;--text:#292524;--accent:#ea580c;--white:#fff;--glass:#1c19171a;--gap:24px;--radius:12px;--section-pad:128px;--font-heading:"Playfair Display", serif;--font-body:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", monospace;--h1-size:clamp(2.5rem, 4.5vw, 4.5rem);--h2-size:clamp(2rem, 5vw, 3rem);--h3-size:1.5rem}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}.hero-title{font-size:var(--h1-size);font-family:var(--font-heading);color:var(--white);margin-bottom:2rem;font-weight:900;line-height:1.1}.hero-title .sub-text{margin-left:.5rem;display:inline}.hero-title .main-word{display:inline}body{background-color:var(--background);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4{font-family:var(--font-heading);color:var(--primary);font-weight:700}h1{font-size:var(--h1-size)}h2{font-size:var(--h2-size)}h3{font-size:var(--h3-size)}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important}}:focus-visible{outline:3px solid var(--accent);outline-offset:4px}.container{max-width:1240px;margin:0 auto;padding:0 20px}@media (width<=600px){.container{padding:0 16px}}header{z-index:1000;background:#000;border-bottom:1px solid #ffffff1a;padding:.5rem 0;position:sticky;top:0}header .container{max-width:100%;padding:0 5% 0 2%}nav{justify-content:space-between;align-items:center;display:flex}.logo{color:var(--white);cursor:pointer;align-items:center;text-decoration:none;display:flex}.navbar-logo{filter:invert()hue-rotate(180deg);width:auto;height:78px;transition:transform .3s}@media (width<=600px){.navbar-logo{height:52px}}.logo:hover .navbar-logo{transform:scale(1.05)}.nav-links{align-items:center;gap:2rem;display:flex}.nav-links a{color:var(--white);cursor:pointer;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.nav-links a:hover{color:var(--accent);transform:translateY(-1px)}.nav-links .btn:hover{color:var(--white)!important}.btn{background:var(--cta);color:var(--white);border-radius:var(--radius);cursor:pointer;text-align:center;z-index:1;border:none;padding:14px 28px;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-block;position:relative;overflow:hidden}.btn:hover{background:var(--accent);transform:translateY(-2px);box-shadow:0 10px 20px #c2410c33}.btn:active{transform:translateY(0)}.hero-palvelut-wrapper{background-color:#0000;position:relative;overflow:hidden}.hero{background:0 0;align-items:stretch;min-height:85vh;padding:0;display:flex;position:relative;overflow:hidden}.hero-left-overlay{-webkit-backdrop-filter:blur(25px);clip-path:polygon(0 0,100% 0,85% 100%,0 100%);z-index:2;background:#000;justify-content:flex-start;align-items:center;width:60%;padding:120px 5% 120px 2%;display:flex;position:relative}@media (width<=1200px) and (width>=901px){.hero-left-overlay{clip-path:polygon(0 0,100% 0,85% 100%,0 100%);width:55%;padding:80px 5% 80px 2%}.hero-content{max-width:500px}.hero-content h1{word-break:normal;overflow-wrap:normal;-webkit-hyphens:none;hyphens:none;font-size:clamp(1.6rem,3.5vw,2.5rem)}.hero-content p{margin-bottom:32px;font-size:1rem}}@media (width<=900px){.hero-left-overlay{clip-path:none;width:100%;min-height:60vh;padding:100px 5%}}.hero-content{max-width:650px;color:var(--white);text-align:left}.hero-content h1{color:var(--white);opacity:0;margin-bottom:32px;line-height:1.15;transform:translateY(20px)}.hero-content h1.animate-in{opacity:1;animation:1s cubic-bezier(.4,0,.2,1) forwards fadeUp;transform:translateY(0)}.hero-content p{max-width:650px;color:var(--white);opacity:0;margin:0 0 48px;font-size:1.35rem;transform:translateY(20px)}.hero-content p.animate-in{opacity:1;animation:1s cubic-bezier(.4,0,.2,1) forwards fadeUp;transform:translateY(0)}.bento-grid{gap:var(--gap);grid-template-columns:repeat(3,1fr);margin-top:40px;padding-bottom:80px;display:grid}.bento-card{border-radius:var(--radius);aspect-ratio:1;cursor:pointer;background-color:#0000;background-position:50%;background-size:cover;border:1px solid #1c19170d;flex-direction:column;justify-content:flex-end;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.bento-card:hover{z-index:2;transform:scale(1.02);box-shadow:0 20px 40px #1c19171a}#referenssit{padding-top:100px}#referenssit .bento-card{cursor:default;pointer-events:none}#referenssit .bento-card:hover{box-shadow:none;z-index:1;transform:none}.bento-card[data-project=ref1]{background-image:url(/static/core-CQ5aFgqm.jpg)}.bento-card[data-project=ref2]{background-image:url(/static/core-BADU3yhf.jpg)}.bento-card[data-project=ref3]{background-image:url(/static/core-BHFKF-Lg.jpg)}.bento-card[data-project=ref4]{background-image:url(/static/core-DKXPS5Si.jpg)}.bento-card[data-project=ref5]{background-image:url(/static/core-yH0ujhq8.jpg)}.bento-card[data-project=ref6]{background-image:url(/static/core-CTQZFQfN.jpg)}.bento-card[data-project=ref7]{background-image:url(/static/core-QO5mp5NT.jpg)}.bento-card[data-project=ref8]{background-image:url(/static/core-qcjRE16K.jpg)}.bento-card[data-project=ref9]{background-image:url(/static/core-Ce2GZrG0.jpg)}.card-overlay{color:#fff;opacity:.9;background:linear-gradient(#0000,#1c1917cc);flex-direction:column;justify-content:flex-end;padding:20px;transition:opacity .3s;display:flex;position:absolute;inset:0}.bento-card:hover .card-overlay{opacity:1}.btn-read-more{display:none}.bento-card:hover .btn-read-more{opacity:1;pointer-events:auto;transform:translate(-50%,-50%)scale(1)}.btn-read-more:hover{color:var(--accent);background:#fff;transform:translate(-50%,-50%)scale(1.05)}.card-overlay .card-icon{color:var(--accent);background:#ffffff1a}.card-1{color:#fff;grid-area:span 2/span 2}.card-2{grid-area:span 1/span 2}.card-3,.card-4{grid-area:span 1/span 1}.card-5{grid-area:span 1/span 2}.bento-card h3{margin-bottom:8px}.card-1 h3{color:#fff;font-size:2.5rem}.card-overlay h3,.card-overlay p{color:#fff;z-index:2;position:relative}.stats-bar,.stats-bar-continuity{background:var(--primary)}.contact-section{background:var(--primary);padding:var(--section-pad) 0}.stats-bar{text-align:center;color:#fff;flex-wrap:wrap;justify-content:space-around;gap:20px;padding:140px 0;display:flex}.contact-section{padding:var(--section-pad) 0;background:#2a2a2a;position:relative}.stat-item h2{color:#fff;margin-bottom:8px;font-size:clamp(2.5rem,8vw,3.5rem);font-weight:800}.stat-item p{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:2px;color:#cbd5e1;font-size:.9rem}.cta-grid{grid-template-columns:1fr 1fr;align-items:flex-start;gap:80px;display:grid}.cta-left{text-align:center;flex-direction:column;justify-content:flex-start;align-items:center;padding:0 20px;display:flex}.cta-header{text-align:center;width:100%}.cta-header .section-title{margin-top:0!important}.cta-title{color:#fff;font-size:clamp(2rem,5vw,3.5rem);font-weight:700;font-family:var(--font-heading);margin-top:0;margin-bottom:1.5rem}.cta-buttons{z-index:10;flex-direction:column;align-items:center;gap:1.2rem;margin-top:1.5rem;display:flex;position:relative}.cta-buttons .btn{border-radius:12px;justify-content:center;align-items:center;gap:12px;min-width:280px;padding:16px 64px 16px 32px;font-size:1.1rem;font-weight:600;line-height:1;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex}.cta-image{aspect-ratio:1.1;object-fit:cover;object-position:center;border-radius:24px;width:100%;display:block;box-shadow:0 20px 40px #0000004d}@media (width<=900px){.cta-grid{grid-template-columns:1fr;gap:40px}.cta-left{text-align:center}.cta-buttons{align-items:center}}.btn-primary{background-color:var(--accent);color:#fff;border:1px solid var(--accent)}.btn-primary:hover{background-color:#d9480f;transform:translateY(-2px);box-shadow:0 10px 20px #ea580c33}.btn-outline{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#ffffff0d;border:1px solid #fff3}.btn-outline:hover{background-color:#ffffff1a;border-color:#fff;transform:translateY(-2px);box-shadow:0 10px 20px #0003}@media (width<=600px){.cta-buttons .btn{justify-content:center;width:100%}}.contact-info .label{font-family:var(--font-mono);color:#94a3b8;text-transform:uppercase;letter-spacing:2.5px;font-size:.8rem}.contact-info .value{color:#fff;font-size:1.75rem;font-weight:700;font-family:var(--font-heading);transition:color .3s}.contact-card:hover .value{color:var(--accent)}.section-title{margin-bottom:60px}.section-title.text-center{text-align:center}.mono-label{font-family:var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:2px;margin-bottom:12px;font-size:calc(.7rem + 4px)}.mono-label-large{font-size:calc(.7rem + 7px)}.section-title h2{color:var(--primary);font-size:2.5rem}.referenced-title{font-size:calc(2.5rem - 3px)!important}.testimonial-title{font-size:clamp(1.8rem,7vw,2.8rem)!important}.section-subtext{color:var(--white);opacity:.9;max-width:800px;margin:20px auto 0;font-size:1.1rem;line-height:1.6}.palvelut-overview .section-title h2,.palvelut-overview .mono-label{color:var(--white)}.palvelut-overview{padding:var(--section-pad) 0;-webkit-backdrop-filter:blur(25px);z-index:2;background:#000;position:relative}.palvelut-grid{grid-template-columns:repeat(2,1fr);gap:30px;max-width:1000px;margin:0 auto;display:grid}.card-icon{width:24px;height:24px;color:var(--accent);margin-bottom:24px}.card-icon svg{width:24px;height:24px}.interfaces-card{background-color:var(--white);color:var(--text);font-family:var(--font-body);opacity:0;border:1px solid #e7e5e4;border-radius:12px;flex-direction:column;width:100%;display:flex;overflow:hidden;transform:translateY(20px);box-shadow:0 4px 20px #00000008}.interfaces-card.animate-in{opacity:1;cursor:pointer;animation:.6s cubic-bezier(.4,0,.2,1) forwards fadeUp;transform:translateY(0)}.interfaces-card:hover{border-color:var(--accent);transform:translateY(-8px);box-shadow:0 20px 40px #1c191714}.card-header{border-bottom:1px solid #f5f5f4;justify-content:space-between;align-items:center;padding:24px;display:flex}.card-title{font-size:1.5rem;font-weight:700;font-family:var(--font-heading);color:var(--primary);word-break:break-word;-webkit-hyphens:auto;hyphens:auto;margin:0}.card-content{flex-direction:column;flex-grow:1;padding:32px 24px;display:flex}.price-section{border-bottom:1px solid #f5f5f4;flex-direction:column;gap:8px;margin-bottom:24px;padding-bottom:24px;display:flex}.price-section .amount{font-family:var(--font-heading);color:var(--cta);font-size:1.25rem;font-weight:600;line-height:1.3}.features-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.features-list li{color:var(--primary);align-items:flex-start;gap:12px;font-size:.95rem;font-weight:700;display:flex}.features-list li:before{content:"✔";color:var(--accent);flex-shrink:0;font-weight:700}.card-footer{background:#fafaf9;border-top:1px solid #f5f5f4;padding:24px}.card-footer .btn{width:100%}.modal-overlay{z-index:2000;opacity:0;visibility:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1c1917e6;justify-content:center;align-items:center;padding:20px;transition:all .3s;display:flex;position:fixed;inset:0}.modal-content{background:var(--white);border-radius:20px;width:100%;max-width:1000px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;transform:scale(.95);box-shadow:0 25px 50px -12px #00000080}.close-modal{cursor:pointer;z-index:10;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:2rem;display:flex;position:absolute;top:20px;right:20px;box-shadow:0 4px 12px #0000001a}.modal-image{background-position:50%;background-size:cover}.modal-info{background:#fafaf9;flex-direction:column;justify-content:center;padding:60px;display:flex}.project-meta{border-top:1px solid #e7e5e4;border-bottom:1px solid #e7e5e4;grid-template-columns:repeat(2,1fr);gap:20px;margin:32px 0;padding:24px 0;display:grid}.meta-item strong{color:#78716c;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.8rem;display:block}.modal-description{color:#44403c;margin-bottom:32px;font-size:1.1rem;line-height:1.7}.modal-features h3{color:var(--primary);margin-bottom:16px;font-size:1rem}.modal-features li{padding-left:24px;font-size:.95rem;position:relative}.modal-features li:before{content:"✔";color:var(--accent);position:absolute;left:0}@media (width<=768px){.modal-grid{grid-template-columns:1fr}.modal-image{height:250px}.modal-info{padding:30px}.project-meta,.modal-features ul{grid-template-columns:1fr}}.animate-in{animation:.6s cubic-bezier(.4,0,.2,1) forwards fadeUp;opacity:1!important;transform:translateY(0)!important}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.nav-toggle{color:#fff;cursor:pointer;z-index:1001;background:0 0;border:none;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.8rem;display:none}@media (width<=900px){.nav-links{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);z-index:1000;background:#000;flex-direction:column;justify-content:center;gap:3rem;width:100%;height:100vh;transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;transform:translate(100%)}.nav-links.active{transform:translate(0)}.nav-links a{font-size:1.5rem}.nav-toggle{display:flex}}.modal-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:2000;opacity:0;visibility:hidden;background:#1c1917cc;justify-content:center;align-items:center;padding:20px;transition:all .4s;display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;visibility:visible}.modal-content{background:var(--white);border-radius:24px;width:100%;max-width:1100px;max-height:90vh;transition:all .5s cubic-bezier(.34,1.56,.64,1);position:relative;overflow-y:auto;transform:translateY(40px)scale(.95);box-shadow:0 40px 100px #00000080}.modal-overlay.active .modal-content{transform:translateY(0)scale(1)}.close-modal{cursor:pointer;z-index:10;background:#0f172a0d;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:24px;transition:all .2s;display:flex;position:absolute;top:24px;right:24px}.close-modal:hover{background:var(--accent);color:#fff;transform:rotate(90deg)}.modal-grid{grid-template-columns:1.2fr 1fr;min-height:600px;display:grid}.modal-image{background-position:50%;background-size:cover;min-height:400px}.modal-info{flex-direction:column;gap:24px;padding:60px;display:flex}.modal-info h2{color:var(--primary);margin:0;font-size:3rem;line-height:1.1}.project-meta{border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;gap:32px;padding:20px 0;display:flex}.meta-item{color:#64748b;font-size:.9rem}.meta-item strong{color:var(--primary);text-transform:uppercase;letter-spacing:1px;font-size:.75rem;display:block}.modal-description{color:var(--text);font-size:1.1rem;line-height:1.7}.modal-features h3{margin-bottom:16px;font-size:1.2rem}.modal-features ul{grid-template-columns:1fr 1fr;gap:12px;list-style:none;display:grid}.modal-features li{color:#475569;padding-left:24px;font-size:.95rem;position:relative}.modal-features li:before{content:"→";color:var(--accent);font-weight:700;position:absolute;left:0}.meista-section{background:var(--white);padding:120px 0}.meista-grid{grid-template-columns:1fr 1.2fr;align-items:center;gap:80px;display:grid}.meista-text h2{margin-bottom:32px;font-size:3rem}.meista-text p{color:var(--text);max-width:600px;margin-bottom:24px;font-size:1.1rem}.meista-values{margin-top:40px;list-style:none}.meista-values li{margin-bottom:16px;padding-left:28px;font-size:1rem;position:relative}.meista-values li:before{content:"✓";color:var(--accent);font-weight:700;position:absolute;left:0}.meista-image-box{position:relative}.meista-photo-card{z-index:10;opacity:1!important;background:#0f172a0d!important;border:2px dashed #0f172a1a!important;height:500px!important;padding:0!important;display:block!important;transform:none!important;box-shadow:0 30px 60px #0000001a!important}.meista-photo-card:hover{transform:scale(1.02)!important}footer{text-align:left;background:#f8fafc;padding:80px 0 40px}.footer-taped-container{background:var(--white);border-radius:40px;padding:80px;position:relative;box-shadow:0 20px 50px #0000000d}.tape-corner{z-index:2;position:absolute}.tape-top-left{top:-20px;left:-20px;transform:rotate(-5deg)}.tape-top-right{top:-15px;right:-30px;transform:rotate(10deg)}.footer-content{flex-direction:column;margin-bottom:80px;display:flex}.footer-brand h3{color:var(--primary);margin-bottom:16px;font-size:2rem}.footer-brand p{color:#64748b;max-width:300px}.footer-grid{grid-template-columns:repeat(3,1fr);gap:80px;margin-bottom:80px;display:grid}.footer-column{text-align:left;flex-direction:column;align-items:flex-start;display:flex}.footer-column h4{color:var(--primary);text-transform:uppercase;letter-spacing:2px;margin-bottom:24px;font-size:1rem}.footer-column a,.footer-column p{color:#64748b;font-size:1.15rem;font-weight:500;text-decoration:none;transition:color .2s}.footer-column ul{flex-direction:column;gap:16px;margin:0;padding:0;list-style:none;display:flex}.footer-column a:hover{color:var(--accent)}.footer-bottom{color:#64748b;border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding-top:40px;font-size:1.1rem;display:flex}.designer-credit a{color:#000;text-decoration:none;transition:color .2s}.designer-credit a:hover{color:var(--accent)}.contact-list{flex-direction:column;align-items:flex-start;gap:16px;display:flex}.contact-item{color:#64748b;align-items:center;gap:12px;font-size:1.15rem;display:flex}.contact-item a{color:inherit;text-decoration:none;transition:color .2s;margin-bottom:0!important}.contact-item a:hover{color:var(--accent)}.footer-icon{color:var(--accent);flex-shrink:0}.facebook-link{color:#1877f2;align-items:center;gap:8px;font-size:1.15rem;font-weight:600;text-decoration:none;transition:opacity .2s;display:flex}.facebook-link:hover,.facebook-link:active{color:navy;opacity:1}@media (width<=1000px){.meista-grid,.footer-content{grid-template-columns:1fr;gap:40px}.footer-taped-container{border-radius:20px;padding:40px 30px}.tape-corner{display:none}}@media (width<=900px){.modal-grid{grid-template-columns:1fr}.modal-image{height:250px;min-height:250px}.modal-info{padding:40px 24px}.modal-info h2{font-size:2.2rem}.palvelut-grid{grid-template-columns:1fr}.service-box{padding:32px 24px}.footer-grid{grid-template-columns:1fr;gap:32px}.footer-column h4{margin-bottom:12px}}@media (width<=600px){.modal-content{border-radius:16px;max-width:96%}.modal-info{padding:24px 16px}.modal-info h2{font-size:1.6rem}.modal-description{font-size:1rem}.project-meta{flex-wrap:wrap;gap:12px;padding:16px 0}.modal-features ul{grid-template-columns:1fr}.footer-bottom{text-align:center;flex-direction:column;gap:24px}.footer-legal,.social-links{justify-content:center;width:100%}}@media (width<=900px){.testimonials-grid{grid-template-columns:1fr}.testimonial-card{padding:30px}.bento-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-top:-30px}.card-1{grid-column:span 2}}@media (width<=600px){.bento-grid{grid-template-columns:1fr;grid-auto-rows:minmax(300px,auto);gap:16px}.card-1,.card-2,.card-5{grid-column:span 1}.bento-card,.card-overlay{padding:24px}.card-1 h3{font-size:1.8rem}.card-title{font-size:1.3rem}.hero-title{margin-bottom:1.5rem}.hero-title .sub-text{margin-top:.2rem;margin-left:0;font-size:.85em;display:block}.hero-title .main-word{font-size:clamp(1.2rem,7.2vw,1.8rem);display:block}.hero-content p{-webkit-hyphens:auto;hyphens:auto;overflow-wrap:break-word;margin-bottom:24px;font-size:1rem}}.palvelut-overview .section-title h2{color:var(--white)!important}.palvelut-overview .section-title .mono-label{color:var(--accent)!important}.hero-main-image{z-index:1;width:60%;height:100%;position:absolute;top:0;right:0;overflow:hidden}.hero-main-image img{object-fit:cover;object-position:65% center;filter:brightness(.85)contrast(1.1)saturate(1.1);width:100%;height:100%}@media (width<=900px){.hero{flex-direction:column;height:auto;min-height:auto}.hero-left-overlay{clip-path:none;width:100%;padding:80px 20px}.hero-content h1{font-size:clamp(1.4rem,8vw,2.2rem);line-height:1.2}.hero-content p{margin-bottom:24px;font-size:1rem}.hero-main-image{clip-path:none;width:100%;height:450px;position:relative}}.referenssit-section{padding:var(--section-pad) 0;background:var(--background)}.toast-notification{background:var(--primary);color:#fff;z-index:9999;opacity:0;pointer-events:none;border:1px solid #ffffff1a;border-radius:100px;padding:12px 24px;font-size:.9rem;font-weight:500;transition:all .4s cubic-bezier(.4,0,.2,1);position:fixed;bottom:30px;left:50%;transform:translate(-50%)translateY(100px);box-shadow:0 10px 30px #0000004d}.toast-notification.show{opacity:1;transform:translate(-50%)translateY(0)}
