/* =========================================================================
   RATSON OÜ — disainisüsteem
   Suund: arhitektuurne, "keevisõmblus" (cyan seam) signatuurmotiiv,
   sügav tint + täpne cyan, fotokesksed heroväljad.
   ========================================================================= */

:root{
  /* --- värvid --- */
  --ink:#0B0E12;          /* põhi-tume */
  --ink-2:#10151B;        /* paneel tume */
  --ink-3:#171D26;        /* tõstetud */
  --ink-line:rgba(255,255,255,.10);
  --ink-line-2:rgba(255,255,255,.06);

  --cyan:#00AEEA;         /* bränd (logost) */
  --cyan-bright:#34C6FF;  /* hover / sära */
  --cyan-deep:#0086B8;    /* pressed */
  --cyan-ghost:rgba(0,174,234,.12);

  --paper:#FFFFFF;
  --paper-2:#F3F6F9;      /* jahe hall paneel */
  --paper-3:#E9EEF3;
  --paper-line:#E2E8EE;

  --fg:#0B0E12;           /* tekst heledal */
  --fg-soft:#48535F;
  --fg-faint:#7B8794;
  --on-dark:#EAF0F6;      /* tekst tumedal */
  --on-dark-soft:#9BA7B4;
  --on-dark-faint:#646F7C;

  /* --- tüpograafia --- */
  --f-display:"Space Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --f-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --f-mono:"Space Mono","SFMono-Regular",ui-monospace,Menlo,monospace;

  /* --- ruum --- */
  --wrap:1240px;
  --wrap-narrow:880px;
  --gut:clamp(20px,5vw,64px);
  --sect:clamp(72px,9vw,140px);
  --radius:4px;
  --radius-lg:10px;

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --shadow:0 1px 2px rgba(11,14,18,.04),0 8px 30px rgba(11,14,18,.06);
  --shadow-lg:0 30px 80px -20px rgba(11,14,18,.35);

  --hd:76px; /* header kõrgus */
}

/* ========================== reset ========================== */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.7;
  color:var(--fg);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
input,textarea,select{font:inherit;color:inherit}
::selection{background:var(--cyan);color:#fff}

/* ========================== layout ========================== */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gut)}
.narrow{max-width:var(--wrap-narrow)}
.section{padding-block:var(--sect)}
.section--tight{padding-block:clamp(48px,6vw,84px)}

/* tume / hele sektsioonid */
.dark{background:var(--ink);color:var(--on-dark)}
.dark h1,.dark h2,.dark h3{color:#fff}
.darker{background:#070A0D;color:var(--on-dark)}
.paper-2{background:var(--paper-2)}

/* ========================== tüpo ========================== */
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;letter-spacing:-.02em;line-height:1.06;color:var(--fg)}
.h-hero{font-size:clamp(2.5rem,6.2vw,5.4rem);font-weight:600;line-height:1.0;letter-spacing:-.03em}
.h1{font-size:clamp(2rem,4.4vw,3.5rem)}
.h2{font-size:clamp(1.7rem,3.4vw,2.7rem)}
.h3{font-size:clamp(1.18rem,1.7vw,1.45rem);letter-spacing:-.01em}
p{text-wrap:pretty}
.lead{font-size:clamp(1.08rem,1.6vw,1.4rem);line-height:1.55;color:var(--fg-soft);font-weight:400}
.dark .lead{color:var(--on-dark-soft)}
.muted{color:var(--fg-soft)}
.dark .muted{color:var(--on-dark-soft)}

/* eyebrow = signatuur mono-silt cyan punktiga */
.eyebrow{
  font-family:var(--f-mono);
  font-size:.74rem;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--cyan-deep);
  display:inline-flex;align-items:center;gap:.65em;
}
.dark .eyebrow{color:var(--cyan-bright)}
.eyebrow::before{
  content:"";width:22px;height:2px;background:var(--cyan);flex:none;
}

/* keevisõmblus joon — signatuurelement */
.seam{height:2px;width:100%;background:
  linear-gradient(90deg,transparent,var(--cyan) 8%,var(--cyan) 92%,transparent);
  opacity:.0;transform:scaleX(0);transform-origin:left;
  transition:transform 1.1s var(--ease-out),opacity .5s ease}
.reveal-in .seam,.seam.shown{opacity:.9;transform:scaleX(1)}

/* ========================== nupud ========================== */
.btn{
  --bg:var(--cyan);--c:#06222B;
  display:inline-flex;align-items:center;gap:.6em;
  background:var(--bg);color:var(--c);
  font-family:var(--f-display);font-weight:600;font-size:.98rem;letter-spacing:-.01em;
  padding:15px 26px;border-radius:var(--radius);
  position:relative;overflow:hidden;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s;
  white-space:nowrap;
}
.btn svg{width:17px;height:17px;transition:transform .3s var(--ease)}
.btn:hover{background:var(--cyan-bright);transform:translateY(-2px);box-shadow:0 12px 30px -8px rgba(0,174,234,.5)}
.btn:hover svg{transform:translateX(4px)}
.btn:active{transform:translateY(0)}
.btn--ghost{
  --bg:transparent;--c:var(--fg);
  border:1.5px solid var(--paper-line);
}
.btn--ghost:hover{background:var(--paper-2);border-color:var(--fg);transform:translateY(-2px);box-shadow:none}
.dark .btn--ghost,.hero .btn--ghost,.ctaband .btn--ghost{--c:#fff;border-color:var(--ink-line)}
.dark .btn--ghost:hover,.hero .btn--ghost:hover,.ctaband .btn--ghost:hover{background:var(--ink-3);border-color:rgba(255,255,255,.4)}
.btn--lg{padding:18px 32px;font-size:1.05rem}
.btn--block{width:100%;justify-content:center}

.txt-link{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--f-display);font-weight:600;color:var(--fg);
  border-bottom:2px solid transparent;padding-bottom:2px;
  transition:color .2s,border-color .2s,gap .2s;
}
.txt-link svg{width:16px;height:16px;transition:transform .3s var(--ease)}
.txt-link:hover{color:var(--cyan-deep);border-color:var(--cyan);gap:.8em}
.dark .txt-link{color:#fff}
.dark .txt-link:hover{color:var(--cyan-bright)}
.txt-link:hover svg{transform:translateX(3px)}

/* ========================== header ========================== */
.hdr{
  position:fixed;inset:0 0 auto 0;z-index:100;
  height:var(--hd);
  display:flex;align-items:center;
  transition:background .35s var(--ease),box-shadow .35s var(--ease),height .35s var(--ease),border-color .35s;
  border-bottom:1px solid transparent;
}
.hdr__in{display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%}
.hdr__logo{display:flex;align-items:center;gap:14px;z-index:2}
.hdr__logo img{height:34px;width:auto;transition:filter .35s}
.hdr__logo .kfml{height:38px;opacity:.9;display:none}
@media(min-width:1100px){.hdr__logo .kfml{display:block}}

/* läbipaistev olek hero kohal */
.hdr--transparent{background:transparent}
.hdr--transparent .nav__link{color:rgba(255,255,255,.9)}
.hdr--transparent .nav__link:hover{color:#fff}
.hdr--transparent .hdr__logo img.logo-main{filter:brightness(0) invert(1)}
.hdr--transparent .burger span{background:#fff}
.hdr--transparent .hdr__phone{color:rgba(255,255,255,.92)}

/* scrollitud / kleepuv olek */
.hdr--solid{
  background:rgba(255,255,255,.86);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom-color:var(--paper-line);
  height:64px;
  box-shadow:0 1px 0 rgba(11,14,18,.02);
}
.hdr--solid .nav__link{color:var(--fg-soft)}
.hdr--solid .nav__link:hover{color:var(--fg)}
.hdr--solid .hdr__logo img.logo-main{filter:none}
.hdr--solid .burger span{background:var(--fg)}

/* nav */
.nav{display:none;align-items:center;gap:4px}
@media(min-width:980px){.nav{display:flex}}
.nav__item{position:relative}
.nav__link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.95rem;font-weight:500;letter-spacing:-.01em;
  padding:10px 14px;border-radius:var(--radius);
  transition:color .2s,background .2s;
}
.nav__link svg{width:11px;height:11px;opacity:.6;transition:transform .25s}
.nav__item:hover .nav__link svg{transform:rotate(180deg)}

/* dropdown */
.nav__menu{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:268px;background:#fff;border:1px solid var(--paper-line);border-radius:var(--radius-lg);
  padding:8px;box-shadow:var(--shadow-lg);
  opacity:0;visibility:hidden;transition:opacity .22s var(--ease),transform .22s var(--ease);
}
.nav__item:hover .nav__menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav__menu::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px}
.nav__sub{
  display:flex;flex-direction:column;gap:1px;padding:11px 14px;border-radius:var(--radius);
  color:var(--fg);transition:background .18s,color .18s;
}
.nav__sub b{font-family:var(--f-display);font-weight:600;font-size:.96rem}
.nav__sub span{font-size:.8rem;color:var(--fg-faint)}
.nav__sub:hover{background:var(--paper-2)}
.nav__sub:hover b{color:var(--cyan-deep)}

.hdr__cta{display:none;align-items:center;gap:16px}
@media(min-width:980px){.hdr__cta{display:flex}}
.hdr__phone{display:none;align-items:center;gap:8px;font-family:var(--f-mono);font-size:.82rem;font-weight:700;letter-spacing:.02em;color:var(--fg)}
@media(min-width:1180px){.hdr__phone{display:inline-flex}}
.hdr__phone svg{width:15px;height:15px;color:var(--cyan)}
.hdr .btn{padding:11px 20px;font-size:.92rem}

/* burger */
.burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;z-index:120;margin-right:-8px}
@media(min-width:980px){.burger{display:none}}
.burger span{width:24px;height:2px;background:var(--fg);margin-left:auto;transition:transform .3s var(--ease),opacity .2s,width .3s}
.burger span:nth-child(2){width:18px}
body.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg);width:24px}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);width:24px}
body.menu-open .burger span{background:#fff !important}

/* mobiilimenüü */
.mnav{
  position:fixed;inset:0;z-index:110;background:var(--ink);color:#fff;
  padding:calc(var(--hd) + 20px) var(--gut) 40px;
  display:flex;flex-direction:column;
  transform:translateY(-100%);transition:transform .5s var(--ease);
  overflow-y:auto;
}
body.menu-open .mnav{transform:translateY(0)}
.mnav__list{display:flex;flex-direction:column;margin-top:8px}
.mnav__a{
  font-family:var(--f-display);font-weight:600;font-size:clamp(1.5rem,7vw,2.2rem);
  letter-spacing:-.02em;padding:16px 0;border-bottom:1px solid var(--ink-line);
  display:flex;align-items:center;justify-content:space-between;color:#fff;
  opacity:0;transform:translateY(16px);
}
body.menu-open .mnav__a{animation:mIn .5s var(--ease-out) forwards}
.mnav__a .idx{font-family:var(--f-mono);font-size:.8rem;color:var(--cyan-bright);font-weight:700}
.mnav__sub{display:flex;flex-direction:column;gap:0;padding:4px 0 8px 2px}
.mnav__sub a{font-family:var(--f-body);font-weight:500;font-size:1.02rem;color:var(--on-dark-soft);padding:9px 0;display:flex;align-items:center;gap:10px}
.mnav__sub a::before{content:"";width:14px;height:1.5px;background:var(--cyan)}
.mnav__sub a:hover{color:#fff}
.mnav__foot{margin-top:auto;padding-top:28px;display:flex;flex-direction:column;gap:14px}
.mnav__foot a{display:flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:.9rem;color:var(--on-dark-soft)}
.mnav__foot a svg{width:16px;height:16px;color:var(--cyan-bright)}
@keyframes mIn{to{opacity:1;transform:translateY(0)}}

/* ========================== HERO ========================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:var(--ink)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 35%;
  transform:scale(1.08);animation:heroZoom 14s var(--ease-out) forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(7,10,13,.55) 0%,rgba(7,10,13,.15) 30%,rgba(7,10,13,.35) 62%,rgba(7,10,13,.92) 100%),
    linear-gradient(90deg,rgba(7,10,13,.7) 0%,rgba(7,10,13,.2) 55%,transparent 100%);
}
.hero__grid{position:absolute;inset:0;z-index:1;opacity:.5;
  background-image:linear-gradient(var(--ink-line-2) 1px,transparent 1px),linear-gradient(90deg,var(--ink-line-2) 1px,transparent 1px);
  background-size:64px 64px;mask-image:linear-gradient(180deg,transparent,#000 40%,#000 70%,transparent)}
.hero__in{position:relative;z-index:2;width:100%;padding-bottom:clamp(48px,7vw,96px);padding-top:calc(var(--hd) + 40px)}
.hero__eyebrow{margin-bottom:26px}
.hero__eyebrow .eyebrow{color:#fff}
.hero__eyebrow .eyebrow::before{background:var(--cyan)}
.hero h1{max-width:16ch;margin-bottom:24px;color:#fff;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.hero h1 .em{color:var(--cyan-bright)}
.hero__sub{max-width:50ch;font-size:clamp(1.05rem,1.7vw,1.3rem);line-height:1.55;color:rgba(255,255,255,.86);margin-bottom:36px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:clamp(40px,5vw,64px)}

/* hero tehnilised andmed (seam-riba) */
.hero__data{
  border-top:1px solid rgba(255,255,255,.16);
  padding-top:26px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px 16px;
  max-width:760px;
}
@media(min-width:680px){.hero__data{grid-template-columns:repeat(4,1fr)}}
.stat__mono{font-family:var(--f-mono);font-size:.7rem;font-weight:700;letter-spacing:.15em;color:var(--cyan-bright);margin-bottom:8px}
.stat__v{font-family:var(--f-display);font-size:clamp(1.7rem,2.6vw,2.3rem);font-weight:600;line-height:1;letter-spacing:-.02em;color:#fff;margin-bottom:6px}
.stat__l{font-size:.84rem;color:rgba(255,255,255,.66);line-height:1.3}

.hero__scroll{position:absolute;left:var(--gut);bottom:24px;z-index:2;display:none;align-items:center;gap:10px;
  font-family:var(--f-mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55)}
@media(min-width:980px){.hero__scroll{display:none}}

/* ========================== trust riba ========================== */
.trust{border-block:1px solid var(--paper-line);background:#fff}
.trust__in{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(24px,4vw,56px);padding-block:24px;justify-content:space-between}
.trust__label{font-family:var(--f-mono);font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-faint);flex:none}
.trust__logos{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(20px,3.5vw,44px);flex:1}
.trust__logos img{height:46px;width:auto;opacity:.85;filter:grayscale(.2);transition:opacity .3s,filter .3s}
.trust__logos img:hover{opacity:1;filter:none}
.trust__badge{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:.74rem;font-weight:700;letter-spacing:.04em;color:var(--fg-soft);
  border:1px solid var(--paper-line);border-radius:100px;padding:8px 16px}
.trust__badge i{width:7px;height:7px;border-radius:50%;background:var(--cyan);font-style:normal}

/* ========================== section head ========================== */
.shead{max-width:720px;margin-bottom:clamp(40px,5vw,64px)}
.shead .eyebrow{margin-bottom:20px}
.shead h2{margin-bottom:18px}
.shead--split{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:24px;max-width:none}
.shead--split .shead__txt{max-width:640px}

/* ========================== teenused ========================== */
.svc-grid{display:grid;grid-template-columns:1fr;gap:2px;background:var(--paper-line);border:1px solid var(--paper-line)}
@media(min-width:680px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.svc-grid{grid-template-columns:repeat(3,1fr)}}
.svc{position:relative;display:flex;flex-direction:column;background:#fff;padding:0;overflow:hidden;transition:background .3s}
.svc__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--ink-2)}
.svc__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.svc:hover .svc__media img{transform:scale(1.06)}
.svc__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(7,10,13,.5));opacity:.4;transition:opacity .3s}
.svc:hover .svc__media::after{opacity:.65}
.svc__num{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--f-mono);font-size:.7rem;font-weight:700;letter-spacing:.1em;color:#fff;background:rgba(7,10,13,.55);backdrop-filter:blur(6px);padding:5px 10px;border-radius:3px}
.svc__body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.svc__body h3{margin-bottom:10px;transition:color .25s}
.svc:hover .svc__body h3{color:var(--cyan-deep)}
.svc__body p{font-size:.95rem;color:var(--fg-soft);margin-bottom:20px;flex:1}
.svc__more{display:inline-flex;align-items:center;gap:.5em;font-family:var(--f-display);font-weight:600;font-size:.92rem;color:var(--fg)}
.svc__more svg{width:15px;height:15px;color:var(--cyan);transition:transform .3s var(--ease)}
.svc:hover .svc__more svg{transform:translateX(4px)}
.svc::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--cyan);z-index:3;transition:width .4s var(--ease-out)}
.svc:hover::before{width:100%}

/* ========================== miks meie (tume, split) ========================== */
.why{display:grid;grid-template-columns:1fr;gap:0}
@media(min-width:900px){.why{grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}}
.why__list{display:flex;flex-direction:column}
.why__item{display:grid;grid-template-columns:auto 1fr;gap:22px;padding:28px 0;border-top:1px solid var(--ink-line)}
.why__item:last-child{border-bottom:1px solid var(--ink-line)}
.why__n{font-family:var(--f-mono);font-size:.8rem;font-weight:700;color:var(--cyan-bright);padding-top:6px}
.why__item h3{color:#fff;margin-bottom:8px}
.why__item p{color:var(--on-dark-soft);font-size:.97rem}
.why__aside h2{margin-bottom:20px}
.why__aside .lead{margin-bottom:28px}
.why__media{position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;margin-top:8px}
.why__media img{width:100%;height:100%;object-fit:cover}

/* ========================== protsess ========================== */
.proc{display:grid;grid-template-columns:1fr;gap:2px;background:var(--paper-line);border:1px solid var(--paper-line)}
@media(min-width:560px){.proc{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.proc{grid-template-columns:repeat(5,1fr)}}
.proc__step{background:var(--paper);padding:30px 24px 34px;position:relative;transition:background .3s}
.proc__step:hover{background:#fff}
.proc__n{font-family:var(--f-mono);font-size:.78rem;font-weight:700;color:var(--cyan-deep);margin-bottom:auto}
.proc__bar{height:2px;background:var(--paper-3);margin:22px 0 20px;position:relative;overflow:hidden}
.proc__bar::after{content:"";position:absolute;inset:0;width:0;background:var(--cyan);transition:width .6s var(--ease-out)}
.proc__step:hover .proc__bar::after,.proc__step.lit .proc__bar::after{width:100%}
.proc__step h3{font-size:1.12rem;margin-bottom:8px}
.proc__step p{font-size:.9rem;color:var(--fg-soft)}

/* ========================== projektid (galerii) ========================== */
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:34px}
.filter{
  font-family:var(--f-display);font-weight:500;font-size:.9rem;
  padding:9px 18px;border:1px solid var(--paper-line);border-radius:100px;
  color:var(--fg-soft);transition:all .2s var(--ease);background:#fff;
}
.filter:hover{border-color:var(--fg);color:var(--fg)}
.filter[aria-pressed="true"]{background:var(--ink);border-color:var(--ink);color:#fff}
.dark .filter{background:transparent;border-color:var(--ink-line);color:var(--on-dark-soft)}
.dark .filter:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.dark .filter[aria-pressed="true"]{background:var(--cyan);border-color:var(--cyan);color:#06222B}

.gal{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(8px,1.4vw,18px)}
@media(min-width:760px){.gal{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1080px){.gal{grid-template-columns:repeat(4,1fr)}}
.gcard{
  position:relative;display:block;aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius);
  background:var(--ink-2);cursor:pointer;
  opacity:0;transform:translateY(24px) scale(.985);
  transition:opacity .6s var(--ease-out),transform .6s var(--ease-out);
}
.gcard.in{opacity:1;transform:none}
.gcard.hide{display:none}
.gcard img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out),filter .4s}
.gcard:hover img{transform:scale(1.07)}
.gcard__veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,10,13,0) 38%,rgba(7,10,13,.86));display:flex;flex-direction:column;justify-content:flex-end;padding:18px;opacity:1;transition:background .3s}
.gcard__cat{font-family:var(--f-mono);font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan-bright);margin-bottom:7px;display:flex;align-items:center;gap:7px}
.gcard__cat .mat{color:rgba(255,255,255,.55);border-left:1px solid rgba(255,255,255,.25);padding-left:7px}
.gcard__t{font-family:var(--f-display);font-weight:600;font-size:1rem;line-height:1.25;color:#fff}
.gcard__plus{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);display:grid;place-items:center;color:#fff;opacity:0;transform:scale(.8);transition:opacity .3s,transform .3s,background .2s,border-color .2s}
.gcard:hover .gcard__plus{opacity:1;transform:scale(1)}
.gcard:hover .gcard__plus{background:var(--cyan);border-color:var(--cyan);color:#06222B}
.gcard__plus svg{width:16px;height:16px}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(5,7,9,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,64px);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.lb.open{opacity:1;visibility:visible}
.lb__inner{max-width:1100px;width:100%;max-height:90vh;display:grid;grid-template-columns:1fr;background:var(--ink-2);border:1px solid var(--ink-line);border-radius:var(--radius-lg);overflow:hidden}
@media(min-width:820px){.lb__inner{grid-template-columns:1.5fr .9fr}}
.lb__img{position:relative;background:#000;min-height:280px;display:flex}
.lb__img img{width:100%;height:100%;object-fit:cover;max-height:90vh}
.lb__meta{padding:clamp(26px,3vw,44px);display:flex;flex-direction:column;color:var(--on-dark)}
.lb__cat{margin-bottom:18px}
.lb__meta h3{color:#fff;font-size:clamp(1.4rem,2.4vw,2rem);margin-bottom:24px;line-height:1.12}
.lb__rows{display:flex;flex-direction:column;gap:0;margin-bottom:28px}
.lb__row{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-top:1px solid var(--ink-line);font-size:.92rem}
.lb__row:last-child{border-bottom:1px solid var(--ink-line)}
.lb__row span:first-child{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--on-dark-faint)}
.lb__row span:last-child{color:#fff;font-weight:500;text-align:right}
.lb__nav{margin-top:auto;display:flex;gap:10px}
.lb__navbtn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border:1px solid var(--ink-line);border-radius:var(--radius);color:var(--on-dark-soft);font-family:var(--f-display);font-weight:600;font-size:.88rem;transition:all .2s}
.lb__navbtn:hover{background:var(--ink-3);color:#fff;border-color:rgba(255,255,255,.3)}
.lb__navbtn svg{width:15px;height:15px}
.lb__close{position:absolute;top:14px;right:14px;z-index:3;width:42px;height:42px;border-radius:50%;background:rgba(7,10,13,.6);backdrop-filter:blur(6px);display:grid;place-items:center;color:#fff;transition:background .2s,transform .2s}
.lb__close:hover{background:var(--cyan);color:#06222B;transform:rotate(90deg)}
.lb__close svg{width:20px;height:20px}

/* ========================== CTA riba ========================== */
.ctaband{position:relative;overflow:hidden;background:var(--ink);color:#fff}
.ctaband::before{content:"";position:absolute;inset:0;
  background:radial-gradient(900px 360px at 80% -10%,rgba(0,174,234,.22),transparent 60%)}
.ctaband__in{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:32px;align-items:center}
@media(min-width:860px){.ctaband__in{grid-template-columns:1.3fr auto}}
.ctaband h2{color:#fff;margin-bottom:16px;max-width:18ch}
.ctaband p{color:var(--on-dark-soft);max-width:46ch}
.ctaband__btns{display:flex;flex-wrap:wrap;gap:14px}

/* ========================== kontakt / vorm ========================== */
.contact{display:grid;grid-template-columns:1fr;gap:clamp(40px,5vw,72px)}
@media(min-width:920px){.contact{grid-template-columns:.9fr 1.1fr}}
.contact__info h2{margin-bottom:20px}
.contact__rows{display:flex;flex-direction:column;margin-top:32px}
.crow{display:flex;align-items:flex-start;gap:18px;padding:22px 0;border-top:1px solid var(--paper-line)}
.crow:last-child{border-bottom:1px solid var(--paper-line)}
.dark .crow{border-color:var(--ink-line)}
.crow__ic{width:44px;height:44px;flex:none;border-radius:50%;display:grid;place-items:center;background:var(--cyan-ghost);color:var(--cyan-deep)}
.dark .crow__ic{color:var(--cyan-bright)}
.crow__ic svg{width:19px;height:19px}
.crow__k{font-family:var(--f-mono);font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-faint);margin-bottom:5px}
.dark .crow__k{color:var(--on-dark-faint)}
.crow__v{font-size:1.05rem;font-weight:500;color:var(--fg)}
.dark .crow__v{color:#fff}
.crow a.crow__v:hover{color:var(--cyan-deep)}
.dark .crow a.crow__v:hover{color:var(--cyan-bright)}

.form{background:#fff;border:1px solid var(--paper-line);border-radius:var(--radius-lg);padding:clamp(26px,3.5vw,44px);box-shadow:var(--shadow)}
.dark .form{background:var(--ink-2);border-color:var(--ink-line)}
.form__grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:560px){.form__grid{grid-template-columns:1fr 1fr}}
.field{display:flex;flex-direction:column;gap:8px}
.field--full{grid-column:1/-1}
.field label{font-family:var(--f-mono);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint)}
.dark .field label{color:var(--on-dark-faint)}
.field input,.field textarea{
  width:100%;padding:14px 16px;border:1.5px solid var(--paper-line);border-radius:var(--radius);
  background:var(--paper-2);font-size:1rem;transition:border-color .2s,background .2s,box-shadow .2s;
}
.dark .field input,.dark .field textarea{background:var(--ink-3);border-color:var(--ink-line);color:#fff}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--cyan);background:#fff;box-shadow:0 0 0 4px var(--cyan-ghost)}
.dark .field input:focus,.dark .field textarea:focus{background:var(--ink-3)}
.field textarea{resize:vertical;min-height:130px}
.form__foot{margin-top:24px;display:flex;flex-wrap:wrap;align-items:center;gap:18px;justify-content:space-between}
.form__note{font-size:.8rem;color:var(--fg-faint);max-width:34ch}
.dark .form__note{color:var(--on-dark-faint)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form__msg{display:none;padding:14px 16px;border-radius:var(--radius);font-size:.92rem;margin-top:18px;font-weight:500}
.form__msg.ok{display:block;background:rgba(0,174,234,.1);color:var(--cyan-deep);border:1px solid rgba(0,174,234,.3)}
.form__msg.err{display:block;background:rgba(220,60,60,.08);color:#c33;border:1px solid rgba(220,60,60,.25)}

/* ========================== teenuselehe pikk sisu ========================== */
.svchero{position:relative;min-height:62vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:var(--ink)}
.svchero__media{position:absolute;inset:0;z-index:0}
.svchero__media img{width:100%;height:100%;object-fit:cover;object-position:center 40%;transform:scale(1.06);animation:heroZoom 12s var(--ease-out) forwards}
.svchero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,10,13,.55),rgba(7,10,13,.2) 40%,rgba(7,10,13,.9))}
.svchero__in{position:relative;z-index:2;width:100%;padding-top:calc(var(--hd) + 56px);padding-bottom:clamp(40px,5vw,72px)}
.crumbs{display:flex;align-items:center;gap:9px;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.06em;color:rgba(255,255,255,.6);margin-bottom:24px;flex-wrap:wrap}
.crumbs a:hover{color:#fff}
.crumbs .sep{opacity:.5}
.crumbs .cur{color:var(--cyan-bright)}
.svchero h1{max-width:18ch;color:#fff;margin-bottom:0}

.article{display:grid;grid-template-columns:1fr;gap:clamp(40px,5vw,72px)}
@media(min-width:940px){.article{grid-template-columns:1.55fr .85fr;align-items:start}}
.prose>*+*{margin-top:22px}
.prose .lead{margin-bottom:8px}
.prose h2{margin-top:14px}
.prose h3{margin-top:10px;color:var(--fg)}
.prose p{color:var(--fg-soft);font-size:1.06rem}
.prose strong{color:var(--fg);font-weight:600}
.checklist{display:grid;grid-template-columns:1fr;gap:2px;margin-top:8px}
@media(min-width:600px){.checklist{grid-template-columns:1fr 1fr}}
.checklist li{display:flex;align-items:flex-start;gap:13px;padding:15px 4px;border-top:1px solid var(--paper-line);font-size:.98rem;color:var(--fg)}
.checklist li svg{width:20px;height:20px;flex:none;color:var(--cyan);margin-top:1px}
.specbox{background:var(--paper-2);border:1px solid var(--paper-line);border-radius:var(--radius-lg);padding:8px 24px}
.specrow{display:flex;flex-direction:column;gap:5px;padding:20px 0;border-top:1px solid var(--paper-line)}
.specrow:first-child{border-top:none}
.specrow .k{font-family:var(--f-display);font-weight:600;font-size:1.02rem;display:flex;align-items:center;gap:10px}
.specrow .k::before{content:"";width:9px;height:9px;background:var(--cyan);border-radius:2px}
.specrow .v{font-size:.92rem;color:var(--fg-soft);padding-left:19px}

/* sticky aside kaart */
.aside-card{position:sticky;top:calc(var(--hd) + 20px);display:flex;flex-direction:column;gap:18px}
.aside-cta{background:var(--ink);color:#fff;border-radius:var(--radius-lg);padding:30px 28px;position:relative;overflow:hidden}
.aside-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 200px at 100% 0,rgba(0,174,234,.25),transparent 60%)}
.aside-cta>*{position:relative;z-index:1}
.aside-cta .eyebrow{color:var(--cyan-bright)}
.aside-cta h3{color:#fff;font-size:1.4rem;margin:14px 0 10px}
.aside-cta p{color:var(--on-dark-soft);font-size:.94rem;margin-bottom:22px}
.aside-phone{display:flex;align-items:center;gap:12px;margin-top:18px;padding-top:18px;border-top:1px solid var(--ink-line)}
.aside-phone svg{width:20px;height:20px;color:var(--cyan-bright)}
.aside-phone a{font-family:var(--f-mono);font-weight:700;font-size:1.05rem;color:#fff}

/* products (vedelplast) */
.prodlist{display:grid;grid-template-columns:1fr;gap:2px;background:var(--paper-line);border:1px solid var(--paper-line);border-radius:var(--radius-lg);overflow:hidden}
.prod{background:#fff;padding:26px 28px;display:grid;grid-template-columns:1fr;gap:8px;transition:background .25s}
@media(min-width:680px){.prod{grid-template-columns:230px 1fr;gap:28px;align-items:start}}
.prod:hover{background:var(--paper-2)}
.prod__name{font-family:var(--f-display);font-weight:600;font-size:1.05rem;display:flex;align-items:flex-start;gap:11px}
.prod__name .dot{width:9px;height:9px;background:var(--cyan);border-radius:2px;margin-top:8px;flex:none}
.prod__desc{font-size:.95rem;color:var(--fg-soft)}

/* projekti detail */
.pdetail{display:grid;grid-template-columns:1fr;gap:clamp(32px,4vw,56px)}
@media(min-width:880px){.pdetail{grid-template-columns:1.4fr .85fr;align-items:start}}
.pdetail__img{border-radius:var(--radius-lg);overflow:hidden;background:var(--ink-2)}
.pdetail__img img{width:100%;height:auto;display:block}
.pmeta{background:var(--paper-2);border:1px solid var(--paper-line);border-radius:var(--radius-lg);padding:8px 26px;position:sticky;top:calc(var(--hd) + 20px)}
.pmeta__row{display:flex;flex-direction:column;gap:5px;padding:18px 0;border-top:1px solid var(--paper-line)}
.pmeta__row:first-child{border-top:none}
.pmeta__row .k{font-family:var(--f-mono);font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint)}
.pmeta__row .v{font-size:1.05rem;font-weight:500;color:var(--fg)}

/* related */
.related{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(8px,1.4vw,16px)}
@media(min-width:880px){.related{grid-template-columns:repeat(4,1fr)}}

/* ========================== footer ========================== */
.ftr{background:#070A0D;color:var(--on-dark-soft);padding-top:clamp(60px,7vw,96px)}
.ftr__top{display:grid;grid-template-columns:1fr;gap:48px;padding-bottom:clamp(48px,6vw,72px);border-bottom:1px solid var(--ink-line)}
@media(min-width:760px){.ftr__top{grid-template-columns:1.4fr 1fr 1fr}}
@media(min-width:1040px){.ftr__top{grid-template-columns:1.6fr 1fr 1fr 1.1fr}}
.ftr__brand img{height:34px;width:auto;filter:brightness(0) invert(1);margin-bottom:22px}
.ftr__brand p{font-size:.95rem;color:var(--on-dark-soft);max-width:34ch;margin-bottom:24px}
.ftr__kfml{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--ink-line);border-radius:var(--radius-lg);max-width:360px}
.ftr__kfml img{height:48px;width:auto;flex:none}
.ftr__kfml span{font-size:.82rem;color:var(--on-dark-soft);line-height:1.4}
.ftr__col h4{font-family:var(--f-mono);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--on-dark-faint);margin-bottom:20px}
.ftr__col ul{display:flex;flex-direction:column;gap:12px}
.ftr__col a{font-size:.96rem;color:var(--on-dark-soft);transition:color .2s;display:inline-flex;align-items:center;gap:9px}
.ftr__col a:hover{color:#fff}
.ftr__col a svg{width:15px;height:15px;color:var(--cyan);flex:none}
.ftr__bottom{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:center;padding-block:28px;font-size:.84rem;color:var(--on-dark-faint)}
.ftr__bottom a{color:var(--on-dark-soft)}
.ftr__bottom a:hover{color:var(--cyan-bright)}
.ftr__legal{display:flex;flex-wrap:wrap;gap:18px;align-items:center}

/* ========================== reveal ========================== */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.08s}.rv-d2{transition-delay:.16s}.rv-d3{transition-delay:.24s}.rv-d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .rv,.gcard{opacity:1 !important;transform:none !important;transition:none !important}
  .hero__media img,.svchero__media img{animation:none;transform:none}
  .mnav__a{animation:none;opacity:1;transform:none}
}

/* utilities */
.center{text-align:center}
.mt-s{margin-top:14px}.mt-m{margin-top:28px}.mt-l{margin-top:44px}
.maxw{max-width:62ch}
.nowrap{white-space:nowrap}
.only-mob{display:block}
@media(min-width:980px){.only-mob{display:none}}

/* ========================== pagehead (siselehtede tume päis) ========================== */
.pagehead{position:relative;background:var(--ink);color:#fff;overflow:hidden;
  padding-top:calc(var(--hd) + 64px);padding-bottom:clamp(44px,6vw,88px)}
.pagehead::before{content:"";position:absolute;inset:0;
  background:radial-gradient(820px 340px at 85% -12%,rgba(0,174,234,.20),transparent 60%)}
.pagehead::after{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(var(--ink-line-2) 1px,transparent 1px),linear-gradient(90deg,var(--ink-line-2) 1px,transparent 1px);
  background-size:64px 64px;mask-image:linear-gradient(180deg,transparent,#000 45%,transparent)}
.pagehead__in{position:relative;z-index:2}
.pagehead .eyebrow{color:var(--cyan-bright);margin-bottom:22px}
.pagehead h1{color:#fff;max-width:20ch;margin-bottom:18px}
.pagehead .lead{color:var(--on-dark-soft);max-width:62ch}
.pagehead .crumbs{margin-bottom:26px}

/* 404 */
.nf{min-height:72vh;display:grid;place-items:center;text-align:center;background:var(--ink);color:#fff;position:relative;overflow:hidden}
.nf::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 300px at 50% 0,rgba(0,174,234,.18),transparent 60%)}
.nf__in{position:relative;z-index:2;padding:120px var(--gut) 80px}
.nf__code{font-family:var(--f-mono);font-weight:700;font-size:clamp(4rem,16vw,9rem);line-height:1;color:var(--cyan-bright);letter-spacing:-.02em}
.nf h1{color:#fff;margin:18px 0 14px}
.nf p{color:var(--on-dark-soft);max-width:46ch;margin:0 auto 32px}

/* intro stack (teenuste lehe sissejuhatus) */
.istack>*+*{margin-top:20px}
.svc-products{margin-top:18px}
