/* ============================================================
   REKORDERLIG DESIGN – DELAD STYLING
   Allt utseende styrs från denna fil.
   Ändra här så uppdateras alla sidor samtidigt.
   ============================================================ */

/* ---------- DESIGN-VARIABLER ----------
   Byt färger, typsnitt eller bredd här. */
:root {
  --bg: #f5f4ed;          /* cremig bakgrund */
  --card-bg: #ffffff;     /* vita kort */
  --text: #2c2c2c;        /* mörk text (samma som logon) */
  --muted: #6b6b6b;       /* grå för subtila detaljer */
  --line: #e5e1d8;        /* tunna linjer */
  --accent: #9d154d;      /* vinröd (samma som logon) */
  --accent-dark: #7a1039; /* mörkare vinröd för hover */
  --max: 1120px;          /* maxbredd för innehåll */
  --max-narrow: 640px;    /* för text-tung lead */
  --grid-columns: 6;      /* hela siten bygger på 6 kolumner */
  --grid-gap: 32px;       /* mellanrum mellan kolumner */
  --shadow-card: 0 1px 2px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.06);
  --shadow-card-hover: 0 1px 2px rgba(0,0,0,0.05), 0 12px 32px rgba(0,0,0,0.09);
  --radius: 6px;
  --font-body: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* ---------- H1 (genomgående styling för alla sidor) ---------- */
h1 {
  font-family: var(--font-body);   /* Open Sans */
  font-size: 44px;
  font-weight: 700;                /* Open Sans Bold */
  letter-spacing: -0.005em;
  line-height: 1.15;
}
@media (max-width: 640px) {
  h1 { font-size: 32px; }
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  font-size: 18px;        /* brödtext */
  font-weight: 400;       /* Open Sans Regular */
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, svg { display: block; max-width: 100%; height: auto; }

a { color: inherit; }

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

/* ---------- 6-KOLUMNS-GRID ----------
   Genomgående system för hela sajten.
   Använd genom att lägga klassen .grid-6 på ett element,
   sedan styra hur många kolumner barnen tar med grid-column: span N. */
.grid-6 {
  display: grid;
  grid-template-columns: repeat(var(--grid-columns), 1fr);
  gap: var(--grid-gap);
}

/* ---------- KNAPPAR ----------
   Använd <a class="button"> eller <button class="button">.
   Lägg till .button.secondary för en mer diskret variant. */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: var(--accent);
  color: #fff;
  font-family: var(--font-body);
  font-size: 17px;
  font-weight: 700;
  text-decoration: none;
  padding: 14px 28px;
  border: 2px solid var(--accent);
  border-radius: var(--radius);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}
.button:hover {
  background: var(--accent-dark);
  border-color: var(--accent-dark);
}
.button:active { transform: translateY(1px); }

.button.secondary {
  background: transparent;
  color: var(--accent);
}
.button.secondary:hover {
  background: var(--accent);
  color: #fff;
}

/* På mobil fyller knappar hela bredden */
@media (max-width: 760px) {
  .button { width: 100%; }
}

/* ---------- HEADER (logga + nav, centrerad) ---------- */
header.site-header {
  padding: 56px 0 56px;
  text-align: center;
}
header.site-header .logo {
  display: inline-block;
  margin-bottom: 24px;
}
header.site-header .logo img,
header.site-header .logo svg {
  width: 130px;
  height: auto;
  margin: 0 auto;
}

nav.main-nav {
  padding: 16px 0 0;
}
nav.main-nav ul {
  list-style: none;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 36px;
}
nav.main-nav a {
  color: var(--text);
  text-decoration: none;
  font-size: 16px;
  font-weight: 700;                /* Open Sans Bold */
  text-underline-offset: 4px;      /* lite luft under bokstäverna */
  text-decoration-thickness: 2px;
  transition: color 0.15s ease;
}
nav.main-nav a:hover,
nav.main-nav a.active {
  text-decoration: underline;
}

/* ---------- SIDRUBRIK (landningssidor) ---------- */
.page-header {
  padding: 32px 0 56px;
  text-align: center;
}
/* Landningssidornas H1: Open Sans Bold 44px – samma som startsidan,
   inte den globala Waverly CF-regeln. */
.page-header h1 {
  font-family: var(--font-body);   /* Open Sans */
  font-size: 44px;
  font-weight: 700;                /* Open Sans Bold */
  letter-spacing: -0.005em;
  line-height: 1.15;
}
@media (max-width: 640px) {
  .page-header h1 { font-size: 32px; }
}

/* ---------- BACK-KNAPP (tillbaka till startsidan) ---------- */
.back-button-area {
  padding: 16px 0 0;
  display: flex;
  justify-content: flex-end;
}
.button.tertiary {
  background: #AD9700;            /* mustardgul */
  border-color: #AD9700;
  color: #ffffff;
}
.button.tertiary:hover {
  background: #8c7a00;
  border-color: #8c7a00;
}

/* ---------- HERO / INTRO ---------- */
.hero {
  padding: 48px 0 64px;
  text-align: center;
}
/* Startsidans H1 använder Open Sans (inte Waverly CF) */
.hero h1 {
  font-family: var(--font-body);   /* Open Sans */
  font-size: 44px;
  font-weight: 700;                /* Open Sans Bold */
  letter-spacing: -0.005em;
  line-height: 1.15;
  margin-bottom: 24px;
}
@media (max-width: 640px) {
  .hero h1 { font-size: 32px; }
}

.hero p {
  max-width: 760px;
  margin: 0 auto;
  font-size: 24px;        /* ingress */
  font-weight: 400;       /* Open Sans Regular */
  line-height: 1.5;
}

/* ---------- PROJEKT (alternerande kort) ---------- */
.projects {
  padding: 0;             /* avstånd till footer styrs av main padding-bottom */
}
.project-card {
  background: var(--card-bg);
  border-radius: var(--radius);
  box-shadow: var(--shadow-card);
  display: grid;
  /* Internt 6-kolumners-grid: bild = 2 kolumner (1/3), text = 4 kolumner (2/3) */
  grid-template-columns: repeat(var(--grid-columns), 1fr);
  overflow: hidden;
  margin-bottom: 32px;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
  min-height: 280px;
  text-decoration: none;   /* ingen understrykning av text i kortet */
  color: inherit;
}
.project-card .media { grid-column: span 2; }     /* 2/6 = 1/3 */
.project-card .body  { grid-column: span 4; }     /* 4/6 = 2/3 */
.project-card:hover {
  box-shadow: none;
  transform: translateY(3px);
}
.project-card:active {
  box-shadow: none;
  transform: translateY(4px);
}
.project-card .media {
  background: #ece8de;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
}
.project-card .media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.project-card .media .placeholder {
  color: var(--muted);
  font-size: 13px;
  text-align: center;
  padding: 24px;
}
.project-card .body {
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.project-card .tags {
  color: var(--accent);
  font-size: 13px;
  font-weight: 700;       /* Open Sans Bold */
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.project-card .tags .sep {
  margin: 0 8px;
  color: var(--accent);
  opacity: 0.6;
}
.project-card h3 {
  font-size: 22px;
  font-weight: 700;       /* Open Sans Bold */
  line-height: 1.3;
  letter-spacing: -0.005em;
  margin-bottom: 14px;
  color: var(--text);
}
.project-card .description {
  color: var(--text);
  font-size: 18px;        /* brödtext */
  font-weight: 400;
  line-height: 1.55;
  margin-bottom: 20px;
}
.project-card .read-more {
  align-self: flex-end;
  color: var(--accent);            /* samma vinröda som pilen */
  text-decoration: none;
  text-underline-offset: 4px;
  text-decoration-thickness: 2px;
  font-size: 16px;
  font-weight: 700;                /* Open Sans Bold */
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.project-card:hover .read-more {
  text-decoration: underline;
}
.project-card .read-more .arrow {
  color: var(--accent);
  transition: transform 0.2s ease;
}
.project-card:hover .read-more .arrow {
  transform: translateX(4px);
}

/* Alternerande layout: jämna kort har bild till höger */
.project-card.image-right .media { order: 2; }

/* ---------- FOOTER (vinröd) ---------- */
footer.site-footer {
  background: var(--accent);
  color: #fff;
  padding: 36px 0;
  margin-top: 0;
}

/* ============================================================
   KONSEKVENT VERTIKALT AVSTÅND
   ============================================================
   Alla "huvudsektioner" har margin-bottom: 64px.
   Sista sektionens margin-bottom kollapsar ut ur main och blir
   avståndet till footern. Mobil: 48px. */
.hero-image,
.project-layout,
.project-gallery,
.content-card,
.button-row,
.bottom-image,
.back-button-area,
.about-card,
.about-button-area {
  margin-bottom: 64px;
}
footer.site-footer .container {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 96px;
  align-items: start;
}
footer.site-footer .footer-logo img,
footer.site-footer .footer-logo svg {
  width: 110px;
  height: auto;
}
footer.site-footer .contact {
  font-size: 16px;
  line-height: 1.8;
}
footer.site-footer .contact strong { font-weight: 700; }
footer.site-footer .contact a {
  color: #fff;
  text-decoration: none;
}
footer.site-footer .contact a:hover {
  text-decoration: underline;
}

/* ============================================================
   PROJEKTSIDOR (för projekt-mall.html och projekt/*.html)
   ============================================================ */

/* Hero-bild överst på projektsidan */
/* Hero-image: margin-bottom 64px sätts av den samlade sektionsregeln */
.hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;          /* maxhöjd på desktop – kapas upp/ner vid behov */
  object-fit: cover;
  border-radius: var(--radius);
  display: block;
  background: #ece8de;
  box-shadow: var(--shadow-card);
}

/* Två-kolumnslayout: huvudinnehåll (4 kol) + sidebar (2 kol).
   Sidebar spänner båda rader så body kan börja direkt under intro
   utan att vänta på att sidebars höjd ska "fyllas". Visuellt gap
   styrs av .lead margin-bottom + h2 margin-top istället. */
.project-layout {
  display: grid;
  grid-template-columns: repeat(var(--grid-columns), 1fr);
  column-gap: 80px;        /* extra luft mellan huvud- och sidokolumn */
  row-gap: 0;
  align-items: start;
  margin-bottom: 64px;
}
/* Grid-placering på desktop:
   intro (H1 + ingress) ligger på rad 1 till vänster, sidebar spänner
   båda rader till höger (men tar bara sin egen höjd via align-self),
   body (Bakgrund osv) ligger på rad 2 till vänster – direkt under intro.
   DOM-ordning: intro → sidebar → body.
   På mobil staplar de i DOM-ordning, vilket innebär att Roll/Ansvarsområden
   kommer mellan ingress och Bakgrund. */
.project-intro   { grid-column: 1 / span 4; grid-row: 1; }
.project-sidebar { grid-column: 5 / span 2; grid-row: 1 / span 2; align-self: start; }
.project-body    { grid-column: 1 / span 4; grid-row: 2; }

/* Intro-block (H1 + ingress) */
.project-intro h1 { margin-bottom: 28px; }
.project-intro .lead {
  font-size: 24px;          /* ingress */
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 18px;      /* matchar p margin-bottom så rytmen blir konsekvent */
}

/* Body-block (Bakgrund, Uppdrag, Designprocess osv) */
.project-body h2 {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.005em;
  margin: 40px 0 16px;
}
/* OBS: vi tar INTE bort margin-top på första h2 längre, så gap mellan
   ingress och första h2 (Bakgrund) = 18px + 40px = 58px, samma som
   gap mellan p och nästa h2. */
.project-body p { margin-bottom: 18px; }
.project-body ul {
  list-style: disc;
  padding-left: 24px;
  margin-bottom: 24px;
}
.project-body ul li { margin-bottom: 8px; }

/* Sidebar (Roll, Ansvarsområden, knapp) */
.project-sidebar h2 {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.005em;
  margin: 32px 0 12px;
}
.project-sidebar h2:first-child { margin-top: 0; }
.project-sidebar p { font-size: 16px; margin-bottom: 16px; }
.project-sidebar ul {
  list-style: disc;
  padding-left: 22px;
  margin-bottom: 24px;
}
.project-sidebar ul li {
  font-size: 16px;
  margin-bottom: 6px;
}
/* Sidebar-knappen fyller hela sidokolumnen så högerkanten linjerar
   med toppbildens högerkant */
.project-sidebar .button {
  margin-top: 16px;
  width: 100%;
}

/* Vit informationsruta (t.ex. Resultat-sektionen) */
.content-card {
  background: var(--card-bg);
  border-radius: var(--radius);
  box-shadow: var(--shadow-card);
  padding: 40px;
  /* margin-bottom 64px sätts av den samlade sektionsregeln */
}
.content-card h2 {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.005em;
  margin: 0 0 16px;
}
.content-card p:last-child { margin-bottom: 0; }

/* Rad med flera knappar (t.ex. Tillbaka + Fler projekt) */
.button-row {
  display: flex;
  gap: 16px;
  justify-content: flex-end;     /* höger-justerad – matchar back-button-area på landningssidor */
  padding: 0;
  flex-wrap: wrap;
  /* margin-bottom 64px sätts av den samlade sektionsregeln */
}

/* "Tillbaka till toppen"-knapp på startsidan, höger-justerad */
.top-button-area {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 64px;          /* matchar sektionsavstånd på övriga sidor */
}

/* ============================================================
   KONTAKTSIDAN
   ============================================================ */
.contact-card {
  background: var(--card-bg);
  border-radius: var(--radius);
  box-shadow: var(--shadow-card);
  padding: 40px;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 48px;
  align-items: start;
  margin-bottom: 64px;
}

/* Vänster: rosa kontaktbox */
.contact-info {
  background: #F6E8EF;
  border-radius: var(--radius);
  padding: 32px;
}
.contact-info h2 {
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 8px;              /* samma avstånd som mellan p:n */
}
.contact-info p {
  margin: 0 0 8px;              /* samma avstånd överallt */
  font-size: 16px;
}
.contact-info p:last-child { margin-bottom: 0; }
.contact-info a {
  color: var(--text);
  text-decoration: none;
}
.contact-info a:hover {
  text-decoration: underline;
}

/* Höger: formulär */
.contact-form .form-field {
  margin-bottom: 20px;
}
.contact-form label {
  display: block;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 8px;
}
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--text);
  border-radius: var(--radius);
  font-family: inherit;
  font-size: 16px;
  background: #fff;
  color: var(--text);
  transition: border-color 0.15s ease;
}
.contact-form input:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--accent);
}
.contact-form textarea {
  resize: vertical;
  min-height: 140px;
}
.contact-form .form-submit {
  display: flex;
  justify-content: flex-end;
  margin-top: 24px;
}
.contact-form button.button {
  /* Behåller alla button-stilar, bara för en explicit knapp-tag */
  border: 2px solid #AD9700;
  cursor: pointer;
  font-family: var(--font-body);
}

/* Honeypot-fält för spam-skydd – dolt visuellt men tillgängligt för bots */
.hidden-honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* Tack-meddelandet efter inskickat formulär */
.contact-thanks {
  align-self: center;           /* centrerar vertikalt i grid-cellen bredvid rosa rutan */
}
.contact-thanks p {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  max-width: 400px;
}

/* Stor bild på botten av sidan
   margin-bottom 64px sätts av den samlade sektionsregeln */
.bottom-image img {
  width: 100%;
  aspect-ratio: 16 / 9;          /* maxhöjd på desktop – kapas upp/ner vid behov */
  object-fit: cover;
  border-radius: var(--radius);
  display: block;
  background: #ece8de;
  box-shadow: var(--shadow-card);
}

/* ============================================================
   OM MIG-SIDAN
   ============================================================
   Ett enda kort som innehåller både text (4 kol) och bild (2 kol).
   Bilden fyller hela höjden via object-fit: cover. */
.about-card {
  display: grid;
  grid-template-columns: repeat(var(--grid-columns), 1fr);
  background: var(--card-bg);
  border-radius: var(--radius);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  /* margin-bottom 64px sätts av den samlade sektionsregeln */
}
.about-card .about-text {
  grid-column: span 4;
  padding: 40px;
}
.about-card .about-photo {
  grid-column: span 2;
  background: #ece8de;
  overflow: hidden;
}
.about-card .about-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Textstilen inuti om-mig-kortet */
.about-text h2 {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.005em;
  margin: 0 0 20px;
}
.about-text .lead {
  font-size: 22px;
  font-weight: 400;
  line-height: 1.5;
  margin: 0 0 24px;
}
.about-text p {
  font-size: 18px;          /* brödtext */
  line-height: 1.6;
  margin-bottom: 16px;
}
.about-text p:last-child { margin-bottom: 0; }

/* Knapp under kortet, höger-justerad */
.about-button-area {
  display: flex;
  justify-content: flex-end;
  padding: 0;
}

/* Bildgalleri (för projekt med flera bilder, t.ex. Vision 2020).
   Använd 6-kol-grid där bilder spänner över 4 eller 2 kolumner. */
.project-gallery {
  display: grid;
  grid-template-columns: repeat(var(--grid-columns), 1fr);
  gap: var(--grid-gap);
  align-items: start;
  /* margin-bottom 64px sätts av den samlade sektionsregeln */
}
.project-gallery .gallery-wide   { grid-column: span 4; }
.project-gallery .gallery-narrow { grid-column: span 2; }
.project-gallery img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius);
  background: #ece8de;
  box-shadow: var(--shadow-card);
}

/* Inline-bild inom brödtexten (om du vill ha en bild mitt i texten) */
.project-image {
  margin: 36px 0;
}
.project-image img {
  width: 100%;
  border-radius: var(--radius);
  background: #ece8de;
  box-shadow: var(--shadow-card);
}
/* För PNG med transparent bakgrund: ingen bg-färg, ingen skugga */
.project-image.transparent img {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}
/* Smalare bild på desktop (t.ex. Personas-bilden) – full bredd på mobil */
.project-image.smaller img {
  max-width: 65%;
}

/* Två bilder bredvid varandra (t.ex. designsystem-mockuper) */
.project-image-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 36px 0;
}
.project-image-pair img {
  width: 100%;
  border-radius: var(--radius);
  background: #ece8de;
  box-shadow: var(--shadow-card);
}
.project-image figcaption {
  margin-top: 10px;
  font-size: 15px;
  color: var(--muted);
}

/* ---------- MOBIL ---------- */
@media (max-width: 760px) {
  header.site-header { padding: 32px 0 16px; }
  header.site-header .logo img,
  header.site-header .logo svg { width: 100px; }
  nav.main-nav ul { gap: 20px; }
  .hero { padding: 32px 0 40px; }

  .project-card {
    grid-template-columns: 1fr;
    min-height: 0;
  }
  /* På mobil: både bild och text spänner över hela bredden, ovanpå varandra */
  .project-card .media,
  .project-card .body {
    grid-column: 1 / -1;
  }
  .project-card .media {
    aspect-ratio: 4 / 3;
    order: 0 !important;
  }
  .project-card.image-right .media { order: 0; }
  .project-card .body { padding: 20px; }

  footer.site-footer .container {
    grid-template-columns: 1fr;
    gap: 24px;
    text-align: center;
    justify-items: center;
  }

  /* Smalare bild fyller hela bredden på mobil */
  .project-image.smaller img { max-width: 100%; }

  /* Bildpar staplas på mobil */
  .project-image-pair { grid-template-columns: 1fr; }

  /* Hero- och bottenbilder återgår till naturligt höjd-format på mobil */
  .hero-image img,
  .bottom-image img {
    aspect-ratio: auto;
  }

  /* Projektsidor på mobil: kolumnerna staplas, mindre marginal mellan sektioner */
  .hero-image,
  .project-layout,
  .project-gallery,
  .content-card,
  .button-row,
  .bottom-image,
  .back-button-area,
  .about-card,
  .about-button-area,
  .top-button-area,
  .contact-card {
    margin-bottom: 48px;
  }

  /* Kontaktsidan: stapla rosa box ovanför formulär på mobil */
  .contact-card {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 24px;
  }
  .contact-form .form-submit { justify-content: stretch; }
  .contact-form .form-submit .button { width: 100%; }
  .project-layout {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .project-intro,
  .project-sidebar,
  .project-body {
    grid-column: 1 / -1;
    grid-row: auto;       /* återställ desktop-värden så de staplar i DOM-ordning */
  }
  .content-card { padding: 24px; }
  .button-row { flex-direction: column; gap: 12px; padding: 0; }

  /* Galleri staplas till en kolumn på mobil */
  .project-gallery { grid-template-columns: 1fr; gap: 16px; }
  .project-gallery .gallery-wide,
  .project-gallery .gallery-narrow { grid-column: 1 / -1; }

  /* Om mig-kortet: bilden hamnar överst, sedan texten under */
  .about-card { grid-template-columns: 1fr; }
  .about-card .about-text,
  .about-card .about-photo { grid-column: 1 / -1; }
  .about-card .about-photo { aspect-ratio: 4 / 3; order: -1; }
  .about-card .about-text { padding: 24px; }
  .about-button-area { justify-content: stretch; padding: 0; }
  .about-button-area .button { width: 100%; }

  /* Subtilare skuggor på mobil så de inte ser ut som smuts */
  :root {
    --shadow-card: 0 1px 2px rgba(0,0,0,0.04), 0 4px 12px rgba(0,0,0,0.05);
  }

  /* Mindre typografi på mobil: ingress 20px, h2 24px */
  .project-intro .lead,
  .about-text .lead { font-size: 20px; }

  .project-body h2,
  .content-card h2,
  .about-text h2 { font-size: 24px; }

  .project-sidebar h2 { font-size: 20px; }

  /* Mindre footer-padding på mobil */
  main { padding-bottom: 48px; }
}
