/* ═══════════════════════════════════════════════════════════════════
   Norsklaben — Shell patches
   Tre nye mønster som tek over på tvers av alle sider:
     1.  .nl-subbar     – sekundærnavigasjon (brødsmular + handlingar)
     2.  .nl-btn        – einsarta knappesystem (primary / gold / ghost / quiet)
     3.  --nl-shadow-*  – 4-stegs skygge-stige (varm forest-tinta rgba)
   Prefiks: `nl-` (Norsklaben), så ingenting kolliderer med `rg-` / `adp-` /
   andre eksisterande stilar. Last dette ark ETTER `styles.css`.
   ═══════════════════════════════════════════════════════════════════ */

:root {
  /* 4-stegs skygge-stige — alle bygd av rgba(26,61,43,...) for varm forest-tone.
     Erstatt evt. legacy --shadow / --shadow-hover med ein konsekvent skala. */
  --nl-shadow-1: 0 1px 2px rgba(26,61,43,.05), 0 1px 4px rgba(26,61,43,.04);
  --nl-shadow-2: 0 1px 4px rgba(26,61,43,.06), 0 4px 16px rgba(26,61,43,.06);
  --nl-shadow-3: 0 4px 16px rgba(26,61,43,.10), 0 8px 32px rgba(26,61,43,.08);
  --nl-shadow-4: 0 18px 40px rgba(26,61,43,.16);

  /* Standard easing for hover / press */
  --nl-ease-out: cubic-bezier(.2,.8,.2,1);
}

/* hidden-attributtet skal ALLTID vinne over display-reglar (flex/grid på
   t.d. .nl-btn slo UA-stilen og gjorde «gøymde» knappar synlege). */
[hidden] { display: none !important; }

/* ─────────────────────────────────────────────────────────────
   1) .nl-subbar — sekundærnavigasjon
   Brødsmular til venstre, handlingsknappar til høgre. Sit rett
   under hovudheaderen, gir tydeleg orientering + retrettrute.
   ───────────────────────────────────────────────────────────── */
.nl-subbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  max-width: 1200px;
  margin: 0 auto;
  padding: 14px 32px 18px;
}

.nl-crumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--tmuted, #7A7670);
}
.nl-crumb a {
  color: var(--tmid, #4A4840);
  text-decoration: none;
  font-weight: 500;
  cursor: pointer;
  transition: color .15s var(--nl-ease-out);
}
.nl-crumb a:hover { color: var(--text, #1C1C1C); text-decoration: underline; text-underline-offset: 3px; }
.nl-crumb-sep { color: var(--border, #E0DBD2); }
.nl-crumb strong {
  color: var(--text, #1C1C1C);
  font-weight: 600;
  font-family: inherit;
}
.nl-crumb-note {
  margin-left: 8px;
  font-size: 12px;
  color: var(--tmuted, #7A7670);
  font-style: italic;
}

.nl-subactions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

/* På mobil — la brødsmular og handlingar stable */
@media (max-width: 720px) {
  .nl-subbar { padding: 10px 16px 14px; gap: 8px; }
  .nl-subactions { width: 100%; justify-content: flex-end; }
}

/* ─────────────────────────────────────────────────────────────
   2) .nl-btn — knappesystem
   Fire variantar: primary (forest), gold, ghost, quiet.
   Storleikar via .nl-btn--sm / .nl-btn--lg.
   ───────────────────────────────────────────────────────────── */
.nl-btn {
  font-family: inherit;
  font-size: 13.5px;
  font-weight: 600;
  line-height: 1;
  border-radius: 8px;
  padding: 10px 16px;
  cursor: pointer;
  border: 1.5px solid transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  text-decoration: none;
  white-space: nowrap;
  transition:
    background-color .18s var(--nl-ease-out),
    color .18s var(--nl-ease-out),
    border-color .18s var(--nl-ease-out),
    transform .12s var(--nl-ease-out);
}
.nl-btn:disabled { opacity: .5; cursor: not-allowed; }
.nl-btn:active:not(:disabled) { transform: scale(.99); }
.nl-btn:focus-visible {
  outline: 2px solid var(--accent, #C8832A);
  outline-offset: 2px;
}

/* Primary — forest, fyller knapp */
.nl-btn--primary {
  background: var(--primary, #1A3D2B);
  color: #fff;
}
.nl-btn--primary:hover:not(:disabled) { background: var(--mid, #2E6B4F); }

/* Gold — accent, brukt for "lagre / publiser / send"-handlingar */
.nl-btn--gold {
  background: var(--accent, #C8832A);
  color: #fff;
}
.nl-btn--gold:hover:not(:disabled) { background: #8E5A19; }

/* Ghost — gjennomsiktig med ramme, sekundær handling */
.nl-btn--ghost {
  background: transparent;
  color: var(--text, #1C1C1C);
  border-color: var(--border, #E0DBD2);
}
.nl-btn--ghost:hover:not(:disabled) {
  border-color: var(--text, #1C1C1C);
}

/* Quiet — som ein tekstlenke, men med trykkflate; for "avbryt" o.l. */
.nl-btn--quiet {
  background: transparent;
  color: var(--tmid, #4A4840);
  padding: 8px 12px;
  font-size: 13px;
}
.nl-btn--quiet:hover:not(:disabled) {
  color: var(--text, #1C1C1C);
  background: var(--bcard, #EDE8E0);
}

/* Storleiksvariantar */
.nl-btn--sm { font-size: 12.5px; padding: 7px 12px; }
.nl-btn--lg { font-size: 15px;   padding: 13px 22px; }

/* Ghost-variant for mørk bakgrunn (på forest hero) */
.nl-btn--ghost-on-dark {
  background: transparent;
  color: rgba(255,255,255,.92);
  border-color: rgba(255,255,255,.28);
}
.nl-btn--ghost-on-dark:hover:not(:disabled) {
  border-color: #fff; color: #fff;
}

/* ─────────────────────────────────────────────────────────────
   3) Skygge-utility-klassar
   For bruk på kort / popovers / modalar. Gir konsekvent stige.
   ───────────────────────────────────────────────────────────── */
.nl-shadow-1 { box-shadow: var(--nl-shadow-1); }
.nl-shadow-2 { box-shadow: var(--nl-shadow-2); }
.nl-shadow-3 { box-shadow: var(--nl-shadow-3); }
.nl-shadow-4 { box-shadow: var(--nl-shadow-4); }

/* "Hover-lift"-mønster: ein kombinasjon av translateY + neste skyggesteg */
.nl-lift {
  transition: transform .2s var(--nl-ease-out), box-shadow .2s var(--nl-ease-out);
}
.nl-lift:hover {
  transform: translateY(-2px);
  box-shadow: var(--nl-shadow-3);
}

/* ─────────────────────────────────────────────────────────────
   4) Header-layout — venstrejustert nav, konto til høgre
   Opt-in: legg `class="nl-hdr-left"` på <header>. Då vert lenkene
   gruppert venstre (rett etter logoen), og profile-knappen blir
   skyvd heilt til høgre. Resten av header-stilen frå styles.css
   står som han er.
   ───────────────────────────────────────────────────────────── */
header.nl-hdr-left {
  justify-content: flex-start;
  gap: 28px;
}
header.nl-hdr-left nav {
  flex: 1;
  align-items: center;
}
/* Profile-knappen / konto-chip / siste lenkje i nav blir skyvd til høgre */
header.nl-hdr-left nav > .profile-btn,
header.nl-hdr-left nav > .nl-konto-wrap,
header.nl-hdr-left nav > .nav-dropdown:last-of-type {
  margin-left: auto;
}
/* På mobil — la den naturlege flyten (kolonne) ta over att */
@media (max-width: 768px) {
  header.nl-hdr-left { gap: 12px; }
  header.nl-hdr-left nav > .profile-btn,
  header.nl-hdr-left nav > .nl-konto-wrap,
  header.nl-hdr-left nav > .nav-dropdown:last-of-type { margin-left: 0; }
}

/* ─────────────────────────────────────────────────────────────
   5) Navmeny-knappeanimasjon
   Tre-stegs hierarki for navlenkene i `.nl-hdr-left`-headeren:
     • rest    – 70 % kvit, ingen dekor
     • hover   – 100 % kvit, underline-stripe glir inn frå senter
     • active  – 100 % kvit + bold + soft bg + gull-underline står fast
   Designet er stille i kvile, tydelig på interaksjon. Pedagogisk
   verdi: gir læraren tydeleg "kvar er eg" utan å skrike.
   ───────────────────────────────────────────────────────────── */
header.nl-hdr-left nav a,
header.nl-hdr-left nav .nav-dropbtn {
  position: relative;
  transition:
    color .18s var(--nl-ease-out),
    background-color .18s var(--nl-ease-out);
}

/* Underline-stripe — felles ::after for både <a> og <button> */
header.nl-hdr-left nav a::after,
header.nl-hdr-left nav .nav-dropbtn::after {
  content: "";
  position: absolute;
  left: 12px; right: 12px; bottom: 4px;
  height: 2px;
  border-radius: 2px;
  background: rgba(255,255,255,.55);
  transform: scaleX(0);
  transform-origin: center;
  transition:
    transform .24s var(--nl-ease-out),
    background-color .18s var(--nl-ease-out),
    height .18s var(--nl-ease-out);
}

/* HOVER — overstyr legacy `background: rgba(255,255,255,.12)` så
   underlinje-en får stå åleine. */
header.nl-hdr-left nav a:hover:not(.active):not(.is-active),
header.nl-hdr-left nav .nav-dropbtn:hover:not(.active) {
  background: transparent;
  color: #fff;
}
header.nl-hdr-left nav a:hover::after,
header.nl-hdr-left nav .nav-dropbtn:hover::after {
  transform: scaleX(.7);
}

/* ACTIVE — bold + soft bg + gull-underline som står fast */
header.nl-hdr-left nav a.active,
header.nl-hdr-left nav a.is-active,
header.nl-hdr-left nav .nav-dropbtn.active,
header.nl-hdr-left nav .nav-dropdown.open .nav-dropbtn {
  color: #fff;
  font-weight: 700;
  background: rgba(255,255,255,.08);
}
header.nl-hdr-left nav a.active::after,
header.nl-hdr-left nav a.is-active::after,
header.nl-hdr-left nav .nav-dropbtn.active::after,
header.nl-hdr-left nav .nav-dropdown.open .nav-dropbtn::after {
  transform: scaleX(1);
  background: var(--accent, #C8832A);
  height: 2.5px;
}

/* Profile-knappen og hamburger skal IKKJE få underline */
header.nl-hdr-left nav .profile-btn::after,
header.nl-hdr-left .nav-hamburger::after {
  content: none;
}

/* Lærarverktøy-dropdown: lenkene ligg inni nav (kvit tekst-kontekst), men
   dropdown-panelet er kvitt. Overstyr den arva kvite farga så lenkene blir
   lesbare. Høgare spesifisitet enn 'header.nl-hdr-left nav a'. */
header.nl-hdr-left nav .nav-dropmenu a {
  color: var(--tmid, #4A4840);
}
header.nl-hdr-left nav .nav-dropmenu a::after { content: none; }
header.nl-hdr-left nav .nav-dropmenu a:hover,
header.nl-hdr-left nav .nav-dropmenu a.active {
  color: var(--primary, #1A3D2B);
  background: var(--plight, #E8F2EC);
}


/* ─────────────────────────────────────────────────────────────
   6) Felles modal-komponent (.nl-modal)
   Same formspråk som ta-modal i tekstanalyse.css: blurra
   skog-grøn backdrop, mørk header med serif-tittel, beige
   footer og roleg inntoningsanimasjon. Brukt av vegvisar.js
   og andre sider som treng dialogar utanfor tekstanalyse.
   Markup:
     <div class="nl-modal" role="dialog" aria-modal="true" hidden>
       <div class="nl-modal-backdrop"></div>
       <div class="nl-modal-dialog">
         <div class="nl-modal-head"><h2>…</h2><button class="nl-modal-close">×</button></div>
         <div class="nl-modal-body">…</div>
         <div class="nl-modal-foot">…</div>
       </div>
     </div>
   ───────────────────────────────────────────────────────────── */
.nl-modal {
  position: fixed;
  inset: 0;
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.nl-modal[hidden] { display: none !important; }
.nl-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(26, 61, 43, 0.72);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.nl-modal-dialog {
  position: relative;
  background: var(--card, #fff);
  border-radius: 16px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.32);
  width: 100%;
  max-width: 560px;
  max-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: nl-modal-in .18s ease-out;
}
.nl-modal-dialog--wide { max-width: 920px; }
@keyframes nl-modal-in {
  from { opacity: 0; transform: translateY(8px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.nl-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 18px 22px 14px;
  background: var(--primary, #1A3D2B);
  color: #fff;
  flex-shrink: 0;
}
.nl-modal-head h2 {
  font-family: 'Playfair Display', serif;
  font-size: 20px;
  font-weight: 600;
  margin: 0;
  color: #fff;
  letter-spacing: -.01em;
}
.nl-modal-close {
  background: rgba(255, 255, 255, 0.15);
  border: 0;
  font-size: 22px;
  line-height: 1;
  color: #fff;
  cursor: pointer;
  width: 30px;
  height: 30px;
  border-radius: 6px;
  flex-shrink: 0;
  transition: background .15s;
}
.nl-modal-close:hover { background: rgba(255, 255, 255, 0.28); }
.nl-modal-body {
  padding: 16px 22px;
  overflow-y: auto;
  flex: 1 1 auto;
  min-height: 0;
}
.nl-modal-intro {
  margin: 0 0 14px;
  font-size: 13.5px;
  color: var(--mid, #2E6B4F);
}
.nl-modal-foot {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  padding: 14px 22px 18px;
  border-top: 1px solid var(--border, #E0DBD2);
  background: var(--bcard, #EDE8E0);
  flex-shrink: 0;
}
.nl-modal-foot-note {
  margin-right: auto;
  font-size: 12px;
  color: var(--tmuted, #7A7670);
}

/* Steg-liste for vegvisingsmodalar (1-2-3 med nummersirkel) */
.nl-vegvis-steg {
  display: flex;
  gap: 13px;
  padding: 10px 0;
  align-items: flex-start;
}
.nl-vegvis-steg + .nl-vegvis-steg { border-top: 1.5px dashed var(--bcard, #EDE8E0); }
.nl-vegvis-steg-n {
  width: 28px;
  height: 28px;
  border-radius: 99px;
  flex-shrink: 0;
  background: var(--plight, #E8F2EC);
  color: var(--primary, #1A3D2B);
  font-weight: 700;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.nl-vegvis-steg b {
  font-size: 14.5px;
  color: var(--text, #1C1C1C);
  display: block;
}
.nl-vegvis-steg p {
  font-size: 13px;
  color: var(--tmid, #4A4840);
  margin: 1px 0 0;
  line-height: 1.45;
}
@media (max-width: 600px) {
  .nl-modal { padding: 12px; }
  .nl-modal-head { padding: 14px 16px 10px; }
  .nl-modal-body { padding: 12px 16px; }
  .nl-modal-foot { padding: 12px 16px 14px; }
}

/* ─────────────────────────────────────────────────────────────
   7) Hjelpeknapp («?») — opnar vegvisingsmodalen att.
   Brukt i .nl-subactions på sider med vegvisar.js.
   ───────────────────────────────────────────────────────────── */
.nl-hjelp-btn {
  width: 32px;
  height: 32px;
  padding: 0 !important;
  justify-content: center;
  border-radius: 99px !important;
  background: var(--plight, #E8F2EC);
  color: var(--primary, #1A3D2B);
  font-weight: 700;
  font-size: 15px;
  border: 1.5px solid transparent;
}
.nl-hjelp-btn:hover:not(:disabled) {
  background: var(--primary, #1A3D2B);
  color: #fff;
}
