/*
Theme Name: Kaverien
Author: 
Version: 0.1
*/

*, *::before, *::after{
  box-sizing: border-box;
}

.top-ticker {
  height: 32px;
  background: #9A3E2A;
  color: #fff;
  display: flex;
  align-items: center;
  width: 100%;
  overflow: hidden;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.top-ticker__viewport {
  width: min(100%, var(--container-max));
  margin: 0 auto;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
  box-sizing: border-box;
  overflow: hidden;
}

.top-ticker__track {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  gap: 170px; 
  padding-left: 170px;
  will-change: transform;
  animation: topTickerMove 40s linear infinite;
}

.top-ticker__item {
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.03em;
  text-transform: none;
}


@keyframes topTickerMove {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}


@media (prefers-reduced-motion: reduce) {
  .top-ticker__track {
    animation: none;
    justify-content: center;
  }
}


:root{
  --side-pad: 25px;
  --container-max: 1200px;
}

@media (max-width: 1200px){
  :root{
    --side-pad: 20px;
  }
}

@media (max-width: 850px){
  :root{
    --side-pad: 10px;
  }
}

/* HEADER */
.site-header{
  background: #fff;
}

.site-header__container{
  width: 100%;
}

.site-header__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;
  height: 96px;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  box-sizing: border-box;
  position: relative;
}

.site-header__inner::after{
  content: "";
  position: absolute;
  left: var(--side-pad);
  right: var(--side-pad);
  bottom: 0;
  height: 1px;
  background: #F2F2F2;
  pointer-events: none;
}

.site-header__left{
  justify-self: start;
  display: flex;
  align-items: center;
}

.site-header__right{
  justify-self: end;
  display: flex;
  align-items: center;
}

/* NAV (desktop) */
.site-nav{ display: block; }

.site-nav__list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;

  gap: clamp(23px, 4vw, 42px);
}

.site-nav__list a{
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.03em;
  color: #000;
  text-decoration: none;
}

.site-nav__list a:hover{ opacity: .75; }

/* LOGO */
.site-header__logo{
  justify-self: center;
  text-decoration: none;
  color: #000;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 28px;
  line-height: 1.45;
  letter-spacing: 0.40em;
  white-space: nowrap;
}

/* CTA */
.cta-btn{
  width: 152px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: #000;
  color: #fff;
  border-radius: 5px;
  text-decoration: none;

  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.03em;
}

/* BURGER (mobile only) */
.burger{
  display: none;
  width: 20px;
  height: 15px;
  padding: 0;
  margin: 0;
  border: 0;
  background: transparent;
  cursor: pointer;

  flex-direction: column;
  justify-content: space-between;
}

.burger__bar{
  display: block;
  height: 1.5px;
  width: 20px;
  background: #000;
}

/* MOBILE MENU PANEL */
.mobile-menu{
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
  padding-top: 14px;
  padding-bottom: 18px;
}

.mobile-menu__list{
  list-style: none;
  margin: 0 0 14px 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.mobile-menu__list a{
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.03em;
  color: #000;
  text-decoration: none;
  padding: 10px 0;
}

/* CTA mobile */
.cta-btn--mobile{
  width: 152px;
}

/* PHONE ICON (mobile) */
.phone-icon{
  display: none;
  width: 30px;
  height: 21px;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.phone-icon svg{
  display: block;
}

@media (max-width: 1200px){
  .site-nav{ display: none; }
  .cta-btn{ display: none; }

  .burger{ display: flex; }
  .phone-icon{ display: inline-flex; }
}

/* Etusivu */
.front-page{
  margin-top: 8px;
}

/* HERO */
.hero{
  width: 100%;
}

.hero__inner{
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
}

/* Kuva */
.hero img{
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  border-radius: 5px;
}

.intro-split{
  margin-top: 30px;
}

.intro-split__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
}

.site-header__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;
}

.site-header__divider{
  width: min(100%, var(--container-max));
  margin-left: auto;
  margin-right: auto;
}

.hero__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;
}

.intro-split__grid{
  background: #F8F5F1;
  border-radius: 5px;
  overflow: hidden;

  width: 100%;
  margin: 0;

  display: grid;

  grid-template-columns: minmax(0, 1fr) 520px;
  grid-template-areas: "content media";
}

.intro-split__content{ grid-area: content; }
.intro-split__media{ grid-area: media; }

.intro-split--reverse .intro-split__grid{
  grid-template-areas: "media content";
}

.intro-split--dark .intro-split__grid{
  background: #F8F5F1;
}

.intro-split__content{
  padding: 70px 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Otsikko */
.intro-split__title{
  margin-bottom: 40px;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 28px;
  letter-spacing: 0.03em;
  color: #000;
  text-align: left;
}

.intro-split__body{
  margin-top: 10px;
}

.intro-split__body p{
  margin: 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 300;
  font-size: 20px;
  letter-spacing: 0;
  color: #000;
  line-height: 1.55;
}

.intro-split__body p + p{
  margin-top: 22px;
}

.intro-split__link{
  margin-top: 50px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #9A3E2A;

  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 0.03em;
}

.intro-split__arrow{
  display: inline-flex;
  align-items: center;
  transform: translateY(1px);
}

.intro-split__arrow svg{
  display: block;
}

.intro-split__link:hover{
  opacity: .85;
}

/* Media-alue (desktop) */
.intro-split__media{
  grid-area: media;
  position: relative;
  min-height: 520px;
}

.intro-split__media img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: 45% center;
}

@media (max-width: 1024px){
  .intro-split__grid{
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
      "content"
      "media";
  }

  .intro-split--reverse .intro-split__grid{
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
      "content"
      "media";
  }

  .intro-split__content{ grid-area: content; }
  .intro-split__media{ grid-area: media; }


  .intro-split__title{ 
    font-size: 22px;
    margin-bottom: 0px;
    margin-top: 5px;
  
  }
  .intro-split__body p{ font-size: 16px; }
  .intro-split__link{ font-size: 16px; }

  .intro-split__content{
    padding: 20px 20px;
  }

  .intro-split__body{ margin-top: 28px; }
  .intro-split__link{ margin-top: 28px; }


  .intro-split__media img{
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: 5px;
    object-position: 45% 50%;
  }

  .intro-split{
  margin-top: 32px;
  }
}

@media (max-width: 850px){
  .intro-split__content{
    padding: 30px 20px;
  }
}

@media (max-width: 850px){
  .site-header__logo{
    font-size: 20px;
    letter-spacing: 0.28em;
  }
}

@media (max-width: 850px){
  .hero img{
    height: 270px;
    object-fit: cover;
    object-position: 50% 50%;
  }
}

@media (max-width: 1024px){
  .intro-split__media{
    min-height: auto;
    padding: 20px 0px 0px 0px;
  }
}

/* isot desktopit */
@media (min-width: 1400px){
  :root{ --container-max: 1360px; }
}

/* ultrawide */
@media (min-width: 1800px){
  :root{ --container-max: 1520px; }
}

/*FOOTER */
.site-footer{
  margin-top: 30px;
  background: #3B2F26;
  color: #fff;
}

.site-footer__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;

  padding-left: clamp(20px, 5vw, 96px);
  padding-right: clamp(20px, 5vw, 96px);
  padding-top: clamp(64px, 6vw, 120px);
  padding-bottom: clamp(64px, 6vw, 120px);

  display: grid;
  grid-template-columns: auto 1fr 1fr 1fr;
  align-items: center;
  column-gap: clamp(32px, 6vw, 110px);

  box-sizing: border-box;
  text-align: center;
}

/* LOGO */
.site-footer__logo{
  justify-self: center;
  text-align: center;

  text-decoration: none;
  color: #fff;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: clamp(26px, 2.6vw, 40px);
  line-height: 1.15;
  letter-spacing: 0.40em;
  padding-left: 0.40em;
  white-space: nowrap;
}

.site-footer__col{
  justify-self: center;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.site-footer__title{
  margin: 0 0 18px 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: 0.03em;
}

.site-footer__list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.site-footer__list a{
  color: rgba(255,255,255,0.9);
  text-decoration: none;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 300;
  font-size: 15px;
  line-height: 1.6;
}

.site-footer__list a:hover{
  opacity: .85;
}

/* FOOTER IMAGE */
.site-footer__image{
  justify-self: center;
  align-self: center;
}

.site-footer__image img{
  display: block;
  max-width: 120px;
  width: 100%;
  height: auto;
}

/* MOBIILI */
@media (max-width: 700px){
  .site-footer__inner{
    grid-template-columns: 1fr;
    row-gap: 45px;
    justify-items: center;
  }

  .site-footer__image{
    order: 3;
  }

  .site-footer__col[aria-label="Tietoa"]{
    order: 1;
  }

  .site-footer__col[aria-label="Yhteystiedot"]{
    order: 2;
  }

  .site-footer__logo{
    order: 4;
    margin-top: 13px;
  }
}



/* =========================
   MEISTÄ-SIVU
   ========================= */

.page-about{
  margin-top: 8px;
}

/* Sivun otsikko */
.page-title__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
  padding-top: 18px;
  padding-bottom: 6px;
}

.page-title__heading{
  margin: 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 32px;
  letter-spacing: 0.03em;
  color: #000;
}

.about-split__title{
  margin: 0;
  font-size: 0;
  line-height: 0;
}

.page-about .about-split .intro-split__content{
  padding-top: 0px;
  padding-bottom: 0px;
}

.page-about .about-split.intro-split--dark .intro-split__content{
  padding-top: 20px;
  padding-bottom: 0px;
}

.page-about .intro-split__body p{
  font-size: 17px;
  line-height: 1.55;
}

/* Väliteksti + linkki */
.about-meta{
  margin-top: 38px;
}

.about-meta__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
}

.about-meta__text{
  margin: 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 1.6;
  color: #000;
}

.about-meta__link{
  margin-top: 14px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #9A3E2A;

  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: 0.03em;
}

.about-meta__link:hover{ opacity: .85; }

.about-meta__plus{
  font-weight: 600;
  font-size: 18px;
  line-height: 1;
}

/* Henkilökortit */
.team{
  margin-top: 42px;
}

.team__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
}

.team__grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}


.team-card{
  background: #F8F5F1;
  border-radius: 5px;
  overflow: hidden;
  display: grid;
  grid-template-columns: clamp(110px, 32vw, 190px) 1fr;
  min-height: 160px;
}

.team-card__photo img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.team-card__body{
  padding: clamp(14px, 3.8vw, 28px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  align-items: center;
  text-align: center;
}

.team-card__name{
  margin: 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: clamp(16px, 4vw, 18px);
  letter-spacing: 0.03em;
  color: #000;
}

.team-card__email,
.team-card__phone{
  text-decoration: none;
  color: #9A3E2A;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 400;
  font-size: clamp(14px, 3.6vw, 15px);
  line-height: 1.6;
}

.team-card__email:hover,
.team-card__phone:hover{
  opacity: .85;
}

@media (max-width: 900px){
  .team__grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px){
  .team-card{
    grid-template-columns: clamp(110px, 32vw, 190px) 1fr;
  }
  .team-card__photo img{
    aspect-ratio: auto;
  }
  .page-about .intro-split__body p{
    font-size: 14.5px;
    line-height: 1.5;
  }
}

@media (max-width: 1024px){
  .page-about .about-split.intro-split--dark .intro-split__content{
    padding-top: 5px;
    padding-bottom: 0px;
  }
  .page-about .intro-split__body p{
    margin-bottom: 27px;
  }

  .page-about .page-title__heading{
    margin-top: 7px;
  }
}

/* =========================
   PALVELUT-SIVU
   ========================= */

.page-services{
  margin-top: 8px;
}

.page-services .intro-split__body p{
  font-size: 15px;
  line-height: 1.55;
}

@media (max-width: 600px){
  .page-services .intro-split__body p{
    font-size: 14.5px;
    line-height: 1.5;
  }
}


.page-services .services-split .intro-split__content{
  padding-top: 40px;
  padding-bottom: 40px;
}


.page-services .services-split .intro-split__media{
  min-height: 300px;
  max-height: 300px;
  overflow: hidden;
}


.services-split__title{
  margin: 0
}


.page-services .services-split .intro-split__media img{
  height: 100%;
  object-fit: cover;
}


.page-services .services-options{
  padding-top: 26px;
  padding-bottom: 26px;
}

.services-options__heading{
  margin: 0 0 27px 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 0.03em;
  color: #000;
}

.services-options__items{
  display: grid;
  gap: 20px;
}

.services-options__title{
  margin: 0 0 6px 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.03em;
  color: #000;
}

.services-options__text{
  margin: 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 300;
  font-size: 14px;
  line-height: 1.55;
  color: #000;
}

.services-meta{
  margin-top: 38px;
  padding-bottom: 8px;
}

.services-meta__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
}

.services-meta__text{
  margin: 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 1.6;
  color: #000;
}

.page-services .services-split--third .intro-split__media{
  min-height: 350px;
  max-height: 350px;
  overflow: hidden;
}

.page-services .services-split--third .intro-split__media img{
  height: 100%;
  object-fit: cover;
}

@media (max-width: 1024px){
  
  .page-services .services-split .intro-split__content{
  padding-top: 0px;
  padding-bottom: 0px;
  }

  .page-services .page-title__heading{
    margin-top: 7px;
  }

  .services-options__heading{
  margin: 37px 0 27px 0;
  }

  .services-options__text{
  margin: 0px 0 5px 0;
  }

  .page-services .intro-split__body p{
  margin: 5px 0 20px 0;
  }

}

/* =========================
   CONTACT CTA
   ========================= */

.contact-cta{
  margin-top: 37px;
}

.contact-cta__inner{
  width: min(100%, var(--container-max));
  margin: 0 auto;
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);
}

.contact-cta__box{
  background: #F8F5F1;
  border-radius: 5px;
  padding: 20px;

  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: 36px;
}

.contact-cta__col{
  display: flex;
  align-items: center;
}

.contact-cta__col--left{
  justify-content: center;
}

.contact-cta__col--center{
  justify-content: center;
}

.contact-cta__col--right{
  justify-content: center;
}

.contact-cta__title{
  margin: 0;
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.03em;
  color: #9A3E2A;
  text-align: center;
}

/* linkit */
.contact-cta__item{
  display: inline-flex;
  align-items: center;
  gap: 12px;

  text-decoration: none;
  color: #9A3E2A;

  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.contact-cta__item:hover{ opacity: .85; }

.contact-cta__icon{
  display: inline-flex;
  width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
}

.contact-cta__icon svg{ display: block; }

@media (max-width: 700px){
  .contact-cta__box{
    grid-template-columns: 1fr 1fr;
    row-gap: 12px;
    column-gap: 18px;
    padding: 16px;
    text-align: center;
  }
  
  .contact-cta{
    margin-top: 30px;
  }

  .contact-cta__col--left{
    justify-content: center;
  }

  .contact-cta__col--center{
    grid-column: 2;
    grid-row: 1;
    justify-content: center;
  }

  .contact-cta__col--right{
    grid-column: 2;
    grid-row: 2;
    justify-content: center;
  }

  .contact-cta__col--left{
    grid-column: 1;
    grid-row: 1 / span 2;
  }

  .contact-cta__title{
    font-size: 16px;
  }

  .contact-cta__item{
    justify-content: center;
    font-size: 14.5px;
  }
}

.page-services .intro-split__body strong{
  font-weight: 500;
}

.page-about .intro-split__body strong{
  font-weight: 500;
}

html{
  scroll-behavior: smooth;
}

@media (max-width: 1024px){

  .page-services .page-title__inner,
  .page-about .page-title__inner{
    padding-top: 8px;
    padding-bottom: 0px;
  }
  
  .page-services .services-options ~ .intro-split__media{
    padding-top: 32px;
  }
  
  .page-services .intro-split__content,
  .page-about .intro-split__content{
    padding-top: 0px;
  }
}