/* Blå tips-feedback for åpne skriveoppgaver */
.tip {
  color: #2066b6 !important;
  background: #eef5fc;
  border-left: 3px solid #2066b6;
  padding: .4rem .7rem;
  border-radius: 0 var(--rs) var(--rs) 0;
  margin-top: .4rem;
  display: block;
  font-size: .95em;
}
/* ═══════════════════════════════════════════
   Norsklaben – Felles stilark
   Brukt av: index.html, skrivelab.html, nynorsklab.html
═══════════════════════════════════════════ */

:root {
  --bg:            #F7F3EE;
  --card:          #ffffff;
  --primary:       #1A3D2B;
  --mid:           #2E6B4F;
  --plight:        #E8F2EC;
  --accent:        #C8832A;
  --alight:        #FDF4E0;
  --text:          #1C1C1C;
  --tmid:          #4A4840;
  --tmuted:        #7A7670;
  --border:        #E0DBD2;
  --bcard:         #EDE8E0;
  --shadow:        0 1px 4px rgba(26,61,43,.06), 0 4px 16px rgba(26,61,43,.06);
  --shadow-hover:  0 4px 16px rgba(26,61,43,.12), 0 8px 32px rgba(26,61,43,.08);
  --r:             10px;
  --rs:            6px;

  /* Operasjonsfargar */
  --op-identifisere: #1D6FD1;
  --op-korrigere:    #C0392B;
  --op-omskrive:     #7B2FBE;
  --op-byggje:       #4a7a3d;
  --op-analysere:    #B05A00;
  --op-rangere:      #0A7C8C;
  --op-fylloppgåve:  #3A5A8C;
}

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

body {
  font-family: 'Source Sans 3', sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 16px;
  line-height: 1.6;
}

/* ─── HEADER ─── */
header {
  background: var(--primary);
  padding: 0 2rem;
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 60px;
  box-shadow: 0 2px 12px rgba(0,0,0,.18);
}

.logo {
  font-family: 'Playfair Display', serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  position: relative;
}
.logo span { color: var(--alight); }
.logo::after {
  content: 'beta';
  position: absolute;
  top: -6px;
  right: -4px;
  background: linear-gradient(135deg, #7ec8e3, #4da8da);
  color: #fff;
  font-family: 'Source Sans 3', sans-serif;
  font-size: .52rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 1.5px 5px 1px;
  border-radius: 3px;
  line-height: 1.3;
  box-shadow: 0 1px 4px rgba(77,168,218,.35);
  transform: rotate(12deg);
  pointer-events: none;
}

nav { display: flex; gap: .25rem; }

.nav-hamburger {
  display: none;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.06);
  border-radius: var(--rs);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
}

.nav-hamburger span {
  width: 18px;
  height: 2px;
  border-radius: 2px;
  background: #fff;
  transition: transform .18s ease, opacity .18s ease;
}

header.nl-nav-open .nav-hamburger span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

header.nl-nav-open .nav-hamburger span:nth-child(2) {
  opacity: 0;
}

header.nl-nav-open .nav-hamburger span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

nav a {
  color: rgba(255,255,255,.7);
  text-decoration: none;
  font-size: .9rem;
  font-weight: 500;
  padding: .4rem .85rem;
  border-radius: var(--rs);
  transition: all .2s;
}
nav a:hover, nav a.active {
  color: #fff;
  background: rgba(255,255,255,.12);
}
nav a.active { font-weight: 700; }

.nav-dropdown {
  position: relative;
}

.nav-dropbtn {
  border: none;
  background: transparent;
  color: rgba(255,255,255,.7);
  font-family: inherit;
  font-size: .9rem;
  font-weight: 500;
  padding: .4rem .85rem;
  border-radius: var(--rs);
  cursor: pointer;
  transition: all .2s;
}

.nav-dropbtn:hover,
.nav-dropbtn.active,
.nav-dropdown.open .nav-dropbtn {
  color: #fff;
  background: rgba(255,255,255,.12);
}

.nav-dropmenu {
  position: absolute;
  top: calc(100% + .45rem);
  right: 0;
  min-width: 180px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  box-shadow: var(--shadow-hover);
  padding: .35rem;
  display: none;
}
.nav-dropmenu::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 0;
  right: 0;
  height: 10px;
}

.nav-dropdown.open .nav-dropmenu {
  display: block;
}

.nav-dropmenu a {
  display: block;
  color: var(--tmid);
  font-size: .86rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 5px;
  padding: .45rem .55rem;
}

.nav-dropmenu a:hover,
.nav-dropmenu a.active {
  color: var(--primary);
  background: var(--plight);
}

/* ─── Language toggle ─── */
.lang-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0;
  margin-left: .45rem;
  background: rgba(255,255,255,.04);
  border-radius: 999px;
  overflow: hidden;
}
.lang-toggle a {
  padding: .18rem .4rem;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .02em;
  color: rgba(255,255,255,.6);
  text-decoration: none;
  transition: all .2s;
  line-height: 1;
}
.lang-toggle a:hover {
  color: #fff;
  background: rgba(255,255,255,.1);
}
.lang-toggle a.active {
  color: #fff;
  background: rgba(255,255,255,.15);
  pointer-events: none;
}

/* ─── HERO (felles base) ─── */
.hero {
  background: var(--primary);
  padding: 3.5rem 2rem 2.5rem;
  color: #fff;
  position: relative;
  overflow: hidden;
}

.hero::before {
  font-family: 'Playfair Display', serif;
  font-size: 8rem;
  font-weight: 700;
  color: rgba(255,255,255,.04);
  position: absolute;
  right: -1rem;
  top: -1rem;
  pointer-events: none;
  line-height: 1;
}

.hero-index {
  text-align: center;
  padding: 5rem 2rem 4rem;
}
.hero-index::before {
  content: 'Norsklaben';
  left: 50%;
  right: auto;
  transform: translateX(-50%);
  font-size: 10rem;
  color: rgba(255,255,255,.03);
}
.skrivelab-hero::before  { content: 'Skrivelab'; }
.nynorsklab-hero::before { content: 'Nynorsklab'; }

.htag {
  display: inline-block;
  background: rgba(200,131,42,.25);
  color: var(--alight);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .2rem .65rem;
  border-radius: 20px;
  border: 1px solid rgba(200,131,42,.3);
  margin-bottom: .8rem;
}

.hero h1 {
  font-family: 'Playfair Display', serif;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: .5rem;
}
.hero-index h1 { font-size: 3.5rem; }

.hero p {
  color: rgba(255,255,255,.7);
  font-size: 1rem;
  max-width: 520px;
}
.hero-index p { margin: 0 auto 2.5rem; font-size: 1.1rem; }

.skrivelab-hero p {
  max-width: 720px;
}

.skrivelab-hero-actions {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  margin-top: 1.4rem;
}

.skrivelab-hero-btn {
  margin-top: 0;
}

.skrivelab-hero-btn-ghost {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
}

.skrivelab-hero-btn-ghost:hover {
  background: rgba(255,255,255,.16);
}

.skrivelab-landing {
  max-width: 1200px;
  margin: -1.1rem auto 0;
  padding: 0 2rem;
  position: relative;
  z-index: 2;
}

.skrivelab-landing-shell {
  background:
    radial-gradient(circle at top right, rgba(200,131,42,.16), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.96) 0%, #fff 100%);
  border: 1.5px solid var(--border);
  border-radius: 20px;
  box-shadow: 0 18px 40px rgba(26,61,43,.12);
  padding: 1.4rem;
}

.skrivelab-landing-head {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
  gap: 1.5rem;
  align-items: end;
  margin-bottom: 1.1rem;
}

.skrivelab-kicker {
  font-size: .73rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: .35rem;
}

.skrivelab-landing-head h2 {
  font-family: 'Playfair Display', serif;
  font-size: 2rem;
  line-height: 1.1;
  color: var(--primary);
}

.skrivelab-landing-lead {
  color: var(--tmid);
  font-size: .98rem;
  line-height: 1.65;
}

.skrivelab-landing-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
}

.skrivelab-path {
  border-radius: 18px;
  padding: 1.6rem 1.7rem;
  border: 1px solid var(--border);
  min-width: 0;
  box-shadow: 0 10px 24px rgba(26,61,43,.08);
}

.skrivelab-path-api {
  background: linear-gradient(180deg, #f6fbf7 0%, #eef7f2 100%);
  border-top: 3px solid var(--primary);
}

.skrivelab-path-master {
  background: linear-gradient(180deg, #fffaf1 0%, #fff4de 100%);
  border-top: 3px solid var(--accent);
}

.skrivelab-path-top h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.45rem;
  color: var(--primary);
  margin-bottom: .35rem;
}

.skrivelab-path-icon {
  width: 3rem;
  height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: rgba(255,255,255,.8);
  border: 1px solid rgba(26,61,43,.08);
  font-size: 1.4rem;
  margin-bottom: .7rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
}

.skrivelab-path-top p {
  color: var(--tmid);
  font-size: .95rem;
  line-height: 1.6;
}

.skrivelab-path-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: rgba(26,61,43,.08);
  color: var(--primary);
  padding: .22rem .62rem;
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: .65rem;
}

.skrivelab-path-badge-gold {
  background: rgba(200,131,42,.16);
  color: #8b5815;
}

.skrivelab-feature-list {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin: .9rem 0 1rem;
}

.skrivelab-choice-line {
  margin: .8rem 0 .95rem;
  padding: .7rem .85rem;
  background: rgba(255,255,255,.7);
  border-left: 4px solid var(--accent);
  border-radius: 0 12px 12px 0;
  color: var(--tmid);
  line-height: 1.55;
}

.skrivelab-choice-line strong {
  color: var(--primary);
}

.skrivelab-feature {
  background: #fff;
  border: 1px solid rgba(46,107,79,.16);
  border-radius: 999px;
  padding: .42rem .75rem;
  font-size: .84rem;
  color: var(--primary);
  font-weight: 600;
}

.skrivelab-api-slot {
  min-height: 180px;
}

.nl-api-fallback {
  display: grid;
  gap: .3rem;
  padding: 1rem;
  border: 1.5px dashed #9fc4a8;
  border-radius: 14px;
  background: rgba(255,255,255,.7);
  color: #42604d;
  line-height: 1.55;
}

.nl-api-fallback strong {
  color: var(--primary);
}

.nl-api-fallback code {
  font-family: 'JetBrains Mono', monospace;
  font-size: .85em;
}

.skrivelab-steps {
  display: grid;
  gap: .7rem;
  margin: 1rem 0 1.1rem;
}

.skrivelab-steps-simple {
  margin-top: 0;
}

.skrivelab-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .65rem;
  align-items: start;
  padding: .75rem .8rem;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(200,131,42,.18);
  border-radius: 14px;
}

.skrivelab-step strong {
  width: 1.9rem;
  height: 1.9rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--primary);
  color: #fff;
  font-size: .88rem;
}

.skrivelab-step span {
  color: var(--tmid);
  line-height: 1.55;
}

.skrivelab-path-actions {
  display: flex;
  gap: .55rem;
  flex-wrap: wrap;
  margin-top: .2rem;
}

.skrivelab-bank-intro {
  max-width: 1200px;
  margin: 1.1rem auto 0;
  padding: 0 2rem;
}

.skrivelab-bank-intro-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  background: linear-gradient(135deg, #fff 0%, #f5f1ea 100%);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  padding: 1rem 1.1rem;
}

.skrivelab-bank-intro-inner h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.35rem;
  color: var(--primary);
  margin-bottom: .2rem;
}

.skrivelab-bank-intro-inner p:last-child {
  color: var(--tmid);
  font-size: .92rem;
  line-height: 1.55;
}

.hero-stats {
  display: flex;
  gap: 2rem;
  margin-top: 2rem;
}
.stat-n {
  font-family: 'Playfair Display', serif;
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}
.stat-l {
  font-size: .78rem;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: .2rem;
}

/* ─── INDEX: CARDS ─── */
.lab-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  max-width: 900px;
  margin: 0 auto;
  padding: 3rem 2rem;
}

.lcard {
  background: var(--card);
  border-radius: var(--r);
  border: 1.5px solid var(--bcard);
  box-shadow: var(--shadow);
  padding: 2rem;
  text-decoration: none;
  color: var(--text);
  transition: all .25s;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.lcard:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}
.lcard-icon { font-size: 2rem; line-height: 1; }
.lcard h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--primary);
}
.lcard p { font-size: .92rem; color: var(--tmid); line-height: 1.6; flex: 1; }
.lcard-meta { display: flex; gap: .5rem; flex-wrap: wrap; }

.tag { font-size: .75rem; font-weight: 600; padding: .2rem .6rem; border-radius: 20px; }
.tag-g { background: var(--plight); color: var(--primary); }
.tag-a { background: var(--alight); color: #B05A00; }

.lbtn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: var(--primary);
  color: #fff;
  font-family: inherit;
  font-size: .9rem;
  font-weight: 600;
  padding: .55rem 1.1rem;
  border-radius: var(--rs);
  margin-top: .5rem;
  transition: background .2s;
}
.lbtn:hover { background: var(--mid); }

/* ─── INDEX: OPPGAVEBANK NOTE ─── */
.index-ob-note {
  max-width: 980px;
  margin: 0 auto 1.2rem;
  padding: 0 2rem;
}

.index-ob-note-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem;
  background: linear-gradient(135deg, #fff9ef 0%, #f7efe2 100%);
  border: 1.5px solid #e8d9bf;
  border-radius: var(--r);
  box-shadow: var(--shadow);
  padding: 1rem 1.1rem;
}

.index-ob-note-icon {
  width: 2.4rem;
  height: 2.4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: #fff;
  border: 1px solid #ecd9bc;
  font-size: 1.25rem;
}

.index-ob-note-text h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.2rem;
  color: var(--primary);
  margin-bottom: .2rem;
}

.index-ob-note-text p {
  color: var(--tmid);
  font-size: .92rem;
  line-height: 1.55;
}

.index-ob-note-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--primary);
  color: #fff;
  text-decoration: none;
  font-size: .86rem;
  font-weight: 700;
  padding: .58rem .88rem;
  border-radius: var(--rs);
  white-space: nowrap;
}

.index-ob-note-btn:hover {
  background: var(--mid);
}

/* ─── INDEX: HOW-TO ─── */
.how {
  background: var(--card);
  border-top: 1px solid var(--border);
  padding: 3rem 2rem;
  text-align: center;
}
.how h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.8rem;
  color: var(--primary);
  margin-bottom: 2rem;
}
.steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.5rem;
  max-width: 800px;
  margin: 0 auto;
}
.step {
  padding: 1.5rem;
  background: var(--bg);
  border-radius: var(--r);
  border: 1.5px solid var(--border);
}
.step-num {
  font-family: 'Playfair Display', serif;
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary);
  line-height: 1;
  margin-bottom: .5rem;
}
.step h3 { font-size: 1rem; font-weight: 700; color: var(--primary); margin-bottom: .4rem; }
.step p  { font-size: .86rem; color: var(--tmuted); }

/* ─── FILTER BAR ─── */
.fbar {
  background: var(--card);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 60px;
  z-index: 90;
  padding: .85rem 2rem;
}
.frow {
  display: flex;
  gap: .85rem;
  align-items: center;
  flex-wrap: wrap;
  max-width: 1200px;
  margin: 0 auto;
}
.swrap { position: relative; flex: 1; min-width: 200px; }
.swrap svg {
  position: absolute;
  left: .7rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--tmuted);
  pointer-events: none;
}
#search-input {
  width: 100%;
  padding: .5rem .7rem .5rem 2.3rem;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  font-family: inherit;
  font-size: .9rem;
  background: var(--bg);
  color: var(--text);
  outline: none;
  transition: border-color .2s;
}
#search-input:focus { border-color: var(--mid); }

.chips { display: flex; gap: .35rem; flex-wrap: wrap; }
.chip {
  padding: .28rem .7rem;
  border-radius: 20px;
  border: 1.5px solid var(--border);
  background: transparent;
  font-family: inherit;
  font-size: .78rem;
  font-weight: 500;
  cursor: pointer;
  color: var(--tmid);
  transition: all .18s;
  white-space: nowrap;
}
.chip:hover { border-color: var(--mid); color: var(--primary); }
.chip.active { background: var(--primary); border-color: var(--primary); color: #fff; }

/* ─── ADAPTIVE PRACTICE ─── */
.adp {
  max-width: 1200px;
  margin: 1rem auto 0;
  padding: 0 2rem;
}

.adp-inner {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  padding: 1rem 1rem 1.1rem;
}

.adp-head h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem;
  color: var(--primary);
  margin-bottom: .2rem;
}

.adp-head p {
  font-size: .9rem;
  color: var(--tmid);
  margin-bottom: .8rem;
}

.adp-gamify {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  gap: .45rem;
  margin: .15rem 0 .85rem;
}

.adp-gamify-cockpit {
  position: relative;
  overflow: hidden;
  border: 1px solid #d7cfbf;
  border-radius: var(--r);
  padding: .75rem;
  background:
    radial-gradient(circle at 92% -8%, rgba(214, 168, 62, .18), transparent 44%),
    radial-gradient(circle at -6% 118%, rgba(181, 124, 42, .14), transparent 42%),
    linear-gradient(145deg, #fffdf7 0%, #f8f4e8 50%, #f4efe1 100%);
  box-shadow: 0 10px 24px rgba(107, 83, 38, .12);
}

.adp-g-orbit {
  position: absolute;
  width: 220px;
  height: 220px;
  top: -145px;
  right: -118px;
  border-radius: 50%;
  border: 1px dashed rgba(26, 86, 219, .24);
  opacity: .8;
  animation: adpOrbit 16s linear infinite;
  pointer-events: none;
}

.adp-g-hero {
  grid-column: 1 / -1;
  border: 1px solid #ddc996;
  border-radius: 12px;
  padding: .56rem .68rem .6rem;
  background: linear-gradient(140deg, #fff8e8 0%, #fef1d2 45%, #fae4b0 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.62), 0 4px 12px rgba(132, 95, 22, .13);
  position: relative;
  z-index: 1;
}

.adp-g-hero-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .6rem;
  margin-bottom: .35rem;
  flex-wrap: wrap;
}

.adp-g-hero-title {
  font-size: .67rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 700;
  color: #7e5a1b;
}

.adp-g-hero-level {
  display: inline-flex;
  align-items: center;
  gap: .34rem;
  font-size: .9rem;
  color: #684615;
}

#nl-ad-prof-level-icon {
  font-size: 1.02rem;
}

#nl-ad-prof-level-name {
  font-family: 'Playfair Display', serif;
  font-size: .98rem;
  color: #6b4914;
}

.adp-g-hero-bar {
  height: 8px;
  border-radius: 99px;
  background: rgba(115, 85, 30, .16);
  overflow: hidden;
  margin-bottom: .34rem;
}

#nl-ad-prof-progress-fill {
  display: block;
  height: 100%;
  width: 0;
  border-radius: 99px;
  background: linear-gradient(90deg, #2c7a57 0%, #c18b2e 100%);
  transition: width .45s cubic-bezier(.4,0,.2,1);
}

#nl-ad-prof-progress-fill.adp-prof-progress-up {
  animation: adpProfBarUp .8s ease;
}

@keyframes adpProfBarUp {
  0% { box-shadow: 0 0 0 rgba(193,139,46,0); filter: saturate(1); }
  35% { box-shadow: 0 0 10px rgba(193,139,46,.45), 0 0 18px rgba(44,122,87,.25); filter: saturate(1.15); }
  100% { box-shadow: 0 0 0 rgba(193,139,46,0); filter: saturate(1); }
}

.adp-g-hero-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  flex-wrap: wrap;
  font-size: .76rem;
  color: #6a522a;
}

#nl-ad-prof-progress-text {
  font-variant-numeric: tabular-nums;
}

.adp-g-hero-trophies {
  display: inline-flex;
  align-items: center;
  gap: .24rem;
  background: rgba(255,255,255,.42);
  border: 1px solid rgba(175, 132, 45, .4);
  border-radius: 999px;
  padding: .08rem .44rem;
}

#nl-ad-prof-trophies {
  color: #734d12;
}

.adp-g-hero-last {
  display: inline-flex;
  align-items: center;
  gap: .28rem;
  background: linear-gradient(135deg, rgba(255,255,255,.64), rgba(255,255,255,.42));
  border: 1px solid rgba(175, 132, 45, .38);
  border-radius: 999px;
  padding: .08rem .46rem;
  color: #6b4a1a;
  font-size: .72rem;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.adp-g-hero-last.adp-g-hero-last-pop {
  animation: adpBadgePop .6s cubic-bezier(.34,1.56,.64,1);
}

@keyframes adpBadgePop {
  0% { transform: scale(.75); opacity: 0; }
  55% { transform: scale(1.08); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}

@keyframes adpOrbit {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.adp-gamify-cockpit .adp-g-pill {
  display: flex;
  align-items: center;
  gap: .58rem;
  border-radius: 12px;
  border: 1px solid transparent;
  padding: .48rem .62rem;
  line-height: 1.2;
  backdrop-filter: blur(2px);
  position: relative;
  z-index: 1;
  transition: transform .2s ease, box-shadow .2s ease;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.55), 0 4px 10px rgba(95, 74, 33, .09);
}

.adp-gamify-cockpit .adp-g-pill::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 42%;
  border-radius: 12px 12px 10px 10px;
  background: linear-gradient(180deg, rgba(255,255,255,.45), rgba(255,255,255,0));
  pointer-events: none;
}

.adp-gamify-cockpit .adp-g-pill::after {
  content: '';
  position: absolute;
  right: .38rem;
  top: .3rem;
  width: .42rem;
  height: .42rem;
  border-radius: 50%;
  background: rgba(255,255,255,.55);
  box-shadow: 0 0 0 2px rgba(255,255,255,.18);
  pointer-events: none;
}

.adp-gamify-cockpit .adp-g-pill:hover {
  transform: translateY(-1px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.62), 0 6px 16px rgba(95, 74, 33, .14);
}

.adp-g-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 10px;
  font-size: 1rem;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.5), 0 2px 6px rgba(80, 60, 24, .22);
  position: relative;
}

.adp-g-icon::before,
.adp-g-icon::after {
  content: '';
  position: absolute;
  bottom: -.28rem;
  width: .36rem;
  height: .42rem;
  border-radius: 0 0 3px 3px;
  opacity: .85;
}

.adp-g-icon::before {
  left: .38rem;
  transform: rotate(8deg);
}

.adp-g-icon::after {
  right: .38rem;
  transform: rotate(-8deg);
}

.adp-g-stack {
  display: grid;
  gap: .1rem;
  min-width: 0;
}

.adp-g-kicker {
  display: block;
  font-size: .64rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(28, 28, 28, .62);
  font-weight: 700;
}

.adp-gamify-cockpit .adp-g-pill strong {
  display: block;
  font-size: 1rem;
  color: var(--primary);
  font-weight: 700;
  margin-top: 0;
}

.adp-g-pill-level {
  background: linear-gradient(135deg, #fdf4cf 0%, #f9e0a0 100%);
  border-color: #e0b95a !important;
}

.adp-g-pill-level .adp-g-icon {
  background: linear-gradient(145deg, #ffefb5 0%, #e8bf58 100%);
}

.adp-g-pill-level .adp-g-icon::before,
.adp-g-pill-level .adp-g-icon::after {
  background: linear-gradient(180deg, #b53f3f 0%, #7d2323 100%);
}

.adp-g-pill-level strong {
  color: #7c5814 !important;
}

.adp-g-pill-xp {
  background: linear-gradient(135deg, #eef4ff 0%, #dce9ff 100%);
  border-color: #adc5ef !important;
}

.adp-g-pill-xp .adp-g-icon {
  background: linear-gradient(145deg, #e8f0ff 0%, #98b8f2 100%);
}

.adp-g-pill-xp .adp-g-icon::before,
.adp-g-pill-xp .adp-g-icon::after {
  background: linear-gradient(180deg, #5a84d6 0%, #305fae 100%);
}

.adp-g-pill-xp strong {
  color: #24467f !important;
}

.adp-g-pill-next {
  background: linear-gradient(135deg, #eaf8f3 0%, #d7efe5 100%);
  border-color: #a7d2c0 !important;
}

.adp-g-pill-next .adp-g-icon {
  background: linear-gradient(145deg, #d4f1e4 0%, #82c5a8 100%);
}

.adp-g-pill-next .adp-g-icon::before,
.adp-g-pill-next .adp-g-icon::after {
  background: linear-gradient(180deg, #2f8c66 0%, #1f6b4c 100%);
}

.adp-g-pill-next strong {
  color: #1f5b43 !important;
}

.adp-g-pill-streak {
  background: linear-gradient(135deg, #fff1e8 0%, #ffd8bf 100%);
  border-color: #efb684 !important;
}

.adp-g-pill-streak .adp-g-icon {
  background: linear-gradient(145deg, #ffd0ae 0%, #ef9358 100%);
}

.adp-g-pill-streak .adp-g-icon::before,
.adp-g-pill-streak .adp-g-icon::after {
  background: linear-gradient(180deg, #a55b2a 0%, #7e3f17 100%);
}

.adp-g-pill-streak strong {
  color: #8a3f18 !important;
}

/* ─── Front page insights (strengths/weaknesses) ─── */
.adp-front-insights {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .6rem;
  margin-top: .65rem;
}
.adp-front-col h5 {
  margin: 0 0 .3rem;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--tmid);
}
.adp-front-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .3rem .5rem;
  margin-bottom: .25rem;
  border-radius: var(--rs);
  font-size: .8rem;
  background: #f7f9f8;
}
.adp-front-row.ok {
  background: #f0faf3;
  color: #1a6b46;
}
.adp-front-row.weak {
  background: #fff7ed;
  color: #7a4a10;
}
.adp-front-row strong {
  font-weight: 600;
}
.adp-front-row span {
  font-size: .74rem;
  opacity: .8;
}

@media (max-width: 520px) {
  .adp-front-insights {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .adp-gamify-cockpit {
    padding: .55rem;
  }

  .adp-g-hero {
    padding: .5rem .55rem .52rem;
  }

  .adp-g-hero-level {
    font-size: .84rem;
  }

  #nl-ad-prof-level-name {
    font-size: .92rem;
  }

  .adp-g-hero-meta {
    font-size: .72rem;
  }

  .adp-gamify-cockpit .adp-g-pill {
    padding: .45rem .52rem;
    gap: .45rem;
  }

  .adp-g-icon {
    width: 1.72rem;
    height: 1.72rem;
    border-radius: 9px;
    font-size: .93rem;
  }

  .adp-gamify-cockpit .adp-g-pill strong {
    font-size: .93rem;
  }
}

.adp-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: .7rem;
}

.adp-field {
  display: flex;
  flex-direction: column;
  gap: .35rem;
}

.adp-field-wide { grid-column: 1 / -1; }

.adp-cat-tools {
  display: flex;
  gap: .5rem;
  margin-top: .45rem;
}

.adp-cat-tool {
  padding: .42rem .78rem;
  font-size: .84rem;
  font-weight: 600;
}

.adp-cat-tool:hover {
  background: var(--bg);
  border-color: var(--mid);
  color: var(--primary);
}

.adp-field label {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--tmuted);
  font-weight: 700;
}

.adp-field select,
.adp-field input {
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .48rem .62rem;
  background: var(--bg);
  color: var(--text);
  font-size: .9rem;
  font-family: inherit;
}

.adp-cats {
  display: grid;
  gap: .55rem;
}

.adp-cat-group {
  border: 1px solid var(--border);
  border-radius: var(--rs);
  background: #fff;
  padding: .45rem .5rem .5rem;
}

.adp-cat-group-title {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--tmuted);
  font-weight: 700;
  margin: 0 0 .35rem;
}

.adp-cat-group-list {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}

.adp-cat {
  padding: .26rem .65rem;
  border: 1.5px solid var(--border);
  border-radius: 999px;
  background: #fff;
  color: var(--tmid);
  font-size: .79rem;
  cursor: pointer;
  transition: all .15s;
}

.adp-cat:hover {
  border-color: var(--mid);
  color: var(--primary);
}

.adp-cat.on {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

.adp-actions {
  margin-top: .75rem;
  display: flex;
  gap: .5rem;
}

.adp-btn {
  border: 1.5px solid var(--border);
  background: #fff;
  color: var(--text);
  border-radius: var(--rs);
  padding: .45rem .8rem;
  font-size: .86rem;
  font-family: inherit;
  font-weight: 600;
  cursor: pointer;
}

.adp-btn-pri {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}
.adp-btn:hover { border-color: var(--mid); color: var(--primary); }
.adp-btn-pri:hover { background: var(--mid); border-color: var(--mid); color: #fff; }

.adp-run-actions {
  margin-top: .65rem;
  display: flex;
  gap: .5rem;
}

#nl-ad-actions {
  display: none;
  justify-content: flex-end;
  flex-wrap: wrap;
}

#nl-ad-actions .adp-win-close {
  margin-right: auto;
}

#nl-ad-win .ex-controls {
  display: none !important;
}

/* Fasit button and fasit-box: always hidden in adaptive mode. */
#nl-ad-win .btn-fasit,
#nl-ad-win .fasit-box {
  display: none !important;
}

/* Question prompt box in adaptive: no bottom gap, flows into instruction */
#nl-ad-win .ibox {
  margin-bottom: 0;
}
#nl-ad-win .ibox > .box {
  border-radius: var(--rs) var(--rs) 0 0;
  border-bottom: none;
  margin-bottom: 0;
  background: #f6f3ef;
  border-color: #d8d2c8;
  font-size: .95rem;
  font-weight: 500;
  color: var(--primary);
  padding: .75rem 1rem;
}

/* Instruction text: visually attached to question box */
#nl-ad-win .inst {
  font-size: .88rem;
  color: #5a554d;
  margin: 0 0 .75rem;
  padding: .35rem 1rem .35rem;
  background: #f0edea;
  border: 1px solid #d8d2c8;
  border-top: none;
  border-radius: 0 0 var(--rs) var(--rs);
  display: block;
  line-height: 1.5;
}

/* Normalize interactive element font sizes inside adaptive window */
#nl-ad-win .mcq-opt   { font-size: .9rem; }
#nl-ad-win .mark-item { font-size: .9rem; padding: .3rem .75rem; }
#nl-ad-win .drag-ord-token,
#nl-ad-win .drag-ord-picked { font-size: .88rem; }
#nl-ad-win .sort-chip  { font-size: .88rem; }
#nl-ad-win .blank-input { font-size: .92rem; }

/* Context box (guide html without .box wrapper) */
#nl-ad-win .ibox > p {
  padding: .5rem .8rem;
  background: #f8f9fa;
  border: 1px solid var(--border);
  border-radius: var(--rs);
  font-size: .9rem;
  color: var(--text);
  margin: 0 0 .6rem;
  line-height: 1.55;
}

/* Hint toggle button in adaptive window */
.adp-hint-toggle {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .35rem .7rem;
  border: 1.5px dashed var(--accent);
  border-radius: var(--rs);
  background: var(--alight);
  color: var(--accent);
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
  margin-bottom: .5rem;
}
.adp-hint-toggle:hover {
  background: #f5e8c8;
  border-color: #a96b1f;
}
.adp-hint-toggle .hint-icon { font-size: .95rem; }

/* Hint content box */
.adp-hint-box {
  display: none;
  border: 1px solid #e8d9b0;
  border-radius: var(--rs);
  background: linear-gradient(135deg, #fffbf0, #fff8e8);
  padding: .65rem .75rem;
  margin-bottom: .6rem;
  font-size: .86rem;
  line-height: 1.55;
  color: var(--text);
  animation: adpHintFade .25s ease;
}
.adp-hint-box.visible { display: block; }
.adp-hint-box strong { color: var(--accent); }

@keyframes adpHintFade {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Rule display in feedback — blue, not green, so it's not confused with "correct" */
.adp-fb-rule {
  margin-top: .5rem;
  padding: .45rem .65rem;
  border-left: 3px solid #4a90d9;
  background: #eef5fc;
  border-radius: 0 var(--rs) var(--rs) 0;
  font-size: .84rem;
  line-height: 1.55;
  color: #1a2e45;
}
.adp-fb-rule strong {
  color: #2563a8;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  display: block;
  margin-bottom: .2rem;
}

/* Fasit (correct answer) display in feedback — green highlight */
.adp-fb-fasit {
  margin-top: .5rem;
  padding: .5rem .7rem;
  border-left: 3px solid #1a7a50;
  background: #edf8f2;
  border-radius: 0 var(--rs) var(--rs) 0;
  font-size: .85rem;
  line-height: 1.55;
  color: #14402a;
}
.adp-fb-fasit strong {
  color: #1a7a50;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  display: block;
  margin-bottom: .2rem;
}

/* Example display in feedback — soft amber */
.adp-fb-eks {
  margin-top: .4rem;
  padding: .4rem .65rem;
  border-left: 3px solid #d4a017;
  background: #fdfaf0;
  border-radius: 0 var(--rs) var(--rs) 0;
  font-size: .83rem;
  line-height: 1.55;
  color: #3d2e00;
}
.adp-fb-eks strong {
  color: #a07800;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  display: block;
  margin-bottom: .15rem;
}

.fb-pedagogy {
  margin: .35rem 0 .25rem;
  font-size: .88rem;
  font-style: italic;
  color: #3a5a4a;
  line-height: 1.45;
}
.wrong-fb .fb-pedagogy {
  color: #5a3a2a;
}

.adp-win {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.adp-win[hidden] {
  display: none !important;
}

.adp-win-bg {
  position: absolute;
  inset: 0;
  background: rgba(10, 16, 24, .55);
}

.adp-win-card {
  position: relative;
  width: min(980px, 96vw);
  max-height: 92vh;
  overflow: auto;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r);
  box-shadow: 0 22px 55px rgba(0, 0, 0, .32);
  padding: 1rem 1.1rem;
}
.adp-win-card::-webkit-scrollbar { width: 6px; }
.adp-win-card::-webkit-scrollbar-track { background: transparent; }
.adp-win-card::-webkit-scrollbar-thumb { background: var(--border); border-radius: 99px; }

.adp-win-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  margin-bottom: .65rem;
}

.adp-win-head h3 {
  margin: 0;
  font-family: 'Playfair Display', serif;
  font-size: 1.08rem;
  color: var(--text);
  line-height: 1.32;
  flex: 1 1 320px;
}

.mt-head-manual-nav-wrap {
  flex-basis: 100%;
  width: 100%;
  margin-top: .42rem;
  padding-top: .28rem;
  border-top: 1px solid #ece7de;
}

.mt-manual-nav-head {
  display: grid;
  gap: .44rem;
  width: 100%;
  margin-top: .08rem;
}

.mt-manual-nav-head label {
  font-size: .74rem;
  font-weight: 700;
  color: var(--tmid);
}

.mt-manual-nav-head .gram-blank {
  width: 100%;
  margin: 0;
  font-size: .84rem;
  padding: .34rem .52rem;
  border: 1.5px solid var(--b2, #ddd);
  border-radius: 8px;
}

.adp-win-close {
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text);
  border-radius: var(--rs);
  padding: .4rem .72rem;
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
}

.adp-win-card.mt-manual-mode .adp-win-close {
  position: static;
  left: auto;
  bottom: auto;
  z-index: auto;
}

.adp-win-body {
  margin-top: .75rem;
}

.adp-win-body .ei {
  outline: none;
  margin: 0;
}

.adp-win-body .etog {
  display: none;
}

.adp-win-body .ec {
  display: block !important;
}

.adp-summary {
  margin-top: .85rem;
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  background: linear-gradient(165deg, #f8fbf9 0%, #f0f7f3 100%);
  padding: 1.1rem 1rem;
}

.adp-summary h4 {
  margin: 0 0 .35rem;
  font-family: 'Playfair Display', serif;
  font-size: 1.18rem;
  color: var(--primary);
  text-align: center;
}

/* Big emoji medal */
.adp-summary-medal {
  text-align: center;
  font-size: 2.8rem;
  line-height: 1;
  margin-bottom: .35rem;
}

/* Percentage ring */
.adp-summary-ring {
  display: flex;
  justify-content: center;
  margin-bottom: .65rem;
}
.adp-summary-ring svg {
  width: 100px;
  height: 100px;
}
.adp-ring-bg { fill: none; stroke: var(--border); stroke-width: 7; }
.adp-ring-fill {
  fill: none;
  stroke: var(--mid);
  stroke-width: 7;
  stroke-linecap: round;
  transform: rotate(-90deg);
  transform-origin: center;
  transition: stroke-dashoffset .8s cubic-bezier(.4,0,.2,1);
}
.adp-ring-text {
  font-family: 'Playfair Display', serif;
  font-size: 1.45rem;
  font-weight: 700;
  fill: var(--primary);
  text-anchor: middle;
  dominant-baseline: central;
}

/* Pedagogisk kommentar */
.adp-summary-comment {
  text-align: center;
  font-size: .95rem;
  color: var(--text);
  line-height: 1.55;
  margin-bottom: .75rem;
  padding: 0 .5rem;
}

.adp-summary-progress-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .6rem;
  align-items: end;
  margin-bottom: .6rem;
}

.adp-summary-progress-wrap,
.adp-summary-streak-wrap {
  border: 1px solid var(--border);
  border-radius: var(--rs);
  background: #fff;
  padding: .5rem .65rem;
}

.adp-summary-progress-bar {
  height: 8px;
  border-radius: 99px;
  background: rgba(115, 85, 30, .16);
  overflow: hidden;
  margin: .28rem 0 .22rem;
}

#nl-ad-sum-progress-fill {
  display: block;
  height: 100%;
  width: 0;
  border-radius: 99px;
  background: linear-gradient(90deg, #2c7a57 0%, #c18b2e 100%);
  transition: width .45s cubic-bezier(.4,0,.2,1);
}

.adp-summary-progress-text {
  display: block;
  font-size: .78rem;
  color: #6a522a;
  font-variant-numeric: tabular-nums;
}

.adp-summary-streak-wrap {
  text-align: center;
  min-width: 122px;
}

.adp-summary-streak-wrap strong {
  display: block;
  margin-top: .18rem;
  font-size: 1.02rem;
  color: #8a3f18;
}

/* ─── SUMMARY: Level progress + Streak boxes (stacked) ─── */
.adp-summary-box {
  border: 1px solid var(--border);
  border-radius: var(--rs);
  background: #fff;
  padding: .7rem .8rem .6rem;
}
.adp-sum-levelbox {
  margin-bottom: .5rem;
}
.adp-sum-lvl-row {
  display: flex;
  align-items: center;
  gap: .4rem;
  margin-bottom: .3rem;
}
.adp-sum-lvl-row .adp-sum-box-icon { font-size: 1.2rem; }
.adp-sum-lvl-name {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--mid);
}
.adp-sum-streakbox { margin-bottom: .8rem; }
.adp-sum-streak-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: .5rem;
  margin-bottom: .45rem;
  flex-wrap: wrap;
}
.adp-sum-streak-header strong {
  font-size: 1.1rem;
}
.adp-sum-streak-record {
  font-size: .78rem;
  color: var(--tmuted);
}
.adp-sum-streak-blocks {
  display: flex;
  gap: 3px;
  flex-wrap: wrap;
}
.adp-sum-block {
  width: 22px; height: 22px;
  border-radius: 4px;
  transition: transform .15s;
}
.adp-sum-block:hover { transform: scale(1.25); }
.adp-sum-block.ok  { background: #2c7a57; }
.adp-sum-block.err { background: #c0392b; }

.adp-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: .5rem;
  margin-bottom: .6rem;
}

.adp-summary-kpi {
  border: 1px solid var(--border);
  border-radius: var(--rs);
  background: #fff;
  padding: .55rem .6rem;
  text-align: center;
}

.adp-summary-lbl {
  display: block;
  font-size: .7rem;
  color: var(--tmuted);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.adp-summary-kpi strong {
  display: block;
  margin-top: .12rem;
  font-size: 1.15rem;
  color: var(--primary);
}
.adp-summary-kpi.kpi-xp strong { color: #7b2fbe; }
.adp-summary-kpi.kpi-ok strong { color: #1d6a45; }
.adp-summary-kpi.kpi-err strong { color: #8b5b1b; }

/* ══════ XP visual effects on correct answer ══════ */

/* Floating "+XP" popup that rises and fades out */
.xp-float {
  position: absolute;
  pointer-events: none;
  font-weight: 800;
  font-size: 1.15rem;
  color: #7b2fbe;
  text-shadow: 0 1px 6px rgba(123,47,190,.35);
  white-space: nowrap;
  z-index: 1600;
  animation: xpFloatUp 2s cubic-bezier(.2,.6,.3,1) forwards;
}
.xp-float.xp-big {
  font-size: 1.5rem;
  color: #c8832a;
  text-shadow: 0 2px 10px rgba(200,131,42,.45);
}
@keyframes xpFloatUp {
  0%   { opacity: 1; transform: translateY(0) scale(1); }
  15%  { opacity: 1; transform: translateY(-10px) scale(1.3); }
  55%  { opacity: 1; transform: translateY(-32px) scale(1.1); }
  100% { opacity: 0; transform: translateY(-70px) scale(.85); }
}

/* Correct-answer flash on the exercise area */
.nl-ad-correct-flash {
  animation: correctFlash 1s ease;
}
@keyframes correctFlash {
  0%   { box-shadow: inset 0 0 0 0 rgba(26,122,80,0); }
  25%  { box-shadow: inset 0 0 40px 6px rgba(26,122,80,.15); }
  60%  { box-shadow: inset 0 0 20px 3px rgba(26,122,80,.08); }
  100% { box-shadow: inset 0 0 0 0 rgba(26,122,80,0); }
}

/* Confetti spark particles */
.xp-spark {
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 1500;
  animation: xpSparkBurst 1.4s cubic-bezier(.2,.8,.3,1) forwards;
}
@keyframes xpSparkBurst {
  0%   { opacity: 1; transform: translate(0,0) scale(1); }
  40%  { opacity: 1; transform: translate(calc(var(--sx) * .6), calc(var(--sy) * .6)) scale(1.1); }
  100% { opacity: 0; transform: translate(var(--sx), var(--sy)) scale(.2); }
}

/* Streak flame icon glow */
.adp-g-pill.streak-glow strong {
  animation: streakGlow 2s ease;
}
@keyframes streakGlow {
  0%   { text-shadow: 0 0 0 transparent; }
  20%  { text-shadow: 0 0 14px rgba(200,131,42,.7), 0 0 28px rgba(200,131,42,.35); }
  60%  { text-shadow: 0 0 8px rgba(200,131,42,.4), 0 0 16px rgba(200,131,42,.2); }
  100% { text-shadow: 0 0 0 transparent; }
}

/* Gamification header pill position context for absolute popups */
.adp-gamify { position: relative; overflow: hidden; }

/* Level-up confetti */
.adp-confetti {
  position: absolute;
  top: -10px;
  font-size: 1.2rem;
  pointer-events: none;
  z-index: 1500;
  animation: confettiFall 2s ease-out forwards;
}
@keyframes confettiFall {
  0%   { opacity: 1; transform: translateY(0) rotate(0deg) scale(1); }
  80%  { opacity: 1; }
  100% { opacity: 0; transform: translateY(180px) rotate(360deg) scale(.4); }
}

/* ─── FULL-SCREEN CONFETTI ON SET COMPLETION ─── */
.nl-confetti-wrap {
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 10001;
  overflow: hidden;
}
.nl-confetti-piece {
  position: absolute;
  top: -20px;
  width: 10px; height: 10px;
  border-radius: 2px;
  pointer-events: none;
  animation: nlConfettiFall var(--dur, 2.5s) cubic-bezier(.25,.46,.45,.94) forwards;
  animation-delay: var(--delay, 0s);
}
@keyframes nlConfettiFall {
  0%   { opacity: 1; transform: translateY(0) rotate(0deg) scale(1); }
  20%  { opacity: 1; transform: translateY(15vh) rotate(120deg) scale(1.1); }
  80%  { opacity: .9; }
  100% { opacity: 0; transform: translateY(105vh) rotate(720deg) scale(.5); }
}
.nl-confetti-bonus {
  position: fixed;
  top: 35%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0);
  font-size: 2rem;
  font-weight: 800;
  color: #c8832a;
  text-shadow: 0 3px 12px rgba(200,131,42,.4);
  pointer-events: none;
  z-index: 10002;
  animation: nlConfettiBonus 2s ease forwards;
}
@keyframes nlConfettiBonus {
  0%   { opacity: 0; transform: translate(-50%, -50%) scale(0); }
  15%  { opacity: 1; transform: translate(-50%, -50%) scale(1.3); }
  30%  { transform: translate(-50%, -50%) scale(1); }
  75%  { opacity: 1; }
  100% { opacity: 0; transform: translate(-50%, -60%) scale(.8); }
}

/* ══════════════════════════════════════════════════════
   MT – Live session card (rendered by v2 engine)
══════════════════════════════════════════════════════ */

.mt-card {
  padding: .25rem 0 0;
}

/* ── Live progress header ── */
.mt-live {
  margin-bottom: .75rem;
}

.mt-live-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  flex-wrap: wrap;
  margin-bottom: .45rem;
}

.mt-live-progress {
  font-size: .82rem;
  font-weight: 600;
  color: var(--primary);
}

.mt-live-kpis {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
}

.mt-live-pill {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .22rem .55rem;
  border-radius: 999px;
  background: var(--bg);
  border: 1px solid var(--border);
  font-size: .73rem;
  font-weight: 500;
  color: var(--tmuted);
  white-space: nowrap;
  transition: transform .2s, box-shadow .2s;
}

.mt-live-pill strong {
  font-size: .82rem;
  font-weight: 700;
  color: var(--primary);
}

/* XP pill special colour */
.mt-live-pill:nth-child(2) strong {
  color: #7b2fbe;
}

/* Streak pill special colour */
.mt-live-pill:nth-child(3) strong {
  color: #c8832a;
}

/* Pill pop animation on value change */
.mt-live-pill.pill-pop {
  animation: pillPop .35s cubic-bezier(.34,1.56,.64,1);
}
@keyframes pillPop {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.18); box-shadow: 0 0 10px rgba(26,61,43,.15); }
  100% { transform: scale(1); }
}

/* ── Progress bar ── */
.mt-live-bar {
  height: 6px;
  border-radius: 99px;
  background: var(--border);
  overflow: hidden;
}

.mt-live-bar span {
  display: block;
  height: 100%;
  width: 0;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--mid) 0%, var(--primary) 100%);
  transition: width .45s cubic-bezier(.4,0,.2,1);
}

/* ── Badges ── */
.mt-badges {
  display: flex;
  gap: .35rem;
  flex-wrap: wrap;
  margin-bottom: .65rem;
}

.mt-badge {
  display: inline-block;
  padding: .18rem .55rem;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .03em;
}

.mt-badge-cat {
  background: var(--plight);
  color: var(--primary);
  border: 1px solid #c5dece;
}

.mt-badge-lett {
  background: #e8f6ee;
  color: #1d6a45;
  border: 1px solid #b8dcc6;
}

.mt-badge-medium {
  background: #fff7e6;
  color: #a07800;
  border: 1px solid #edd9a4;
}

.mt-badge-vanskeleg {
  background: #fceced;
  color: #a83232;
  border: 1px solid #f0c5c5;
}

.mt-badge-retry {
  background: #eef5fc;
  color: #2563a8;
  border: 1px solid #b7cfff;
}

/* ── Rule shown before question ── */
.mt-rule-first {
  margin-bottom: .65rem;
  padding: .55rem .75rem;
  border-left: 3px solid #4a90d9;
  background: linear-gradient(135deg, #eef5fc, #f5f8ff);
  border-radius: 0 var(--rs) var(--rs) 0;
  font-size: .86rem;
  line-height: 1.55;
  color: #1a2e45;
}

.mt-rule-first strong {
  color: #2563a8;
  font-size: .73rem;
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* ── Question ── */
.mt-question {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  line-height: 1.55;
  margin-bottom: .6rem;
}

/* ── Context text (reading passage) ── */
.mt-context-text {
  padding: .65rem .85rem;
  background: #f8f9fa;
  border: 1px solid var(--border);
  border-radius: var(--rs);
  font-size: .9rem;
  color: var(--text);
  line-height: 1.65;
  margin-bottom: .7rem;
}

/* ── Hint ── */
.mt-hint {
  display: flex;
  align-items: flex-start;
  gap: .4rem;
  padding: .45rem .65rem;
  background: linear-gradient(135deg, #fffbf0, #fff8e8);
  border: 1px dashed #e6d198;
  border-radius: var(--rs);
  font-size: .84rem;
  color: #5a4520;
  line-height: 1.5;
  margin-bottom: .65rem;
}

/* ── Feedback area ── */
.mt-feedback {
  display: none;
  margin-top: .85rem;
  padding: .7rem .85rem;
  border-radius: var(--rs);
  font-size: .9rem;
  line-height: 1.55;
  animation: mtFbSlideIn .3s ease;
}

@keyframes mtFbSlideIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.mt-feedback.mt-fb-correct {
  background: linear-gradient(135deg, #edfaf2 0%, #e0f5e8 100%);
  border: 1.5px solid #8ed4a8;
  color: #14402a;
}

.mt-feedback.mt-fb-partial {
  background: linear-gradient(135deg, #fff9eb 0%, #fdf3d7 100%);
  border: 1.5px solid #edd9a4;
  color: #4f3d1d;
}

.mt-feedback.mt-fb-wrong {
  background: linear-gradient(135deg, #fef2f2 0%, #fce8e8 100%);
  border: 1.5px solid #f0b8b8;
  color: #5a1a1a;
}

.mt-fb-heading {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: .35rem;
}

.mt-fb-correct .mt-fb-heading { color: #1a6b46; }
.mt-fb-partial .mt-fb-heading { color: #a07800; }
.mt-fb-wrong .mt-fb-heading   { color: #a83232; }

.mt-fb-detail {
  font-size: .86rem;
  color: inherit;
  opacity: .85;
  margin-bottom: .3rem;
}

.mt-fb-streak {
  display: inline-block;
  margin-top: .3rem;
  padding: .22rem .6rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #fff1d6, #ffe4a8);
  border: 1px solid #f0c840;
  font-size: .82rem;
  font-weight: 700;
  color: #8a5a00;
  animation: mtStreakBounce .5s cubic-bezier(.34,1.56,.64,1);
}

@keyframes mtStreakBounce {
  0%   { transform: scale(.7); opacity: 0; }
  50%  { transform: scale(1.15); }
  100% { transform: scale(1); opacity: 1; }
}

.mt-fb-fasit {
  margin-top: .4rem;
  padding: .45rem .65rem;
  border-left: 3px solid #1a7a50;
  background: #edf8f2;
  border-radius: 0 var(--rs) var(--rs) 0;
  font-size: .85rem;
  color: #14402a;
}

.mt-fb-fasit strong {
  color: #1a7a50;
}

.mt-fb-extra {
  margin-top: .3rem;
  font-size: .86rem;
  color: inherit;
}

.mt-fb-forklaring {
  margin-top: .45rem;
  padding: .45rem .65rem;
  background: rgba(255,255,255,.5);
  border-radius: var(--rs);
  font-size: .86rem;
  color: inherit;
  line-height: 1.55;
}

.mt-fb-rule {
  margin-top: .35rem;
  padding: 0;
  border: none;
  background: transparent;
  border-radius: 0;
  font-size: .84rem;
  line-height: 1.55;
  color: inherit;
}

.mt-fb-rule strong {
  color: inherit;
  font-size: .73rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  opacity: .85;
}

.mt-fb-eks {
  margin-top: .2rem;
  padding: 0;
  border: none;
  background: transparent;
  border-radius: 0;
  font-size: .83rem;
  line-height: 1.55;
  color: inherit;
}

.mt-fb-eks strong {
  color: inherit;
  font-size: .73rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  opacity: .85;
}

.mt-fb-correction {
  margin-top: .45rem;
  padding: .45rem .6rem;
  border-radius: var(--rs);
  background: rgba(255,255,255,.35);
  border: 1px solid rgba(140,115,66,.22);
}

.mt-fb-corr-row {
  margin-top: .24rem;
  font-size: .83rem;
  line-height: 1.55;
}

.mt-fb-corr-row:first-child {
  margin-top: 0;
}

.mt-mark-bad {
  color: #a32020;
  background: rgba(210,61,61,.14);
  border-radius: 4px;
  padding: 0 3px;
}

.mt-mark-ok {
  color: #17653e;
  background: rgba(26,122,80,.14);
  border-radius: 4px;
  padding: 0 3px;
}

.mt-fb-fasit-inline {
  color: #17653e;
  font-weight: 600;
  font-size: .8rem;
}

.mt-fb-retry-tip {
  margin-top: .4rem;
  font-size: .82rem;
  color: #2563a8;
  font-style: italic;
}

.mt-fb-retry-win {
  margin-top: .35rem;
  padding: .3rem .6rem;
  border-radius: var(--rs);
  background: linear-gradient(135deg, #e8f6ee, #d4f0e0);
  border: 1px solid #8ed4a8;
  font-size: .84rem;
  font-weight: 600;
  color: #1a6b46;
  animation: mtStreakBounce .5s cubic-bezier(.34,1.56,.64,1);
}

.mt-fb-xp {
  display: inline-block;
  margin-top: .45rem;
  padding: .2rem .55rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #f0e8ff, #e0d0ff);
  border: 1px solid #c8a8f0;
  font-size: .82rem;
  font-weight: 700;
  color: #7b2fbe;
  animation: mtXpPop .4s cubic-bezier(.34,1.56,.64,1);
}

@keyframes mtXpPop {
  0%   { transform: scale(0); opacity: 0; }
  60%  { transform: scale(1.2); opacity: 1; }
  100% { transform: scale(1); }
}

/* ── Open-type model answer boxes ── */
.mt-fb-models {
  display: grid;
  gap: .4rem;
  margin-top: .45rem;
}

.mt-fb-model {
  padding: .5rem .7rem;
  border-radius: var(--rs);
  font-size: .86rem;
  line-height: 1.55;
}

.mt-fb-model-weak {
  background: #fef7f0;
  border: 1px solid #f0c8a0;
  color: #5a3a1a;
}

.mt-fb-model-good {
  background: #edfaf2;
  border: 1px solid #8ed4a8;
  color: #14402a;
}

.mt-fb-model-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .2rem;
}

.mt-fb-model-weak .mt-fb-model-label { color: #a07800; }
.mt-fb-model-good .mt-fb-model-label { color: #1a6b46; }

/* ══════ Streak fire ring aura (3+) ══════ */
.mt-live-pill.streak-fire {
  animation: streakFireRing 1.5s ease;
}
@keyframes streakFireRing {
  0%   { box-shadow: 0 0 0 0 rgba(200,131,42,0); }
  20%  { box-shadow: 0 0 0 4px rgba(200,131,42,.35), 0 0 12px rgba(200,131,42,.2); }
  60%  { box-shadow: 0 0 0 2px rgba(200,131,42,.15), 0 0 6px rgba(200,131,42,.1); }
  100% { box-shadow: 0 0 0 0 rgba(200,131,42,0); }
}

/* ══════ Level-up celebration ══════ */
.level-up-flash {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
  animation: levelUpFlash 5s ease forwards;
}
.level-up-flash-out { opacity: 0; transition: opacity .6s ease; }
.level-up-flash-inner {
  display: flex; flex-direction: column; align-items: center; gap: .3rem;
  animation: levelUpPop .6s ease .1s both;
}
.level-up-flash-icon { font-size: 3.2rem; }
.level-up-flash-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.6rem; font-weight: 700; color: #7b2fbe;
  text-shadow: 0 2px 8px rgba(123,47,190,.25);
}
.level-up-flash-name {
  font-size: 1.15rem; font-weight: 600; color: #c8832a;
}
@keyframes levelUpFlash {
  0%   { background: rgba(123,47,190,0); }
  8%   { background: rgba(123,47,190,.15); }
  25%  { background: rgba(123,47,190,.08); }
  85%  { background: rgba(123,47,190,.06); }
  100% { background: rgba(123,47,190,0); }
}
@keyframes levelUpPop {
  0%   { transform: scale(0); opacity: 0; }
  50%  { transform: scale(1.15); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}

.adp-summary-msg {
  margin: .7rem 0 .4rem;
  color: var(--text);
}

.adp-summary-row {
  display: grid;
  gap: .2rem;
  margin-bottom: .45rem;
  padding: .5rem .55rem;
  border: 1px solid var(--border);
  border-radius: var(--rs);
  background: #fff;
  font-size: .84rem;
}

.adp-summary-row.ok {
  border-color: #beddc9;
  background: #f2fbf5;
  color: #1a6b46;
}

#nl-ad-sum-strengths .adp-summary-row.ok strong {
  color: #1a6b46;
}

#nl-ad-sum-strengths .adp-summary-row.ok span {
  color: #2e6b4f;
}

#sum-strengths .adp-summary-row.ok strong {
  color: #1a6b46;
}

#sum-strengths .adp-summary-row.ok span {
  color: #2e6b4f;
}

#nl-ad-sum-retting .adp-summary-row {
  border-color: #ecd5a1;
  background: #fff9eb;
}

/* "Null feil" success row in retting section — green/gold, not amber */
#nl-ad-sum-retting .adp-summary-row.ok {
  border-color: #a8d5b8;
  background: linear-gradient(135deg, #f0faf3 0%, #fdf8ec 100%);
  color: #1a6b46;
}

#nl-ad-sum-retting .adp-summary-row.ok strong {
  color: #1a6b46;
}

#nl-ad-sum-retting .adp-summary-row strong {
  color: #5f451b;
}

#nl-ad-sum-retting .adp-summary-row span {
  color: #6b5837;
}

#sum-corrections .adp-summary-row {
  border-color: #ecd5a1;
  background: #fff9eb;
}

#sum-corrections .adp-summary-row strong {
  color: #5f451b;
}

#sum-corrections .adp-summary-row span {
  color: #6b5837;
}

#sum-corrections .adp-summary-row.ok {
  border-color: #beddc9;
  background: #f2fbf5;
  color: #1a6b46;
}

#sum-corrections .adp-summary-row.ok strong {
  color: #1a6b46;
}

#sum-corrections .adp-summary-row.ok span {
  color: #2e6b4f;
}

.adp-summary-rule {
  color: var(--tmid);
}

.adp-summary-corrections h5 {
  margin: .5rem 0 .4rem;
  font-size: .88rem;
  color: var(--primary);
  font-family: 'Playfair Display', serif;
}

.adp-summary-teacher {
  margin-top: .75rem;
  padding: .7rem .75rem;
  border: 2px dashed var(--accent);
  border-radius: var(--rs);
  background: linear-gradient(135deg, #fffbf0 0%, #fff8e8 100%);
  color: #4f3d1d;
  font-size: .86rem;
  text-align: center;
  line-height: 1.55;
}
.adp-summary-teacher .teacher-icon {
  display: block;
  font-size: 1.4rem;
  margin-bottom: .25rem;
}
.adp-summary-teacher strong {
  display: block;
  font-size: .92rem;
  margin-bottom: .2rem;
}

.adp-summary-meta {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-top: .5rem;
  font-size: .74rem;
  color: #6b5430;
}
.adp-summary-meta span {
  padding: .15rem .4rem;
  background: rgba(200,131,42,.1);
  border-radius: 4px;
  font-weight: 600;
}

.adp-summary-actions {
  margin-top: .7rem;
  display: flex;
  gap: .5rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.nl-ad-hidden,
.nl-ad-hidden-card {
  display: none !important;
}

.ei.nl-ad-current {
  outline: 2px solid rgba(26, 61, 43, .28);
  outline-offset: 2px;
}

.ei.nl-ad-done .etog {
  background: #f0edea;
}

/* ─── MAIN / GROUPS ─── */
.main { max-width: 1200px; margin: 0 auto; padding: 2rem; }

.grp { margin-bottom: 3rem; }

.glabel {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1.2rem;
  padding-bottom: .7rem;
  border-bottom: 2px solid var(--border);
}
.gdot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.glabel h2 {
  font-family: 'Playfair Display', serif;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--primary);
}
.gcnt {
  font-size: .78rem;
  color: var(--tmuted);
  background: var(--bg);
  padding: .15rem .55rem;
  border-radius: 20px;
  border: 1px solid var(--border);
}
.gsub {
  grid-column: 1 / -1;
  font-family: 'Playfair Display', serif;
  font-size: .92rem;
  font-weight: 600;
  color: var(--tmuted);
  letter-spacing: .02em;
  margin: .6rem 0 -.4rem;
  padding-bottom: .35rem;
  border-bottom: 1px solid var(--border);
}
.gsub:first-of-type { margin-top: 0; }

@media (min-width: 1200px) {
  .grp-sjanger .grid {
    grid-template-columns: repeat(3, minmax(280px, 1fr));
    grid-auto-flow: row;
    align-items: start;
  }
  .grp-sjanger .grid > .gsub {
    grid-row: 1;
    margin: 0 0 .15rem;
  }
  .grp-sjanger .grid > .gsub:nth-of-type(1),
  .grp-sjanger .grid > .card[data-cat="tekststruktur-delar"],
  .grp-sjanger .grid > .card[data-cat="bindeord-overgangar"],
  .grp-sjanger .grid > .card[data-cat="sjangerkompetanse"] {
    grid-column: 1;
  }
  .grp-sjanger .grid > .gsub:nth-of-type(2),
  .grp-sjanger .grid > .card[data-cat="fagartikkel"],
  .grp-sjanger .grid > .card[data-cat="debattinnlegg"],
  .grp-sjanger .grid > .card[data-cat="overskrift-ingress"] {
    grid-column: 2;
  }
  .grp-sjanger .grid > .gsub:nth-of-type(3),
  .grp-sjanger .grid > .card[data-cat="novelle"] {
    grid-column: 3;
  }

  .grp-sjanger .grid > .card[data-cat="tekststruktur-delar"] { grid-row: 2; }
  .grp-sjanger .grid > .card[data-cat="bindeord-overgangar"] { grid-row: 3; }
  .grp-sjanger .grid > .card[data-cat="sjangerkompetanse"] { grid-row: 4; }

  .grp-sjanger .grid > .card[data-cat="fagartikkel"] { grid-row: 2; }
  .grp-sjanger .grid > .card[data-cat="debattinnlegg"] { grid-row: 3; }
  .grp-sjanger .grid > .card[data-cat="overskrift-ingress"] { grid-row: 4; }

  .grp-sjanger .grid > .card[data-cat="novelle"] { grid-row: 2; }
}

/* ─── CATEGORY CARDS ─── */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 1.2rem; }

.card {
  background: var(--card);
  border: 1.5px solid var(--bcard);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: box-shadow .2s, transform .2s;
}
.card:hover { box-shadow: var(--shadow-hover); transform: translateY(-1px); }

.ch {
  padding: 1.2rem 1.2rem .85rem;
  cursor: pointer;
  display: flex;
  align-items: flex-start;
  gap: .8rem;
  user-select: none;
}
.ci {
  width: 40px;
  height: 40px;
  border-radius: var(--rs);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
  margin-top: .1rem;
  font-weight: 700;
}
.cm { flex: 1; }
.ct {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  margin-bottom: .2rem;
}
.cn {
  font-family: 'Playfair Display', serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--primary);
}
.cbdg { display: flex; gap: .3rem; align-items: center; }
.new {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  background: var(--accent);
  color: #fff;
  padding: .12rem .45rem;
  border-radius: 20px;
}
.exc {
  font-size: .76rem;
  color: var(--tmuted);
  background: var(--bg);
  padding: .12rem .45rem;
  border-radius: 20px;
  border: 1px solid var(--border);
}
.cd { font-size: .86rem; color: var(--tmuted); line-height: 1.5; }

.ctog {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--bg);
  border: 1.5px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all .2s;
  margin-top: .1rem;
}
.card.open .ctog { background: var(--primary); border-color: var(--primary); transform: rotate(180deg); }
.ctog svg { width: 12px; height: 12px; stroke-width: 2.5; stroke: currentColor; }
.card.open .ctog svg { stroke: #fff; }

/* ─── EXERCISES ─── */
.exlist { display: block; border-top: 1.5px solid var(--bcard); }
body.nl-js-collapsible .exlist { display: none; }
body.nl-js-collapsible .card.open .exlist { display: block; }

.ei { border-bottom: 1px solid var(--bcard); }
.ei:last-child { border-bottom: none; }

.etog {
  width: 100%;
  text-align: left;
  padding: .85rem 1.2rem;
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: .7rem;
  font-family: inherit;
  transition: background .15s;
}
.etog:hover, .ei.open .etog { background: var(--bg); }

.etit { flex: 1; font-size: .88rem; font-weight: 600; color: var(--text); text-align: left; }

/* Operasjonsbadges */
.b { font-size: .7rem; font-weight: 600; padding: .15rem .5rem; border-radius: 20px; white-space: nowrap; }
.oi { background: #EBF3FF; color: var(--op-identifisere); }
.ok { background: #FDECEC; color: var(--op-korrigere); }
.oo { background: #F4EDFC; color: var(--op-omskrive); }
.ob { background: #eef2e8; color: var(--op-byggje); }
.oa { background: #FFF0E0; color: var(--op-analysere); }
.or { background: #E3F6F8; color: var(--op-rangere); }
.of { background: #EBF0FA; color: var(--op-fylloppgåve); }
.osu { background: #fce4ec; color: #880e4f; }

/* Vanskegradsbadges */
.dg { background: #e8f2f8; color: #1a567a; }
.dm { background: #FFF0E0; color: #B05A00; }
.da { background: #FDECEC; color: #C0392B; }

.earr { color: var(--tmuted); transition: transform .2s; flex-shrink: 0; }
.ei.open .earr { transform: rotate(90deg); }

/* ─── EXERCISE CONTENT ─── */
.ec {
  display: none;
  padding: 0 1.2rem 1.2rem;
  background: var(--bg);
  border-top: 1px solid var(--bcard);
}
.ei.open .ec { display: block; }

.inst {
  font-size: .86rem;
  color: var(--tmid);
  margin-bottom: .65rem;
  padding-top: .6rem;
  line-height: 1.5;
}
.inst strong {
  color: var(--text);
  font-weight: 600;
}

.subinst {
  font-size: .84rem;
  color: var(--text);
  font-weight: 600;
  margin: .35rem 0 .35rem;
}

.box {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--rs);
  padding: .7rem .85rem;
  font-size: .88rem;
  line-height: 1.6;
  margin-bottom: .65rem;
}
.box-inline {
  margin: .35rem 0 .65rem;
}
.box p + p { margin-top: .5rem; }
.box ul, .box ol { padding-left: 1.2rem; }
.box li { margin-bottom: .25rem; }

.mono { font-family: 'JetBrains Mono', monospace; font-size: .8rem; line-height: 1.75; }

.cols { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; margin-bottom: .85rem; }
.cols > div {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .75rem .9rem;
}
.cols h4 {
  font-size: .76rem;
  font-weight: 700;
  color: var(--tmuted);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .4rem;
}
.cols p, .cols li { font-size: .86rem; }

.blank {
  display: inline-block;
  min-width: 70px;
  border-bottom: 2px solid var(--mid);
  vertical-align: bottom;
}

.mark-area {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin-bottom: .75rem;
}

.mark-item {
  border: 1.5px solid var(--border);
  border-radius: 20px;
  background: #fff;
  color: var(--tmid);
  padding: .28rem .65rem;
  font-size: .82rem;
  cursor: pointer;
  user-select: none;
  transition: all .15s;
}

.mark-item:hover {
  border-color: var(--mid);
  color: var(--primary);
}

.mark-item.sel {
  background: #e8eef8;
  border-color: #5b7aab;
  color: #2b4f85;
}

.mark-item.ok {
  background: rgba(26, 122, 80, .10);
  border-color: #1A7A50;
  color: #1A7A50;
}

.mark-item.err {
  background: rgba(192, 57, 43, .10);
  border-color: #C0392B;
  color: #C0392B;
}

.mark-item.missed {
  background: rgba(176, 90, 0, .10);
  border-color: #B05A00;
  color: #B05A00;
}

/* ─── INLINE MARK (finn_feil: inline flowing text) ─── */
.mark-inline {
  display: block;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .75rem .85rem;
  line-height: 1.9;
  font-size: .95rem;
}
.mark-inline .mark-item {
  display: inline;
  border: none;
  border-radius: 3px;
  background: transparent;
  padding: .08rem .12rem;
  font-size: inherit;
  cursor: pointer;
  transition: background .15s;
}
.mark-inline .mark-item:hover {
  background: rgba(91, 122, 171, .10);
  color: inherit;
  border: none;
}
.mark-inline .mark-item.sel {
  background: rgba(91, 122, 171, .14);
  border-bottom: 2px solid #5b7aab;
  color: #2b4f85;
}
.mark-inline .mark-item.ok {
  background: rgba(26, 122, 80, .12);
  border-bottom: 2px solid #1A7A50;
  color: #1A7A50;
}
.mark-inline .mark-item.err {
  background: rgba(192, 57, 43, .12);
  border-bottom: 2px solid #C0392B;
  color: #C0392B;
}
.mark-inline .mark-item.missed {
  background: rgba(176, 90, 0, .12);
  border-bottom: 2px solid #B05A00;
  color: #B05A00;
}

hr.sep { border: none; border-top: 1px solid var(--border); margin: .7rem 0; }

/* ─── INPUTS / CHECK CONTROLS ─── */
.ibox {
  margin-bottom: .6rem;
}

.ibox > .box,
.ibox > .cols {
  margin-bottom: 0;
}

.write-area,
.fix-area {
  width: 100%;
  min-height: 120px;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .75rem .85rem;
  background: #fff;
  color: var(--text);
  font: inherit;
  line-height: 1.6;
  outline: none;
}

.multi-inputs {
  display: grid;
  gap: .65rem;
  margin-bottom: .65rem;
}

.multi-input-row {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .55rem .6rem .6rem;
}

.multi-input-label {
  display: block;
  font-size: .76rem;
  font-weight: 700;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: .3rem;
}

.multi-write-area {
  min-height: 84px;
  margin: 0;
}

.write-area:focus,
.fix-area:focus {
  border-color: var(--mid);
  box-shadow: 0 0 0 3px rgba(46, 107, 79, .12);
}

.fix-mark-ok {
  background: rgba(26, 122, 80, .16);
  color: #155f3e;
  border-bottom: 2px solid rgba(26, 122, 80, .55);
  border-radius: 3px;
  padding: 0 .06rem;
}

.fix-mark-err {
  background: rgba(192, 57, 43, .14);
  color: #8a2319;
  border-bottom: 2px solid rgba(192, 57, 43, .55);
  border-radius: 3px;
  padding: 0 .06rem;
}

.fill-text {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .75rem .85rem;
}

.blank-input {
  min-width: 3.8rem;
  border: none;
  border-bottom: 2px solid var(--mid);
  background: transparent;
  font: inherit;
  font-weight: 600;
  color: var(--primary);
  padding: .05rem .2rem;
  outline: none;
}

.blank-input.inp-ok {
  border-bottom-color: #1A7A50;
  background: rgba(26, 122, 80, .08);
}

.blank-input.inp-err {
  border-bottom-color: #C0392B;
  background: rgba(192, 57, 43, .08);
}

/* ─── Inline select fill (fillsel) ─── */
.fillsel-sentence {
  font-size: .88rem;
  line-height: 1.85;
  color: var(--tdark);
  margin-bottom: .35rem;
}
.fillsel-sentence:last-child { margin-bottom: 0; }
.fill-select {
  font: inherit;
  font-size: .84rem;
  font-weight: 600;
  color: var(--primary);
  background: #fff;
  border: 1.5px solid var(--mid);
  border-radius: 6px;
  padding: .18rem .45rem .18rem .3rem;
  cursor: pointer;
  transition: border-color .2s, background .2s, box-shadow .2s;
  vertical-align: baseline;
  outline: none;
}
.fill-select:focus { border-color: var(--primary); box-shadow: 0 0 0 2px rgba(26,61,46,.12); }
.fill-select:hover { border-color: var(--primary); }
.fill-select.sel-ok {
  border-color: #1A7A50;
  background: rgba(26, 122, 80, .10);
  color: #1A7A50;
}
.fill-select.sel-err {
  border-color: #C0392B;
  background: rgba(192, 57, 43, .10);
  color: #C0392B;
}

.mcq-area {
  display: grid;
  gap: .45rem;
  margin-bottom: .65rem;
}

.mcq-opt {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .5rem .65rem;
  font-size: .84rem;
  color: var(--tmid);
  cursor: pointer;
  transition: all .15s;
}

.mcq-opt:hover {
  border-color: var(--mid);
}

.mcq-opt.ok {
  border-color: #1A7A50;
  background: rgba(26, 122, 80, .08);
  color: #1A7A50;
}

.mcq-opt.err {
  border-color: #C0392B;
  background: rgba(192, 57, 43, .08);
  color: #C0392B;
}

.drag-ord-area {
  display: grid;
  gap: .5rem;
  margin-bottom: .65rem;
}

.drag-ord-bank,
.drag-ord-answer {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .5rem .55rem;
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  min-height: 2.8rem;
}

.drag-ord-answer {
  background: var(--bg);
  border-style: dashed;
}

.drag-ord-token,
.drag-ord-picked {
  border: 1.5px solid rgba(26, 61, 43, .22);
  border-radius: 20px;
  background: var(--plight);
  color: var(--primary);
  font-size: .82rem;
  font-weight: 600;
  padding: .24rem .62rem;
  cursor: pointer;
  touch-action: none;
  user-select: none;
  transition: all .15s;
}

.drag-ord-bank.drag-over,
.drag-ord-answer.drag-over {
  border-color: var(--mid);
  background: var(--plight);
}

.drag-ord-token.dragging,
.drag-ord-picked.dragging {
  opacity: .35;
}

.drag-ord-token:hover,
.drag-ord-picked:hover {
  border-color: var(--mid);
  transform: translateY(-1px);
}

.drag-ord-picked.ok {
  border-color: #1A7A50;
  background: rgba(26, 122, 80, .10);
  color: #1A7A50;
}

.drag-ord-picked.err {
  border-color: #C0392B;
  background: rgba(192, 57, 43, .10);
  color: #C0392B;
}

.word-count {
  font-size: .78rem;
  color: var(--tmuted);
  margin-top: .4rem;
}

.word-count.warn {
  color: #8b5b1b;
  font-weight: 700;
}

.word-count.limit {
  color: #b33624;
  font-weight: 800;
}

.ex-controls {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .7rem;
}

.ex-controls button,
.btn-check,
.btn-reset,
.btn-fasit {
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  background: #fff;
  color: var(--tmid);
  font-family: inherit;
  font-size: .8rem;
  font-weight: 600;
  padding: .36rem .8rem;
  cursor: pointer;
  transition: all .18s;
}

.btn-check {
  background: #EBF3FF;
  border-color: #BFD8F7;
  color: #1D6FD1;
}

.btn-reset {
  background: #fff;
  color: var(--tmuted);
}

.btn-fasit {
  background: var(--plight);
  border-color: #BFD8CC;
  color: var(--primary);
}

.ex-controls button:hover,
.btn-check:hover,
.btn-reset:hover,
.btn-fasit:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}

.ex-score {
  font-size: .78rem;
  font-weight: 600;
  color: var(--tmuted);
  background: #fff;
  border: 1px dashed var(--border);
  border-radius: 20px;
  padding: .18rem .6rem;
}

.ex-score.ok {
  color: #1A7A50;
  border-color: rgba(26, 122, 80, .35);
  background: rgba(26, 122, 80, .08);
}

.ex-score.err {
  color: #C0392B;
  border-color: rgba(192, 57, 43, .35);
  background: rgba(192, 57, 43, .08);
}

/* ─── FASIT ─── */
.ftog {
  background: none;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .35rem .8rem;
  font-family: inherit;
  font-size: .8rem;
  font-weight: 600;
  color: var(--tmuted);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: .35rem;
  transition: all .2s;
  margin-top: .2rem;
}
.ftog:hover { border-color: var(--mid); color: var(--primary); }
.ftog.shown { background: var(--plight); border-color: var(--mid); color: var(--primary); }

.fb {
  display: none;
  margin-top: .7rem;
  padding: .85rem .95rem;
  background: var(--plight);
  border: 1.5px solid rgba(26,61,43,.15);
  border-radius: var(--rs);
  font-size: .86rem;
  line-height: 1.7;
}
.fb.shown { display: block; }
.fb .fl {
  font-weight: 700;
  color: var(--primary);
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: .5rem;
}
.fb .fb-ans {
  margin: 0 0 .6rem;
  font-weight: 500;
  color: var(--text);
}
.fb .fr {
  margin-top: .5rem;
  padding: .35rem .6rem;
  border-radius: var(--rs);
  font-size: .82rem;
  line-height: 1.55;
}
.fb .fr:first-of-type { border-top: 1px solid rgba(26,61,43,.12); margin-top: .6rem; padding-top: .55rem; }
.fb .fr strong {
  font-size: .74rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  display: inline-block;
  margin-right: .3rem;
}
/* Regel: blue accent in non-adaptive fasit box */
.fb .fr:has(strong:first-child) {
  color: #1a2e45;
}
.fb p + p { margin-top: .35rem; }

.ok2  { color: #1A7A50; font-weight: 600; }
.note { font-size: .8rem; color: var(--tmuted); font-style: italic; margin-top: .4rem; }

/* ─── RANK EXERCISE ─── */
.rank-list {
  display: flex;
  flex-direction: column;
  gap: .4rem;
  margin-bottom: .75rem;
}
.rank-item {
  display: flex;
  align-items: center;
  gap: .6rem;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .5rem .7rem;
  cursor: grab;
  touch-action: none;
  user-select: none;
  font-size: .86rem;
  transition: all .15s;
}
.rank-item:hover { border-color: var(--mid); }
.rank-item.dragging { opacity: .4; cursor: grabbing; }
.rank-item.drag-over { border-color: var(--mid); background: var(--plight); }
.rank-grip { color: var(--tmuted); flex-shrink: 0; }
.rank-num {
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 50%;
  background: var(--bg);
  border: 1px solid var(--border);
  font-size: .72rem;
  font-weight: 700;
  color: var(--tmuted);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.rank-item.rank-ok { border-color: #1A7A50; background: rgba(26,122,80,.07); }
.rank-item.rank-ok .rank-num { background: #1A7A50; border-color: #1A7A50; color: #fff; }
.rank-item.rank-err { border-color: #C0392B; background: rgba(192,57,43,.07); }
.rank-item.rank-err .rank-num { background: #C0392B; border-color: #C0392B; color: #fff; }

/* ─── SORT EXERCISE (drag-to-bucket) ─── */
.sort-bank {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .55rem .7rem .7rem;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: .4rem;
  margin-bottom: .75rem;
  min-height: 2.8rem;
}
.sort-bank-label {
  width: 100%;
  font-size: .72rem;
  font-weight: 700;
  color: var(--tmuted);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .15rem;
}
.sort-chip {
  display: inline-block;
  background: var(--plight);
  border: 1.5px solid rgba(26,61,43,.2);
  border-radius: 20px;
  padding: .25rem .65rem;
  font-size: .82rem;
  font-weight: 600;
  color: var(--primary);
  cursor: grab;
  touch-action: none;
  user-select: none;
  transition: all .15s;
}
.sort-chip:hover { border-color: var(--mid); background: #d4ebe0; }
.sort-chip.dragging { opacity: .35; cursor: grabbing; }
.sort-chip.picked {
  background: #ebf3ff;
  border-color: #1D6FD1;
  color: #1D6FD1;
  box-shadow: 0 0 0 2px rgba(29,111,209,.18);
}
.sort-chip.chip-ok { background: rgba(26,122,80,.10); border-color: #1A7A50; color: #1A7A50; }
.sort-chip.chip-err { background: rgba(192,57,43,.10); border-color: #C0392B; color: #C0392B; }
.sort-buckets {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .6rem;
  margin-bottom: .75rem;
}
.sort-bucket-label {
  font-size: .74rem;
  font-weight: 700;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .3rem;
  cursor: pointer;
}
.sort-bucket-drop {
  min-height: 5.2rem;
  background: var(--bg);
  border: 2px dashed var(--border);
  border-radius: var(--rs);
  padding: .55rem .55rem .9rem;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
  gap: .35rem;
  transition: all .15s;
  touch-action: none;
}
.sort-bucket-drop.drag-over { border-color: var(--mid); background: var(--plight); }

/* ─── BURGER SORT (advanced column sorting) ─── */
.burger-bank {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .6rem .75rem .75rem;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: .45rem;
  margin-bottom: .8rem;
  min-height: 3rem;
}
.burger-bank-label {
  width: 100%;
  font-size: .72rem;
  font-weight: 700;
  color: var(--tmuted);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .15rem;
}
.burger-chip {
  display: inline-block;
  background: #fff6ea;
  border: 1.5px solid rgba(176,90,0,.3);
  border-radius: 16px;
  padding: .28rem .65rem;
  font-size: .8rem;
  font-weight: 600;
  color: #7f4300;
  cursor: grab;
  touch-action: none;
  user-select: none;
  transition: all .15s;
}
.burger-chip:hover {
  border-color: #b05a00;
  background: #ffedd5;
}
.burger-chip.dragging { opacity: .35; cursor: grabbing; }
.burger-chip.picked {
  border-color: #1D6FD1;
  background: #ebf3ff;
  color: #1D6FD1;
  box-shadow: 0 0 0 2px rgba(29,111,209,.18);
}
.burger-chip.burger-ok {
  background: rgba(26,122,80,.10);
  border-color: #1A7A50;
  color: #1A7A50;
}
.burger-chip.burger-err {
  background: rgba(192,57,43,.10);
  border-color: #C0392B;
  color: #C0392B;
}
.burger-buckets {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .65rem;
}
.burger-bucket {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .45rem;
}
.burger-bucket-label {
  font-size: .73rem;
  font-weight: 800;
  color: #7f4300;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: .35rem;
  cursor: pointer;
}
.burger-bucket-drop {
  min-height: 8rem;
  background: #fff8ef;
  border: 2px dashed #f3cfaa;
  border-radius: calc(var(--rs) - 2px);
  padding: .6rem .55rem 1rem;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
  gap: .35rem;
  transition: all .15s;
  touch-action: none;
}
.burger-bucket-drop.drag-over {
  border-color: #b05a00;
  background: #ffedd5;
}

/* ─── WELCOME / MOTIVATIONAL MODAL ─── */
.nl-welcome-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 10000;
  display: flex; align-items: center; justify-content: center;
  animation: nlWelcFadeIn .3s ease;
}
.nl-welcome-overlay[hidden] { display: none !important; }
@keyframes nlWelcFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes nlWelcPop { from { transform: scale(.85) translateY(25px); opacity: 0; } to { transform: scale(1) translateY(0); opacity: 1; } }
.nl-welcome-card {
  background: #fff;
  border-radius: 1.2rem;
  padding: 2rem 2.2rem 1.6rem;
  max-width: 420px;
  width: 92vw;
  text-align: center;
  box-shadow: 0 16px 48px rgba(0,0,0,.25);
  animation: nlWelcPop .4s ease .1s both;
}
.nl-welcome-emoji { font-size: 3rem; margin-bottom: .4rem; }
.nl-welcome-title { font-family: 'Playfair Display', serif; color: var(--primary); font-size: 1.5rem; margin: 0 0 .5rem; }
.nl-welcome-msg { color: var(--tmuted); font-size: .92rem; line-height: 1.55; margin: 0 0 1rem; }
.nl-welcome-stats {
  display: flex; justify-content: center; gap: 1rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
.nl-welcome-stat {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: .6rem;
  padding: .4rem .7rem;
  font-size: .82rem;
  color: var(--primary);
  display: flex; align-items: center; gap: .3rem;
}
.nl-ws-icon { font-size: 1.05rem; }
.nl-welcome-tips {
  background: #fffbe6;
  border: 1px solid #f5e6a3;
  border-radius: .6rem;
  padding: .7rem 1rem;
  margin-bottom: 1rem;
  text-align: left;
}
.nl-welcome-tips h4 { margin: 0 0 .35rem; font-size: .82rem; color: #7f6600; }
.nl-welcome-tips ul { margin: 0; padding-left: 1.2rem; list-style: disc; }
.nl-welcome-tips li { font-size: .82rem; color: #665200; line-height: 1.5; }
.nl-welcome-btn {
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: .7rem;
  padding: .65rem 2rem;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
}
.nl-welcome-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(26,61,43,.25);
}

/* ─── WELCOME MODAL — LEVEL SHOWCASE BOX ─── */
.nl-welcome-level-box {
  display: flex;
  align-items: center;
  gap: .9rem;
  background: linear-gradient(135deg, #f0faf5 0%, #fff8ec 100%);
  border: 1.5px solid var(--border);
  border-radius: .85rem;
  padding: .8rem 1rem;
  margin-bottom: 1rem;
}
.nl-wlvl-icon { font-size: 2.6rem; line-height: 1; }
.nl-wlvl-info { flex: 1; text-align: left; }
.nl-wlvl-name {
  font-family: 'Playfair Display', serif;
  font-weight: 800;
  font-size: 1.15rem;
  color: var(--primary);
  margin-bottom: .25rem;
}
.nl-wlvl-bar {
  height: 8px;
  border-radius: 99px;
  background: rgba(115,85,30,.14);
  overflow: hidden;
  margin-bottom: .2rem;
}
.nl-wlvl-fill {
  display: block;
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(90deg, #2c7a57, #c18b2e);
  transition: width .6s cubic-bezier(.4,0,.2,1);
}
.nl-wlvl-xp {
  font-size: .76rem;
  color: var(--tmuted);
  font-variant-numeric: tabular-nums;
}

/* ─── LEVEL-UP MODAL + FIREWORKS ─── */
.nl-levelup-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.6);
  z-index: 10001;
  display: flex; align-items: center; justify-content: center;
  animation: nlWelcFadeIn .3s ease;
  transition: opacity .5s ease;
}
.nl-levelup-overlay[hidden] { display: none !important; }
.nl-levelup-overlay.nl-lvl-fadeout { opacity: 0; }
.nl-levelup-card {
  position: relative;
  background: #fff;
  border-radius: 1.2rem;
  padding: 2.2rem 2.2rem 1.8rem;
  max-width: 380px;
  width: 88vw;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
  animation: nlWelcPop .45s ease .1s both;
  overflow: hidden;
}
.nl-levelup-fireworks {
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: flex; align-items: center; justify-content: center;
}
.nl-fw-spark {
  position: absolute;
  width: 7px; height: 7px;
  border-radius: 50%;
  animation: nlFwBurst 1.5s ease var(--fw-delay, 0s) both;
}
@keyframes nlFwBurst {
  0%   { transform: translate(0,0) scale(1); opacity: 1; }
  100% { transform: translate(
           calc(cos(var(--fw-angle)) * var(--fw-dist)),
           calc(sin(var(--fw-angle)) * var(--fw-dist))
         ) scale(0); opacity: 0; }
}
.nl-levelup-icon { font-size: 3.5rem; margin-bottom: .3rem; position: relative; z-index: 1;
  animation: nlLvlBounce .6s ease .3s both; }
@keyframes nlLvlBounce {
  0%   { transform: scale(0); }
  60%  { transform: scale(1.25); }
  100% { transform: scale(1); }
}
.nl-levelup-title {
  font-family: 'Playfair Display', serif;
  color: var(--primary);
  font-size: 1.6rem;
  margin: 0 0 .2rem;
  position: relative; z-index: 1;
}
.nl-levelup-name {
  font-size: 1.3rem;
  font-weight: 800;
  color: #c8832a;
  margin-bottom: .5rem;
  position: relative; z-index: 1;
}
.nl-levelup-msg {
  font-size: .88rem;
  color: var(--tmuted);
  line-height: 1.5;
  margin: 0 0 1.1rem;
  position: relative; z-index: 1;
}

.touch-drag-ghost {
  z-index: 9999;
  opacity: .94;
  box-shadow: 0 8px 18px rgba(0,0,0,.22);
}

/* ─── TABELL (nynorsklab) ─── */
.table-wrap { overflow-x: auto; margin-bottom: .85rem; }
table { width: 100%; border-collapse: collapse; font-size: .86rem; }
th, td { padding: .5rem .75rem; border: 1px solid var(--border); text-align: left; }
th { background: var(--primary); color: #fff; font-weight: 600; }
tr:nth-child(even) td { background: var(--bg); }

/* ─── LEIKEKASSA PAGES ─── */
.play-main {
  max-width: 980px;
  margin: 0 auto;
  padding: 2rem;
}

.play-intro {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  padding: 1.2rem 1.2rem 1.35rem;
  margin-bottom: 1.2rem;
}

.play-intro h2 {
  font-family: 'Playfair Display', serif;
  color: var(--primary);
  font-size: 1.5rem;
  margin-bottom: .45rem;
}

.play-intro p {
  color: var(--tmid);
  font-size: .95rem;
  line-height: 1.7;
}

.ml-shell,
.vr-shell {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  padding: 1.1rem;
}

.ml-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .75rem;
}

.ml-field {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  font-size: .86rem;
  color: var(--tmid);
  font-weight: 600;
}

.ml-field input,
.ml-toolbar select {
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .5rem .6rem;
  background: var(--bg);
  color: var(--text);
  font-family: inherit;
  font-size: .9rem;
  outline: none;
}

.ml-field input:focus,
.ml-toolbar select:focus {
  border-color: var(--mid);
}

.ml-toolbar {
  display: flex;
  gap: .75rem;
  align-items: flex-end;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.ml-toolbar label {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  font-size: .8rem;
  color: var(--tmid);
  font-weight: 700;
  letter-spacing: .02em;
}

.ml-actions,
.vr-actions {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  margin-top: 1rem;
}

.btn-main,
.btn-alt {
  border-radius: 999px;
  padding: .52rem 1rem;
  font-family: inherit;
  font-size: .88rem;
  font-weight: 700;
  cursor: pointer;
}

.btn-main {
  border: none;
  background: var(--primary);
  color: #fff;
}

.btn-main:hover {
  background: var(--mid);
}

.btn-alt {
  border: 1.5px solid var(--border);
  background: transparent;
  color: var(--tmid);
}

.btn-alt:hover {
  border-color: var(--mid);
  color: var(--primary);
}

.ml-output {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: var(--rs);
  background: #f4f7ff;
  border: 1px solid #d6e0f6;
  color: #1f2a45;
  line-height: 1.8;
}

.ml-output strong {
  color: #1d4ed8;
  text-decoration: underline;
  text-decoration-style: dotted;
}

.vr-stepbar {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin-bottom: 1rem;
}

.vr-step-chip {
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--tmid);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: .25rem .6rem;
}

.vr-step-chip.active {
  color: #fff;
  background: #be185d;
  border-color: #be185d;
}

.vr-student {
  font-family: 'JetBrains Mono', monospace;
  font-size: .85rem;
  line-height: 1.9;
  color: #2f3137;
  background: #faf8ff;
  border: 1px solid #e7e2f5;
  border-radius: var(--rs);
  padding: .85rem .9rem;
}

.vr-rubric {
  display: grid;
  grid-template-columns: repeat(2, minmax(160px, 1fr));
  gap: .55rem;
  margin-top: .9rem;
}

.vr-rubric label {
  display: flex;
  flex-direction: column;
  gap: .25rem;
  font-size: .8rem;
  color: var(--tmid);
  font-weight: 700;
}

.vr-rubric select,
.vr-grade select {
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  padding: .45rem .55rem;
  font-size: .86rem;
  background: #fff;
  color: var(--text);
  font-family: inherit;
  outline: none;
}

.vr-grade {
  margin-top: .8rem;
  max-width: 200px;
}

.vr-summary {
  margin-top: 1rem;
  padding: .9rem;
  border-radius: var(--rs);
  border: 1px solid #f4bfd4;
  background: #fff3f8;
  color: #831843;
  font-size: .9rem;
}

/* ─── NYNORSKLAB ADAPTIVE (V1 IMPORT) ─── */
#grammatikk {
  padding: 2rem;
}

.gram-inner {
  max-width: 980px;
  margin: 0 auto;
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  padding: 1.25rem;
}

.gram-heading {
  font-family: 'Playfair Display', serif;
  font-size: 1.9rem;
  line-height: 1.2;
  color: var(--primary);
  margin-bottom: .4rem;
}

.gram-sub {
  color: var(--tmid);
  font-size: .95rem;
  margin-bottom: 1rem;
}

.gram-config {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: .7rem;
}

.gram-config label {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--tmuted);
  font-weight: 700;
}

.gram-config select,
.gram-config input {
  border: 1.5px solid var(--border);
  border-radius: var(--rs);
  background: var(--bg);
  color: var(--text);
  font-family: inherit;
  font-size: .9rem;
  padding: .48rem .55rem;
  outline: none;
}

.gram-config select:focus,
.gram-config input:focus {
  border-color: var(--mid);
}

.gram-start-btn {
  margin-top: .95rem;
  border: none;
  border-radius: 999px;
  background: var(--primary);
  color: #fff;
  font-family: inherit;
  font-size: .9rem;
  font-weight: 700;
  padding: .6rem 1rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.gram-start-btn:hover {
  background: var(--mid);
}

.gram-top-actions {
  margin-top: .95rem;
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
}

.gram-top-actions .gram-start-btn {
  margin-top: 0;
}

#gram-quiz-area {
  margin-top: 1.1rem;
}

.gram-progress-wrap {
  display: flex;
  align-items: center;
  gap: .55rem;
  margin-bottom: .8rem;
}

.gram-progress-bar {
  flex: 1;
  background: var(--bg);
  border-radius: 99px;
  height: 8px;
  overflow: hidden;
}

.gram-progress-fill {
  height: 100%;
  background: var(--primary);
  transition: width .25s ease;
}

.gram-progress-label {
  font-size: .75rem;
  color: var(--tmuted);
  min-width: 48px;
  text-align: right;
}

.gram-score-badge {
  display: inline-flex;
  margin-bottom: .7rem;
  background: var(--alight);
  color: #7b4300;
  border-radius: 999px;
  font-size: .78rem;
  padding: .2rem .65rem;
  font-weight: 700;
}

.gram-task-card {
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  background: #fff;
  padding: .95rem;
}

.gram-task-meta {
  display: flex;
  gap: .4rem;
  margin-bottom: .55rem;
}

.gram-badge {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  border: 1px solid var(--border);
  border-radius: 99px;
  padding: .15rem .5rem;
  color: var(--tmid);
}

.gram-task-q {
  font-size: .96rem;
  color: var(--text);
  line-height: 1.7;
  margin-bottom: .7rem;
}

.gram-task-instr {
  font-size: .92rem;
  color: var(--tmuted);
  margin-bottom: .35rem;
  line-height: 1.55;
}

#nl-ad-win .inst,
#nl-ad-win .subinst {
  font-size: .92rem;
  line-height: 1.55;
}

.gram-blank {
  min-width: 130px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: .22rem .45rem;
  font-family: inherit;
  font-size: .9rem;
  background: var(--bg);
  margin: 0 .25rem;
}

.gram-choices {
  display: grid;
  gap: .45rem;
}

.gram-choice-btn {
  text-align: left;
  border: 1.5px solid var(--border);
  background: #fff;
  border-radius: 8px;
  padding: .5rem .65rem;
  font-family: inherit;
  font-size: .9rem;
  cursor: pointer;
}

.gram-choice-btn:hover {
  border-color: var(--mid);
}

.gram-choice-btn.correct,
.gram-blank.correct {
  border-color: #1a7a50;
  background: rgba(26,122,80,.1);
}

.gram-choice-btn.wrong,
.gram-blank.wrong {
  border-color: #c0392b;
  background: rgba(192,57,43,.1);
}

.gram-feedback {
  margin-top: .75rem;
  border-radius: 8px;
  padding: .6rem .7rem;
  font-size: .87rem;
  line-height: 1.6;
  display: none;
}

.gram-feedback.show {
  display: block;
}

.gram-feedback.correct-fb {
  background: rgba(26,122,80,.1);
  border: 1px solid rgba(26,122,80,.35);
  color: #1a5c42;
}

.gram-feedback.wrong-fb {
  background: rgba(192,57,43,.1);
  border: 1px solid rgba(192,57,43,.35);
  color: #8a2b21;
}

/* ── Nye oppgåvetypar (finn_feil, sann_usann, sorter_rekke, fillsel) ── */
.ff-word.active { background: #ffe082; border-color: #f9a825; }
.ff-word.correct { background: rgba(26,122,80,.15); border-color: #1a7a50; }
.ff-word.wrong { background: rgba(192,57,43,.15); border-color: #c0392b; }
.su-btn.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.sr-token { transition: transform .15s, border-color .2s, background .2s; }
.sr-token:hover { transform: translateX(4px); }

.fb-heading {
  font-weight: 700;
  margin-bottom: .3rem;
}

.gram-actions {
  display: flex;
  gap: .55rem;
  margin-top: .8rem;
}

.gram-btn {
  border-radius: 999px;
  border: 1.5px solid var(--border);
  background: #fff;
  color: var(--tmid);
  padding: .5rem .9rem;
  font-family: inherit;
  font-size: .85rem;
  font-weight: 700;
  cursor: pointer;
}

.gram-btn.primary {
  border: none;
  background: var(--primary);
  color: #fff;
}

.gram-summary {
  display: none;
  margin-top: .9rem;
}

.gram-summary.show {
  display: block;
}

.gram-summary.adp-summary .adp-summary-actions {
  justify-content: flex-end;
}

/* ─── FOOTER ─── */
footer {
  background: var(--primary);
  color: rgba(255,255,255,.5);
  text-align: center;
  padding: 2rem;
  font-size: .85rem;
  margin-top: 4rem;
}
footer strong { color: rgba(255,255,255,.8); }

/* ─── UTILITIES ─── */
.hidden { display: none !important; }

/* Better touch drag behavior on mobile/iPad for drag-based tasks */
.mt-dk-token,
.mt-bs-token,
.mt-sr-token,
.mt-do-token,
.drag-ord-token,
.drag-ord-picked,
.sort-chip,
.burger-chip,
.rank-item {
  touch-action: none;
  -webkit-user-select: none;
  user-select: none;
}

/* ─── RESPONSIVE ─── */
@media (max-width: 768px) {
  .adp { padding: 0 1.25rem; }
  .adp-grid { grid-template-columns: 1fr; }
  .adp-summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .adp-actions,
  .adp-run-actions { flex-wrap: wrap; }
  .adp-summary-actions { justify-content: stretch; }
  .adp-summary-actions .adp-btn { flex: 1 1 auto; }
  .adp-win-card { width: min(100%, 620px); max-height: 94vh; padding: .7rem; }
  .adp-win-head { align-items: flex-start; gap: .68rem; }
  .adp-win-close { padding: .36rem .62rem; font-size: .78rem; }
  .adp-win-card.mt-manual-mode .adp-win-close { left: auto; bottom: auto; }
  .mt-head-manual-nav-wrap { margin-top: .5rem; padding-top: .34rem; }
  .mt-manual-nav-head { gap: .5rem; }
  .mt-manual-nav-head .gram-blank { font-size: .82rem; }
  header {
    padding: .65rem 1.25rem;
    height: auto;
    min-height: 60px;
    align-items: center;
    flex-wrap: wrap;
    row-gap: .45rem;
  }
  .hero { padding: 2rem 1.25rem; }
  .hero h1 { font-size: 1.9rem; }
  .hero::before { font-size: 4rem; }
  .hero-index h1 { font-size: 2.5rem; }
  .hero-index::before { font-size: 5rem; }
  .hero-stats { gap: 1.2rem; }
  .skrivelab-hero-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .skrivelab-hero-btn {
    justify-content: center;
  }
  .skrivelab-landing {
    margin-top: -.6rem;
    padding: 0 1.25rem;
  }
  .skrivelab-landing-shell {
    padding: 1rem;
  }
  .skrivelab-landing-head,
  .skrivelab-landing-grid {
    grid-template-columns: 1fr;
  }
  .skrivelab-landing-head h2 {
    font-size: 1.6rem;
  }
  .skrivelab-bank-intro {
    padding: 0 1.25rem;
  }
  .skrivelab-bank-intro-inner {
    flex-direction: column;
    align-items: flex-start;
  }
  .skrivelab-bank-intro-inner .adp-btn {
    width: 100%;
    justify-content: center;
  }
  .fbar { padding: .85rem 1.25rem; }
  .main { padding: 1.25rem; }
  .grid { grid-template-columns: 1fr; }
  .cols { grid-template-columns: 1fr; }
  .lab-cards { padding: 2rem 1.25rem; }
  .index-ob-note {
    padding: 0 1.25rem;
    margin-bottom: 1rem;
  }
  .index-ob-note-inner {
    grid-template-columns: 1fr;
    align-items: flex-start;
    gap: .65rem;
  }
  .index-ob-note-btn {
    width: 100%;
  }
  .how { padding: 2rem 1.25rem; }
  .sort-buckets { grid-template-columns: repeat(2, 1fr); }
  .burger-buckets { grid-template-columns: 1fr; }
  .nav-hamburger {
    display: inline-flex;
    margin-left: auto;
  }
  nav {
    width: 100%;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: .35rem;
    padding: .3rem 0 .2rem;
  }
  header.nl-nav-open nav {
    display: flex;
  }
  nav a {
    width: 100%;
    padding: .55rem .7rem;
  }
  .nav-dropdown {
    width: 100%;
  }
  .nav-dropbtn {
    width: 100%;
    text-align: left;
    padding: .55rem .7rem;
    font-size: .9rem;
  }
  .nav-dropmenu {
    position: static;
    right: auto;
    margin-top: .2rem;
    min-width: 0;
    box-shadow: none;
    border-radius: var(--rs);
  }
  .lang-toggle {
    margin-left: 0;
    align-self: flex-start;
  }
  .play-main {
    padding: 1.25rem;
  }
  .vr-rubric {
    grid-template-columns: 1fr;
  }
  #grammatikk {
    padding: 1.25rem;
  }
  .gram-inner {
    padding: .9rem;
  }
  .gram-heading {
    font-size: 1.55rem;
  }
  .sum-breakdown {
    grid-template-columns: 1fr;
  }
}
