/* ============================================== *\
   RESET O GLOBAL
\* ============================================== */
:root{
  --accent: #E2FF82;
  --text: #0b0b0b;
  --max-width: 1200px;
  --pad-x: 24px;
  --hover: rgba(11, 11, 11, 0.65);
  --nav-offset: 76px;
}
*,
*::before,
*::after{
  box-sizing: border-box;
}
html, body{
  margin: 0;
  padding: 0;
}
body{
  font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  line-height: 1.4;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  padding-top: var(--nav-offset);
}
.container{
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
/* Media defaults */
img, video, canvas, svg{
  display: block;
  max-width: 100%;
  height: auto;
}
/* Form elements inherit font????????????????????????????????????? */
input, button, textarea, select{
  font: inherit;
}
.accent{
  color: var(--accent);
}
:focus-visible{
  outline: 2px solid var(--text);
  outline-offset: 3px;
}
/* ---------------- Header/Nav ---------------- */
.qs-nav{
  background: var(--accent);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  transition: background 220ms ease, box-shadow 220ms ease;
  padding:14px 0;
}
.qs-nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}
.page--home .home-hero{
  padding-top: var(--nav-offset);
}
.page--home{
padding-top: 0;
}
.qs-logo{
  flex-shrink:0; 
}
.qs-logo img{
  height: 44px; 
  width:auto; 
  display:block;
}
/* Hamburger (mobil/tablet) */
.menu-toggle{
  display:none;
  border:0;
  background:transparent;
  cursor:pointer;
  padding:10px;
  z-index: 1999999;
}
.burger{
  position:relative;
  width:24px;
  height:14px;
  display:block;
}
.burger span{
  position:absolute;
  left:0;
  right:0;
  height:3px;
  background:var(--text);
  transition:
    transform 200ms ease,
    top 200ms ease,
    opacity 200ms ease;
}
/* kryss istället för hamburger */
.burger span:nth-child(1){ 
  top:0; 
}
.burger span:nth-child(2){ 
  top:6px; 
}
.burger span:nth-child(3){ 
  top:12px; 
}
.qs-nav.is-open .burger span:nth-child(1){
  top:6px;
  transform:rotate(45deg);
}
.qs-nav.is-open .burger span:nth-child(2){
  opacity:0;
}
.qs-nav.is-open .burger span:nth-child(3){
  top:6px;
  transform:rotate(-45deg);
}
/* Menyval (höger) */
.qs-menu{
  list-style:none;
  margin:0;
  margin-left: auto;
  padding:4px 0px;
  display:flex;
  align-items:center;
  gap:36px;
  position:relative;
}
.qs-link{
  appearance:none; 
  border:0;
  background:transparent;
  cursor:pointer;
  padding:0;
  color: var(--text);
  text-decoration:none;
  font-size:16px;
  font-weight:600;
  line-height:1.1;
}
/* Dropdown tjänster */
.qs-has-dropdown{
  position:relative;
}
.qs-dropdown{
  list-style: none;
  margin: 12px 0 0;
  padding: 4px 0;
  position: absolute;
  top: 100%;
  left: 0;
  display: none;
  min-width: 200px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(0,0,0,0.08);
  z-index: 10000000;
}
.qs-dropdown a{
  display: block;
  padding: 10px 12px;
  color: #111;
  text-decoration: none;
  font-size: 15px;
  font-weight: 450;
  line-height: 1.1;
}
.qs-has-dropdown.is-open > .qs-dropdown{
  display:block;
}
/* Pil ned (stängd dropdown) */
.qs-dropdown-toggle{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.qs-dropdown-toggle::after{
  content:"";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-right: 2px solid var(--text);
  border-bottom: 2px solid var(--text);
  transform: rotate(45deg);
  transition: transform 180ms ease;
  margin-top: -2px;  
}
/* Pil upp (öppen dropdown) */
.qs-dropdown-toggle[aria-expanded="true"]::after{
  transform: rotate(-135deg);
}
/* Logga och navbar fade vid scroll*/
.page--home .qs-nav{
  background: transparent;
  box-shadow: none;
}
.page--home .qs-nav.is-solid{
  background: var(--accent);
  box-shadow: 0 6px 24px rgba(0,0,0,0.08);
}
.page--home .qs-logo{
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity 100ms ease, transform 240ms ease;
}
.page--home .qs-logo.is-visible{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
#nav-trigger{
  height: 1px;
  margin-top: -1px;
}
@media (hover: hover){
  .qs-link:hover,
  .qs-link:focus-visible,
  .qs-dropdown a:hover,
  .qs-dropdown a:focus-visible{
    color: var(--hover);
  }
  .qs-dropdown-toggle:hover::after,
  .qs-dropdown-toggle:focus-visible::after{
    border-right-color: var(--hover);
    border-bottom-color: var(--hover);
  }
}
/* ---------------- Section titles ---------------- */
.section-title{
  font-family: "JetBrains Mono", monospace;
  letter-spacing: -0.07em;
  font-weight: 800;
}
.highlight-bar{
  display: inline-block;
  background: #000;
  color: #fff;
  padding: 8px 18px;
}
/* ---------------- Footer ---------------- */
.qs-footer {
  background: #000;
  color: white;
  padding: 72px 0 28px;
}
.qs-footer-inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1.4fr;
  gap: 56px;
  align-items: start;
}
.qs-footer a {
  color: white;
  text-decoration: none;
}
.qs-footer a:hover {
  opacity: 0.7;
}
/* Logo */
.qs-footer-brand img {
  width: 210px;
}
/* CTA (btn o text) */
.qs-footer-cta p {
  font-size: 14px;
  line-height: 1.4;
  margin: 0 0 18px 0;
  max-width: 440px;
}
.qs-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  background: var(--accent);
  font-weight: 600;
  padding: 18px 30px;
  border-radius: 999px;
  font-size: 14px;
  transition: transform 0.2s ease;
  text-decoration: none;
  border: none;
}
.qs-btn span{
  color: black;
}
.qs-btn img {
  width: 18px;
  height: 18px;
}
.qs-btn:hover {
  transform: translateY(-6px);
}
/* Bottom row */
.qs-footer-bottom {
  margin-top: 56px;
  text-align: center;
  font-size: 11px;
  color: grey;
}
.qs-footer-bottom p {
  margin: 6px 0;
}
/* ---------------- place indicator ---------------- */
.page-index{
  position: fixed;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 50;
}
.page-index span{
  display: block;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-weight: 500;
  font-size: 20px;
  letter-spacing: 0.18em;
  pointer-events: none;
}
.page-index-right{
  left: auto;
  right: 18px;
}
.page-index-left{
  right: auto;
  left: 18px;
}
/* ============================================== *\
   DESKTOP
\* ============================================== */
/* ---------------- INDEX ---------------- */
/* - Hero - */
.home-hero .container{
  width: 100%;
}
.home-hero{
  background: var(--accent);
  min-height: 100vh;
  display:flex;
  align-items:flex-end;
  padding: 0 0 80px;
}
.home-hero-title{
  font-family: "JetBrains Mono", monospace;
  font-weight: 800;
  font-size: clamp(100px, 20vw, 340px);
  letter-spacing: -18px;
  line-height: 0.9;
  margin: 0;
  color: var(--text);
}
/* - Services - */
.home-services{
  padding: 96px 0;
}
.home-services-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  align-items: start;
}
.service-card{
  position: relative;
}
.service-card-link{
  display: block;
  position: relative;
  text-decoration: none;
  color: var(--text);
}
.service-card-image{
  aspect-ratio: 0.72 / 1;
  overflow: hidden;
}
.service-card-image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 280ms ease;
}
.service-card-button{
  position: absolute;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 14px 24px;
  min-height: 52px;
  min-width: 210px;
  border-radius: 999px;
  background: var(--accent);
  transition: transform 0.2s ease;
}
.service-card-button span{
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0;
  color: #000;
  text-align: center;
}
.service-card-button img{
  width: 16px;
  height: 16px;
  margin-left: 12px;
  flex-shrink: 0;
}
@media (hover: hover){
  .service-card-link:hover .service-card-image img,
  .service-card-link:focus-visible .service-card-image img{
    transform: scale(1.04);
  }
  .service-card-link:hover .service-card-button{
    transform: translate(-50%, -6px);
  }
   a.contact-detail:hover{
    opacity: 0.65;
}
}
/* - Om oss (index) - */
.home-about{
  background: #000;
  color: #fff;
}
.home-about-grid{
  display: grid;
  grid-template-columns: 0.8fr 1fr;
  align-items: stretch;
}
.home-about-image{
  overflow: hidden;
}
.home-about-image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home-about-content{
  padding: 80px 72px;
  max-width: 520px;
}
.home-about-label{
  margin: 0 0 24px;
  font-size: 52px;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.home-about-text{
  margin: 0 0 18px;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.9);
  font-weight: 450;
}
.home-about-btn{
  margin-top: 28px;
  text-decoration: none;
}
/* - Kontakt (index) - */
.contact-section{
  padding: 96px 0 104px;
}
.contact-grid{
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 72px;
  align-items: start;
}
.contact-intro{
  max-width: 360px;
}
.contact-title{
  margin: 0 0 24px;
  font-size: 52px;
  line-height: 0.95;
  font-weight: 700;
  letter-spacing: -0.03em;
}
.contact-text{
  margin: 0 0 16px; 
  font-size: 15px;
  line-height: 1.5;
  color: rgba(11, 11, 11, 0.9);
}
.contact-form{
  width: 100%;
}
.form-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.form-group{
  margin-bottom: 14px;
}
.form-group label{
  display: block;
  margin: 0 0 4px;
  font-size: 12px;
  line-height: 1.2;
}
.form-group input,
.form-group textarea{
  width: 100%;
  border: 1px solid rgba(11, 11, 11, 0.55);
  background: transparent;
  border-radius: 0;
  padding: 10px 12px;
  color: var(--text);
  outline: none;
}
.form-group input{
  height: 42px;
}
.form-group textarea{
  min-height: 140px;
  resize: vertical;
}
.contact-details{
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.contact-detail{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--text);
  font-size: 14px;
}
.contact-detail img{
  width: 16px;
  height: 16px;
}
.contact-detail-static {
  align-items: flex-start;
  color:white;
}
.contact-detail-static span {
  line-height: 1.4;
}
.contact-detail-static img {
  margin-top: 2px;
}
.form-group input:focus,
.form-group textarea:focus{
  border-color: var(--text);
}
.contact-btn{
  margin-top: 12px;
}
.form-note {
  font-size: 0.85rem;
  color: #777;
  margin-top: 10px;
  line-height: 1.4;
}

/* - Compact kontakt (index) - */
.contact-section--compact {
  padding: 56px 0 64px;
}
.contact-section--compact .contact-grid {
  gap: 32px;
}
.contact-section--compact .contact-intro {
  max-width: 520px;
}
.contact-section--compact .contact-text {
  max-width: 720px;
}
.contact-section--compact .contact-form {
  max-width: 520px;
}
/* ---------------- OM OSS ---------------- */
/* - Intro (om oss) - */
.about-page{
  padding: 40px 0 60px;
}
.about-intro-grid{
  max-width: 760px;
}
.about-title{
  font-size: 42px;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.about-text{
  max-width: 720px;
}
.about-text p{
  margin: 0 0 18px;
  font-size: 15px;
  line-height: 1.6;
}
/* - team jocke o ec (om oss) - */
.about-team{
  margin-top: 120px;
}
.about-team-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.about-team-images{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.about-team-images img{
  width: 100%;
  height: 320px;
  object-fit: cover;
  filter: grayscale(100%);
}
.about-studio{
  margin: 0 0 20px;
  font-size: 48px;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.about-team-text p{
  margin: 0 0 18px;
  font-size: 15px;
  line-height: 1.6;
}
/* - qquali/qualia (om oss) - */
.about-qualia{
  margin-top: 140px;
}
.about-qualia-inner{
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
}
.about-qualia-title{
  margin: 0 0 16px;
  font-size: 20px;
  font-weight: 600;
}
.about-qualia-text{
  margin: 0;
  font-size: 18px;
  font-style: italic;
  line-height: 1.6;
}
/* ---------------- TJÄNSTER: WEBDESIGN/UXUI/STRATEGI ---------------- */
/* - information tjänst (tjänster) - */
.service-page {
  padding: 80px 40px;
}
.service-layout {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 80px;
  align-items: start;
  padding-left: clamp(20px, 4vw, 60px);
}
.image-wrapper {
  position: relative;
  max-width: 420px;
}
.promo-image {
  width: 100%;
  height: auto;
  display: block;
}
.circle-desktop {
  width: 150px;
  margin-bottom: 40px;
}
.circle-mobile {
  display: none;
}
.text-block {
  max-width: 420px;
}
.text-block p {
  margin-bottom: 24px;
}
/* - Fler tjänster (tjänster) - */
.service-more {
  margin-top: 72px;
}
.service-more-title {
  margin: 0 0 24px;
  font-size: 42px;
  line-height: 0.95;
}
.service-more-grid {
  display: grid;
  grid-template-columns: repeat(2, 280px);
  gap: 32px;
  justify-content: space-evenly;
}
.service-more-card {
  display: block;
  text-decoration: none;
  color: var(--text);
}
.service-more-image {
  aspect-ratio: 1 / 1;
  overflow: hidden;
  margin-bottom: 14px;
}
.service-more-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.service-more-body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.service-more-heading {
  margin: 0 0 8px;
  font-family: "JetBrains Mono", monospace;
  font-size: 22px;
  line-height: 1.05;
  font-weight: 800;
  letter-spacing: -0.04em;
}
.service-more-text {
  margin: 0;
  max-width: 34ch;
  font-size: 15px;
  line-height: 1.55;
  color: rgba(11, 11, 11, 0.9);
}
.service-more-btn {
  margin-top: 16px;
}
@media (hover: hover) {
  .service-more-card:hover .service-more-image img,
  .service-more-card:focus-visible .service-more-image img {
    transform: scale(1.04);
  }
}
/* ---------------- Cases ---------------- */
/* - Information (cases) - */
.cases-page {
  min-height: 100dvh;
  display: grid;
  align-items: center;
}
.cases-content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: minmax(420px, 560px) minmax(420px, 1fr);
  gap: 64px;
  align-items: center;
}
.cases-image {
  width: 100%;
  height: auto;
  display: block;
}
.cases-text {
  max-width: 560px;
}
.cases-content h1 {
  font-size: 2.5rem;
}
.cases-text p {
  margin: 24px 0;
  font-size: 1rem;
  line-height: 1.6;
}
.cases-page .qs-btn {
  position: relative;
  z-index: 1;
}
.portfolio-title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  margin: 0;
}
.portfolio-title span {
  display: inline-block;
  background: #000;
  color: #fff;
  padding: 12px 16px;
  line-height: 0.95;
}

/* ============================================== *\
   <= 1200px
\* ============================================== */
@media (max-width: 1200px) {
  /* ---------------- Global ---------------- */
  .page-index {
    display: none;
  }
  /* ---------------- Index ---------------- */
  /* - Hero (index) - */
  .home-hero {
    min-height: 60vh;
    padding: 0 0 56px;
  }
  .home-hero-title {
    font-size: 220px;
    letter-spacing: -10px;
    line-height: 0.9;
  }
  /* - Services (index) - */
  .home-services {
    padding: 72px 0;
  }
  .home-services-grid {
    gap: 20px;
  }
  .service-card-button {
    min-width: 190px;
    padding: 12px 20px;
  }
  /* - Om oss (index) - */
  .home-about-content {
    padding: 64px 48px;
    max-width: 100%;
  }
  .home-about-label {
    font-size: 28px;
    margin-bottom: 20px;
  }
  .home-about-text {
    font-size: 14px;
  }
  .home-about-btn {
    margin-top: 24px;
  }
  /* ---------------- Om oss ---------------- */
  .about-page {
    padding: 72px 0 60px;
  }
  .about-intro-grid {
    max-width: 640px;
  }
  /* - Team (om oss) - */
  .about-team-grid {
    gap: 48px;
  }
  .about-team-images img {
    height: 260px;
  }
  /* - Studio (om oss) - */
  .about-studio {
    font-size: 40px;
  }
  .about-qualia {
    margin-top: 100px;
  }

  /* ---------------- Cases ---------------- */
  /* - information (cases) - */
  .cases-page {
    min-height: auto;
    padding: 80px 0;
    display: block;
  }
  .cases-content {
    max-width: 720px;
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    flex-direction: column;
  }
  .cases-text {
    max-width: 100%;
  }
  .cases-page .section-title {
    font-size: 56px;
    letter-spacing: -0.06em;
  }
  .cases-text p {
    max-width: 560px;
    font-size: 16px;
    line-height: 1.6;
  }
  .cases-image {
    width: 100%;
    margin-top: 32px;
    order: 2;
  }
  /* ---------------- Kontakt ---------------- */
  /* - information (kontakt) - */
  .contact-grid {
    grid-template-columns: 1fr;
    gap: 48px;
    align-items: start;
    width: 100%;
  }
  .contact-section {
    padding: 88px 0 180px;
  }
  .contact-title {
    font-size: 44px;
  }
  .contact-intro {
    max-width: 900px;
  }
  .contact-text {
    max-width: 720px;
    font-size: 16px;
    line-height: 1.6;
  }
  /* - form (kontakt) - */
  .contact-form {
    max-width: 960px;
    width: 100%;
  }
  .form-group input {
    height: 46px;
  }
  .form-group textarea {
    min-height: 160px;
  }
  .contact-btn {
    margin-top: 18px;
  }
  /* (kompakt version) */
  .contact-section--compact {
    padding: 64px 0 72px;
  }
  .contact-section--compact .contact-intro,
  .contact-section--compact .contact-form {
    max-width: 960px;
  }
}

/* ============================================== *\
   <= 900px
\* ============================================== */
@media (max-width: 900px) {
  /* ---------------- Global ---------------- */
  .page-index {
    display: none;
  }
  /* - Footer (global) - */
  .qs-footer {
    padding: 80px 24px 32px;
  }
  .qs-footer-inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .qs-footer-brand img {
    width: 180px;
    padding-bottom: 10px;
  }
  /* - Navbar/hamburger menu (global) - */
  .qs-nav {
    padding: 12px 0;
  }
  .menu-toggle {
    display: block;
  }
  .qs-menu {
    position: fixed;
    inset: 0;
    background: var(--accent);
    padding: 120px 0 0;
    margin: 0;
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
    text-align: center;
    list-style: none;
  }
  .qs-nav.is-open .qs-menu {
    display: flex;
  }
  .qs-menu > li {
    width: 100%;
  }
  .qs-menu > li > .qs-link,
  .qs-menu > li > a.qs-link {
    display: block;
    width: 100%;
    padding: 18px 0;
    font-size: 20px;
    font-weight: 600;
    border-top: 1px solid rgba(0, 0, 0, 0.16);
  }
  .qs-menu > li:first-child > .qs-link,
  .qs-menu > li:first-child > a.qs-link {
    border-top: 0;
  }
  .qs-dropdown {
    position: static;
    margin: 0;
    padding: 0;
    min-width: 100%;
    background: transparent;
    box-shadow: none;
  }
  .qs-dropdown a {
    display: block;
    width: 100%;
    padding: 12px 0;
    font-size: 18px;
    font-weight: 450;
  }
  .qs-dropdown-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  .qs-dropdown-toggle::after {
    display: inline-block;
    width: 10px;
    height: 10px;
  }
  /* ---------------- INDEX ---------------- */
  /* - Hero (index) - */
  .home-hero {
    display: flex;
    align-items: flex-end;
    min-height: 42vh;
  }
  .home-hero-title {
    font-size: clamp(56px, 18vw, 92px);
    line-height: 0.9;
    letter-spacing: -5px;
  }
  /* - Services (index) - */
  .home-services-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .home-services-grid .service-card:nth-child(3) {
    grid-column: 1 / -1;
  }
  .service-card {
    max-width: none;
    margin: 0;
  }
  .service-card-image {
    aspect-ratio: 1 / 1;
  }
   .home-services-grid .service-card:nth-child(3) .service-card-image {
    aspect-ratio: 2 / 1;
  }
  .service-card-button {
    min-width: 180px;
    min-height: 46px;
    padding: 12px 20px;
    bottom: 12px;
  }
  .service-card-button span {
    font-size: 11px;
  }
  .service-card-button img {
    width: 14px;
    height: 14px;
    margin-left: 10px;
  }
  /* - Om oss (index) - */
  .home-about-grid {
    grid-template-columns: 1fr;
  }
  .home-about-image {
    display: none;
  }
  .home-about-content {
    padding: 40px 24px;
    max-width: 100%;
  }
  .home-about-label {
    margin: 0 0 20px;
    font-size: 28px;
    line-height: 0.95;
    letter-spacing: -0.03em;
  }
  .home-about-text {
    margin: 0 0 14px;
    font-size: 15px;
    line-height: 1.45;
  }
  .home-about-btn {
    margin-top: 28px;
  }
  /* - Kontakt (index) - */
  .contact-section {
    padding: 56px 0 64px;
  }
  .contact-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .contact-intro {
    max-width: 100%;
  }
  .contact-title {
    font-size: 42px;
    margin-bottom: 20px;
  }
  .contact-text {
    font-size: 15px;
    line-height: 1.5;
  }
  .contact-details {
    margin-top: 18px;
  }
  .form-row {
    grid-template-columns: 1fr;
  }
  .form-group input {
    height: 44px;
  }
  .form-group textarea {
    min-height: 120px;
  }
  .contact-btn {
    margin-top: 16px;
  }
  /* ---------------- OM OSS ---------------- */
  /* - Information (om oss) - */
  .about-page {
    padding: 56px 0 48px;
  }
  .about-intro-grid {
    max-width: 100%;
  }
  .about-title {
    font-size: 32px;
    margin-bottom: 20px;
  }
  .about-text p {
    font-size: 15px;
    line-height: 1.55;
  }
  /* - team (om oss) - */
  .about-team {
    margin-top: 64px;
  }
  .about-team-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .about-team-images {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
  .about-team-images img {
    height: 420px;
  }
  .about-studio {
    font-size: 36px;
  }
  .about-team-text p {
    font-size: 15px;
    line-height: 1.55;
  }
  /* - Qualia (om oss) - */
  .about-qualia {
    margin-top: 72px;
  }
  .about-qualia-title {
    font-size: 18px;
  }
  .about-qualia-text {
    font-size: 16px;
  }
  /* ---------------- SERVICES ---------------- */
  .service-page {
    padding: 60px 40px;
  }
  .service-layout {
    display: grid;
    grid-template-columns: minmax(280px, 360px) 1fr;
    gap: 48px;
    align-items: start;
  }
  .service-media {
    margin-bottom: 0;
  }
  .image-wrapper {
    width: 100%;
    max-width: 360px;
    margin: 0;
  }
  .circle-desktop {
    display: block;
    width: 130px;
    margin-bottom: 32px;
  }
  .circle-mobile {
    display: none;
  }
  .service-content {
    padding: 0;
  }
  .text-block {
    max-width: 380px;
    margin: 0;
    text-align: left;
  }
}

/* ============================================== *\
   <= 768px
\* ============================================== */
@media (max-width: 768px) {
  /* ---------------- Services ---------------- */
  /* - Om tjänsten (Services) - */
  .service-page {
    padding: 40px 0 60px;
  }
  .service-layout {
    display: block;
  }
  .service-media {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 18px;
    margin-bottom: 32px;
    padding: 0 28px;
  }
  .image-wrapper {
    width: 68vw;
    max-width: 220px;
    margin: 0;
  }
  .circle-desktop {
    display: none;
  }
  .circle-mobile {
    display: block;
    position: static;
    width: 115px;
    transform: none;
    margin: 0;
    flex-shrink: 0;
  }
  .service-content {
    padding: 0 28px;
  }
  .text-block {
    max-width: 600px;
    margin: 0 auto;
    text-align: left;
  }
  /* - Fler tjänster (Services) - */
  .service-more-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .service-more-card {
    max-width: 420px;
    margin: 0 auto;
  }
  .service-more-image {
    aspect-ratio: 1 / 1;
  }
  /* ---------------- CASES ---------------- */
  .cases-page {
    min-height: auto;
    padding: 56px 0 80px;
    display: block;
  }
  .cases-content {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 24px;
  }
  .portfolio-title {
    gap: 6px;
  }
  .portfolio-title span {
    padding: 10px 14px;
  }
  .cases-page .section-title {
    font-size: 44px;
    letter-spacing: -0.05em;
  }
  .cases-content p {
    max-width: 60vw;
    font-size: 15px;
    line-height: 1.55;
  }
  .home-services {
    padding: 40px 0 56px;
  }
  .home-services-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .home-services-grid .service-card:nth-child(3) {
    grid-column: auto;
  }
  .service-card {
    max-width: none;
    margin: 0;
  }
  .service-card-image{
      aspect-ratio: 2 / 1;    
  }
  .service-card-button {
    min-width: 170px;
    min-height: 44px;
    bottom: 12px;
  }
}

/* ============================================== *\
   <= 500px
\* ============================================== */
@media (max-width: 500px) {
  /* ---------------- INDEX ---------------- */
  /* - tjänster (index) - */
  .home-services-grid {
    gap: 10px;
    grid-template-columns: 1fr;
  }
  .service-card-image {
    aspect-ratio: 1 / 1;
  }
  .home-services-grid .service-card:nth-child(3) {
    grid-column: auto;
  }
  .service-card {
    max-width: 320px;
    margin: 0 auto;
  }
  .service-card-image,
  .home-services-grid .service-card:nth-child(3) .service-card-image {
    aspect-ratio: 1 / 1;
  }
  .home-services .container {
    padding-left: 20px;
    padding-right: 20px;
  }
}