/* ================================================
   VARIABLER OG TEMA
   ================================================ */

:root {
  --red: #d45456;
  --paper: #EADCC8;
  --text: #3B3B3B;
  --header-text: #e9e3d7;
  --divider: #ddd6c5;

  --red-current: var(--red);
  --paper-current: var(--paper);
  --text-current: var(--text);
  --header-text-current: var(--header-text);
  --divider-current: var(--divider);

  --font-body: "Fraunces", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-nav: "IBM Plex Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html[data-theme="dark"] {
  --red-current: #cc241d;
  --paper-current: #282828;
  --text-current: #ebdbb2;
  --header-text-current: #fbf1c7;
  --divider-current: #3c3836;
}


/* ================================================
   FONTER
   ================================================ */

@font-face {
  font-family: "Inter";
  src: url("/fonts/Inter-Variable.woff2") format("woff2-variations");
  font-weight: 100 900;
  font-style: normal;
}

@font-face {
  font-family: "Author";
  src: url("/fonts/Author-Variable.woff2") format("woff2");
  font-weight: 200 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Fraunces";
  src: url("/fonts/Fraunces-Variable.woff2") format("woff2");
  font-weight: 200 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Sans";
  src: url("/fonts/IBMPlexSans-Variable.woff2") format("woff2-variations"),
       url("/fonts/IBMPlexSans-Variable.woff2") format("woff2");
  font-weight: 100 700;
  font-style: normal;
  font-display: swap;
}


/* ================================================
   BASE
   ================================================ */

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

body {
  font-family: var(--font-body);
  margin: 0;
  background: var(--paper-current);
  color: var(--text-current);
  font-size: 18px;
  line-height: 1.6;
  letter-spacing: 0.05em;
  font-weight: 300;
}


/* ================================================
   HEADER
   ================================================ */

.site-header {
  background-color: #d45456;
  color: var(--header-text-current);
  height: 60vh;
}

.site-header-inner {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  padding-top: 2rem;
  padding-right: 4rem;
  padding-bottom: 3rem;
  padding-left: 4rem;
}

.logo img {
  display: block;
  max-width: 80vw;
  height: auto;
}


/* ================================================
   NAVIGASJON
   ================================================ */

.main-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  display: flex;
  justify-content: center;
  gap: 2rem;
  padding-top: 1rem;
  padding-right: 2rem;
  padding-bottom: 1rem;
  padding-left: 2rem;
  background: #d45456;
  color: var(--header-text-current);
  flex-wrap: wrap;
}

.main-nav a {
  font-family: var(--font-nav);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--header-text-current);
  text-decoration: none;
}

.theme-toggle {
  background: none;
  border: 0;
  color: var(--header-text-current);
  cursor: pointer;
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.9rem;
  margin-left: 0.5rem;
}

.theme-icon {
  display: inline-block;
}

html[data-theme="light"] .theme-icon-sun  { display: inline-block; }
html[data-theme="light"] .theme-icon-moon { display: none; }

html[data-theme="dark"] .theme-icon-sun  { display: none; }
html[data-theme="dark"] .theme-icon-moon { display: inline-block; }


/* ================================================
   INNHOLDSKOLONNE (600 px)
   ================================================ */

.article-page,
.archive-page {
  max-width: 37.5rem;
  margin-top: 4rem;
  margin-right: auto;
  margin-bottom: 0;
  margin-left: auto;
  padding-top: 0;
  padding-right: 1.5rem;
  padding-bottom: 1rem;
  padding-left: 1.5rem;
}


/* ================================================
   FORSIDE + NOTE
   ================================================ */

.home-hero {
  text-align: center;
  margin-top: 4rem;
  margin-right: 0;
  margin-bottom: 3rem;
  margin-left: 0;
}

.home-hero h1 {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 1rem;
  margin-left: 0;
  font: 400 32px var(--font-body);
}

.home-hero p {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  font-size: 1.2rem;
  font-weight: 300;
}

.home-divider {
  border: 0;
  border-top-width: 1px;
  border-top-style: solid;
  border-top-color: var(--divider-current);
  margin-top: 2rem;
  margin-right: 0;
  margin-bottom: 2rem;
  margin-left: 0;
}

.home-divider--notes {
  margin-top: 1rem;
  margin-bottom: 4rem;
}

.note-item {
  max-width: 29.5rem;
  margin-top: 0;
  margin-right: auto;
  margin-bottom: 1rem;
  margin-left: auto;
}

.article-body .note-item h2 {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 1rem;
  margin-left: 0;
  font-family: "Fraunces", serif;
  font-size: 2rem;
  font-weight: 300;
  line-height: 1.2;
  letter-spacing: 0.01em;
  text-align: left;
}

/* sitatet med vertikal strek og innrykk */
.note-quote {
  position: relative;
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  padding-top: 0;
  padding-right: 0;
  padding-bottom: 0;
  padding-left: 8px;
  text-align: left;
}

.note-quote::before {
  content: "";
  position: absolute;
  top: 0.5rem;
  right: auto;
  bottom: 0.5rem;
  left: 0;
  width: 1.5px;
  background-color: rgba(212, 84, 86, 1);
  opacity: 0.4;
}

.note-quote p {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 15px;
  line-height: 1.45;
  letter-spacing: 0.01em;
  text-wrap: pretty;
}

.note-quote p + p {
  margin-top: 0.6rem;
}

.note-quote .note-source {
  margin-top: 10px;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  font-size: 11px;
  line-height: 1.4;
  color: var(--text-muted);
}

.note-quote .note-source a {
  color: inherit;
  text-decoration-line: none;
  border-bottom-width: 1px;
  border-bottom-style: solid;
  border-bottom-color: rgba(138, 136, 136, 0.4);
  padding-bottom: 1px;
}

.note-quote .note-source a:hover {
  border-bottom-color: rgba(212, 84, 86, 1);
}

/* kommentaren under sitatet */
.note-comment,
.article-body .note-item > p:last-child {
  margin-top: 18px;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  font-size: 19px;
  line-height: 1.55;
  letter-spacing: 0;
}


/* ================================================
   ARTIKKEL
   ================================================ */

.article-title {
  font-family: "Fraunces", sans-serif;
  text-align: center;
  font-weight: 400;
  font-size: 32px;
  letter-spacing: 0.03em;
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 1.5rem;
  margin-left: 0;
}

.article-body {
  line-height: 1.5;
  font-size: inherit;
}

.article-body h2 {
  font-size: 1.2rem;
  font-weight: 400;
  margin-top: 2.2rem;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  line-height: 1.2;
  letter-spacing: 0.09em;
}

.article-body h2 + p {
  margin-top: 0.5rem;
}

.article-body a {
  color: inherit;
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 0.3em;
  text-decoration-color: #bbbbbb;
  transition:
    text-decoration-color 0.15s ease-out,
    text-underline-offset 0.15s ease-out;
}

.article-body a:hover {
  text-decoration-color: #d45456;
}

/* Halvfet etterfulgt av liste */
p:has(> strong) {
  margin-bottom: 0;
}

p:has(> strong) + ul {
  margin-top: 0;
}


/* ================================================
   ARTIKKEL-NAVIGASJON
   ================================================ */

.article-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 0.5rem;
  font-size: 2rem;
}

.article-nav-prev,
.article-nav-next {
  text-decoration: none;
  color: #d45456;
}

.article-nav-prev { margin-right: auto; }
.article-nav-next { margin-left: auto; }


/* ================================================
   ARKIV
   ================================================ */

.archive-page h1 {
  font-family: "Fraunces", sans-serif;
  text-align: center;
  font-size: 32px;
  font-weight: 400;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 3rem;
  margin-left: 0;
}

.archive-year {
  font-family: "Fraunces", sans-serif;
  font-size: 22px;
  font-weight: 400;
  margin-top: 2rem;
  margin-right: 0;
  margin-bottom: 0.6rem;
  margin-left: 0;
}

.archive-list {
  list-style: none;
  padding-top: 0;
  padding-right: 0;
  padding-bottom: 0;
  padding-left: 0;
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 2.5rem;
  margin-left: 0;
  border-top-width: 1px;
  border-top-style: solid;
  border-top-color: var(--divider-current);
}

.archive-item {
  display: flex;
  align-items: baseline;
  gap: 4rem;
  padding-top: 0.9rem;
  padding-right: 0;
  padding-bottom: 0.9rem;
  padding-left: 0;
  border-bottom-width: 1px;
  border-bottom-style: solid;
  border-bottom-color: var(--divider-current);
  font-size: 18px;
}

.archive-date {
  min-width: 6rem;
}

.archive-link {
  flex: 1;
  color: var(--text-current);
  text-decoration: none;
}


/* ================================================
   BILDER (shortcode)
   ================================================ */

.image-block {
  display: block;
  max-width: 100%;
  margin-top: 32px;
  margin-right: 0;
  margin-bottom: 32px;
  margin-left: 0;
}

/* Selve artikkelbildet via img-shortcode */
.image-block img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  margin-top: 0;
  margin-right: auto;
  margin-bottom: 0;
  margin-left: auto;
  border-radius: 8px;
  border-width: 1px;
  border-style: solid;
  border-color: rgba(0, 0, 0, 0.06);
}

/* Bildetekst under bildet */
.image-block figcaption {
  margin-top: 8px;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  font-size: 14px;
  line-height: 1.4;
  color: var(--text-current);
  opacity: 0.8;
}

.image-block.image-no-border img {
  border: none;
}

/* ================================================
   FOOTER
   ================================================ */

.site-footer {
  max-width: 41.25rem;
  margin-top: 3rem;
  margin-right: auto;
  margin-bottom: 1rem;
  margin-left: auto;
  padding-top: 1.5rem;
  padding-right: 1.5rem;
  padding-bottom: 0;
  padding-left: 1.5rem;
  text-align: center;
  font-size: 0.8rem;
}

.site-footer::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--divider-current);
  margin-top: 0;
  margin-right: auto;
  margin-bottom: 1rem;
  margin-left: auto;
}


/* ================================================
   MOBIL
   ================================================ */

@media (max-width: 768px) {
  .site-header {
    height: 50svh;
  }

  .site-header-inner {
    padding-top: 1.5rem;
    padding-right: 1.25rem;
    padding-bottom: 1.75rem;
    padding-left: 1.25rem;
  }

  .main-nav {
    padding-top: 1rem;
    padding-right: 1.25rem;
    padding-bottom: 1rem;
    padding-left: 1.25rem;
    gap: 1.25rem;
  }

  .main-nav a {
    font-size: 0.85rem;
  }

  .article-body .note-item h2 {
    font-size: 1.75rem;
  }

  .note-inner {
    max-width: 22rem;
  }

  .note-quote p {
    font-size: 17px;
  }

  .note-source {
    font-size: 12px;
  }
}


/* ================================================
   FONTTEST (list.html)
   ================================================ */

.fonttest {
  max-width: 680px;
  margin-top: 2rem;
  margin-right: auto;
  margin-bottom: 0;
  margin-left: auto;
  padding-top: 0;
  padding-right: 1.5rem;
  padding-bottom: 0;
  padding-left: 1.5rem;
}

.fonttest-block {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 3rem;
  margin-left: 0;
  padding-top: 0;
  padding-right: 0;
  padding-bottom: 2rem;
  padding-left: 0;
  border-bottom-width: 1px;
  border-bottom-style: solid;
  border-bottom-color: var(--divider-current);
  font-size: 1.1rem;
  line-height: 1.7;
  max-width: 65ch;
}


/* ============= BØRSEN ============= */

.borsen-layout {
  max-width: 1100px;
  margin-top: 4rem;
  margin-right: auto;
  margin-bottom: 0;
  margin-left: auto;
  padding-top: 0;
  padding-right: 1.5rem;
  padding-bottom: 1rem;
  padding-left: 1.5rem;
}

.borsen-grid {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 4rem;
  align-items: start;
}

.borsen-sidebar {
  position: sticky;
  top: 5rem;
  order: 1;
  margin-top: 140px;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
}

.borsen-sidebar-title {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 1rem;
  margin-left: 0;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.borsen-sidebar-empty {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  font-size: 0.95rem;
  opacity: 0.8;
}

.borsen-archive-list {
  list-style: none;
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  padding-top: 0;
  padding-right: 0;
  padding-bottom: 0;
  padding-left: 0;
  border-top-width: 1px;
  border-top-style: solid;
  border-top-color: var(--divider-current);
}

.borsen-archive-item {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  padding-top: 0.85rem;
  padding-right: 0;
  padding-bottom: 0.85rem;
  padding-left: 0;
  border-bottom-width: 1px;
  border-bottom-style: solid;
  border-bottom-color: var(--divider-current);
}

.borsen-archive-item a {
  color: var(--text-current);
  text-decoration-line: none;
}

.borsen-archive-item a:hover {
  text-decoration-line: underline;
}

.borsen-main-column {
  min-width: 0;
  order: 2;
}

.borsen-header {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 2.5rem;
  margin-left: 0;
}

.borsen-header h1 {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0.75rem;
  margin-left: 0;
  font-family: "Fraunces", sans-serif;
  font-weight: 100;
  font-size: 56px;
  letter-spacing: 0.01em;
}

.borsen-intro {
  margin-top: 1rem;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
}

.borsen-intro p {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 1rem;
  margin-left: 0;
}

.borsen-main {
  max-width: 42rem;
  min-width: 0;
}

.borsen-current-header {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 1.5rem;
  margin-left: 0;
}

.borsen-current-header h2 {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--red-current);
}

.borsen-current-content {
  font-size: 1.08rem;
  line-height: 1.65;
  letter-spacing: 0.01em;
}

.borsen-current-content > * + * {
  margin-top: 1rem;
}

.borsen-entry {
  position: relative;
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 2.75rem;
  margin-left: 0;
  padding-top: 0;
  padding-right: 0;
  padding-bottom: 0;
  padding-left: 0;
}

.borsen-entry:last-child {
  margin-bottom: 0;
}

.borsen-entry p {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 0;
  margin-left: 0;
}

.borsen-entry p + p {
  margin-top: 0.85rem;
}

.borsen-lead {
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 0.92em;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.borsen-current-content h2,
.borsen-current-content h3,
.borsen-current-content h4 {
  margin-top: 2rem;
  margin-right: 0;
  margin-bottom: 0.75rem;
  margin-left: 0;
  font-family: "IBM Plex Sans", sans-serif;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.borsen-current-content ul,
.borsen-current-content ol {
  margin-top: 0;
  margin-right: 0;
  margin-bottom: 1rem;
  margin-left: 1.25rem;
  padding-top: 0;
  padding-right: 0;
  padding-bottom: 0;
  padding-left: 0;
}

.borsen-current-content li + li {
  margin-top: 0.4rem;
}

@media (max-width: 900px) {
  .borsen-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .borsen-main-column {
    min-width: 0;
    order: 1;
  }

  .borsen-main {
    max-width: 100%;
  }

  .borsen-sidebar {
    position: static;
    order: 2;
    margin-top: 1rem;
    margin-right: 0;
    margin-bottom: 0;
    margin-left: 0;
    padding-top: 1.5rem;
    padding-right: 0;
    padding-bottom: 0;
    padding-left: 0;
    border-top-width: 1px;
    border-top-style: solid;
    border-top-color: var(--divider-current);
  }
}


/* ============BØRSEN FLEKSBOX =========*/

.borsen-entry--media {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.borsen-entry--media-right {
  flex-direction: row-reverse;
}

.borsen-entry-figure {
  margin: 0;
  width: 72px;
  flex: 0 0 72px;
}

.borsen-entry-figure img {
  display: block;
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border-radius: 8px;
}

.borsen-entry-body {
  flex: 1;
  min-width: 0;
}

@media (max-width: 700px) {
  .borsen-entry--media {
    gap: 0.75rem;
  }

  .borsen-entry-figure {
    width: 56px;
    flex-basis: 56px;
  }

  .borsen-entry--media-right {
  flex-direction: row-reverse;
}



/* =========== BØRSEN SLUTT =========== */