

:root{
  --focus-ring: #3e5c76;         
  --focus-bg:   rgba(62,92,118,.15);
  --focus-text: #0d1321;
  --focus-offset: 3px;
}
body.light-mode{
  --focus-ring: #1d2d44;         
  --focus-bg:   rgba(29,45,68,.15);
  --focus-text: #0d1321;
}


*:focus{ outline: revert; outline-offset: revert; }


:where(a,button,[role="button"],input,select,textarea,
      summary,details,[tabindex]:not([tabindex="-1"])):focus-visible{
  outline: 2px solid var(--focus-ring);
  outline-offset: var(--focus-offset);
  box-shadow:
    0 0 0 4px var(--focus-bg); 
}

:where(button,.overlay-btn,.hero-btn-static,.somet-circle,img, .somet-circle img){
  border-radius: 999px; 
}


.kylki-valikko a:focus-visible{
  text-decoration: underline;
  text-underline-offset: 3px;
}



:where(.content-box,[role="link"],[role="button"],.overlay-btn):focus-visible{
  outline-width: 3px;
}


#chatbot-scroll-btn:focus-visible,
#chatbot-toggle:focus-visible,
#chatbot-close:focus-visible{
  outline: 2px solid var(--focus-ring);
  outline-offset: var(--focus-offset);
  box-shadow: 0 0 0 4px var(--focus-bg);
}

.kylki-socials .somet-circle:focus-visible,
.social-icons-inline .somet-circle:focus-visible{
  outline: 2px solid var(--focus-ring);
  outline-offset: 4px;
  box-shadow: 0 0 0 6px var(--focus-bg);
}

@media (prefers-reduced-motion: reduce){
  .skip-link{ transition: none; }
}




.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  margin: -1px; padding: 0; border: 0;
  clip: rect(0 0 0 0); clip-path: inset(50%);
  overflow: hidden; white-space: nowrap;
}

.lang-toggle-circle:focus-visible,
.icon-button:focus-visible {
  outline: 3px solid #748cab;
  outline-offset: 3px;
  border-radius: 999px;
}

@media (prefers-reduced-motion: reduce) {
  * , *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }

  .hero-lines,
  .ltr-sweep,
  .hero-buttons-wrapper { 
    transform: none !important;
    animation: none !important;
  }

  body.lines-flipped,
  body.panels-open,
  body.content-visible { }

  .kvStickyArea .kuutiopelle3-inner { transform: none !important; }
}



:root {
  
  --c-ink: #0d1321;     
  --c-ink-2: #1d2d44;
  --c-ink-3: #3e5c76;
  --c-ink-4: #748cab;

  --c-paper: #f0ebdb;   
  --c-black: #000000;
  --c-white: #ffffff;

  --font-body-size: clamp(16px, 1.6vw, 18px);
  --line-body: 1.6;
}

body {
  color: var(--c-paper);
  background: var(--c-ink);
  font-size: var(--font-body-size);
  line-height: var(--line-body);
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body.light-mode {
  color: var(--c-ink);
  background: var(--c-paper);
}

a { color: var(--c-ink-3); }
body:not(.light-mode) a { color: var(--c-ink-4); }

input, textarea, select, button {
  font-size: max(16px, 1rem);
  line-height: 1.4;
}



.body-copy {
  font-size: var(--font-body-size);   
  line-height: var(--line-body);
  letter-spacing: .01em;
}

.note {
  font-size: clamp(16px, 1.4vw, 17px);
  opacity: .9;
}

.lead {
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.55;
}


a:focus, button:focus, input:focus, textarea:focus, select:focus {
  outline: 3px solid #748cab;  
  outline-offset: 3px;
}