/* =========================================================
   TOKENS (oppdatert til paletten)
   ========================================================= */
:root{
  /* Palett */
  --blue-900:#073B4C;  /* hoved-ink / mørk blågrønn */
  --blue-700:#214f5e;
  --blue-600:#396270;
  --blue-500:#537682;
  --blue-400:#6a8995;
  --blue-300:#839da6;
  --blue-200:#9cb1b7;
  --blue-150:#b5c5ca;
  --blue-120:#ced8db;
  --blue-050:#e7ebec;

  --lion:    #caa566;      /* knappfarge */
  --lion-200:#d5b785;      /* lys variant (hover) */
  --lion-100:#dfc9a2;      /* enda lysere */
  --lion-050:#eadbc2;

  --plum:    #744253;

  --gray-050:#fff;
  --gray-200:#dbdada;
  --gray-300:#cccccb;
  --mint-050:#ebf6f4;
  --teal-400:#4da1a9;

  /* Semantikk */
  --brand-gold: var(--lion);
  --brand-plum: var(--plum);
  --ink-dark: var(--blue-900);
  --ink-light:#ffffff;

  --bg-hero-top: var(--blue-700);
  --bg-hero-bot: var(--blue-900);
  --max-width:1200px;
}

/* =========================================================
   TYPOGRAFI (Inter overalt) + fet tekst = 600
   ========================================================= */
html, body { height:100%; }
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--ink-dark);
  line-height:1.5;
  background: #fff; /* global bakgrunn */
}

/* All “fet tekst” skal være 600 */
h1,h2,h3,h4,h5,h6,strong,b{ font-weight:600; }

/* =========================================================
   Hero
   ========================================================= */
.hero{
  background:linear-gradient(180deg,var(--bg-hero-top),var(--bg-hero-bot));
  color:var(--ink-light);
  padding:4rem 1rem 5rem;
  min-height:88vh;
  display:flex; align-items:center;
}
.hero__inner{max-width:var(--max-width);margin:0 auto;display:flex;gap:3rem;align-items:center;width:100%}
.hero__text{flex:1 1 45ch}
.hero__title{font-size:clamp(2.1rem,5vw,3.7rem);font-weight:600;line-height:1.14;margin:0 0 1.5rem;letter-spacing:-.01em}
.hero__body{margin:0 0 2.5rem;font-size:1.17rem;color:#e7eaea;max-width:38ch}

/* Kun “design-knapper”, ikke absolutt alle <button> */
.btn,
.btn-secondary,
.plan__cta,
.module-intro__btn,
.uc-btn,
.btn-ghost,
.contact-page .btn-dark {
  background: var(--lion);
  color:#000;
  border:1px solid transparent;
  padding:.72rem 1.35rem;
  border-radius:.4rem;
  font-weight:600;
  display:inline-block;
  text-decoration:none;
  transition:filter .15s ease, transform .15s ease, box-shadow .15s ease, background .2s ease;
}

button:hover,
.btn:hover,
.btn-secondary:hover,
.plan__cta:hover,
.module-intro__btn:hover,
.uc-btn:hover,
.btn-ghost:hover,
.contact-page .btn-dark:hover,
.contact-page .btn-dark:focus{
  background: var(--lion-200) !important;
  color:#000 !important;
  transform: translateY(-1px);
  box-shadow:0 6px 14px rgba(0,0,0,.12);
}

.btn-secondary{font-size:1.06rem}

/* Ghost-knappen får ikke lenger “ghost” – følger kravet om Lion */
.btn-ghost{ border-color: transparent; }

/* Illustrasjonsboks (skal være hvit) */
.hero__graphic{
  background:#fff;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; border-radius:18px;
  box-shadow:0 15px 40px rgba(0,0,0,.15);
  min-height:300px; width:100%; max-width:800px; margin:0 auto;
  padding: clamp(8px, 1.5vw, 16px);
}
.hero__graphic img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}

@media (max-width: 900px) {
  .hero__inner { flex-direction: column; align-items: center; text-align: center; gap:0; }
  .hero__text { max-width: 560px; margin: 0 auto; }
  .hero__cta { justify-content: center; }
  .hero__graphic { order: 2; margin: 0 auto; padding: clamp(6px, 1vw, 12px); }

  .stats{ order:2; position:static; width:auto; height:auto; margin-top:.75rem;
    display:grid; grid-template-columns:1fr 1fr; gap:12px; transform:none; }
  .stats__img{ position:static; width:100%; height:auto; border-radius:12px; filter:none; }
  .s5{ grid-column:1 / -1; }

  .hero__title_undersite{ font-size: clamp(1.9rem, 6vw, 2.3rem); line-height:1.2; margin-bottom:1rem; }
  .hero__body_undersite { font-size:1rem; margin-bottom:1.5rem; }
}

/* =========================================================
   Partners (seksjon var hvit -> site-grå)
   ========================================================= */
.partners{padding:1.25rem 1rem 2rem;background:var(--gray-050)}
.partners__title{font-size:1.05rem;font-weight:600;text-align:center;margin:0 0 .75rem;letter-spacing:.01em;color:var(--ink-dark)}
.partners__rail{
  box-sizing:border-box;max-width:var(--max-width);margin:0 auto;background:var(--gray-050);border-radius:12px;overflow:visible;
  padding:1rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.1rem;align-items:center;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)
}
.partners__item{height:clamp(64px,9vw,80px);display:flex;align-items:center;justify-content:center;min-width:0}
.partners__item img{max-width:95%;max-height:100%;width:auto;height:auto;object-fit:contain}
@media (min-width:721px){
  .partners__rail{grid-template-columns:repeat(4,minmax(0,1fr));gap:2rem;padding:1.25rem 1.5rem}
  .partners__item{height:clamp(72px,7.5vw,90px)}
}

/* =========================================================
   Fototjenester – forsiden
   ========================================================= */
.photo-services{
  background: var(--gray-050);
  padding: 3rem 1rem 3.2rem;
  color: var(--ink-dark);
}

.photo-services__inner{
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr);
  gap: 2.2rem;
}

.photo-services__head{
  max-width: 640px;
}

.photo-services__tag{
  display: inline-block;
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue-900);
  background: rgba(7, 59, 76, 0.06);
  border-radius: 999px;
  padding: 0.2rem 0.8rem;
  margin-bottom: 0.5rem;
  font-weight: 600;
}

.photo-services__head h2{
  font-size: clamp(1.9rem, 3vw, 2.4rem);
  margin: 0 0 0.6rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.photo-services__head p{
  margin: 0;
  max-width: 52ch;
  font-size: 1rem;
  opacity: 0.92;
}

/* Kortene */
.photo-services__grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.6rem;
}

.photo-card{
  background: #ffffff;
  border-radius: 14px;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.08);
  padding: 1.4rem 1.4rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.photo-card__title{
  margin: 0 0 0.1rem;
  font-size: 1.15rem;
  font-weight: 600;
}

.photo-card__text{
  margin: 0;
  font-size: 0.97rem;
  opacity: 0.92;
}

.photo-card__list{
  margin: 0.5rem 0 0.6rem;
  padding-left: 1.1rem;
  font-size: 0.95rem;
}

.photo-card__list li{
  margin: 0.15rem 0;
}

.photo-card__link{
  margin-top: auto;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--blue-900);
  text-decoration: none;
}

.photo-card__link:hover{
  text-decoration: underline;
}

/* CTA-knappen under kortene */
.photo-services__cta{
  margin-top: 0.4rem;
}

/* Responsiv */
@media (max-width: 900px){
  .photo-services__inner{
    gap: 1.8rem;
  }

  .photo-services__grid{
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   Feature (seksjon var hvit -> site-grå)
   ========================================================= */
.feature{background:var(--gray-050);padding:3rem 1rem;color:var(--ink-dark)}
.feature__inner{max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.feature__title{font-size:clamp(1.8rem,4vw,3rem);line-height:1.1;margin:0 0 1rem;letter-spacing:-.01em;font-weight:600}
.feature__body{margin:0;font-size:1.06rem;max-width:55ch}
.feature__media{border-radius:14px;overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.12)}
.feature__media img{display:block;width:100%;height:auto;object-fit:cover}
@media (max-width:900px){
  .feature__inner{grid-template-columns:1fr;gap:1.5rem;text-align:left}
  .feature__media{order:2}
}
.feature--image-left .feature__inner{grid-template-columns:1fr 1fr}
.feature--image-left .feature__text{order:2}
.feature--image-left .feature__media{order:1}

/* =========================================================
   Plans (seksjon var hvit -> site-grå)
   ========================================================= */
.plans{background:var(--gray-050);padding:3rem 1rem;color:var(--ink-dark)}
.plans__inner{max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem}
.plan{background:var(--gray-050);border-radius:0;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.08);display:flex;flex-direction:column}
.plan__head{background:var(--bg-hero-bot);color:var(--ink-light);padding:.9rem 1.1rem;text-align:center;border-radius:0}
.plan__head h3{margin:0;font-weight:600;letter-spacing:.01em}
.plan__body{background:#fff;padding:1.25rem 1.25rem 1.1rem;display:flex;flex-direction:column;gap:1rem}
.plan__lead{font-weight:600;margin:0;text-align:center}
.plan__price{margin:0 .25rem .25rem;text-align:center;font-size:1rem}
.plan__price strong{font-size:1.6rem;font-weight:600}
.plan__price span{opacity:.8}
.plan__features{list-style:none;padding:0;margin:.25rem 0 0;display:grid;gap:.55rem}
.plan__features li{position:relative;padding-left:1.4rem;line-height:1.35}
/* Bullets skal være svarte */
.plan__features li::before{content:"";position:absolute;left:0;top:.35rem;width:.7rem;height:.7rem;border-radius:50%;background:#000;box-shadow:0 0 0 3px rgba(0,0,0,.08)}
.plan__cta{margin-top:.5rem;align-self:center}

/* Mobil */
@media (max-width:720px){.plans__inner{grid-template-columns:1fr}}



/* =========================================================
   Feature list (bullets = svarte)
   ========================================================= */
.feature-list{ list-style:none; padding:0; margin:0 0 1.6rem; }
.feature-list li{ position:relative; padding-left:1.1rem; margin:.35rem 0; }
.feature-list li::before{
  content:""; position:absolute; left:0; top:.55rem;
  width:.45rem; height:.45rem; border-radius:50%;
  background:#000;
}
.hero__cta{display:flex; gap:.8rem; align-items:center;}

/* =========================================================
   Hvit hero uten sidescroll + statistikk
   (seksjonsbakgrunn var hvit -> site-grå)
   ========================================================= */
.hero--white { background:var(--gray-050) !important; color:var(--ink-dark); padding:4rem 1rem 5rem; overflow-x:hidden; }
.hero--white__inner { position:relative; max-width:var(--max-width); margin:0 auto; min-height:610px; display:block; overflow:hidden; }
.hero--white .hero__text { max-width:520px; z-index:5; position:relative; }
.stats { position:absolute; top:38px; right:0; width:625px; height:536px; pointer-events:none; overflow:visible; transform:translateX(-2%); }
.stats__img{
  position:absolute; display:block; border-radius:14px; max-width:100%; height:auto;
  filter: drop-shadow(0 8px 17px rgba(0,0,0,.1));
}
.s1 { width: 276px; height: 129px; left: 30px;  top: 0px; }
.s2 { width: 276px; height: 129px; left: 0px;   top: 196px; }
.s3 { width: 276px; height: 129px; left: 360px; top: 60px; }
.s4 { width: 276px; height: 129px; left: 350px; top: 231px; }
.s5 { width: 276px; height: 129px; left: 170px; top: 410px; }

.hero__title_undersite{
  font-size:clamp(2.1rem,2vw,3.7rem);
  font-weight:600;
  line-height:1.14;
  margin:0 0 1.5rem;
  color:var(--blue-900);
  letter-spacing:-.01em
}
.hero__body_undersite{
  margin:0 0 2.5rem;
  font-size:1.17rem;
  color:#000;
  max-width:38ch;
}

/* Mobiljusteringer for hero white */
@media (max-width: 1100px) {
  .hero--white__inner { min-height:unset; text-align:center; }
  .hero--white .hero__text { max-width:560px; margin:0 auto; }
  .feature-list{ display:inline-block; text-align:left; margin:0 auto 1.6rem; }
  .hero__cta{ justify-content:center; }
  .stats{
    position:static; width:auto; height:auto; margin-top:1.5rem;
    display:grid; grid-template-columns:1fr 1fr; gap:12px; transform:none;
    grid-template-areas:"s5 s5" "s1 s2" "s3 s4";
  }
  .stats__img{ position:static; width:100%; height:auto; filter:none; border-radius:10px; }
  .s5{ grid-area:s5; } .s1{ grid-area:s1; } .s2{ grid-area:s2; } .s3{ grid-area:s3; } .s4{ grid-area:s4; }
  .hero__title_undersite { font-size: clamp(1.8rem, 6vw, 2.2rem); margin-bottom:.9rem; }
  .hero__body_undersite  { font-size: 1rem; margin-bottom:1.6rem; }
}

/* =========================================================
   Modul-intro (seksjon var hvit -> site-grå)
   ========================================================= */
.module-intro{ background:var(--gray-050); color:var(--ink-dark); padding:2.5rem 1rem 0; }
.module-intro__inner{ max-width:var(--max-width); margin:0 auto; }
.module-intro h2{ font-size:clamp(1.6rem, 2.6vw, 2.25rem); line-height:1.2; margin:0 0 .75rem; letter-spacing:-.01em; font-weight:600; }
.module-intro__lead{ font-size:clamp(1rem, 1.4vw, 1.125rem); margin:0 0 1rem; }
.module-intro__bullets{ display:grid; gap:.5rem; margin:0 0 1.25rem; padding:0; list-style:none; }
.module-intro__bullets li{ position:relative; padding-left:1.25rem; }
.module-intro__bullets li::before{
  content:""; position:absolute; left:0; top:.55em; width:.5rem; height:.5rem; border-radius:50%;
  background:#000; box-shadow:0 0 0 2px rgba(0,0,0,.04);
}
.module-intro__actions{ display:flex; gap:.75rem; align-items:center; }
@media (min-width: 960px){ .module-intro{ padding:3rem 1rem 0; } }

/* =========================================================
   How it works (egen farge beholdes)
   ========================================================= */
.how-it-works{
  --hiw-max: var(--max-width, 1200px);
  --hiw-gap: clamp(1rem, 2vw, 2rem);
  --hiw-box-w: clamp(180px, 26vw, 260px);
  --hiw-radius: 14px;
  --hiw-border: 1px solid rgba(0,0,0,.08);
  --hiw-bg: var(--ink-light);
  --hiw-ink: var(--ink-dark);
  --hiw-dark: var(--blue-900);
  --hiw-dot: var(--blue-900);
  --hiw-dot-size: 8px;
  --hiw-dot-gap: 10px;
  padding:2rem 1rem 3rem;
  color:var(--hiw-ink);
  background-color: var(--lion-200);
}
.how-it-works__inner{ max-width:var(--hiw-max); margin:0 auto; }
.hiw__title{ margin:0 0 1rem; font-weight:600; letter-spacing:-.01em; }
.hiw__lead{ max-width:60ch; margin-top:1rem; font-size:.95rem; opacity:.9; }
.hiw__flow{ display:flex; align-items:center; justify-content:center; gap:var(--hiw-gap); flex-wrap:nowrap; overflow:hidden; }
.hiw__box{ width:var(--hiw-box-w); aspect-ratio:4/3; background:var(--hiw-bg); border:var(--hiw-border); border-radius:var(--hiw-radius); box-shadow:0 8px 20px rgba(0,0,0,.06); display:grid; grid-template-rows:1fr auto; padding:clamp(.75rem,1.2vw,1rem); }
.hiw__box--dark{ background:var(--hiw-dark); border:1px solid rgba(255,255,255,.08); color:#fff; }
.hiw__img{ width:100%; height:100%; object-fit:contain; display:block; filter: drop-shadow(0 10px 18px rgba(0,0,0,.18)); }
.hiw__box--logos .hiw__logos{ display:grid; grid-auto-rows:1fr; gap:.75rem; align-items:center; justify-items:center; height:100%; }
.hiw__img--logo{ width:72%; max-height:56%; object-fit:contain; filter: brightness(0) invert(1) drop-shadow(0 8px 14px rgba(0,0,0,.35)); }
.hiw__caption{ margin-top:.5rem; }
.hiw__link--plain{ font-size:.92rem; color:currentColor; text-decoration:underline; }
.hiw__link--plain:hover{ opacity:.85; }
.hiw__dots{ display:inline-flex; align-items:center; justify-content:center; gap:var(--hiw-dot-gap); align-self:center; padding-inline:.25rem; min-width: calc(var(--hiw-dot-size) * 5 + var(--hiw-dot-gap) * 4); }
.hiw__dots span{ width:var(--hiw-dot-size); height:var(--hiw-dot-size); border-radius:50%; background:var(--hiw-dot); opacity:1; }
@media (max-width:800px){ .hiw__flow{ flex-direction:column; gap:1rem; } .hiw__dots{ transform:rotate(90deg); } }

/* =========================================================
   Rapporter – desktop/mobil
   ========================================================= */
:root{ --rep-max: var(--max-width, 1200px); --rep-ink: var(--ink-dark); --rep-shadow-1: 0 18px 40px rgba(0,0,0,.12); --rep-shadow-2: 0 6px 16px rgba(0,0,0,.10); }
.reports-d{ padding: clamp(2rem,4vw,4rem) 1rem; color: var(--rep-ink); }
.reports-d__inner{ max-width: var(--rep-max); margin: 0 auto; display:grid; grid-template-columns:1.1fr 1fr; align-items:center; gap: clamp(1.5rem,4vw,3.5rem); }
.reports-d__text h2{ margin:0 0 .75rem; line-height:1.1; font-weight:600; letter-spacing:-.01em; }
.reports-d__lead{ margin:0 0 1rem; opacity:.9; }
.reports-d__list{ margin:.5rem 0 0; padding-left:1.2rem; }
.reports-d__list li{ margin:.25rem 0; }
.reports-d__figure{ margin:0; }
.reports-d__mockup{ width:min(680px,100%); margin-inline:auto; }
.reports-d__mockup img{ display:block; width:100%; height:auto; border-radius:10px; }

.reports-m{ display:none; padding:2rem 1rem 2.5rem; color: var(--rep-ink); }
.reports-m__inner{
  max-width: var(--rep-max); margin:0 auto; display:grid; grid-template-columns:1fr 1fr;
  grid-template-areas:"head head" "list mockup"; gap:1rem 1.25rem; align-items:start;
}
.reports-m__head{ grid-area:head; }
.reports-m__head h2{ margin:0 0 .5rem; font-weight:600; line-height:1.12; letter-spacing:-.01em; font-size:clamp(1.5rem,6vw,2rem); }
.reports-m__lead{ margin:0 0 .5rem; opacity:.9; }
.reports-m__intro{ margin:0 0 .25rem; }
.reports-m__list{ grid-area:list; margin:0; padding-left:1.2rem; }
.reports-m__list li{ margin:.22rem 0; }
.reports-m__figure{ grid-area:mockup; margin:0; }
.reports-m__mockup{ justify-self:end; width:min(360px,95%); transform:translateY(-6px); }
.reports-m__mockup img{ display:block; width:100%; height:auto; border-radius:10px; }
@media (max-width:380px){
  .reports-m__inner{ grid-template-columns:1fr; grid-template-areas:"head" "mockup" "list"; }
  .reports-m__mockup{ width:100%; justify-self:stretch; transform:none; }
}
@media (max-width:800px){ .reports-d{ display:none; } .reports-m{ display:block; } }

/* =========================================================
   Budsjett (egen bakgrunn beholdes)
   ========================================================= */
.budget{
  --budget-bg: var(--lion-200);
  --max: var(--max-width);
  --ink: var(--ink-dark);
  background:
    radial-gradient(120% 100% at 70% 60%, rgba(0,0,0,.10) 0, rgba(0,0,0,0) 60%),
    var(--budget-bg);
  color: var(--ink);
  padding: clamp(2rem, 6vw, 5rem) 1rem;
}
.budget__inner{ max-width:var(--max); margin:0 auto; display:grid; grid-template-columns:.9fr 1.1fr; gap: clamp(1rem,4vw,2.5rem); align-items:center; }
.budget__text h2{ margin:0; line-height:1.1; font-weight:600; letter-spacing:-.01em; text-align:center; }
.budget__card{ margin:0; position:relative; background:#fff; border-radius:5px; box-shadow:0 18px 40px rgba(0,0,0,.18), 0 6px 16px rgba(0,0,0,.12); overflow:hidden; }
.budget__card img{ display:block; width:min(760px,100%); height:auto; }
.budget__card::after{
  content:""; position:absolute; left:8%; right:8%; bottom:-12%; height:22%;
  border-radius:999px; background: radial-gradient(60% 100% at 50% 0%, rgba(0,0,0,.30), rgba(0,0,0,0) 70%); pointer-events:none;
}
@media (max-width:900px){ .budget__inner{ grid-template-columns:1fr; gap:1.25rem; } .budget__text{ text-align:left; } .budget__card img{ width:100%; } }

/* =========================================================
   Suppliers
   ========================================================= */
.suppliers{ --max: var(--max-width); --tile-bg: var(--blue-900); --tile-ink:#fff; --gap: clamp(3rem, 3vw, 3rem); padding:1.5rem 1rem 2rem; }
.suppliers__inner{ max-width:var(--max); margin:0 auto; }
.suppliers h2{ margin:0 0 1rem; font-weight:600; letter-spacing:-.01em; color:var(--ink-dark); }
.suppliers__grid{ display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:var(--gap); }
.supplier{ background:var(--tile-bg); color:var(--tile-ink); border-radius:4px; box-shadow:0 8px 24px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.08); min-height:86px; padding:14px; display:grid; place-items:center; }
.supplier_white_off{ background:var(--tile-bg); color:var(--tile-ink); border-radius:4px; box-shadow:0 8px 24px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.08); min-height:86px; padding:14px; display:grid; place-items:center; }
.supplier img{ max-width:72%; max-height:44px; object-fit:contain; display:block; filter: brightness(0) invert(1); opacity:.98; transition: transform .15s ease, opacity .15s ease; }
.supplier--sg img{ filter: grayscale(1) brightness(1); }
.supplier:hover img{ transform:scale(1.03); opacity:1; }
.supplier--text{ text-align:center; font-weight:600; letter-spacing:.2px; }
.supplier--text span{ display:block; }
@media (max-width:900px){
  .suppliers__grid{ grid-template-columns:repeat(3,minmax(0,1fr)); gap:.75rem; }
  .supplier{ min-height:74px; padding:10px; border-radius:8px; }
  .supplier img{ max-width:82%; max-height:48px; }
  .supplier--text{ font-size:.9rem; line-height:1.1; }
}
@media (max-width:380px){ .suppliers__grid{ gap:.5rem; } .supplier{ min-height:70px; padding:8px; } .supplier img{ max-height:46px; } }

/* =========================================================
   Om oss – hero/slices/fokus
   ========================================================= */
.about-hero{
  --about-overlay: rgba(0,0,0,.45);
  --about-ink: var(--ink-light);
  --about-maxw: var(--max-width);
  position:relative; color:var(--about-ink);
  min-height: clamp(380px, 150vh, 720px);
  display:grid; place-items:center; padding:clamp(2rem,5vw,4rem) 1rem; overflow:hidden;
  background:
    linear-gradient(var(--about-overlay), var(--about-overlay)),
    var(--about-hero-bg) center/cover no-repeat,
    radial-gradient(120% 100% at 50% 100%, rgba(0,0,0,.15), transparent 60%);
}
.about-hero::after{ content:""; position:absolute; inset:0; box-shadow: inset 0 -80px 120px rgba(0,0,0,.25), inset 0 0 80px rgba(0,0,0,.18); pointer-events:none; }
.about-hero__inner{ position:relative; z-index:1; max-width:var(--about-maxw); margin:0 auto; text-align:center; padding-inline: clamp(8px, 2vw, 24px); }
.about-hero__title{ margin:0 0 .8rem; font-weight:600; letter-spacing:-.01em; line-height:1.15; text-wrap:balance; font-size:clamp(1.9rem, 4.8vw, 3.1rem); text-shadow:0 2px 6px rgba(0,0,0,.35); }
.about-hero__lead{ margin:0; max-width:62ch; margin-inline:auto; font-size: clamp(1.25rem, 1.6vw, 1.15rem); line-height:1.5; color: rgba(255,255,255,.92); text-shadow:0 1px 4px rgba(0,0,0,.35); }
@media (max-width:900px){ .about-hero{ min-height: clamp(340px, 56vh, 560px); --about-overlay: rgba(0,0,0,.50); } .about-hero__lead{ max-width:48ch; } }
@media (max-width:560px){ .about-hero{ padding:2.2rem 1rem; } .about-hero__title{ margin-bottom:.6rem; } .about-hero__lead{ font-size:1rem; } }

/* Seksjon var hvit -> site-grå */
.about-slice{ --slice-maxw: var(--max-width); --slice-gap: clamp(1rem,4vw,3rem); background:var(--gray-050); padding: clamp(1.5rem,4vw,3rem) 1rem; }
.about-slice__inner{ max-width:var(--slice-maxw); margin: 0 auto; display:grid; grid-template-columns:1.1fr 1fr; gap:var(--slice-gap); align-items:center; }
.about-slice__media{ margin:0; overflow:hidden; box-shadow:0 14px 34px rgba(0,0,0,.12); }
.about-slice__media img{ display:block; width:100%; height:auto; }
.about-slice__text{ color:var(--ink-dark); font-size:1.05rem; line-height:1.6; }
@media (max-width:900px){ .about-slice__inner{ grid-template-columns:1fr; } .about-slice__media{ order:1; } .about-slice__text{ order:2; font-size:1rem; } }

/* Fokus (egen plum beholdes) */
.about-focus{
  --focus-bg: var(--plum);
  --focus-ink: #ffffff;
  --focus-dim: rgba(255,255,255,.88);
  --focus-maxw: var(--max-width);
  background: var(--focus-bg); color: var(--focus-ink);
  padding: clamp(2.5rem, 5vw, 4rem) 1rem; text-align:center;
}
.about-focus__inner{ max-width:var(--focus-maxw); margin:0 auto; }
.about-focus__title{ font-size:clamp(1.8rem,4vw,2.6rem); font-weight:600; margin:0 0 2.2rem; }
.about-focus__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(2rem,3vw,3rem); text-align:left; justify-items:center; }
.about-focus__item{ display:flex; flex-direction:column; align-items:flex-start; color:var(--focus-dim); }
.about-focus__icon{ height:52px; margin-bottom:1rem; }
.about-focus__icon img{ display:block; height:100%; width:auto; filter:brightness(0) invert(1); opacity:.95; }
.about-focus__subtitle{ color:var(--focus-ink); font-size:1.15rem; font-weight:600; margin:0 0 .6rem; }
.about-focus__item p{ margin:0; font-size:1rem; line-height:1.55; max-width:38ch; }
@media (max-width:900px){ .about-focus__grid{ grid-template-columns:1fr; text-align:center; } .about-focus__item{ align-items:center; } .about-focus__icon{ margin-bottom:.8rem; } .about-focus__item p{ max-width:50ch; } }

/* Historie – farger bundet til paletten (seksjon var hvit -> site-grå) */
/* ====== Basic 3-up slider ====== */
.about-history{
  --ah-maxw: var(--max-width, 1200px);
  --ink: var(--ink-dark, #0f172a);
  --bg: var(--gray-050, #f6f7f8);
  --gap: 16px;                        /* mellomrom mellom kort */
  --card-1: var(--blue-900, #073B4C);
  --card-2: var(--plum, #593440);
  --card-3: var(--lion, #b99857);

  color: var(--ink);
  background: var(--bg);
  padding: clamp(2rem,5vw,3.5rem) 1rem;
}
.about-history__inner{ max-width:var(--ah-maxw); margin:0 auto; }
.about-history__title{
  margin:0 0 1rem; text-align:center; font-weight:600;
  letter-spacing:-.01em; font-size:clamp(1.8rem,4vw,2.4rem);
}

/* Slider-ramme */
.ah-slider{ position:relative; }
.ah-viewport{
  overflow-x:auto; overflow-y:hidden;
  scrollbar-width:none; -ms-overflow-style:none;
}
.ah-viewport::-webkit-scrollbar{ display:none; }

/* Track & cards */
.ah-track{
  display:flex; gap:var(--gap); padding:0; margin:0; list-style:none;
}
.ah-card{
  flex: 0 0 calc((100% - var(--gap)*2) / 3);  /* 3 per view */
  border-radius:20px; color:#fff;
  padding:clamp(1rem,2.2vw,1.4rem); min-height:220px;
  display:flex; flex-direction:column; justify-content:center;
}
.ah-card:nth-child(3n+1){ background:var(--card-1); }
.ah-card:nth-child(3n+2){ background:var(--card-2); }
.ah-card:nth-child(3n+3){ background:var(--card-3); }
.ah-card__year{ margin:0 0 .4rem; font-weight:700; letter-spacing:.5px; font-size:clamp(1.4rem,3.2vw,2rem); }
.ah-card__text{ margin:0; line-height:1.55; opacity:.97; }

/* Piler */
.ah-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  width:46px; height:46px; border-radius:999px;
  border:1px solid rgba(0,0,0,.5);
  background:#fff; color:var(--ink); display:grid; place-items:center;
  box-shadow:0 6px 14px rgba(0,0,0,.08);
  z-index:2; cursor:pointer;
  transition:transform .12s ease, background .12s ease, opacity .12s ease;
}
.ah-arrow:hover{ transform:translateY(-50%) translateY(-1px); background:#f6f7f8; }
.ah-arrow[disabled]{ opacity:.4; pointer-events:none; }
.ah-prev{ left:-6px; }   /* kan justeres til 8–12px inne i viewport hvis ønskelig */
.ah-next{ right:-6px; }

/* Tablet: 2 per view */
@media (max-width: 1100px){
  .ah-card{ flex-basis: calc((100% - var(--gap)) / 2); }
}
/* Mobil: 1 per view */
@media (max-width: 680px){
  .ah-card{ flex-basis: 100%; }
  .ah-prev{ left:6px; }
  .ah-next{ right:6px; }
}



/* =========================================================
   Kontakt oss
   ========================================================= */
.contact-page .contact-hero h1 { letter-spacing:-0.01em; font-weight:600; }
.contact-page .contact-hero .lead { max-width:46ch; }
.contact-page .contact-hero__img { max-width:460px; }

/* Skjema-kortet (egen sand/lys) */
.contact-page .contact-card { background: var(--lion-200); border:1px solid rgba(0,0,0,.05); }
.contact-page .contact-card .form-label { font-weight:600; }
.contact-page .contact-card .form-control { background: #EFE9DF; border:0; border-radius:.7rem; height:44px; }
.contact-page .contact-card textarea.form-control { height:auto; min-height:120px; }
.contact-page .thankyou-box { color: var(--ink-dark); animation: fadeIn .5s ease forwards; }
@keyframes fadeIn { from {opacity:0; transform: translateY(10px);} to {opacity:1; transform:none;} }

/* Team-seksjon */
.contact-page .right-col { min-height:100%; }
.contact-page .contact-aside-title { max-width:480px; line-height:1.05; }
.contact-page .contact-team { margin-top:1rem; }
.contact-page .team-card { background: var(--gray-300); border:1px solid rgba(0,0,0,.06); color:#000; }
.contact-page .team-card a,
.contact-page .team-card a:link,
.contact-page .team-card a:visited{ color:#000 !important; text-decoration:none; }
.contact-page .team-card a:hover, .contact-page .team-card a:focus{ color:#2d2d2d !important; text-decoration:underline; }
.contact-page .team-card .text-muted{ color: rgba(0,0,0,.85) !important; }
.contact-page .team-photo{ width:112px; height:112px; object-fit:cover; border-radius:16px; flex:0 0 112px; background: var(--blue-900); }

/* =========================================================
   Under konstruksjon
   ========================================================= */
:root{ --uc-ink: var(--blue-900); --uc-btn: var(--lion); --uc-maxw:1200px; }
.uc-hero{ position:relative; min-height:60vh; display:flex; align-items:center; overflow:hidden; }
.uc-hero--light{ background: var(--gray-050); }
.uc-inner{
  position:relative;
  z-index:1;
  width:100%;
  max-width:var(--uc-maxw);
  margin:0 auto;
  padding:clamp(24px,5vw,72px);
  color:var(--uc-ink);
}.uc-title{ margin:0 0 .5rem; font-weight:600; line-height:1; letter-spacing:-0.01em; font-size:clamp(1.6rem,3.6vw,3rem); color:#000; }
.uc-lead{ margin:0 0 1.25rem; opacity:.9; font-size:clamp(1rem,1.4vw,1.125rem); max-width:60ch; color:#000; }
.uc-art{
  position:absolute;
  right:0;
  bottom:0;
  height:115%;
  max-width:none;
  opacity:.22;
  z-index:0;           /* bak innholdet */
  pointer-events:none; /* ikke klikkbar */
}
@media (max-width:768px){ .uc-art{ height:85%; opacity:.18; } }

/*-- ===== Fjernhjelp / TeamViewer QuickSupport ===== */
/* --- Fjernhjelp blokk --- */
.remote-help__inner{ max-width:900px; margin:0 auto; }
.remote-help__lead{ margin:.25rem 0 1rem; color:#21313a; }
.steps{ margin:1.25rem 0 0.5rem; padding-left:1.2rem; }
.remote-help__contact{ margin:.25rem 0 0; color:#3b4c55; }

/* Bildknapp – responsiv, uten å forvrenge bildefilen */
.dl-image{ display:inline-block; line-height:0; }
.dl-image img{
  max-width:100%;
  height:auto;
  display:block;
  border-radius:12px;              /* valgfritt, matcher knappefølelse */
  box-shadow:0 6px 20px rgba(0,0,0,.12);
}
.dl-image:hover img{ transform:translateY(-1px); transition:transform .12s ease; }


/* =========================================================
   Ansattfoto
   ========================================================= */

 .hero-slider {
  position: relative;
}

.hs-viewport {
  position: relative;
  overflow: hidden;
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 16px;
  height: clamp(320px, 60vh, 720px);
}

.hs-track {
  display: flex;
  transition: transform 0.6s ease;
  height: 100%;
}

.hs-slide {
  min-width: 100%;
  position: relative;
}

.hs-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Tekst-overlay */
.hs-overlay {
  position: absolute;
  inset: auto 0 0 0;
  padding: 2rem;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 80%);
  color: white;
}

.hs-title {
  font-size: clamp(1.6rem, 4vw, 2.6rem);
  margin: 0 0 0.25rem;
  font-weight: 700;
}

.hs-lead {
  margin: 0 0 0.75rem;
  font-size: clamp(1rem, 2.4vw, 1.2rem);
}

.hs-cta {
  display: inline-block;
  padding: 0.6rem 1.1rem;
  border-radius: 999px;
  background: #b99857;
  color: #111;
  text-decoration: none;
  font-weight: 600;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

/* Piler */
.hs-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: none;
  color: #000;
  font-size: 3rem;
  cursor: pointer;
  padding: 0 0.5rem;
  transition: opacity 0.2s ease;
  user-select: none;
}

.hs-arrow:hover {
  opacity: 0.6;
}

.hs-prev {
  left: 16px;
}

.hs-next {
  right: 16px;
}
