
    :root {
      --navy:        #0d2237;
      --navy-mid:    #163350;
      --navy-soft:   #1e4a73;
      --sail-white:  #fafaf6;
      --cream:       #f3ebd9;
      --cream-deep:  #e8dcbf;
      --teak:        #a0683f;
      --teak-deep:   #7d4e2e;
      --signal-red:  #c41e2d;
      --gold-star:   #f5b600;
      --green-go:    #2d6a4f;
      --font-sans:   'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
      --font-serif:  'Source Serif 4', Georgia, serif;
      --ease-out:    cubic-bezier(0.2, 0.7, 0.2, 1);
      /* Guide-tokens (alias) */
      --ink:         #0d2237;
      --ink-2:       #163350;
      --ink-3:       #506a83;
      --accent:      #a0683f;
      --surface:     #fafaf6;
      --border:      rgba(13, 34, 55, 0.12);
    }
    * { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: var(--font-sans);
      color: var(--navy);
      background: var(--sail-white);
      line-height: 1.6;
      -webkit-font-smoothing: antialiased;
      overflow-x: hidden;
    }
    img { max-width: 100%; display: block; }
    ::selection { background: var(--teak); color: var(--sail-white); }
    :focus-visible { outline: 2px solid var(--teak); outline-offset: 3px; border-radius: 4px; }
    a { color: inherit; }

    /* ======== HEADER ======== */
    .top {
      position: fixed; top: 0; left: 0; right: 0; z-index: 100;
      background: rgba(13, 34, 55, 0);
      backdrop-filter: blur(0px);
      border-bottom: 1px solid transparent;
      transition: background 0.4s var(--ease-out), backdrop-filter 0.4s var(--ease-out), border-color 0.4s var(--ease-out), padding 0.4s var(--ease-out);
    }
    .top.scrolled {
      background: rgba(250, 250, 246, 0.92);
      backdrop-filter: blur(24px) saturate(150%);
      border-bottom: 1px solid rgba(13, 34, 55, 0.08);
    }
    .top-row {
      max-width: 1400px; margin: 0 auto;
      padding: 22px 40px;
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      align-items: center; gap: 32px;
      transition: padding 0.4s var(--ease-out);
    }
    .top.scrolled .top-row { padding: 14px 40px; }
    .nav-left { display: flex; gap: 36px; font-size: 14px; font-weight: 500; }
    .nav-left a {
      color: var(--sail-white); text-decoration: none;
      transition: color 0.4s var(--ease-out); position: relative;
    }
    .nav-left a::after {
      content: ''; position: absolute; left: 0; bottom: -4px;
      width: 0; height: 1px; background: currentColor;
      transition: width 0.3s var(--ease-out);
    }
    .nav-left a:hover::after { width: 100%; }
    .top.scrolled .nav-left a { color: var(--navy); }
    .brand-mark { display: inline-flex; align-items: center; text-decoration: none; line-height: 0; }
    .brand-logo {
      font-family: var(--font-serif); font-weight: 500;
      font-size: 22px; letter-spacing: -0.01em;
      color: var(--sail-white);
      transition: color 0.4s var(--ease-out);
    }
    .top.scrolled .brand-logo { color: var(--navy); }
    .nav-right { display: flex; justify-content: flex-end; align-items: center; gap: 8px; }
    .login-btn {
      display: inline-flex; align-items: center; gap: 8px;
      padding: 10px 18px;
      border-radius: 999px;
      background: rgba(250, 250, 246, 0.12);
      border: 1px solid rgba(250, 250, 246, 0.35);
      font-size: 14px; font-weight: 500;
      color: var(--sail-white);
      text-decoration: none;
      transition: all 0.4s var(--ease-out);
    }
    .top.scrolled .login-btn {
      background: var(--navy);
      border-color: var(--navy);
      color: var(--sail-white);
    }
    .login-btn:hover { background: rgba(250, 250, 246, 0.22); }
    .top.scrolled .login-btn:hover { background: var(--navy-mid); }
    .login-btn svg { width: 16px; height: 16px; }

    /* ======== HERO ======== */
    .hero {
      position: relative;
      min-height: 78vh;
      padding: 180px 40px 100px;
      overflow: hidden;
      color: var(--sail-white);
      background:
        radial-gradient(ellipse 80% 60% at 80% 30%, rgba(160, 104, 63, 0.22) 0%, transparent 60%),
        radial-gradient(ellipse 60% 50% at 10% 80%, rgba(30, 74, 115, 0.45) 0%, transparent 55%),
        linear-gradient(160deg, #071624 0%, var(--navy) 45%, var(--navy-mid) 100%);
    }
    .hero-grain {
      position: absolute; inset: 0; z-index: 1;
      pointer-events: none; opacity: 0.05;
      mix-blend-mode: overlay;
      background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
      background-size: 160px 160px;
    }
    .hero-inner {
      position: relative; z-index: 2;
      max-width: 1400px; margin: 0 auto;
      display: grid;
      grid-template-columns: 1.4fr 1fr;
      gap: 64px; align-items: center;
    }
    .hero-text { max-width: 720px; }
    .hero-eyebrow {
      display: inline-flex; align-items: center; gap: 12px;
      font-size: 12px; font-weight: 500;
      letter-spacing: 0.22em; text-transform: uppercase;
      color: var(--cream); margin-bottom: 28px;
    }
    .hero-eyebrow .dot {
      width: 6px; height: 6px;
      background: var(--signal-red);
      border-radius: 50%;
      box-shadow: 0 0 0 0 rgba(196, 30, 45, 0.7);
      animation: pulse 2.2s infinite;
    }
    @keyframes pulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(196, 30, 45, 0.6); }
      50%      { box-shadow: 0 0 0 10px rgba(196, 30, 45, 0); }
    }
    .hero h1 {
      font-family: var(--font-serif);
      font-weight: 400;
      font-size: clamp(38px, 5vw, 72px);
      line-height: 1.02;
      letter-spacing: -0.03em;
      margin-bottom: 24px;
      color: var(--sail-white);
    }
    .hero h1 em { font-style: italic; color: var(--cream); }
    .hero-lede {
      font-family: var(--font-serif);
      font-size: clamp(15px, 1.1vw, 17px);
      line-height: 1.6;
      color: rgba(250, 250, 246, 0.85);
      max-width: 52ch;
      margin-bottom: 36px;
    }
    .hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; }
    .btn-primary {
      display: inline-flex; align-items: center; gap: 12px;
      background: var(--sail-white); color: var(--navy);
      font-weight: 600; font-size: 15px;
      padding: 18px 32px; min-height: 44px;
      border-radius: 999px; border: none;
      cursor: pointer; text-decoration: none;
      transition: transform 0.2s var(--ease-out), background 0.2s, box-shadow 0.2s;
    }
    .btn-primary:hover {
      background: var(--cream);
      box-shadow: 0 10px 32px rgba(0,0,0,0.25);
      transform: translateY(-1px);
    }
    .btn-primary svg { width: 16px; height: 16px; }
    .btn-ghost {
      display: inline-flex; align-items: center; gap: 12px;
      background: transparent; color: var(--sail-white);
      font-weight: 500; font-size: 15px;
      padding: 18px 28px; min-height: 44px;
      border-radius: 999px;
      border: 1px solid rgba(250, 250, 246, 0.4);
      text-decoration: none;
      transition: all 0.2s var(--ease-out);
    }
    .btn-ghost:hover { background: rgba(250,250,246,0.1); border-color: var(--sail-white); }
    .btn-ghost svg { width: 16px; height: 16px; }

    /* Hero pris-kort til høyre */
    .hero-card {
      background: rgba(250, 250, 246, 0.06);
      backdrop-filter: blur(14px);
      -webkit-backdrop-filter: blur(14px);
      border: 1px solid rgba(250, 250, 246, 0.18);
      border-radius: 18px;
      padding: 32px 30px;
    }
    .hero-card-label {
      font-size: 11px; font-weight: 500;
      letter-spacing: 0.2em; text-transform: uppercase;
      color: var(--cream); margin-bottom: 14px;
    }
    .hero-card-price {
      font-family: var(--font-serif);
      font-size: 48px; font-weight: 500;
      line-height: 1; color: var(--sail-white);
      letter-spacing: -0.025em; margin-bottom: 4px;
    }
    .hero-card-price em {
      font-size: 18px; font-style: italic;
      color: var(--cream); margin-left: 4px;
      font-weight: 400; letter-spacing: 0;
    }
    .hero-card-sub {
      font-family: var(--font-serif); font-style: italic;
      font-size: 14px; color: rgba(250, 250, 246, 0.7);
      margin-bottom: 24px;
    }
    .hero-card-list { list-style: none; padding: 0; margin: 0; }
    .hero-card-list li {
      display: flex; align-items: flex-start; gap: 10px;
      padding: 10px 0;
      border-top: 1px solid rgba(250, 250, 246, 0.1);
      font-size: 13px; color: rgba(250, 250, 246, 0.82);
      line-height: 1.45;
    }
    .hero-card-list li:first-child { border-top: none; padding-top: 4px; }
    .hero-card-list svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 3px; color: var(--cream); }

    /* ======== STAT BAR ======== */
    .statbar {
      background: var(--cream);
      padding: 28px 40px;
      border-bottom: 1px solid rgba(160, 104, 63, 0.18);
    }
    .statbar-inner {
      max-width: 1400px; margin: 0 auto;
      display: grid; grid-template-columns: repeat(4, 1fr);
      gap: 32px; align-items: center;
    }
    .stat-item { display: flex; align-items: center; gap: 14px; }
    .stat-icon {
      width: 36px; height: 36px;
      color: var(--teak); flex-shrink: 0;
    }
    .stat-icon svg { width: 100%; height: 100%; }
    .stat-icon.red { color: var(--signal-red); }
    .stat-text strong {
      display: block;
      font-family: var(--font-serif); font-weight: 500;
      font-size: 17px; color: var(--navy); line-height: 1.2;
      margin-bottom: 2px;
    }
    .stat-text span {
      font-family: var(--font-serif); font-style: italic;
      font-size: 13px; color: var(--navy-mid); line-height: 1.4;
    }

    /* ======== KURSLISTE ======== */
    .city-courses {
      background: var(--cream);
      padding: 100px 40px;
      border-bottom: 1px solid rgba(160, 104, 63, 0.18);
    }
    .city-courses-inner { max-width: 920px; margin: 0 auto; }
    .city-courses-head {
      text-align: center; margin-bottom: 40px;
      max-width: 640px; margin-left: auto; margin-right: auto;
    }
    .city-courses-head .eyebrow {
      display: inline-block;
      font-size: 12px; font-weight: 500;
      letter-spacing: 0.2em; text-transform: uppercase;
      color: var(--teak); margin-bottom: 16px;
    }
    .city-courses-head h2 {
      font-family: var(--font-serif); font-weight: 400;
      font-size: clamp(28px, 3.4vw, 42px);
      line-height: 1.1; letter-spacing: -0.025em;
      color: var(--navy); margin-bottom: 12px;
    }
    .city-courses-head h2 em { font-style: italic; }
    .city-courses-head p {
      font-family: var(--font-serif); font-style: italic;
      font-size: 16px; color: var(--navy-mid);
    }
    .courses-list {
      display: flex; flex-direction: column; gap: 0;
      background: var(--sail-white);
      border-radius: 14px;
      border: 1px solid rgba(13, 34, 55, 0.08);
      overflow: hidden;
      box-shadow: 0 4px 24px rgba(13, 34, 55, 0.05);
    }
    .course-row {
      display: grid;
      grid-template-columns: 110px 1fr auto auto;
      gap: 24px;
      align-items: center;
      padding: 22px 28px;
      text-decoration: none;
      color: var(--navy);
      border-bottom: 1px solid rgba(13, 34, 55, 0.06);
      transition: background 0.2s var(--ease-out), padding 0.2s var(--ease-out);
      min-height: 72px;
    }
    .course-row:last-child { border-bottom: none; }
    .course-row:hover {
      background: var(--cream);
      padding-left: 36px;
    }
    .c-date {
      font-family: var(--font-serif); font-weight: 500;
      font-size: 19px; line-height: 1.1;
      color: var(--navy);
    }
    .c-date small {
      display: block; font-family: var(--font-sans);
      font-size: 11px; text-transform: uppercase;
      letter-spacing: 0.12em; color: var(--teak);
      font-weight: 500; margin-top: 4px;
    }
    .c-venue {
      font-family: var(--font-sans);
      font-size: 14px; color: var(--navy-mid);
      line-height: 1.4;
    }
    .c-venue strong {
      display: block; color: var(--navy);
      font-size: 15px; font-weight: 500;
      margin-bottom: 2px;
    }
    .c-status {
      font-size: 11px; font-weight: 500;
      letter-spacing: 0.1em; text-transform: uppercase;
      padding: 4px 10px; border-radius: 999px;
      background: rgba(45, 106, 79, 0.12);
      color: var(--green-go);
      white-space: nowrap;
    }
    .c-status.few {
      background: rgba(196, 30, 45, 0.1);
      color: var(--signal-red);
    }
    .c-cta {
      font-size: 13px; font-weight: 500;
      color: var(--teak);
      display: inline-flex; align-items: center; gap: 6px;
      white-space: nowrap;
    }
    .c-cta svg { width: 14px; height: 14px; }
    .courses-empty {
      padding: 48px 28px;
      text-align: center;
      font-family: var(--font-serif); font-style: italic;
      color: var(--navy-mid);
    }
    .courses-empty a { color: var(--teak); text-decoration: underline; text-underline-offset: 3px; }
    .courses-loading { padding: 32px; text-align: center; color: var(--navy-mid); font-size: 14px; }

    /* ======== GENERIC SECTION ======== */
    .section { padding: 120px 40px; background: var(--sail-white); }
    .section.cream { background: var(--cream); }
    .section.navy {
      background: linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 50%, var(--navy-soft) 100%);
      color: var(--sail-white); position: relative; overflow: hidden;
    }
    .section.navy::before {
      content: ''; position: absolute; inset: -50%;
      background: radial-gradient(ellipse, rgba(160, 104, 63, 0.18) 0%, transparent 50%);
      animation: drift 18s ease-in-out infinite;
      pointer-events: none;
    }
    @keyframes drift {
      0%, 100% { transform: translate(0, 0) rotate(0deg); }
      50%      { transform: translate(6%, -4%) rotate(8deg); }
    }
    .container { max-width: 1100px; margin: 0 auto; position: relative; z-index: 1; }
    .container.narrow { max-width: 860px; }

    .eyebrow {
      display: inline-block; font-size: 12px; font-weight: 500;
      letter-spacing: 0.2em; text-transform: uppercase;
      color: var(--teak); margin-bottom: 20px;
    }
    .section.navy .eyebrow { color: var(--cream); }
    .section-head { text-align: center; max-width: 720px; margin: 0 auto 64px; }
    .section-head h2 {
      font-family: var(--font-serif); font-weight: 400;
      font-size: clamp(34px, 4vw, 52px);
      line-height: 1.08; letter-spacing: -0.025em;
      color: var(--navy); margin-bottom: 16px;
    }
    .section.navy .section-head h2 { color: var(--sail-white); }
    .section-head h2 em { font-style: italic; }
    .section.navy .section-head h2 em { color: var(--cream); }
    .section-head p {
      font-family: var(--font-serif); font-style: italic;
      font-size: 17px; color: var(--navy-mid);
    }
    .section.navy .section-head p { color: rgba(250,250,246,0.75); }

    /* ======== HOW STEPS ======== */
    .steps-grid {
      display: grid; grid-template-columns: repeat(4, 1fr);
      gap: 0;
      border-top: 1px solid rgba(13, 34, 55, 0.12);
      position: relative;
    }
    .step {
      padding: 40px 28px 8px 0;
      border-right: 1px solid rgba(13, 34, 55, 0.08);
      position: relative;
    }
    .step:last-child { border-right: none; padding-right: 0; }
    .step:not(:first-child) { padding-left: 32px; }
    .step-num {
      font-family: var(--font-serif);
      font-size: 13px; color: var(--teak);
      letter-spacing: 0.16em; margin-bottom: 24px;
      display: inline-block;
    }
    .step h3 {
      font-family: var(--font-serif); font-weight: 500;
      font-size: 22px; line-height: 1.2;
      color: var(--navy); margin-bottom: 14px;
      letter-spacing: -0.015em;
    }
    .step p { font-size: 15px; color: var(--navy-mid); line-height: 1.65; }

    .editorial-text h2 {
      font-family: var(--font-serif); font-weight: 400;
      font-size: clamp(30px, 3.4vw, 46px);
      line-height: 1.1; letter-spacing: -0.025em;
      margin-bottom: 24px; color: var(--navy);
    }
    .editorial-text h2 em { font-style: italic; }
    .editorial-text p {
      font-size: 16px; line-height: 1.75;
      color: var(--navy-mid); margin-bottom: 18px;
    }
    .editorial-quote {
      margin-top: 28px; padding-top: 24px;
      border-top: 1px solid rgba(13, 34, 55, 0.12);
      font-family: var(--font-serif); font-style: italic;
      font-size: 15px; color: var(--navy);
    }
    .editorial-quote .who {
      display: block;
      font-style: normal; font-family: var(--font-sans);
      font-size: 12px; text-transform: uppercase;
      letter-spacing: 0.12em; color: var(--teak);
      margin-top: 10px;
    }

    /* ======== PRIS ======== */
    .price-card {
      max-width: 640px; margin: 0 auto;
      background: var(--sail-white);
      border: 1px solid rgba(13, 34, 55, 0.1);
      border-radius: 18px;
      padding: 48px 44px;
      box-shadow: 0 12px 48px rgba(13, 34, 55, 0.08);
    }
    .price-amount {
      font-family: var(--font-serif); font-weight: 500;
      font-size: clamp(52px, 6vw, 72px); line-height: 1;
      color: var(--navy); letter-spacing: -0.025em;
      margin-bottom: 4px;
    }
    .price-amount em {
      font-style: italic; font-size: 20px;
      color: var(--teak); margin-left: 6px;
      font-weight: 400; letter-spacing: 0;
    }
    .price-sub {
      font-family: var(--font-serif); font-style: italic;
      font-size: 15px; color: var(--navy-mid);
      margin-bottom: 32px; padding-bottom: 28px;
      border-bottom: 1px solid rgba(13, 34, 55, 0.1);
    }
    .price-list { list-style: none; padding: 0; margin: 0 0 32px; }
    .price-list li {
      position: relative; padding: 11px 0 11px 32px;
      font-size: 15px; color: var(--navy);
      border-bottom: 1px solid rgba(13, 34, 55, 0.06);
    }
    .price-list li:last-child { border-bottom: none; }
    .price-list li::before {
      content: '';
      position: absolute; left: 0; top: 50%; transform: translateY(-50%);
      width: 18px; height: 18px;
      background: var(--green-go); border-radius: 50%;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 7l3 3 5-5' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
      background-size: 12px 12px;
      background-position: center;
      background-repeat: no-repeat;
    }
    .price-extra {
      padding-top: 24px; border-top: 1px solid rgba(13, 34, 55, 0.1);
      font-family: var(--font-serif); font-style: italic;
      font-size: 14px; color: var(--navy-mid); line-height: 1.6;
    }
    .price-extra strong { color: var(--navy); font-weight: 600; font-style: normal; }
    .price-cta { text-align: center; margin-top: 36px; }
    .btn-secondary {
      display: inline-flex; align-items: center; gap: 12px;
      background: var(--navy); color: var(--sail-white);
      font-weight: 500; font-size: 15px;
      padding: 18px 32px; min-height: 44px;
      border-radius: 999px; border: none;
      cursor: pointer; text-decoration: none;
      transition: transform 0.2s var(--ease-out), background 0.2s, box-shadow 0.2s;
    }
    .btn-secondary:hover {
      background: var(--navy-mid);
      box-shadow: 0 10px 28px rgba(13, 34, 55, 0.2);
      transform: translateY(-1px);
    }
    .btn-secondary svg { width: 16px; height: 16px; }

    /* ======== FAQ ======== */
    .faq-list {
      display: flex; flex-direction: column; gap: 0;
      border-top: 1px solid rgba(13, 34, 55, 0.12);
    }
    .faq-item { border-bottom: 1px solid rgba(13, 34, 55, 0.12); }
    .faq-item > summary {
      list-style: none; cursor: pointer;
      display: flex; justify-content: space-between; align-items: center;
      gap: 16px; padding: 24px 0; min-height: 44px;
      font-family: var(--font-serif); font-weight: 500;
      font-size: clamp(17px, 1.6vw, 20px);
      color: var(--navy); line-height: 1.35;
      transition: color 0.2s ease;
    }
    .faq-item > summary::-webkit-details-marker { display: none; }
    .faq-item > summary:hover { color: var(--teak); }
    .faq-chevron {
      width: 22px; height: 22px; color: var(--teak);
      flex-shrink: 0; transition: transform 0.25s var(--ease-out);
    }
    .faq-item[open] .faq-chevron { transform: rotate(180deg); }
    .faq-body {
      padding: 0 0 28px;
      font-size: 16px; line-height: 1.7;
      color: var(--navy-mid); max-width: 68ch;
    }
    .faq-body strong { color: var(--navy); font-weight: 600; }

    /* ======== INTEREST FORM ======== */
    .form-card {
      max-width: 600px; margin: 0 auto;
      background: var(--sail-white);
      border: 1px solid rgba(13, 34, 55, 0.1);
      border-radius: 18px;
      padding: 48px 44px;
      box-shadow: 0 12px 48px rgba(13, 34, 55, 0.06);
    }
    .form-card h3 {
      font-family: var(--font-serif); font-weight: 500;
      font-size: 26px; color: var(--navy);
      margin-bottom: 10px; letter-spacing: -0.015em;
    }
    .form-card .form-intro {
      font-family: var(--font-serif); font-style: italic;
      font-size: 15px; color: var(--navy-mid);
      margin-bottom: 28px;
    }
    .form-group { margin-bottom: 18px; }
    .form-group label {
      display: block; font-size: 13px; font-weight: 500;
      color: var(--navy-mid); margin-bottom: 8px;
      letter-spacing: 0.02em;
    }
    .form-group label .req { color: var(--signal-red); }
    .form-group input {
      width: 100%; padding: 14px 16px;
      background: var(--sail-white);
      border: 1px solid rgba(13, 34, 55, 0.18);
      border-radius: 10px;
      color: var(--navy); font-size: 15px;
      font-family: inherit; box-sizing: border-box;
      transition: border-color 0.2s;
    }
    .form-group input:focus { outline: none; border-color: var(--teak); }
    .form-group input::placeholder { color: rgba(13, 34, 55, 0.35); }
    .form-consent {
      display: flex; align-items: flex-start; gap: 10px;
      margin: 18px 0 22px;
      font-size: 13px; color: var(--navy-mid); line-height: 1.55;
    }
    .form-consent input[type="checkbox"] { margin-top: 3px; flex-shrink: 0; }
    .form-consent a { color: var(--teak); text-decoration: underline; text-underline-offset: 2px; }
    .form-submit {
      width: 100%; background: var(--navy); color: var(--sail-white);
      border: none; padding: 16px; border-radius: 999px;
      font-size: 15px; font-weight: 600;
      cursor: pointer; font-family: inherit;
      transition: background 0.2s, transform 0.2s;
      min-height: 52px;
    }
    .form-submit:hover { background: var(--navy-mid); transform: translateY(-1px); }
    .form-submit:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
    .form-msg { display: none; padding: 14px 18px; border-radius: 10px; font-size: 14px; margin-top: 16px; line-height: 1.55; }
    .form-msg.success { background: rgba(45, 106, 79, 0.1); border: 1px solid rgba(45, 106, 79, 0.3); color: var(--green-go); }
    .form-msg.error { background: rgba(196, 30, 45, 0.08); border: 1px solid rgba(196, 30, 45, 0.3); color: var(--signal-red); }

    /* ======== NEARBY CITIES ======== */
    .nearby-grid {
      display: grid; grid-template-columns: repeat(3, 1fr);
      gap: 20px;
    }
    .nearby-card {
      background: var(--sail-white);
      border: 1px solid rgba(13, 34, 55, 0.1);
      border-radius: 14px;
      padding: 28px 28px;
      text-decoration: none; color: var(--navy);
      transition: transform 0.25s var(--ease-out), box-shadow 0.25s, border-color 0.25s;
      display: block;
    }
    .nearby-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 16px 40px rgba(13, 34, 55, 0.1);
      border-color: rgba(160, 104, 63, 0.3);
    }
    .nearby-region {
      display: inline-block; font-size: 11px; font-weight: 500;
      letter-spacing: 0.16em; text-transform: uppercase;
      color: var(--teak); margin-bottom: 14px;
    }
    .nearby-city {
      font-family: var(--font-serif); font-weight: 500;
      font-size: 26px; color: var(--navy);
      letter-spacing: -0.015em; margin-bottom: 8px;
    }
    .nearby-link {
      font-size: 13px; color: var(--navy-mid);
      display: inline-flex; align-items: center; gap: 6px;
      transition: gap 0.2s var(--ease-out), color 0.2s;
    }
    .nearby-card:hover .nearby-link { gap: 10px; color: var(--teak); }
    .nearby-link svg { width: 14px; height: 14px; }

    /* ======== FINAL CTA ======== */
    .final-cta { text-align: center; }
    .final-cta-stats {
      display: inline-flex; flex-wrap: wrap; justify-content: center;
      gap: 16px;
      font-size: 13px;
      color: rgba(250, 250, 246, 0.78);
      letter-spacing: 0.06em; text-transform: uppercase;
      margin: 0 0 36px;
    }
    .final-cta-stats .dot-sep { color: var(--teak); }
    .final-cta-disclaimer {
      font-family: var(--font-serif); font-style: italic;
      font-size: 13px; line-height: 1.55;
      color: rgba(243, 235, 217, 0.7);
      max-width: 480px; margin: -18px auto 32px;
    }
    .btn-cta-large {
      display: inline-flex; align-items: center; gap: 14px;
      background: var(--sail-white); color: var(--navy);
      font-weight: 600; font-size: 16px;
      padding: 22px 40px; min-height: 56px;
      border-radius: 999px; border: none;
      cursor: pointer; text-decoration: none;
      transition: transform 0.2s var(--ease-out);
      box-shadow: 0 12px 36px rgba(0, 0, 0, 0.18);
    }
    .btn-cta-large:hover { transform: translateY(-2px); }
    .final-cta-sub {
      display: inline-block; margin-top: 28px;
      color: var(--cream);
      font-family: var(--font-serif); font-style: italic;
      font-size: 15px; text-decoration: none;
      border-bottom: 1px solid rgba(243, 235, 217, 0.4);
      padding-bottom: 4px; transition: border-color 0.2s ease;
    }
    .final-cta-sub:hover { border-color: var(--cream); }

    /* ======== FOOTER ======== */
    footer {
      background: var(--navy);
      color: rgba(250, 250, 246, 0.7);
      padding: 80px 40px 36px;
    }
    /* Kurssteder-grid (internlinking til alle 28 by-sider) */
    .footer-cities {
      max-width: 1400px; margin: 0 auto 56px;
      padding-bottom: 48px;
      border-bottom: 1px solid rgba(250, 250, 246, 0.1);
    }
    .footer-cities-title {
      font-family: var(--font-serif); font-weight: 400;
      font-size: clamp(22px, 2.4vw, 28px);
      color: var(--sail-white); letter-spacing: -0.02em;
      line-height: 1.2; margin: 0 0 10px;
    }
    .footer-cities-title em { font-style: italic; color: var(--cream); }
    .footer-cities-sub {
      font-family: var(--font-serif); font-style: italic;
      font-size: 14px; color: rgba(250, 250, 246, 0.7);
      margin: 0 0 24px;
    }
    .footer-cities-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 8px 24px;
    }
    .footer-cities-grid a {
      display: block;
      color: rgba(250, 250, 246, 0.78);
      text-decoration: none;
      font-size: 13px;
      padding: 5px 0;
      transition: color 0.15s, padding-left 0.15s var(--ease-out);
    }
    .footer-cities-grid a:hover {
      color: var(--cream); padding-left: 4px;
    }
    @media (max-width: 900px) {
      .footer-cities-grid { grid-template-columns: repeat(2, 1fr); gap: 6px 16px; }
    }
    @media (max-width: 480px) {
      .footer-cities-grid { grid-template-columns: 1fr; gap: 2px; }
      .footer-cities-grid a { font-size: 14px; padding: 7px 0; }
    }
    .footer-inner {
      max-width: 1400px; margin: 0 auto;
      display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
      gap: 56px; margin-bottom: 56px;
    }
    .footer-brand {
      font-family: var(--font-serif); font-weight: 500;
      font-size: 26px; color: var(--sail-white);
      letter-spacing: -0.01em; margin-bottom: 16px;
    }
    .footer-tag {
      font-family: var(--font-serif); font-style: italic;
      font-size: 15px; max-width: 32ch; line-height: 1.55;
    }
    footer h4 {
      font-size: 12px; color: var(--cream);
      text-transform: uppercase; letter-spacing: 0.14em;
      margin-bottom: 22px; font-weight: 500;
    }
    footer ul { list-style: none; }
    footer li { margin-bottom: 12px; font-size: 14px; }
    footer a { color: rgba(250, 250, 246, 0.7); text-decoration: none; transition: color 0.15s; }
    footer a:hover { color: var(--sail-white); }
    .footer-bottom {
      max-width: 1400px; margin: 0 auto;
      padding-top: 36px;
      border-top: 1px solid rgba(250, 250, 246, 0.1);
      display: flex; justify-content: space-between;
      flex-wrap: wrap; gap: 16px;
      font-size: 12px; letter-spacing: 0.04em;
      color: rgba(250, 250, 246, 0.5);
    }
    .footer-bottom a { color: rgba(250, 250, 246, 0.5); }
    .footer-bottom a:hover { color: var(--sail-white); }

    /* ======== COOKIE BANNER — shadcn-style, hairline borders, kompakt
       kort nede til venstre. z-index 900 < booking-modal-overlay. ======== */
    .cookie {
      position: fixed; bottom: 16px; left: 16px;
      width: calc(100% - 32px); max-width: 380px;
      z-index: 900;
      background: rgba(252, 251, 248, 0.85);
      color: var(--navy);
      padding: 16px;
      border: 1px solid rgba(13, 34, 55, 0.08);
      border-radius: 16px;
      box-shadow:
        0 1px 2px rgba(13, 34, 55, 0.04),
        0 8px 24px rgba(13, 34, 55, 0.08),
        0 24px 48px -16px rgba(13, 34, 55, 0.12);
      backdrop-filter: blur(20px) saturate(180%);
      -webkit-backdrop-filter: blur(20px) saturate(180%);
      display: flex; flex-direction: column; gap: 12px;
      animation: cookieFadeIn 0.4s cubic-bezier(0.16, 1, 0.3, 1) both;
      font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
      -webkit-font-smoothing: antialiased;
    }
    @keyframes cookieFadeIn {
      from { opacity: 0; transform: translateY(8px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    .cookie-head { display: flex; flex-direction: column; gap: 6px; }
    .cookie-title-row { display: flex; align-items: center; gap: 8px; }
    .cookie-title-icon {
      display: inline-flex; align-items: center; justify-content: center;
      width: 24px; height: 24px;
      border-radius: 6px;
      background: rgba(13, 34, 55, 0.05);
      color: var(--navy);
      flex-shrink: 0;
    }
    .cookie-title-icon svg { width: 14px; height: 14px; }
    .cookie-title {
      font-size: 13.5px; font-weight: 600;
      color: var(--navy); margin: 0;
      letter-spacing: -0.011em; line-height: 1.3;
    }
    .cookie-text {
      color: rgba(13, 34, 55, 0.6);
      font-size: 12.5px; line-height: 1.5;
      margin: 0;
      letter-spacing: -0.003em;
    }
    .cookie-text a {
      color: var(--navy);
      font-weight: 500;
      text-decoration: underline;
      text-decoration-color: rgba(13, 34, 55, 0.25);
      text-underline-offset: 2px;
      text-decoration-thickness: 1px;
      transition: text-decoration-color 0.15s ease;
    }
    .cookie-text a:hover { text-decoration-color: rgba(13, 34, 55, 0.7); }
    .cookie-btns { display: flex; gap: 6px; align-items: stretch; }
    .cookie-btn {
      flex: 1 1 0;
      padding: 0 14px; border-radius: 8px;
      font-size: 12.5px; font-weight: 500; cursor: pointer;
      font-family: inherit; border: 1px solid transparent;
      height: 34px;
      letter-spacing: -0.002em;
      transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
    }
    .cookie-accept { background: var(--navy); color: #fcfbf8; border-color: var(--navy); }
    .cookie-accept:hover { background: var(--navy-mid); border-color: var(--navy-mid); }
    .cookie-reject { background: transparent; color: rgba(13, 34, 55, 0.85); border-color: rgba(13, 34, 55, 0.12); }
    .cookie-reject:hover { background: rgba(13, 34, 55, 0.03); border-color: rgba(13, 34, 55, 0.2); color: var(--navy); }

    /* ======== RESPONSIVE ======== */
    @media (max-width: 1000px) {
      .hero-inner { grid-template-columns: 1fr; gap: 40px; }
      .steps-grid { grid-template-columns: 1fr; border-top: none; }
      .step { border-right: none; border-bottom: 1px solid rgba(13,34,55,0.08); padding: 32px 0; }
      .step:not(:first-child) { padding-left: 0; }
      .step:last-child { border-bottom: none; }
      .nearby-grid { grid-template-columns: 1fr; gap: 14px; }
      .footer-inner { grid-template-columns: 1fr 1fr; gap: 40px; }
    }
    @media (max-width: 800px) {
      .nav-left { display: none; }
      .top-row { padding: 16px 20px; }
      .top.scrolled .top-row { padding: 12px 20px; }
      .hero { padding: 130px 20px 80px; min-height: 0; }
      .statbar { padding: 20px 20px; }
      .statbar-inner { grid-template-columns: 1fr 1fr; gap: 18px; }
      .section { padding: 80px 20px; }
      .city-courses { padding: 64px 16px; }
      .course-row {
        grid-template-columns: 80px 1fr auto;
        gap: 14px; padding: 16px 18px; min-height: 64px;
      }
      .course-row:hover { padding-left: 18px; }
      .c-date { font-size: 16px; }
      .c-date small { font-size: 10px; letter-spacing: 0.1em; }
      .c-venue { font-size: 13px; }
      .c-venue strong { font-size: 14px; }
      .c-cta { display: none; }
      .c-status { font-size: 10px; padding: 4px 8px; }
      .price-card, .form-card { padding: 32px 24px; }
      .footer-inner { grid-template-columns: 1fr; gap: 32px; }
      footer { padding: 64px 20px 24px; }
      .cookie {
        bottom: calc(12px + env(safe-area-inset-bottom));
        left: 12px; right: 12px;
        width: auto; max-width: none;
      }
    }
  
    /* ============ GUIDE-LAG v2 (2026-06-12) ============
       Layout + typografi for guide-sidene. Klassene fantes i markup
       uten regler — dette laget gir dem lys editorial design. */

    .guide-hero {
      min-height: 0;
      padding: 150px 24px 56px;
      background: linear-gradient(180deg, var(--cream) 0%, var(--sail-white) 88%);
      color: var(--navy);
    }
    .guide-hero .hero-eyebrow,
    .guide-hero h1,
    .guide-hero .hero-lede,
    .guide-hero .guide-meta {
      max-width: 740px;
      margin-left: auto;
      margin-right: auto;
    }
    .guide-hero .hero-eyebrow {
      display: flex; align-items: center; gap: 10px;
      font-size: 12px; font-weight: 600;
      letter-spacing: 0.18em; text-transform: uppercase;
      color: var(--teak-deep);
      margin-bottom: 22px;
    }
    .guide-hero .hero-eyebrow .dot {
      width: 7px; height: 7px; border-radius: 50%;
      background: var(--signal-red); display: inline-block;
    }
    .guide-hero h1 {
      font-family: var(--font-serif);
      font-weight: 500;
      font-size: clamp(34px, 4.6vw, 52px);
      line-height: 1.08; letter-spacing: -0.015em;
      color: var(--navy);
      margin-bottom: 20px;
    }
    .guide-hero h1 em { font-style: italic; color: var(--navy-soft); }
    .guide-hero .hero-lede {
      font-family: var(--font-serif);
      font-size: 19px; line-height: 1.65;
      color: var(--navy-mid);
      margin-bottom: 26px;
    }
    .guide-hero .guide-meta {
      display: flex; flex-wrap: wrap; gap: 8px 22px;
      font-size: 13px; color: var(--navy-mid); opacity: 0.75;
    }
    .guide-hero .guide-meta span { display: inline-flex; align-items: center; gap: 6px; }
    .guide-hero .guide-meta span + span::before {
      content: '·'; margin-right: 16px; opacity: 0.6;
    }

    /* Felles innholds-kolonne */
    .guide-toc, .guide-body, .guide-faq, .related-guides, .guide-cta {
      max-width: 740px;
      margin-left: auto; margin-right: auto;
      padding-left: 24px; padding-right: 24px;
      box-sizing: content-box;
    }

    .guide-toc {
      margin-top: 8px; margin-bottom: 12px;
    }
    .guide-toc > * {
      margin: 0;
    }
    .guide-toc {
      padding-top: 22px; padding-bottom: 22px;
    }
    .guide-toc .guide-toc-title {
      font-size: 12px; font-weight: 600;
      letter-spacing: 0.16em; text-transform: uppercase;
      color: var(--teak-deep);
      margin-bottom: 12px;
    }
    .guide-toc ol {
      margin: 0; padding: 0 0 0 20px;
      columns: 2; column-gap: 40px;
      font-size: 14.5px; line-height: 2;
    }
    .guide-toc li { break-inside: avoid; }
    .guide-toc a {
      color: var(--navy-mid); text-decoration: none;
      border-bottom: 1px solid rgba(13,34,55,0.15);
    }
    .guide-toc a:hover { color: var(--teak-deep); border-bottom-color: var(--teak); }

    .guide-body {
      font-family: var(--font-serif);
      font-size: 18px; line-height: 1.72;
      color: var(--navy-mid);
      padding-bottom: 28px;
    }
    .guide-body h2 {
      font-family: var(--font-serif); font-weight: 500;
      font-size: clamp(26px, 3vw, 32px);
      line-height: 1.18; letter-spacing: -0.01em;
      color: var(--navy);
      margin: 52px 0 18px;
      scroll-margin-top: 96px;
    }
    .guide-body h3 {
      font-family: var(--font-sans); font-weight: 600;
      font-size: 18px; color: var(--navy);
      margin: 34px 0 12px;
      scroll-margin-top: 96px;
    }
    .guide-body p { margin: 0 0 18px; }
    .guide-body ul, .guide-body ol { margin: 0 0 20px; padding-left: 26px; }
    .guide-body li { margin-bottom: 8px; }
    .guide-body li::marker { color: var(--teak); }
    .guide-body strong { color: var(--navy); font-weight: 600; }
    .guide-body a { color: var(--teak-deep); text-decoration-color: rgba(160,104,63,0.4); text-underline-offset: 3px; }
    .guide-body a:hover { text-decoration-color: var(--teak-deep); }

    .guide-body .guide-figure {
      margin: 32px 0;
    }
    .guide-body .guide-figure img {
      display: block;
      width: 100%;
      height: auto;
      border: 1px solid var(--border);
      border-radius: 12px;
      background: var(--sail-white);
    }
    .guide-body .guide-figure figcaption {
      margin-top: 10px;
      font-family: var(--font-sans);
      font-size: 14px;
      line-height: 1.5;
      color: var(--ink-3);
      text-align: center;
    }

    .guide-body .answer-block {
      background: var(--cream);
      border-left: 3px solid var(--teak);
      border-radius: 0 10px 10px 0;
      padding: 20px 24px;
      margin: 0 0 30px;
      font-size: 17.5px;
    }

    .guide-body table {
      width: 100%; border-collapse: collapse;
      font-family: var(--font-sans); font-size: 15px;
      margin: 6px 0 28px;
    }
    .guide-body th {
      background: var(--cream);
      text-align: left; font-weight: 600; color: var(--navy);
      padding: 10px 14px;
      border-bottom: 2px solid rgba(13,34,55,0.12);
    }
    .guide-body td {
      padding: 10px 14px;
      border-bottom: 1px solid rgba(13,34,55,0.08);
      vertical-align: top;
    }

    .guide-faq {
      padding-top: 18px; padding-bottom: 34px;
    }
    .guide-faq h2 {
      font-family: var(--font-serif); font-weight: 500;
      font-size: 28px; color: var(--navy);
      margin: 0 0 8px;
    }
    .guide-faq .faq-item {
      border-bottom: 1px solid rgba(13,34,55,0.1);
      padding: 18px 0;
    }
    .guide-faq .faq-q {
      font-family: var(--font-sans); font-weight: 600;
      font-size: 16.5px; color: var(--navy);
      margin: 0 0 8px;
    }
    .guide-faq .faq-a {
      font-family: var(--font-serif);
      font-size: 16.5px; line-height: 1.65;
      color: var(--navy-mid); margin: 0;
    }

    .related-guides {
      padding-top: 14px; padding-bottom: 26px;
    }
    .related-guides h3 {
      font-size: 12px; font-weight: 600;
      letter-spacing: 0.16em; text-transform: uppercase;
      color: var(--teak-deep);
      margin: 0 0 16px;
    }
    .related-grid {
      display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
    }
    .related-card {
      display: block;
      background: var(--sail-white);
      border: 1px solid rgba(13,34,55,0.1);
      border-radius: 12px;
      padding: 16px 18px;
      text-decoration: none;
      transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
    }
    .related-card:hover {
      transform: translateY(-2px);
      border-color: rgba(160,104,63,0.45);
      box-shadow: 0 8px 22px rgba(13,34,55,0.08);
    }
    .related-card .related-eyebrow {
      font-size: 11px; font-weight: 600;
      letter-spacing: 0.14em; text-transform: uppercase;
      color: var(--teak-deep); margin: 0 0 6px;
    }
    .related-card .related-title {
      font-family: var(--font-serif);
      font-size: 15.5px; line-height: 1.35;
      color: var(--navy); margin: 0;
    }

    .guide-cta {
      background: var(--navy);
      color: var(--sail-white);
      border-radius: 18px;
      padding: 44px 36px;
      text-align: center;
      margin-top: 16px; margin-bottom: 80px;
    }
    .guide-cta h3 {
      font-family: var(--font-serif); font-weight: 500;
      font-size: 28px; margin: 0 0 12px;
    }
    .guide-cta p {
      font-size: 16px; line-height: 1.6;
      color: rgba(250,250,246,0.85);
      max-width: 520px; margin: 0 auto 24px;
    }
    .guide-cta .btn-primary { display: inline-flex; }
    .guide-cta-fine {
      display: block; margin-top: 20px;
      font-size: 12.5px; line-height: 1.5;
      color: rgba(250,250,246,0.6);
    }

    @media (max-width: 720px) {
      .guide-hero { padding: 120px 20px 40px; }
      .guide-toc ol { columns: 1; }
      .guide-toc, .guide-body, .guide-faq, .related-guides, .guide-cta {
        padding-left: 20px; padding-right: 20px;
      }
      .guide-body { font-size: 17px; }
      .related-grid { grid-template-columns: 1fr; }
      .guide-cta { border-radius: 0; margin-bottom: 0; padding: 40px 24px; }
    }

    /* Guide-sider har lys hero — header alltid i "scrolled"-stil */
    .top {
      background: rgba(250, 250, 246, 0.92);
      backdrop-filter: blur(12px);
      border-bottom: 1px solid rgba(13, 34, 55, 0.08);
    }
    .nav-left a, .brand-logo { color: var(--navy); }
    .login-btn {
      background: var(--navy); color: var(--sail-white);
      border-color: var(--navy);
    }
    .login-btn:hover { background: var(--navy-mid); }

    /* Nøkkeltall-grid (brukes av pensum/steg-for-steg) */
    .guide-body .stat-grid {
      display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
      margin: 10px 0 30px;
    }
    .guide-body .stat-card {
      background: var(--sail-white);
      border: 1px solid rgba(13,34,55,0.1);
      border-radius: 12px;
      padding: 16px 14px;
      text-align: center;
    }
    .guide-body .stat-num {
      font-family: var(--font-serif);
      font-size: 30px; font-weight: 500; line-height: 1.1;
      color: var(--navy);
    }
    .guide-body .stat-label {
      font-family: var(--font-sans);
      font-size: 12px; letter-spacing: 0.04em;
      color: var(--navy-mid); opacity: 0.8;
      margin-top: 6px;
    }
    .guide-body td.us, .guide-body td.win { color: var(--navy); font-weight: 600; }
    @media (max-width: 720px) {
      .guide-body .stat-grid { grid-template-columns: repeat(2, 1fr); }
    }
