
html, body, div, span, applet, object, iframe,
  h1, h2, h3, h4, h5, h6, p, blockquote, pre,
  a, abbr, acronym, address, big, cite, code,
  del, dfn, em, img, ins, kbd, q, s, samp,
  small, strike, strong, sub, sup, tt, var,
  b, u, center,
  dl, dt, dd, ol, ul, li,
  fieldset, form, label, legend,
  table, caption, tbody, tfoot, thead, tr, th, td,
  article, aside, canvas, details, embed, 
  figure, figcaption, footer, header, hgroup, 
  menu, nav, output, ruby, section, summary,
  time, mark, audio, video {
      margin: 0;
      padding: 0;
      border: 0;
      font-size: 100%;
      font: inherit;
      vertical-align: baseline;
  }
  article, aside, details, figcaption, figure, 
  footer, header, hgroup, menu, nav, section {
      display: block;
  }
  body {
      line-height: 1;
  }
  ol, ul {
      list-style: none;
  }
  blockquote, q {
      quotes: none;
  }
  blockquote:before, blockquote:after,
  q:before, q:after {
      content: '';
      content: none;
  }
  table {
      border-collapse: collapse;
      border-spacing: 0;
  }
* { box-sizing: border-box; }

html,body {
    margin: 0;
    min-height: 100vh;
    min-height: -webkit-fill-available;
}
body {
font-family:system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;

}

html {
    font-size: 62.5%; /* 1rem = 10px istället för 16px */
    scroll-behavior: smooth;
}

h1 {
    font-size: clamp(3.2rem, 5vw, 4.8rem); /* 28px → 48px */
    margin-bottom: clamp(0.7rem, 3vw, 1.2rem); /* 14px → 24px */
}

  
  h2 {
    font-size: clamp(2.4rem, 4.5vw, 3.6rem); /* 24px → 36px */
    margin-bottom: clamp(0.7rem, 3vw, 1.2rem); /* 14px → 24px */
  }
  
  h3,.cta,button {
    font-size: clamp(2rem, 4vw, 2rem); /* 20px → 30px */
    margin-bottom: clamp(0.7rem, 3vw, 1.2rem); /* 14px → 24px */
  }
  
  nav a {
    font-size: clamp(1.6rem, 2.5vw, 2rem); /* 20px → 30px */
  }

  .cta {
    margin-top: clamp(0.7rem, 3vw, 1.2rem); /* 14px → 24px */
  }

  p,input,select,footer {
    font-size: clamp(1.6rem, 2.5vw, 2rem); /* 16px → 20px */
    line-height: clamp(2.2rem, 2.5vw, 3.2rem); /* 16px → 20px */
    margin-bottom: clamp(0.7rem, 3vw, 1.2rem); /* 14px → 24px */
  }
  
  a {
    font-size: clamp(1.6rem, 2.5vw, 2rem); /* 16px → 20px */
  }

  p {opacity: 0.8; display: inline-block;}

  small {
    font-size: clamp(1.2rem, 1.8vw, 1.6rem); /* 12px → 16px */
  }
  

.mobileMenu {display: none;}

header {
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    display: flex;
    height: 70px;
    justify-content: center;
    align-items: center;
    z-index: 100;
}

button,input,select,.cta {height: 50px; display: inline-block;}
.cta {background: #000; color: #fff; max-width: fit-content; min-width: 200px; border-radius: 8px; display: flex; align-items: center; justify-content: center; text-decoration: none;}

header .inner {
    max-width: 1400px;
    width: 100%;
    display: flex;
    align-items: center;
    height: 100%;
    padding: 16px;
}

header .inner nav {
margin-left: auto;
display: flex;
margin-right: -16px;
height: 100%;
align-items: center;
}

.sectionInner {padding: 16px; z-index: 1;}
header .logotype img {max-height: 50px; width: auto;}
.footerLogotype {display: flex; justify-content: center;}
.footerLogotype img {max-width: 250px;}
header .inner nav a{
padding-left: 16px; padding-right: 16px;
color: #000;
text-decoration: none;
transition: all 0.35s;
}

header .inner nav a.active {opacity: 1; font-weight: bold;}
header .inner nav a.hover {opacity: 1}



content {
    padding-top: 70px;
    position: relative;
    display: table;
    min-height: 100vh;
    width: 100%;
}

.grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    margin-bottom: clamp(0.7rem, 3vw, 1.2rem); /* 14px → 24px */
    gap: clamp(2rem, 3vw, 3rem); /* 14px → 24px */
    padding: 16px;
}



footer {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 16px;
        padding: 16px;
}

video,img {
    max-width: 100%;
    height: auto;
}

section {
    width: 100%;position: relative; margin-left: auto; margin-right: auto; opacity: 0; transition: all 0.8s;
    padding-top: 400px;
    padding-bottom: clamp(2.8rem, 5vw, 4.8rem);
}
section.active {
    opacity: 1;
    padding-top: clamp(5rem, 5vw, 12rem);
    padding-top: clamp(2.8rem, 5vw, 4.8rem);
}
.hero .sectionWrapper {width: 100%; height: 100%; position: absolute; z-index: 2; display: flex; align-items: center; justify-content: center;}

.textContent {padding-left:16px; padding-right: 16px;}



section.top {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(2rem, 5vw, 4rem);
    min-height: fit-content
}

section.bottom {
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
    gap: clamp(2rem, 5vw, 4rem);
    min-height: fit-content
}

section.left {
    display: flex;
    align-items: center;
    gap: clamp(2.8rem, 5vw, 4.8rem);
    min-height: fit-content
}

section.right {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    gap: clamp(2.8rem, 5vw, 4.8rem);
    min-height: fit-content
}

.textLeft {
    display: flex;
    align-items: start;
    flex-direction: column;
}

.textCenter {
    display: flex;
    align-items: center;
    flex-direction: column;
    text-align: center;
}

.textRight {
    display: flex;
    align-items: end;
    flex-direction: column;
}



.mediaContent,.textContent {
    width: 100%;
}

.hero {
    position: relative;
    min-height: 100vh;
    margin-top: -70px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.videoBackground video {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

footer .logotype {
    display: flex;
    justify-content: center;
}

@media only screen and (max-width: 768px) {

    header .logotype img {max-height: 40px; width: auto;}

section.right,section.left,section.bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(2rem, 5vw, 4rem);
    padding-bottom: clamp(2.8rem, 5vw, 4.8rem);
    min-height: fit-content;
    padding-top: 0;
}

}

b {font-weight: bold;}

.grid-item .textContent {padding: 0; padding-top: 16px;}