/* =========================================================
   GEMENSAM STIL FÖR UNDERSIDORNA – Trädgårdsstil & Design
   Samma färger och typsnitt som startsidan (index.html).
   Byt färger här om paletten ska justeras överallt samtidigt.
   ========================================================= */
:root{
  --salvia:        #e7ece1;   /* ljus salviegrön – sidans bakgrund */
  --salvia-djup:   #d9e0d2;   /* djupare salvia – platshållare för bilder */
  --skog:          #2d4a2f;   /* mörk skogsgrön – knappar, accenter */
  --skog-morkare:  #223a24;   /* hover-läge */
  --benvit:        #fbfaf5;   /* varmt benvitt – kort och ytor */
  --text:          #232a23;
  --text-mjuk:     #55604f;

  --display: 'Jost', sans-serif;
  --brod:    'Karla', sans-serif;

  --max-bredd: 1180px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  font-family: var(--brod);
  font-weight: 300;
  background: var(--salvia);
  color: var(--text);
  line-height: 1.7;
  font-size: 1.05rem;
}

img{ display:block; max-width:100%; }

.inre{ max-width: var(--max-bredd); margin:0 auto; padding:0 24px; }

h1,h2,h3{
  font-family: var(--display);
  font-weight: 300;
  line-height: 1.15;
  color: var(--text);
}

/* ============ HEADER (samma som startsidan) ============ */
header{
  position: sticky; top:0; z-index:50;
  background: var(--salvia);
  border-bottom: 1px solid rgba(45,74,47,.12);
}
.header-rad{
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 24px; max-width:var(--max-bredd); margin:0 auto;
}
.logotyp{
  font-family:var(--display); font-weight:400; font-size:1.35rem;
  letter-spacing:.22em; text-decoration:none; color:var(--text); line-height:1.3;
}
nav ul{ display:flex; gap:42px; list-style:none; }
nav a{
  font-family:var(--display); font-weight:400; font-size:.92rem;
  letter-spacing:.18em; text-transform:uppercase; text-decoration:none;
  color:var(--text); padding-bottom:4px;
  border-bottom:1px solid transparent; transition:border-color .25s;
}
nav a:hover, nav a:focus-visible{ border-bottom-color:var(--skog); }
nav a[aria-current="page"]{ border-bottom-color:var(--skog); }

.hamburgare{ display:none; background:none; border:none; cursor:pointer; padding:8px; }
.hamburgare span{
  display:block; width:26px; height:2px; background:var(--text);
  margin:6px 0; transition:transform .3s, opacity .3s;
}
.hamburgare[aria-expanded="true"] span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.hamburgare[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.hamburgare[aria-expanded="true"] span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* ============ SIDHUVUD PER UNDERSIDA ============ */
.sidrubrik{
  padding: 90px 0 60px;
}
.sidrubrik h1{
  font-size: clamp(2.6rem, 6vw, 4.4rem);
  letter-spacing:.04em;
}
.sidrubrik p.ingress{
  color:var(--text-mjuk);
  max-width:58ch;
  margin-top:24px;
  font-size:1.12rem;
}

/* ============ PROCESS-LISTA (Tjänster) ============ */
.process{ padding: 20px 0 90px; }

.steg{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:48px;
  align-items:start;
  padding:56px 0;
  border-top:1px solid rgba(45,74,47,.25);
}
.steg:last-child{ border-bottom:1px solid rgba(45,74,47,.25); }

.steg h2{
  font-size: clamp(1.9rem, 3.6vw, 2.9rem);
  max-width: 14ch;
}
.steg p{ color:var(--text-mjuk); max-width:52ch; padding-top:8px; }

/* ============ PRISLISTA ============ */
.prislista{ padding: 0 0 100px; }

.prislista .ram{
  background: var(--benvit);
  border:1px solid rgba(45,74,47,.1);
  padding: 24px 56px;
  max-width: 860px;
  margin: 0 auto;
}

.pris-post{
  padding: 44px 0;
  border-bottom:1px solid rgba(45,74,47,.25);
}
.pris-post:last-of-type{ border-bottom:none; }

.pris-rad{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:24px;
  margin-bottom:18px;
}
.pris-rad h3{
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  max-width: 16ch;
}
.pris{
  font-family:var(--display);
  font-size:1.25rem;
  text-align:right;
  white-space:nowrap;
}
.pris small{
  display:block;
  font-size:.85rem;
  color:var(--text-mjuk);
}
.pris-post p{ color:var(--text-mjuk); max-width:56ch; }

.knapp{
  display:inline-block;
  font-family:var(--display); font-weight:400; font-size:.88rem;
  letter-spacing:.16em; text-transform:uppercase; text-decoration:none;
  color:var(--benvit); background:var(--skog);
  padding:16px 32px; border:none; cursor:pointer;
  transition:background .25s;
}
.knapp:hover, .knapp:focus-visible{ background:var(--skog-morkare); }

.centrerad{ text-align:center; padding: 0 0 100px; }

/* ============ OM MIG ============ */
.om-mig{ padding: 0 0 100px; }

.om-mig .inre{
  display:grid;
  grid-template-columns: 1fr 1.2fr;
  gap:64px;
  align-items:start;
}

.logga-ram{
  background: var(--benvit);
  padding: 56px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.logga-ram img{ max-width: 360px; width:100%; }

.om-text{
  background: var(--benvit);
  padding: 64px 56px;
}
.om-text h2{
  font-size: clamp(1.9rem, 3.4vw, 2.7rem);
  margin-bottom: 28px;
}
.om-text p{
  color:var(--text-mjuk);
  margin-bottom: 22px;
  max-width: 56ch;
}
.om-text p:last-child{ margin-bottom:0; }

/* ============ PROJEKT ============ */
.projektlista{ padding: 0 0 100px; }

.projekt-rutor{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.projektkort{
  background: var(--benvit);
  border:1px solid rgba(45,74,47,.08);
}
.projektkort .bild{
  background: var(--salvia-djup);
  aspect-ratio: 4 / 3;
  overflow:hidden;
}
.projektkort img{
  width:100%; height:100%; object-fit:cover;
  transition: transform .6s ease;
}
.projektkort:hover img{ transform: scale(1.04); }

.projektkort .text{ padding: 26px 28px 32px; }
.projektkort h3{
  font-size: 1.3rem;
  font-weight: 400;
  margin-bottom: 8px;
}
.projektkort p{
  color:var(--text-mjuk);
  font-size: .95rem;
}

/* ============ FOOTER ============ */
.footer-rad{
  background: var(--salvia);
  border-top:1px solid rgba(45,74,47,.12);
  padding: 28px 24px;
  text-align:right;
  font-size:.9rem;
  color:var(--text-mjuk);
}

/* ============ MOBIL ============ */
@media (max-width: 900px){
  .steg{ grid-template-columns: 1fr; gap: 16px; padding: 40px 0; }
  .om-mig .inre{ grid-template-columns: 1fr; gap: 32px; }
  .projekt-rutor{ grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .prislista .ram{ padding: 8px 28px; }
  .sidrubrik{ padding: 60px 0 40px; }

  .hamburgare{ display:block; }
  nav{
    position:absolute; top:100%; left:0; right:0;
    background:var(--salvia);
    border-bottom:1px solid rgba(45,74,47,.12);
    display:none;
  }
  nav.oppen{ display:block; }
  nav ul{ flex-direction:column; gap:0; padding:12px 0; }
  nav li{ border-top:1px solid rgba(45,74,47,.08); }
  nav a{ display:block; padding:16px 24px; border-bottom:none; }
}

@media (max-width: 520px){
  .projekt-rutor{ grid-template-columns: 1fr; }
  .pris-rad{ flex-direction:column; gap:6px; }
  .pris{ text-align:left; }
  .om-text, .logga-ram{ padding: 36px 28px; }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .projektkort img{ transition:none; }
}
