@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:       #060606;
  --bg-1:     #0D0D0D;
  --bg-2:     #141414;
  --cream:    #EDE7DC;
  --cream-2:  #9A948A;
  --cream-3:  #4A4642;
  --gold:     #B8902E;
  --gold-hi:  #D4A83A;
  --gold-lo:  rgba(184,144,46,.12);
  --blue:     #1A52CC;
  --line:     rgba(237,231,220,.07);
  --line-s:   rgba(237,231,220,.13);
  --hd:'Cormorant Garamond',serif;
  --bd:'DM Sans',sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
html{scroll-behavior:smooth;font-size:16px;cursor:none}
body{font-family:var(--bd);background:var(--bg);color:var(--cream);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* GRAIN */
.grain{position:fixed;inset:0;z-index:2000;pointer-events:none;opacity:.028;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px}

/* CURSOR */
#c-dot,#c-ring{position:fixed;border-radius:50%;pointer-events:none;z-index:9999;top:0;left:0;transform:translate(-50%,-50%)}
#c-dot{width:5px;height:5px;background:var(--gold)}
#c-ring{width:32px;height:32px;border:1px solid rgba(184,144,46,.4);transition:width .35s var(--ease),height .35s var(--ease),border-color .35s}
.c-grow #c-ring{width:52px;height:52px;border-color:var(--gold)}
@media(hover:none){#c-dot,#c-ring{display:none}html{cursor:auto}}

/* NAV */
nav{position:fixed;top:0;inset-inline:0;z-index:500;display:flex;align-items:center;justify-content:space-between;padding:1.4rem 3rem;background:linear-gradient(to bottom,rgba(6,6,6,.85),transparent);transition:background .5s var(--ease),padding .4s var(--ease)}
nav.solid{background:rgba(6,6,6,.97);backdrop-filter:blur(14px);padding:1rem 3rem;border-bottom:1px solid var(--line)}
.nav-logo{text-decoration:none;display:flex;align-items:center}
.nav-logo img{height:80px;width:auto;display:block;padding:.25rem .6rem}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{font-size:.7rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;color:var(--cream-2);transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav-links a:hover{color:var(--cream)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-btn{font-size:.7rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;color:var(--gold);border:1px solid var(--gold);padding:.55rem 1.4rem;transition:background .2s,color .2s}
.nav-btn:hover{background:var(--gold);color:var(--bg)}
.nav-ham{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-ham span{display:block;width:20px;height:1px;background:var(--cream);transition:.3s}
@media(max-width:880px){nav{padding:1rem 1.5rem}.nav-links,.nav-btn{display:none}.nav-ham{display:flex}}

/* DRAWER */
.drawer{position:fixed;inset:0;z-index:480;background:var(--bg);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2rem;transform:translateY(-100%);transition:transform .6s cubic-bezier(.77,0,.175,1)}
.drawer.open{transform:none}
.drawer a{font-family:var(--hd);font-size:2.8rem;font-weight:300;font-style:italic;color:var(--cream);text-decoration:none;transition:color .2s}
.drawer a:hover{color:var(--gold)}

/* HERO */
#hero{position:relative;height:100svh;min-height:600px;overflow:hidden;display:flex;align-items:flex-end;background:var(--bg)}
.hero-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:.6}
.hero-veil{position:absolute;inset:0;background:linear-gradient(160deg,rgba(6,6,6,.5) 0%,rgba(6,6,6,.1) 45%,rgba(6,6,6,.9) 85%,#060606 100%)}
.hero-body{position:relative;z-index:1;padding:0 3rem 5rem;width:100%;display:grid;grid-template-columns:1fr max-content;gap:4rem;align-items:flex-end}
.hero-eyebrow{display:flex;align-items:center;gap:.75rem;margin-bottom:1.6rem;opacity:0;animation:au .8s .15s var(--ease) forwards}
.hero-eyebrow-bar{width:28px;height:1px;background:var(--gold)}
.hero-eyebrow-txt{font-size:.65rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
h1.hero-h1{font-family:var(--hd);font-size:clamp(2.6rem,9.5vw,9.5rem);font-weight:300;line-height:.93;letter-spacing:-.04em;color:var(--cream);margin-bottom:1.8rem;opacity:0;animation:au .95s .3s var(--ease) forwards}
h1.hero-h1 em{font-style:italic;color:var(--gold)}
.hero-value{font-family:var(--hd);font-size:clamp(1.1rem,2vw,1.55rem);font-weight:300;font-style:italic;color:var(--cream-2);line-height:1.5;max-width:480px;margin-bottom:2.5rem;padding-left:1.25rem;border-left:1px solid var(--gold);opacity:0;animation:au .8s .5s var(--ease) forwards}
.hero-value strong{color:var(--cream);font-style:normal;font-weight:400}
.hero-btns{display:flex;gap:1.25rem;align-items:center;flex-wrap:wrap;opacity:0;animation:au .8s .65s var(--ease) forwards}
.btn-primary{padding:.9rem 2.2rem;background:var(--cream);color:var(--bg);font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;border:1px solid var(--cream);display:inline-block;transition:background .25s,color .25s,transform .25s}
.btn-primary:hover{background:transparent;color:var(--cream);transform:translateY(-2px)}
.btn-secondary{padding:.9rem 2.2rem;background:transparent;color:var(--cream-2);font-size:.72rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;border:1px solid var(--line-s);display:inline-block;transition:border-color .2s,color .2s}
.btn-secondary:hover{border-color:var(--cream);color:var(--cream)}
.hero-stats{display:flex;flex-direction:column;gap:1.5rem;align-items:flex-end;opacity:0;animation:au .8s .75s var(--ease) forwards;padding-bottom:.2rem}
.hs-item{text-align:right}
.hs-num{font-family:var(--hd);font-size:2.8rem;font-weight:300;color:var(--cream);letter-spacing:-.04em;line-height:1;display:block}
.hs-num sup{font-size:1.1rem;color:var(--gold);font-weight:300;vertical-align:super}
.hs-lbl{font-size:.58rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-3);margin-top:.2rem;display:block}
.hs-div{width:40px;height:1px;background:var(--line);margin-left:auto}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.4rem;color:var(--cream-3);font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;opacity:0;animation:au 1s 1.4s var(--ease) forwards}
.hero-scroll svg{width:14px;height:14px;stroke:currentColor}
@keyframes au{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:880px){.hero-body{grid-template-columns:1fr;padding:0 1.5rem 4rem;gap:2rem}.hero-stats{align-items:flex-start;flex-direction:row;gap:2.5rem;flex-wrap:wrap}.hs-item{text-align:left}.hs-div{display:none}}

/* STATEMENT */
.statement{padding:5.5rem 3rem;background:var(--gold);text-align:center;overflow:hidden;position:relative}
.statement::before{content:'"';font-family:var(--hd);font-size:clamp(14rem,25vw,28rem);font-weight:400;color:rgba(255,255,255,.04);position:absolute;top:-20%;left:50%;transform:translateX(-50%);line-height:1;pointer-events:none;user-select:none}
.statement-inner{position:relative;z-index:1;max-width:820px;margin:0 auto}
.statement-tag{font-size:.62rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.55);display:block;margin-bottom:1.25rem}
.statement-h{font-family:var(--hd);font-size:clamp(1.8rem,4vw,3.8rem);font-weight:400;font-style:italic;color:var(--bg);line-height:1.2;letter-spacing:-.02em}
.statement-h strong{font-style:normal;color:rgba(6,6,6,.85)}
.statement-pre{margin-top:2.5rem;font-size:clamp(1rem,2vw,1.4rem);font-weight:500;color:#fff;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem 2rem;background:#0a0a0a;border:1px solid rgba(200,169,110,.4);border-radius:4px;text-align:center}
.statement-pre-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#c8a96e;animation:blink 1.2s ease-in-out infinite;flex-shrink:0;box-shadow:0 0 8px rgba(200,169,110,.8)}
.statement-pre a{display:inline-block;margin-left:.5rem;color:#0a0a0a;background:#c8a96e;text-decoration:none;font-weight:700;padding:.45rem 1.1rem;border-radius:3px;border:none;transition:background .2s,transform .15s}
.statement-pre a:hover{background:#b8953a;transform:translateY(-1px)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
@media(max-width:760px){.statement{padding:4rem 1.5rem}.statement-pre{flex-wrap:wrap;gap:.6rem}.statement-h{font-size:clamp(1.6rem,5.5vw,3.8rem)}}

/* MARQUEE */
.marquee{overflow:hidden;padding:.65rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg)}
.marquee-track{display:flex;width:max-content;animation:mq 32s linear infinite;white-space:nowrap}
.marquee-track:hover{animation-play-state:paused}
.mi{display:inline-flex;align-items:center;gap:1.75rem;padding:0 1.75rem;font-family:var(--hd);font-size:1rem;font-weight:300;font-style:italic;color:var(--cream-2);flex-shrink:0}
.mi-dot{width:3px;height:3px;border-radius:50%;background:var(--gold);flex-shrink:0}
@keyframes mq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* HELPERS */
.eyebrow{display:flex;align-items:center;gap:.7rem;margin-bottom:.9rem}
.eyebrow-bar{width:24px;height:1px;background:var(--gold)}
.eyebrow-txt{font-size:.62rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.sh{font-family:var(--hd);font-size:clamp(2.2rem,4vw,4rem);font-weight:300;line-height:1.05;letter-spacing:-.03em;color:var(--cream)}
.sh em{font-style:italic}

/* SERVICES */
#palvelut{padding:8rem 3rem;background:var(--bg)}
.srv-top{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:end;margin-bottom:5rem}
.srv-top-body{font-size:.875rem;font-weight:300;color:var(--cream-2);line-height:1.9;max-width:400px}
.srv-list{border-top:1px solid var(--line)}
.srv-row{display:grid;grid-template-columns:56px 1fr 1fr max-content;gap:2.5rem;align-items:start;padding:2.5rem 0;border-bottom:1px solid var(--line);position:relative;overflow:hidden;cursor:default;transition:background .25s}
.srv-row::after{content:'';position:absolute;inset:0;background:rgba(237,231,220,.03);opacity:0;transition:opacity .25s}
.srv-row:hover::after{opacity:1}
.srv-row:hover .srv-row-num{color:var(--gold)}
.srv-row-num{font-family:var(--hd);font-size:.78rem;font-style:italic;color:var(--cream-3);padding-top:.3rem;letter-spacing:.05em;transition:color .25s}
.srv-row-name{font-family:var(--hd);font-size:1.7rem;font-weight:300;color:var(--cream);letter-spacing:-.02em;line-height:1.1}
.srv-row-desc{font-size:.83rem;font-weight:300;color:var(--cream-2);line-height:1.8}
.srv-row-tags{display:flex;flex-direction:column;gap:.35rem;align-items:flex-end}
.srv-tag{font-size:.6rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);border:1px solid rgba(26,82,204,.28);padding:.18rem .5rem;white-space:nowrap}
@media(max-width:880px){#palvelut{padding:5rem 1.5rem}.srv-top{grid-template-columns:1fr;gap:2rem;margin-bottom:3rem}.srv-row{grid-template-columns:40px 1fr;gap:1rem}.srv-row-desc{grid-column:1/-1}.srv-row-tags{display:none}}

/* MACHINE */
.machine{display:grid;grid-template-columns:1fr 1fr;background:var(--bg-1)}
.machine-visual{position:relative;overflow:hidden;min-height:560px}
.machine-visual img{width:100%;height:100%;object-fit:cover;display:block;opacity:.6;transition:transform 1.2s var(--ease)}
.machine:hover .machine-visual img{transform:scale(1.04)}
.machine-body{padding:6rem 4.5rem;display:flex;flex-direction:column;justify-content:center}
.machine-body .sh{color:var(--cream)}
.machine-body p{font-size:.9rem;font-weight:300;color:var(--cream-2);line-height:1.9;margin-top:2rem;max-width:380px}
.machine-specs{display:grid;grid-template-columns:1fr 1fr;gap:2rem 3rem;margin-top:3.5rem;padding-top:3rem;border-top:1px solid var(--line)}
.ms-num{font-family:var(--hd);font-size:2.6rem;font-weight:300;color:var(--cream);display:block;letter-spacing:-.04em;line-height:1}
.ms-num span{font-size:1.1rem;color:rgba(237,231,220,.4)}
.ms-lbl{font-size:.6rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-3);margin-top:.3rem;display:block}
.machine-friankor{display:flex;align-items:center;gap:.9rem;margin-top:2.75rem;padding:1rem 1.25rem;border:1px solid var(--line-s);background:rgba(237,231,220,.04)}
.mf-logo{background:#fff;padding:.3rem .6rem;flex-shrink:0}
.mf-logo img{height:26px;width:auto;display:block}
.mf-lbl{font-size:.58rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(237,231,220,.4);display:block;margin-bottom:.2rem}
.mf-val{font-size:.82rem;color:rgba(237,231,220,.8)}
@media(max-width:880px){.machine{grid-template-columns:1fr}.machine-visual{min-height:280px}.machine-body{padding:4rem 1.5rem}}

/* GALLERY */
#galleria{padding:8rem 3rem;background:var(--bg)}
.gal-header{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:4rem}
.gal-header p{font-size:.875rem;font-weight:300;color:var(--cream-2);line-height:1.9;max-width:380px}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:320px 240px;gap:2px;background:rgba(255,255,255,.03)}
.g-item{overflow:hidden;position:relative;background:var(--bg-2)}
.g-item:first-child{grid-row:span 2}
.g-item img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.75) saturate(.85);transition:transform .8s var(--ease),filter .5s}
.g-item:hover img{transform:scale(1.07);filter:brightness(.92) saturate(1.1)}
.g-cap{position:absolute;bottom:0;inset-inline:0;padding:.9rem 1.1rem;background:linear-gradient(transparent,rgba(0,0,0,.8));font-size:.7rem;letter-spacing:.04em;color:rgba(255,255,255,.9);opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
.g-item:hover .g-cap{opacity:1;transform:none}
@media(max-width:880px){#galleria{padding:5rem 1.5rem}.gal-header{grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem}.gal-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}.g-item:first-child{grid-row:auto;grid-column:span 2}.g-item img{min-height:200px}}
@media(max-width:520px){.gal-grid{grid-template-columns:1fr}.g-item:first-child{grid-column:auto}}

/* SOCIAL PROOF */
.sp{display:grid;grid-template-columns:1fr 1fr;background:var(--bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sp-l{padding:7rem 3rem;border-right:1px solid var(--line);display:flex;flex-direction:column;justify-content:center}
.sp-h{font-family:var(--hd);font-size:clamp(1.8rem,3.5vw,3.5rem);font-weight:300;font-style:italic;color:var(--cream);line-height:1.15;letter-spacing:-.02em;margin-top:1rem}
.sp-h strong{font-style:normal;color:var(--gold)}
.sp-r{padding:7rem 3.5rem;display:flex;flex-direction:column;justify-content:center;gap:1.5rem}
.sp-item{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--bg-1);border-left:3px solid var(--gold)}
.sp-item svg{color:var(--gold);flex-shrink:0;margin-top:2px}
.sp-item p{font-size:.875rem;font-weight:300;color:var(--cream-2);line-height:1.65}
@media(max-width:880px){.sp{grid-template-columns:1fr}.sp-l{padding:5rem 1.5rem;border-right:none;border-bottom:1px solid var(--line)}.sp-r{padding:4rem 1.5rem}}

/* PORTFOLIO */
#portfolio{padding:8rem 3rem;background:var(--bg-1)}
.port-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4.5rem}
.port-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:3px;background:rgba(255,255,255,.02)}
.p-item{overflow:hidden;background:var(--bg-2);position:relative;cursor:pointer}
.p-item:nth-child(1){grid-column:1/7;grid-row:1/3}
.p-item:nth-child(2){grid-column:7/10;aspect-ratio:1}
.p-item:nth-child(3){grid-column:10/13;aspect-ratio:1}
.p-item:nth-child(4){grid-column:7/10;aspect-ratio:1}
.p-item:nth-child(5){grid-column:10/13;aspect-ratio:1}
.p-item:nth-child(6){grid-column:1/5;aspect-ratio:4/3}
.p-item:nth-child(7){grid-column:5/9;aspect-ratio:4/3}
.p-item:nth-child(8){grid-column:9/13;aspect-ratio:4/3}
.p-bg{width:100%;height:100%;min-height:200px;background-size:cover;background-position:center;filter:brightness(.7) saturate(.8);transition:transform .7s var(--ease),filter .4s}
.p-item:nth-child(1) .p-bg{min-height:460px}
.p-item:hover .p-bg{transform:scale(1.06);filter:brightness(.92) saturate(1.1)}
.p-info{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,transparent 55%);padding:1.5rem;display:flex;flex-direction:column;justify-content:flex-end;opacity:0;transition:opacity .3s var(--ease)}
.p-item:hover .p-info{opacity:1}
.p-title{font-size:.875rem;font-weight:500;color:#fff}
.p-sub{font-size:.68rem;color:rgba(255,255,255,.5);margin-top:.2rem}
@media(max-width:880px){#portfolio{padding:5rem 1.5rem}.port-header{flex-direction:column;align-items:flex-start;gap:1.5rem}.p-item:nth-child(1){grid-column:1/13}.p-item:nth-child(2),.p-item:nth-child(3),.p-item:nth-child(4),.p-item:nth-child(5){grid-column:span 6}.p-item:nth-child(6),.p-item:nth-child(7),.p-item:nth-child(8){grid-column:span 12}}

/* PROCESS */
#prosessi{padding:8rem 3rem;background:var(--bg);position:relative;overflow:hidden}
#prosessi::after{content:'';position:absolute;top:-30%;right:-15%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(26,82,204,.06),transparent 70%);pointer-events:none}
.proc-header{margin-bottom:5rem}
.proc-steps{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.proc-step{padding:2.5rem 2.5rem 2.5rem 0;border-right:1px solid var(--line);transition:background .2s}
.proc-step:last-child{border-right:none;padding-right:0}
.proc-step:hover{background:rgba(255,255,255,.02)}
.proc-n{font-size:.68rem;font-style:italic;color:var(--gold);font-family:var(--hd);letter-spacing:.05em;margin-bottom:1.5rem;display:block}
.proc-name{font-family:var(--hd);font-size:1.3rem;font-weight:400;color:var(--cream);margin-bottom:.8rem;letter-spacing:-.01em}
.proc-body{font-size:.82rem;font-weight:300;color:var(--cream-2);line-height:1.8}
@media(max-width:880px){#prosessi{padding:5rem 1.5rem}.proc-steps{grid-template-columns:1fr 1fr}.proc-step{border-right:none;border-bottom:1px solid var(--line);padding:2rem 0}}
@media(max-width:520px){.proc-steps{grid-template-columns:1fr}}

/* ABOUT */
#meista{display:grid;grid-template-columns:1fr 1fr}
.about-img{position:relative;overflow:hidden;min-height:560px}
.about-img img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.6) saturate(.8);transition:transform 1.2s var(--ease)}
.about-img:hover img{transform:scale(1.04)}
.about-img-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,82,204,.25),rgba(6,6,6,.4));display:flex;align-items:center;justify-content:center}
.about-letter{font-family:var(--hd);font-size:14rem;font-weight:300;font-style:italic;color:rgba(255,255,255,.06);letter-spacing:-.06em;user-select:none}
.about-body-col{padding:7rem 4.5rem;display:flex;flex-direction:column;justify-content:center;background:var(--bg-1)}
.about-txt{font-size:.9rem;font-weight:300;color:var(--cream-2);line-height:1.95;margin-top:2rem;max-width:420px}
.about-nums{display:flex;gap:3rem;flex-wrap:wrap;margin-top:3.5rem;padding-top:3rem;border-top:1px solid var(--line)}
.an-v{font-family:var(--hd);font-size:2.8rem;font-weight:300;color:var(--cream);display:block;letter-spacing:-.04em;line-height:1}
.an-l{font-size:.6rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-3);margin-top:.3rem;display:block}
@media(max-width:880px){#meista{grid-template-columns:1fr}.about-img{min-height:280px}.about-body-col{padding:4rem 1.5rem}}

/* CTA STRIP */
.cta-strip{padding:7rem 3rem;background:var(--gold);text-align:center;overflow:hidden;position:relative}
.cta-strip::before{content:'PRINT';font-family:var(--hd);font-size:clamp(10rem,24vw,26rem);font-weight:300;font-style:italic;color:rgba(255,255,255,.035);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none;user-select:none}
.cta-strip-inner{position:relative;z-index:1;max-width:700px;margin:0 auto}
.cta-tag{font-size:.62rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.5);display:block;margin-bottom:1.25rem}
.cta-h{font-family:var(--hd);font-size:clamp(2.2rem,5vw,5rem);font-weight:300;font-style:italic;color:var(--bg);line-height:1.1;letter-spacing:-.025em;margin-bottom:2.5rem}
.btn-dark{padding:.95rem 2.5rem;background:var(--bg);color:var(--gold);font-size:.75rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;display:inline-block;transition:background .2s,color .2s,transform .2s}
.btn-dark:hover{background:rgba(6,6,6,.8);transform:translateY(-2px)}
@media(max-width:760px){.cta-strip{padding:5rem 1.5rem}}

/* CONTACT */
#yhteystiedot{padding:8rem 3rem;background:var(--bg)}
.ct-wrap{display:grid;grid-template-columns:1fr 1.25fr;gap:6rem;align-items:start}
.ct-tagline{font-family:var(--hd);font-size:1.5rem;font-style:italic;color:var(--cream-2);line-height:1.35;margin:1.75rem 0 2.5rem}
.cd{margin-bottom:1.75rem}
.cd-l{font-size:.6rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.3rem}
.cd-v{font-size:.9rem;color:var(--cream);font-weight:300}
.cd-v a{color:var(--cream);text-decoration:none;border-bottom:1px solid var(--line-s);padding-bottom:1px;transition:color .2s,border-color .2s}
.cd-v a:hover{color:var(--gold);border-color:var(--gold)}
.cform{display:flex;flex-direction:column;gap:1.1rem}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.fg{display:flex;flex-direction:column;gap:.35rem}
.fg label{font-size:.6rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-3)}
.fg input,.fg textarea,.fg select{padding:.9rem 1rem;background:rgba(237,231,220,.04);border:1px solid var(--line-s);color:var(--cream);font-family:var(--bd);font-size:.875rem;outline:none;min-height:44px;transition:border-color .2s,background .2s;-webkit-appearance:none}
.fg input::placeholder,.fg textarea::placeholder{color:var(--cream-3);opacity:.7}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--gold);background:rgba(184,144,46,.05)}
.fg select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%234A4642' stroke-width='1.4' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center;background-color:rgba(237,231,220,.04);padding-right:2.2rem}
.fg select option{background:#111;color:var(--cream)}
.fg textarea{resize:vertical;min-height:130px}
.ferr{font-size:.68rem;color:#E05555;display:none;margin-top:.15rem}
.ferr.on{display:block}
.fsucc{display:none;padding:.9rem 1.1rem;border-left:2px solid var(--gold);background:rgba(184,144,46,.07);font-size:.82rem;color:var(--gold);margin-bottom:.25rem}
.fsucc.on{display:block}
.btn-submit{align-self:flex-start;padding:1rem 2.5rem;background:var(--gold);color:var(--bg);font-family:var(--bd);font-size:.75rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--gold);cursor:pointer;transition:background .2s,color .2s,transform .2s;min-height:44px}
.btn-submit:hover{background:transparent;color:var(--gold);transform:translateY(-2px)}
.btn-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}
.fnote{font-size:.68rem;color:var(--cream-3)}
@media(max-width:880px){#yhteystiedot{padding:5rem 1.5rem}.ct-wrap{grid-template-columns:1fr;gap:3rem}.fr{grid-template-columns:1fr}.btn-submit{align-self:stretch;text-align:center}}

/* FOOTER */
footer{padding:4rem 3rem 2.5rem;background:var(--bg-1);border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid var(--line);margin-bottom:2rem}
.footer-logo img{height:80px;width:auto;display:block;padding:.3rem .65rem;margin-bottom:1rem}
.footer-tagline{font-size:.78rem;font-weight:300;color:rgba(237,231,220,.35);line-height:1.75;max-width:220px}
.fc h4{font-size:.58rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:rgba(237,231,220,.3);margin-bottom:.9rem}
.fc a{display:block;font-size:.78rem;font-weight:300;color:rgba(237,231,220,.45);text-decoration:none;margin-bottom:.4rem;transition:color .2s}
.fc a:hover{color:rgba(237,231,220,.9)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:rgba(237,231,220,.25)}
.footer-gold{color:rgba(184,144,46,.7)}
@media(max-width:880px){footer{padding:3rem 1.5rem}.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}.footer-bottom{flex-direction:column;gap:.75rem;text-align:center}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* STICKY */
.sticky{position:fixed;bottom:0;inset-inline:0;z-index:450;background:var(--gold);padding:.8rem 2rem;display:flex;align-items:center;justify-content:space-between;transform:translateY(100%);transition:transform .55s var(--ease)}
.sticky.show{transform:none}
.sticky span{font-size:.78rem;font-weight:500;color:var(--bg)}
.sticky a{padding:.45rem 1.35rem;background:var(--bg);color:var(--gold);font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:opacity .2s}
.sticky a:hover{opacity:.8}
@media(max-width:520px){.sticky{flex-direction:column;gap:.5rem;text-align:center}}

/* SMALL SCREENS (≤480px) */
@media(max-width:480px){
  .hero-value{font-size:1rem;padding-left:1rem}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .btn-primary,.btn-secondary{width:100%;text-align:center}
  .hs-num{font-size:2.2rem}
  .p-item:nth-child(2),.p-item:nth-child(3),.p-item:nth-child(4),.p-item:nth-child(5){grid-column:span 12}
  .port-grid{gap:2px}
  .machine-specs{grid-template-columns:1fr 1fr;gap:1.5rem 2rem}
  .about-nums{gap:2rem}
}

/* REVEAL */
.r{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease);will-change:opacity,transform}
.r.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}.d4{transition-delay:.28s}
