/* ═══════════════════════════════════════════════════════
   TUFTEBYE AI — Felles stilark (Emil Kowalski v2)
   Gjelder alle undersider under tuftebyeai.com
   ═══════════════════════════════════════════════════════ */

/* ─── DESIGN TOKENS ──────────────────────────────────── */
:root {
  --navy:       #141c2e;
  --navy-mid:   #1a2540;
  --navy-card:  #1e2d45;
  --gold:       #C4A060;
  --gold-light: #D8BC84;
  --gold-dark:  #A08448;
  --platinum:   #C0CDD8;
  --text:       #EAE2D4;
  --text-body:  #C8C2B8;
  --text-muted: #8A9AA8;
  --divider:    rgba(196,160,96,0.25);
  --card-bg:    rgba(30,45,69,0.7);
  --radius:     6px;

  /* Emil: Custom easing — never use generic ease/ease-in-out */
  --ease-out:    cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in-out: cubic-bezier(0.77, 0, 0.175, 1);
  --ease-snappy: cubic-bezier(0.34, 1.56, 0.64, 1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--navy);
  color:var(--text);
  font-family:'Inter',sans-serif;
  font-weight:400;
  line-height:1.65;
  min-height:100vh;
  overflow-x:hidden;
}

/* ─── TYPOGRAPHY ─────────────────────────────────────── */
h1,h2,h3,h4 { font-family:'Playfair Display',serif; line-height:1.2; }
h1 { font-size:clamp(2.2rem,5vw,3.8rem); font-weight:700; }
h2 { font-size:clamp(1.7rem,3vw,2.4rem); font-weight:600; }
h3 { font-size:clamp(1.2rem,2vw,1.5rem); font-weight:500; }
p  { line-height:1.75; }
a  { color:inherit; text-decoration:none; }
.eyebrow {
  font-family:'Inter',sans-serif; font-size:.75rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; color:var(--gold);
  margin-bottom:1rem; display:block;
}
.gold       { color:var(--gold); }
.gold-light { color:var(--gold-light); }
.platinum   { color:var(--platinum); }
.muted      { color:var(--text-muted); }

/* ─── LAYOUT ─────────────────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:0 2rem; }
main { position:relative; z-index:1; min-height:calc(100vh - 80px); padding-top:80px; }

/* Gold divider — clip-path reveal from centre */
.gold-divider {
  width:80px; height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin:1.5rem auto;
  clip-path:inset(0 50% 0 50%);
  transition:clip-path 600ms var(--ease-out);
}
.gold-divider.left  { margin-left:0; }
.gold-divider.visible { clip-path:inset(0 0% 0 0%); }

.section    { padding:5rem 0; }
.section-sm { padding:3rem 0; }
.section-dark {
  background:rgba(10,14,24,.5);
  border-top:1px solid var(--divider);
  border-bottom:1px solid var(--divider);
}
.section-title { text-align:center; margin-bottom:3rem; }

/* ─── SCROLL PROGRESS BAR ────────────────────────────── */
.scroll-progress {
  position:fixed; top:0; left:0; right:0; z-index:1001;
  height:2px; pointer-events:none;
}
.scroll-progress-bar {
  height:100%;
  background:linear-gradient(90deg,var(--gold-dark),var(--gold-light));
  transform:scaleX(0);
  transform-origin:left center;
  will-change:transform;
}

/* ─── HEADING WORD REVEAL ───────────────────────────── */
.word-wrap {
  overflow:hidden; display:inline-block;
  vertical-align:bottom; margin-right:0.22em;
}
.word-wrap:last-child { margin-right:0; }
.word {
  display:inline-block;
  transform:translateY(110%);
  transition:transform 550ms var(--ease-out);
}
h2.words-revealed .word { transform:translateY(0); }

/* ═══════════════════════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(20,28,46,.96); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--divider); height:80px;
  display:flex; align-items:center;
  transition:height 200ms var(--ease-out), background 200ms var(--ease-out);
}
.nav.scrolled {
  height:64px;
  background:rgba(14,20,36,.98);
}
.nav-inner {
  max-width:1200px; margin:0 auto; padding:0 2rem; width:100%;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo { display:flex; align-items:center; height:44px; }
.nav-logo img { height:40px; width:auto; object-fit:contain; display:block; }
.nav-links { display:flex; align-items:center; gap:.25rem; list-style:none; }

.nav-link {
  font-size:.875rem; font-weight:500; letter-spacing:.05em;
  color:var(--text-muted); padding:.5rem 1rem;
  border-radius:var(--radius);
  transition:color 150ms var(--ease-out), background 150ms var(--ease-out);
  position:relative; display:block;
}
@media (hover:hover) and (pointer:fine) {
  .nav-link:hover { color:var(--text); background:rgba(196,160,96,.08); }
}
.nav-link.active { color:var(--gold); }
.nav-link.active::after {
  content:''; position:absolute; bottom:-1px; left:1rem; right:1rem;
  height:2px; background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

.nav-cta {
  font-size:.8rem; font-weight:600; letter-spacing:.08em;
  color:var(--navy); background:linear-gradient(135deg,var(--gold-light),var(--gold));
  border:none; padding:.55rem 1.4rem; border-radius:var(--radius);
  cursor:pointer; text-transform:uppercase; display:inline-block;
  transition:transform 160ms var(--ease-out), box-shadow 160ms var(--ease-out), background 200ms var(--ease-out);
}
/* FIXED: removed gold box-shadow (light glow on dark = AI slop tell) */
@media (hover:hover) and (pointer:fine) {
  .nav-cta:hover {
    background:linear-gradient(135deg,var(--gold),var(--gold-dark));
    transform:translateY(-1px);
  }
}
.nav-cta:active { transform:scale(0.97); transition-duration:100ms; }

/* ─── MOBILE HAMBURGER ──────────────────────────────── */
.nav-hamburger {
  display:none; flex-direction:column; justify-content:center; gap:5px;
  background:none; border:none; cursor:pointer; padding:.5rem; flex-shrink:0;
}
.nav-hamburger span {
  display:block; width:22px; height:2px;
  background:var(--text); border-radius:2px;
  transition:transform 200ms var(--ease-out), opacity 150ms var(--ease-out);
}
.nav-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Emil: mobile menu — transform/opacity, NEVER display toggle */
.nav-mobile-menu {
  display:block;
  position:fixed; top:80px; left:0; right:0; z-index:999;
  background:rgba(14,20,36,.99); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--divider);
  opacity:0;
  transform:translateY(-8px);
  pointer-events:none;
  transition:opacity 200ms var(--ease-out), transform 200ms var(--ease-out);
}
.nav-mobile-menu.open {
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.nav-mobile-link {
  display:block; padding:.9rem 1.5rem;
  font-size:.95rem; font-weight:500; color:var(--text-muted);
  border-bottom:1px solid rgba(196,160,96,.08);
  transition:color 150ms var(--ease-out), padding-left 150ms var(--ease-out);
}
.nav-mobile-link:hover,
.nav-mobile-link.active { color:var(--gold); padding-left:2rem; }
.nav-mobile-cta {
  display:block; margin:1.25rem 1.5rem 1.5rem;
  font-size:.85rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:var(--navy); background:linear-gradient(135deg,var(--gold-light),var(--gold));
  border:none; padding:.8rem; border-radius:var(--radius); cursor:pointer;
  text-align:center; width:calc(100% - 3rem);
  transition:transform 160ms var(--ease-out);
}
.nav-mobile-cta:active { transform:scale(0.97); }

/* ═══════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════ */
.btn-primary {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:'Inter',sans-serif; font-size:.85rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--navy); background:linear-gradient(135deg,var(--gold-light),var(--gold));
  border:none; padding:.85rem 2rem; border-radius:var(--radius); cursor:pointer;
  transition:transform 160ms var(--ease-out), box-shadow 160ms var(--ease-out), background 200ms var(--ease-out);
}
/* FIXED: removed gold box-shadow glow (anti-pattern on dark backgrounds) */
@media (hover:hover) and (pointer:fine) {
  .btn-primary:hover {
    background:linear-gradient(135deg,var(--gold),var(--gold-dark));
    transform:translateY(-2px);
  }
}
.btn-primary:active { transform:scale(0.97); transition-duration:100ms; }

.btn-outline {
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:'Inter',sans-serif; font-size:.85rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--gold); background:transparent; border:1px solid var(--gold);
  padding:.85rem 2rem; border-radius:var(--radius); cursor:pointer;
  transition:transform 160ms var(--ease-out), background 150ms var(--ease-out);
}
@media (hover:hover) and (pointer:fine) {
  .btn-outline:hover { background:rgba(196,160,96,.1); transform:translateY(-2px); }
}
.btn-outline:active { transform:scale(0.97); transition-duration:100ms; }

/* ═══════════════════════════════════════════════════════
   CARDS (generic)
   ═══════════════════════════════════════════════════════ */
.card {
  background:var(--card-bg); border:1px solid var(--divider);
  border-radius:var(--radius); padding:2rem;
  backdrop-filter:blur(4px);
  transition:transform 200ms var(--ease-out), box-shadow 200ms var(--ease-out), border-color 200ms var(--ease-out);
}
/* FIXED: removed border-top:3px (layout shift) and gold box-shadow (anti-pattern)
   Top accent delivered via ::before clip-path reveal — no layout shift */
.card { position:relative; overflow:hidden; }
.card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0;
  clip-path:inset(0 100% 0 0);
  transition:clip-path 300ms var(--ease-out), opacity 300ms var(--ease-out);
}
@media (hover:hover) and (pointer:fine) {
  .card:hover {
    transform:translateY(-3px);
    border-color:rgba(196,160,96,.5);
  }
  .card:hover::before {
    clip-path:inset(0 0% 0 0);
    opacity:1;
  }
}

/* ═══════════════════════════════════════════════════════
   SCROLL REVEAL — generic (used on all subsider)
   ═══════════════════════════════════════════════════════ */
.reveal {
  opacity:0;
  transform:translateY(18px);
  transition:opacity 500ms var(--ease-out), transform 500ms var(--ease-out);
}
.reveal.visible {
  opacity:1;
  transform:translateY(0);
}
.reveal-left {
  opacity:0;
  transform:translateX(-12px);
  transition:opacity 400ms var(--ease-out), transform 400ms var(--ease-out);
}
.reveal-left.visible {
  opacity:1;
  transform:translateX(0);
}

/* ═══════════════════════════════════════════════════════
   PAGE HERO (undersider)
   ═══════════════════════════════════════════════════════ */
.page-hero {
  padding:5rem 0 3rem; text-align:center; position:relative;
}
.page-hero::after {
  content:''; display:block; width:100px; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin:2rem auto 0;
}

/* ═══════════════════════════════════════════════════════
   TJENESTER
   ═══════════════════════════════════════════════════════ */
.tjenester-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; margin-bottom:1.5rem; }
.tjeneste-card {
  background:var(--card-bg); border:1px solid var(--divider);
  border-radius:var(--radius); padding:2rem;
  position:relative; display:flex; flex-direction:column;
  /* reveal start state */
  opacity:0; transform:translateY(18px);
  transition:
    opacity 500ms var(--ease-out),
    transform 500ms var(--ease-out),
    border-color 200ms var(--ease-out),
    box-shadow 200ms var(--ease-out);
}
.tjeneste-card.visible { opacity:1; transform:translateY(0); }
@media (hover:hover) and (pointer:fine) {
  .tjeneste-card:hover { transform:translateY(-3px); border-color:rgba(196,160,96,.4); box-shadow:0 8px 32px rgba(0,0,0,.25); }
  .tjeneste-card.visible:hover { transform:translateY(-3px); }
}
/* FIXED: border-top:3px → ::before accent stripe (no layout shift) */
.tjeneste-card.core::before,
.tjeneste-card.core-featured::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent 0%, var(--gold) 40%, var(--gold-light) 60%, transparent 100%);
  opacity:0.9;
}
.tjeneste-card.core-featured {
  grid-column:span 2;
  background:rgba(30,45,69,.9);
}
.tjeneste-badge {
  display:inline-block; font-size:.65rem; font-weight:600; letter-spacing:.1em;
  text-transform:uppercase; padding:.25rem .7rem; border-radius:2rem; margin-bottom:1rem;
}
.badge-core     { background:rgba(196,160,96,.15); color:var(--gold); border:1px solid rgba(196,160,96,.3); }
.badge-secondary { background:rgba(192,205,216,.1); color:var(--platinum); border:1px solid rgba(192,205,216,.2); }
.tjeneste-card h3 { margin-bottom:.75rem; font-size:1.2rem; }
.tjeneste-card p  { color:var(--text-body); font-size:.9rem; line-height:1.7; margin-bottom:1rem; }
.tjeneste-features { list-style:none; display:flex; flex-direction:column; gap:.4rem; margin-bottom:1.25rem; }
.tjeneste-features li { font-size:.85rem; color:var(--text-body); display:flex; align-items:flex-start; gap:.5rem; }
.tjeneste-features li::before { content:'→'; color:var(--gold); flex-shrink:0; margin-top:.05rem; }
.tjeneste-price {
  font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--gold-light);
  margin-top:auto; padding-top:1rem; border-top:1px solid var(--divider);
}
.tjeneste-price small { font-family:'Inter',sans-serif; font-size:.75rem; color:var(--text-muted); font-weight:400; }

.secondary-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.secondary-card {
  background:rgba(20,28,46,.6); border:1px solid var(--divider);
  border-radius:var(--radius); padding:1.5rem;
  display:flex; flex-direction:column;
  opacity:0; transform:translateY(18px);
  transition:
    opacity 500ms var(--ease-out),
    transform 500ms var(--ease-out),
    border-color 200ms var(--ease-out);
}
.secondary-card.visible { opacity:1; transform:translateY(0); }
@media (hover:hover) and (pointer:fine) {
  .secondary-card:hover { border-color:rgba(196,160,96,.3); background:rgba(30,45,69,.6); transform:translateY(-2px); }
  .secondary-card.visible:hover { transform:translateY(-2px); }
}
.secondary-card h4 { font-family:'Inter',sans-serif; font-weight:600; font-size:.95rem; margin-bottom:.5rem; color:var(--text); }
.secondary-card p  { font-size:.82rem; color:var(--text-body); margin-bottom:.75rem; flex:1; }
.secondary-card .tjeneste-price { font-size:.95rem; padding-top:.75rem; }

.pakker-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; align-items:start; }
.pakke-card {
  background:var(--card-bg); border:1px solid var(--divider);
  border-radius:var(--radius); padding:2.25rem 2rem; position:relative;
  opacity:0; transform:translateY(18px);
  transition:
    opacity 500ms var(--ease-out),
    transform 500ms var(--ease-out),
    box-shadow 200ms var(--ease-out);
}
.pakke-card.visible { opacity:1; transform:translateY(0); }
@media (hover:hover) and (pointer:fine) {
  .pakke-card:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(0,0,0,.3); }
  .pakke-card.visible:hover { transform:translateY(-3px); }
}
.pakke-card.featured { border-color:var(--gold); background:rgba(30,45,69,.9); }
.pakke-card.featured::before {
  content:'MEST POPULÆR'; position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  background:linear-gradient(135deg,var(--gold-light),var(--gold)); color:var(--navy);
  font-size:.65rem; font-weight:700; letter-spacing:.12em; padding:.25rem 1rem; border-radius:2rem;
}
.pakke-name     { font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:600; margin-bottom:.4rem; }
.pakke-tagline  { font-size:.8rem; color:var(--text-muted); margin-bottom:1.5rem; }
.pakke-price    { font-family:'Playfair Display',serif; font-size:2rem; color:var(--gold); line-height:1; margin-bottom:.3rem; }
.pakke-price-note { font-size:.75rem; color:var(--text-muted); margin-bottom:1.5rem; }
.pakke-includes { list-style:none; margin-bottom:2rem; display:flex; flex-direction:column; gap:.6rem; }
.pakke-includes li { font-size:.875rem; color:var(--text-body); display:flex; align-items:flex-start; gap:.6rem; }
.pakke-includes .check { color:var(--gold); flex-shrink:0; }

/* ═══════════════════════════════════════════════════════
   OM OSS
   ═══════════════════════════════════════════════════════ */
.bio-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-bottom:5rem; }
.bio-card {
  background:var(--card-bg); border:1px solid var(--divider); border-radius:var(--radius); overflow:hidden;
  opacity:0; transform:translateY(18px);
  transition:opacity 500ms var(--ease-out), transform 500ms var(--ease-out);
}
.bio-card.visible { opacity:1; transform:translateY(0); }
.bio-card:nth-child(2) { transition-delay:100ms; }
.bio-header {
  background:linear-gradient(135deg,rgba(196,160,96,.12),rgba(20,28,46,.8));
  padding:2.5rem 2rem 2rem; border-bottom:1px solid var(--divider);
}
.bio-name  { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:600; margin-bottom:.25rem; }
.bio-title { font-size:.8rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); }
.bio-body  { padding:2rem; }
.bio-body p { color:var(--text-body); font-size:.9rem; line-height:1.8; margin-bottom:1.25rem; }
.bio-body p:last-child { margin-bottom:0; }
.bio-creds { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.25rem; }
.bio-cred {
  font-size:.7rem; font-weight:500; letter-spacing:.06em; color:var(--platinum);
  background:rgba(192,205,216,.1); border:1px solid rgba(192,205,216,.2);
  padding:.3rem .75rem; border-radius:2rem;
}

.verdier-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem; }
.verdi-card {
  background:var(--card-bg); border:1px solid var(--divider);
  border-radius:var(--radius); padding:1.75rem 1.5rem;
  text-align:center;
  opacity:0; transform:translateY(18px);
  transition:
    opacity 500ms var(--ease-out),
    transform 500ms var(--ease-out),
    border-color 200ms var(--ease-out);
}
.verdi-card.visible { opacity:1; transform:translateY(0); }
.verdi-card:nth-child(2) { transition-delay:60ms; }
.verdi-card:nth-child(3) { transition-delay:120ms; }
.verdi-card:nth-child(4) { transition-delay:180ms; }
/* FIXED: border-top:3px on hover → ::before approach */
.verdi-card { position:relative; overflow:hidden; }
.verdi-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0;
  clip-path:inset(0 50% 0 50%);
  transition:clip-path 300ms var(--ease-out), opacity 300ms var(--ease-out);
}
@media (hover:hover) and (pointer:fine) {
  .verdi-card:hover { border-color:rgba(196,160,96,.4); transform:translateY(-3px); }
  .verdi-card:hover::before { clip-path:inset(0 0% 0 0%); opacity:1; }
  .verdi-card.visible:hover { transform:translateY(-3px); }
}
.verdi-icon   { font-size:2rem; margin-bottom:1rem; }
.verdi-card h4 { font-family:'Playfair Display',serif; font-size:1rem; margin-bottom:.5rem; color:var(--gold-light); }
.verdi-card p  { font-size:.82rem; color:var(--text-body); line-height:1.6; }

/* ═══════════════════════════════════════════════════════
   INNSIKT
   ═══════════════════════════════════════════════════════ */
.innsikt-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.article-card {
  background:var(--card-bg); border:1px solid var(--divider);
  border-radius:var(--radius); overflow:hidden; display:block;
  opacity:0; transform:translateY(18px);
  transition:
    opacity 500ms var(--ease-out),
    transform 500ms var(--ease-out),
    border-color 200ms var(--ease-out),
    box-shadow 200ms var(--ease-out);
}
.article-card.visible { opacity:1; transform:translateY(0); }
.article-card:nth-child(2) { transition-delay:60ms; }
.article-card:nth-child(3) { transition-delay:120ms; }
.article-card:nth-child(4) { transition-delay:0ms; }
.article-card:nth-child(5) { transition-delay:60ms; }
.article-card:nth-child(6) { transition-delay:120ms; }
@media (hover:hover) and (pointer:fine) {
  .article-card:hover { transform:translateY(-3px); border-color:rgba(196,160,96,.4); box-shadow:0 8px 32px rgba(0,0,0,.3); }
  .article-card.visible:hover { transform:translateY(-3px); }
}
.article-img { height:160px; position:relative; overflow:hidden; }
.article-img-bg {
  width:100%; height:100%;
  background:linear-gradient(135deg,var(--navy-mid),var(--navy-card));
  display:flex; align-items:center; justify-content:center;
  font-size:3rem; position:relative;
}
.article-img-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(196,160,96,.15),transparent);
  opacity:.3; transition:opacity 200ms var(--ease-out);
}
@media (hover:hover) and (pointer:fine) {
  .article-card:hover .article-img-overlay { opacity:.6; }
}
.article-body  { padding:1.5rem; }
.article-tag {
  display:inline-block; font-size:.65rem; font-weight:600; letter-spacing:.1em;
  text-transform:uppercase; color:var(--gold);
  background:rgba(196,160,96,.12); border:1px solid rgba(196,160,96,.25);
  padding:.2rem .6rem; border-radius:2rem; margin-bottom:.75rem;
}
.article-title {
  font-family:'Playfair Display',serif; font-size:1.05rem; font-weight:600;
  margin-bottom:.65rem; color:var(--text); line-height:1.35;
}
.article-excerpt { font-size:.83rem; color:var(--text-body); line-height:1.7; margin-bottom:1rem; }
.article-meta {
  display:flex; align-items:center; justify-content:space-between;
  font-size:.75rem; color:var(--text-muted);
  padding-top:.875rem; border-top:1px solid var(--divider);
}
.article-read-more {
  font-size:.72rem; font-weight:600; color:var(--gold); letter-spacing:.06em;
  display:inline-flex; align-items:center; gap:.3rem; text-transform:uppercase;
}

/* ─── ARTIKKEL-SIDE ────────────────────────────────── */
.article-page-container {
  max-width:780px; margin:0 auto; padding:5rem 2rem 4rem;
  position:relative; z-index:1;
}
.article-breadcrumb {
  font-size:.85rem; color:var(--text-muted); margin-bottom:2.5rem;
  display:flex; align-items:center; gap:.5rem;
}
.article-breadcrumb a {
  color:var(--gold);
  transition:color 150ms var(--ease-out);
}
@media (hover:hover) and (pointer:fine) {
  .article-breadcrumb a:hover { color:var(--gold-light); }
}
.article-header { padding-bottom:2rem; border-bottom:1px solid var(--divider); margin-bottom:2.5rem; }
.article-header .article-tag { display:inline-block; margin-bottom:1rem; }
.article-page-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.6rem,3.5vw,2.4rem); font-weight:700;
  line-height:1.25; margin-bottom:1rem; color:var(--text);
}
.article-page-meta { font-size:.8rem; color:var(--text-muted); display:flex; gap:1.5rem; flex-wrap:wrap; }
.article-content { color:var(--text-body); line-height:1.85; font-size:.975rem; }
.article-content h2 {
  font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:600;
  color:var(--gold-light); margin:2rem 0 .75rem;
}
.article-content h3 {
  font-family:'Inter',sans-serif; font-size:1.1rem; font-weight:600;
  color:var(--text); margin:1.5rem 0 .5rem;
}
.article-content p  { margin-bottom:1.25rem; }
.article-content ul,.article-content ol { padding-left:1.5rem; margin-bottom:1.25rem; }
.article-content li { line-height:1.8; margin-bottom:.35rem; }
.article-content strong { color:var(--text); }
.article-content em { font-style:italic; }
.article-cta-box {
  background:rgba(196,160,96,.08); border:1px solid rgba(196,160,96,.3);
  border-radius:var(--radius); padding:1.75rem 2rem; margin-top:2.5rem; text-align:center;
}
.article-cta-box p { color:var(--text); font-size:1rem; font-weight:500; margin-bottom:1.25rem; }

/* ═══════════════════════════════════════════════════════
   KONTAKT
   ═══════════════════════════════════════════════════════ */
.kontakt-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.kontakt-info h2 { margin-bottom:1.25rem; }
.kontakt-info p  { color:var(--text-body); margin-bottom:2rem; line-height:1.8; }
.kontakt-items { display:flex; flex-direction:column; gap:1.25rem; }
.kontakt-item {
  display:flex; align-items:flex-start; gap:1rem; padding:1.25rem;
  background:rgba(30,45,69,.5); border-radius:var(--radius); border:1px solid var(--divider);
  opacity:0; transform:translateX(-12px);
  transition:opacity 400ms var(--ease-out), transform 400ms var(--ease-out);
}
.kontakt-item.visible { opacity:1; transform:translateX(0); }
.kontakt-item:nth-child(2) { transition-delay:60ms; }
.kontakt-item:nth-child(3) { transition-delay:120ms; }
.kontakt-item:nth-child(4) { transition-delay:180ms; }
.kontakt-item-icon {
  width:40px; height:40px; flex-shrink:0;
  background:rgba(196,160,96,.12); border:1px solid rgba(196,160,96,.25);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center; font-size:1rem;
}
.kontakt-item-text h4 { font-family:'Inter',sans-serif; font-size:.85rem; font-weight:600; color:var(--text); margin-bottom:.2rem; }
.kontakt-item-text p  { font-size:.85rem; color:var(--text-body); margin:0; }
.kontakt-item-text a  { color:var(--gold); }
@media (hover:hover) and (pointer:fine) {
  .kontakt-item-text a:hover { color:var(--gold-light); }
}
.kontakt-form-card {
  background:var(--card-bg); border:1px solid var(--divider); border-radius:var(--radius); padding:2.5rem;
  opacity:0; transform:translateY(18px);
  transition:opacity 500ms var(--ease-out), transform 500ms var(--ease-out);
}
.kontakt-form-card.visible { opacity:1; transform:translateY(0); }
.form-title    { font-family:'Playfair Display',serif; font-size:1.3rem; margin-bottom:.5rem; }
.form-subtitle { font-size:.875rem; color:var(--text-muted); margin-bottom:2rem; }
.form-group    { margin-bottom:1.25rem; }
.form-group label {
  display:block; font-size:.8rem; font-weight:600; letter-spacing:.05em;
  text-transform:uppercase; color:var(--platinum); margin-bottom:.5rem;
}
.form-group input,.form-group select,.form-group textarea {
  width:100%; background:rgba(20,28,46,.8); border:1px solid var(--divider);
  border-radius:var(--radius); padding:.85rem 1rem; color:var(--text);
  font-family:'Inter',sans-serif; font-size:.9rem; outline:none; appearance:none;
  transition:border-color 150ms var(--ease-out), box-shadow 150ms var(--ease-out);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus {
  border-color:var(--gold); box-shadow:0 0 0 3px rgba(196,160,96,.1);
}
.form-group textarea { resize:vertical; min-height:120px; }
.form-group select  { cursor:pointer; }
.form-group select option { background:var(--navy); }

/* ─── FOOTER ──────────────────────────────────────────── */
.footer {
  background:rgba(10,14,24,.8); border-top:1px solid var(--divider);
  padding:3rem 0 2rem; position:relative; z-index:1;
}
.footer-inner {
  max-width:1200px; margin:0 auto; padding:0 2rem;
  display:grid; grid-template-columns:2fr 1fr 1fr; gap:3rem; margin-bottom:2.5rem;
}
.footer-brand p { color:var(--text-body); font-size:.875rem; line-height:1.75; margin-top:1rem; max-width:320px; }
.footer-col h4 {
  font-family:'Inter',sans-serif; font-size:.75rem; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin-bottom:1.25rem;
}
.footer-links { list-style:none; display:flex; flex-direction:column; gap:.6rem; }
.footer-links li a {
  font-size:.875rem; color:var(--text-body); display:inline-block;
  transition:color 150ms var(--ease-out), transform 150ms var(--ease-out);
}
@media (hover:hover) and (pointer:fine) {
  .footer-links li a:hover { color:var(--gold); transform:translateX(3px); }
}
.footer-bottom {
  max-width:1200px; margin:0 auto; padding:1.5rem 2rem 0;
  border-top:1px solid var(--divider);
  display:flex; align-items:center; justify-content:space-between;
}
.footer-bottom p  { font-size:.8rem; color:var(--text-muted); }
.footer-tagline   { font-size:.75rem; color:var(--gold); font-style:italic; font-family:'Playfair Display',serif; }

/* ─── PRIS-ADVARSEL ───────────────────────────────── */
.price-warning {
  display:block; font-size:.7rem; font-weight:600; color:#e05252;
  letter-spacing:.04em; margin-top:.3rem;
}

/* ═══════════════════════════════════════════════════════
   REDUCED MOTION
   ═══════════════════════════════════════════════════════ */
@media (prefers-reduced-motion:reduce) {
  .tjeneste-card, .secondary-card, .pakke-card,
  .bio-card, .verdi-card, .article-card,
  .kontakt-item, .kontakt-form-card, .reveal, .reveal-left {
    opacity:1; transform:none;
    transition:opacity 200ms var(--ease-out);
  }
  .tjeneste-card.visible, .secondary-card.visible, .pakke-card.visible,
  .bio-card.visible, .verdi-card.visible, .article-card.visible,
  .kontakt-item.visible, .kontakt-form-card.visible,
  .reveal.visible, .reveal-left.visible { opacity:1; }
  .gold-divider { clip-path:none !important; transition:none; }
  .word { transform:none !important; transition:none; }
  .scroll-progress { display:none; }
}

/* ═══════════════════════════════════════════════════════
   RESPONSIV: TABLET
   ═══════════════════════════════════════════════════════ */
@media (min-width:769px) and (max-width:1024px) {
  .bio-grid         { grid-template-columns:1fr; }
  .verdier-grid     { grid-template-columns:repeat(2,1fr); }
  .pakker-grid      { grid-template-columns:1fr; }
  .innsikt-grid     { grid-template-columns:repeat(2,1fr); }
  .promise-grid     { grid-template-columns:1fr; }
  .container        { padding:0 1.5rem; }
}

/* ═══════════════════════════════════════════════════════
   RESPONSIV: MOBIL
   ═══════════════════════════════════════════════════════ */
@media (max-width:768px) {
  /* NAV */
  .nav-links,.nav-cta { display:none; }
  .nav-hamburger      { display:flex; }
  .nav-inner          { padding:0 1rem; }

  /* SPACING */
  .section    { padding:2.5rem 0; }
  .section-sm { padding:1.75rem 0; }
  .container  { padding:0 1.1rem; }
  .section-title { margin-bottom:2rem; }

  /* PAGE HERO */
  .page-hero { padding:2.5rem 0 1.5rem; }

  /* TJENESTER */
  .tjenester-grid { grid-template-columns:1fr; }
  .tjeneste-card.core-featured { grid-column:span 1; }
  .tjeneste-card.core-featured > div { grid-template-columns:1fr !important; gap:1rem; }
  .secondary-grid { grid-template-columns:1fr; }
  .tjeneste-card[style*="span 2"] { grid-column:span 1 !important; }
  .tjeneste-card[style*="span 2"] > div { grid-template-columns:1fr !important; }
  .pakker-grid { grid-template-columns:1fr; }
  /* Reset stagger on mobile */
  .verdi-card:nth-child(2),
  .verdi-card:nth-child(3),
  .verdi-card:nth-child(4) { transition-delay:0ms; }
  .article-card:nth-child(2),
  .article-card:nth-child(3),
  .article-card:nth-child(4),
  .article-card:nth-child(5),
  .article-card:nth-child(6) { transition-delay:0ms; }

  /* BIO */
  .bio-grid   { grid-template-columns:1fr; margin-bottom:3rem; }
  .bio-header { padding:1.75rem 1.5rem 1.5rem; }
  .bio-body   { padding:1.5rem; }
  .bio-card:nth-child(2) { transition-delay:0ms; }

  /* VERDIER */
  .verdier-grid { grid-template-columns:repeat(2,1fr); gap:1rem; }

  /* INNSIKT */
  .innsikt-grid { grid-template-columns:1fr; }

  /* KONTAKT */
  .kontakt-grid { grid-template-columns:1fr; gap:2rem; }
  .kontakt-item:nth-child(2),
  .kontakt-item:nth-child(3),
  .kontakt-item:nth-child(4) { transition-delay:0ms; }

  /* FOOTER */
  .footer-inner  { grid-template-columns:1fr; gap:2rem; margin-bottom:1.5rem; }
  .footer-bottom { flex-direction:column; gap:.5rem; text-align:center; }

  /* ARTIKKEL */
  .article-page-container { padding:3rem 1.25rem 3rem; }

  /* H SIZES */
  h2 { font-size:clamp(1.4rem,5vw,1.8rem); }
}
