/* ==========================================================================
   TRYGG PÅ JOBB — styles.css (global)
   Lys modus låst. WCAG, mikrointeraksjoner.
   ========================================================================== */

/* ---------------------- Design tokens ---------------------- */
:root{
  /* Fortell UA at kun lys er støttet (skjema/scrollbars etc) */
  color-scheme: light;

  /* Farger (lys) */
  --bg:#ffffff;
  --surface:#f6f8fb;
  --panel:#ffffff;
  --text:#0a0a0a;
  --muted:#6b7280;
  --border: color-mix(in oklab, #000 18%, transparent);

  /* Brand */
  --brand:#0ea5a5;
  --brand-ink:#063d3d;

  /* Aksenfarger */
  --accent-1:#0ea5a5;
  --accent-2:#22d3ee;

  /* Effekter / radius / timing */
  --shadow-sm:0 1px 2px rgba(2,6,23,.06);
  --shadow-md:0 8px 24px rgba(2,6,23,.10);
  --shadow-lg:0 14px 38px rgba(2,6,23,.16);
  --radius:14px;
  --radius-lg:18px;
  --transition:160ms cubic-bezier(.22,1,.36,1);

  /* Layout */
  --container:1100px;
  --container-narrow:820px;

  /* Focus ring */
  --focus:0 0 0 3px rgba(14,165,165,.28);
  --ring:0 0 0 3px color-mix(in oklab, var(--accent-1) 45%, transparent);
}

/* Merk: all dark-mode-styling er fjernet.
   Ingen @media (prefers-color-scheme: dark) lenger. */

/* ---------------------- Reset/base ---------------------- */
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--bg); color:var(--text);
  font: 400 15px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  text-rendering: optimizeLegibility;
}
img{max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:none}
a:hover{opacity:.98}
a:focus-visible{outline:none; box-shadow:var(--focus); border-radius:10px}
::selection{background: color-mix(in oklab, var(--brand) 25%, transparent)}

/* ---------------------- Layout ---------------------- */
.container{max-width:var(--container); margin:0 auto; padding:0 18px}
.container.narrow{max-width:var(--container-narrow)}
section[id]{
  scroll-margin-top: calc(var(--headerH, 84px) + 8px);
}
/* Skip-link */
.skip-link{
  position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden
}
.skip-link:focus{
  position:fixed; left:10px; top:10px; width:auto; height:auto; padding:.5rem .75rem;
  background:#111; color:#fff; border-radius:.5rem; z-index:10000
}

/* ---------------------- Typografi ---------------------- */
h1,h2,h3{margin:0 0 8px}
.h2{ font-size: clamp(24px, 3.6vw, 32px) }
.h3{ font-size:18px; margin:0 }
h1{
  font-size: clamp(36px, 6vw, 64px);
  line-height:1.08;
  letter-spacing:-.01em;
  font-weight:800;
  text-wrap:balance;
}
.lead{ color:#0f172a; max-width: 82ch }
.muted, .subtle{ color:var(--muted) }
.accent{
  background:linear-gradient(90deg,var(--accent-1), var(--accent-2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* ---------------------- Seksjoner & utilities ---------------------- */
.section{ padding:56px 0 }
.section.alt{
  background: color-mix(in oklab, var(--bg) 96%, #000 4%);
  border-block: 1px solid var(--border);
}
/* La hero ligge bak sticky-headeren fra toppen */
.section.hero{
  /* trekker hele hero-seksjonen opp bak headeren */
  margin-top: calc(-1 * var(--headerH, 60px));
}

.stack{ display:grid; gap:10px }
.center{ text-align:center }
.mt-1{ margin-top:8px }
.mt-2{ margin-top:10px }
.mt-3{ margin-top:16px }
.mt-4{ margin-top:24px }

/* Progressive reveal (IntersectionObserver i index) */
[data-reveal]{
  opacity:0;
  transform: translateY(14px) scale(.995);
  filter: saturate(.9);
  transition:
    opacity .7s cubic-bezier(.22,1,.36,1),
    transform .7s cubic-bezier(.22,1,.36,1),
    filter .7s cubic-bezier(.22,1,.36,1);
  transition-delay: var(--d, 0ms);
}
[data-reveal].in-view{
  opacity:1;
  transform:none;
  filter:none;
}

/* ---------------------- Header / Navbar ---------------------- */
.site-header{
  position:sticky; top:0; z-index:999;
  backdrop-filter:saturate(160%) blur(6px); -webkit-backdrop-filter:saturate(160%) blur(6px);
  background: color-mix(in oklab, var(--bg) 90%, #fff 10%);
  border-bottom:1px solid var(--border);
  transition: box-shadow .2s ease, background .2s ease;
}
.site-header.is-scrolled{ box-shadow: var(--shadow-sm) }

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:60px;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  letter-spacing:-.01em;
  color:inherit;
}
.brand img{
  width:28px;
  height:28px;
  border-radius:6px;
  display:block;
}

.nav{
  display:flex;
  align-items:center;
  gap:10px;
}
.nav a{
  color:inherit;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid transparent;
}
.nav a:hover{
  border-color:var(--border);
  background: color-mix(in oklab, var(--bg) 92%, #000 8%);
}
.nav .cta{
  font-weight:800;
  background:var(--brand);
  color:var(--brand-ink);
  border:1px solid color-mix(in oklab, var(--brand) 60%, transparent);
  border-radius:12px;
}
.nav .cta:hover{ filter:brightness(0.98) }

/* Mobilmeny (enkel fallback – header.html har mer avansert logikk) */
.nav-toggle{
  display:none;
  appearance:none;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--bg) 92%, #000 8%);
  width:38px; height:38px;
  border-radius:10px;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.nav-toggle svg{ display:block }
.nav-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.25);
  z-index:998;
}

@media (max-width: 900px){
  .nav{
    display:none;
    position:absolute;
    inset:auto 18px 10px 18px;
    flex-direction:column;
    gap:8px;
    padding:10px;
    border:1px solid var(--border);
    border-radius:14px;
    background:var(--bg);
    box-shadow:var(--shadow-md);
  }
  .nav[data-open="true"]{ display:flex }
  .nav a{ width:100%; text-align:center }
  .nav .cta{ width:100% }
  .nav-toggle{ display:inline-flex }
  .nav-overlay[data-open="true"]{ display:block }
}

/* ---------------------- Kort / grid ---------------------- */
.grid{ display:grid; gap:16px }
.auto-fit{ grid-template-columns: repeat(auto-fit, minmax(260px,1fr)) }
.card{
  border:1px solid var(--border);
  border-radius:16px;
  background: color-mix(in oklab, var(--bg) 92%, #000 8%);
  padding:18px;
  box-shadow: var(--shadow-sm);
  transition:
    transform .25s var(--transition),
    box-shadow .25s var(--transition),
    border-color .25s var(--transition),
    background .25s var(--transition);
}
.card:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}
.services .icon{
  width:46px; height:46px;
  border-radius:12px;
  border:1px solid var(--border);
  display:grid;
  place-items:center;
  background:#fff;
}

/* ---------------------- Metrics ---------------------- */
.metrics{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(200px,1fr));
  gap:14px;
  margin-top:18px;
}
.metric{
  border:1px solid var(--border);
  border-radius:14px;
  padding:14px;
  background: color-mix(in oklab, var(--bg) 96%, #000 4%);
  text-align:center;
  box-shadow: var(--shadow-sm);
}
.metric .num{
  font-size: clamp(28px, 4.6vw, 40px);
  font-weight:800;
  letter-spacing:-.02em;
}

/* ---------------------- Prosess / tidslinje ---------------------- */
.timeline{
  position:relative;
  display:grid;
  gap:14px;
  counter-reset: step;
}
.step{
  border:1px solid var(--border);
  border-radius:14px;
  background: color-mix(in oklab, var(--bg) 96%, #000 4%);
  padding:16px;
  display:grid;
  gap:6px;
}
.step::before{
  counter-increment: step;
  content: counter(step);
  width:28px; height:28px;
  border-radius:999px;
  display:grid;
  place-items:center;
  font-weight:800;
  background:var(--accent-1);
  color:var(--brand-ink);
}

/* ---------------------- Karusell (gammel testimonials-komponent) ---------------------- */
.carousel{
  overflow:auto;
  scroll-snap-type:x mandatory;
  display:flex;
  gap:14px;
  padding-bottom:4px;
}
.carousel::-webkit-scrollbar{ height:10px }
.carousel > article{
  scroll-snap-align:center;
  min-width: min(520px, 88vw);
  flex:0 0 auto;
  border:1px solid var(--border);
  border-radius:16px;
  padding:18px;
  background: color-mix(in oklab, var(--bg) 92%, #000 8%);
  box-shadow: var(--shadow-sm);
}
.carousel-nav{
  display:flex;
  justify-content:center;
  gap:10px;
  margin-top:10px;
}
.carousel-nav .dot{
  width:8px; height:8px;
  border-radius:50%;
  background: color-mix(in oklab, #000 18%, transparent);
}
.carousel-nav .dot[aria-current="true"]{ background: var(--accent-1) }

/* ---------------------- FAQ – aksessibel akkordion ---------------------- */
.faq{
  max-width:900px;
  margin: 0 auto;
}
.faq-item{
  border:1px solid var(--border);
  border-radius:14px;
  background: color-mix(in oklab, var(--bg) 92%, #000 8%);
  margin:0 0 10px;
}
.faq-btn{
  width:100%;
  background:transparent;
  border:0;
  padding:14px 16px;
  text-align:left;
  font-weight:800;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  font-size:16px;
}
.faq-btn:focus-visible{
  outline:none;
  box-shadow: var(--ring);
  border-radius:12px;
}
.faq-panel{
  height:0;
  overflow:hidden;
  transition: height .28s ease;
}
.faq-item[open] .faq-panel{ height:auto } /* noscript-tilfelle */
.faq-content{
  padding:0 16px 16px;
  color:var(--muted);
}
.chev{ transition: transform .25s ease }
.faq-item[aria-expanded="true"] .chev{ transform: rotate(180deg) }

/* ---------------------- Skjema ---------------------- */
form.form{ max-width:720px; margin-inline:auto }
.form label{ display:grid; gap:6px; font-weight:600 }
.form.row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
@media (max-width:740px){
  .form.row{ grid-template-columns:1fr }
}

.form input,
.form textarea{
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  color:var(--text);
  height:44px;
  padding:10px 12px;
  font:400 14px/1.2 system-ui;
  transition:
    border-color var(--transition),
    box-shadow var(--transition),
    background var(--transition);
}
.form textarea{
  height:auto;
  min-height:120px;
  resize:vertical;
}
.form input::placeholder,
.form textarea::placeholder{
  color: color-mix(in oklab, var(--muted) 70%, transparent);
}
.form input:focus,
.form textarea:focus{
  outline:none;
  border-color: var(--brand);
  box-shadow: var(--focus);
}
.form input:invalid,
.form textarea:invalid{
  border-color:#ef4444;
}

/* ---------------------- Knapper (robust mot flex-shrink) ---------------------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:700;
  font-size:15px;
  line-height:1.2;
  border-radius:12px;
  padding:12px 16px;
  min-height:44px;
  border:1px solid var(--border);
  background:#fff;
  color:#111;
  box-shadow:var(--shadow-sm);
  transition:
    transform var(--transition),
    box-shadow var(--transition),
    filter var(--transition),
    background var(--transition);
  white-space:nowrap;

  /* Kritisk del: ikke la flex-container krympe knappen under innholdet */
  flex: 0 0 auto;
  min-width: max-content;
  max-width: 100%;
  box-sizing: border-box;
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow-md);
}
.btn:active{ transform:translateY(0) }
.btn:focus-visible{
  outline:none;
  box-shadow:var(--focus);
}
.btn[disabled]{ opacity:.55; pointer-events:none }

.btn-primary{
  background:var(--brand);
  color:var(--brand-ink);
  border-color: color-mix(in oklab, var(--brand) 60%, transparent);
}
.btn-primary:hover{ filter:brightness(.98) }

.btn-ghost{ background:#fff; color:#111 }

.btn.icon svg{
  margin-left:6px;
  transition: transform .2s;
}
.btn.icon:hover svg{ transform: translateX(2px) }

/* ---------------------- Footer ---------------------- */
.site-footer{
  position:relative;
  margin-top:40px;
  border-top:1px solid var(--border);
  background: color-mix(in oklab, var(--bg) 96%, #000 4%);
}
.site-footer::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:3px;
  background: linear-gradient(90deg, var(--accent-1), var(--accent-2));
  opacity:.95;
}

.f-wrap{
  display:grid;
  gap:16px;
  padding:18px 0;
  grid-template-columns: 2fr 1fr 1.2fr;
}
@media (max-width:900px){
  .f-wrap{ grid-template-columns:1fr }
}

.f-col{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.f-brand{
  display:flex;
  align-items:center;
  gap:12px;
  color:inherit;
  text-decoration:none;
}
.f-logo{
  width:32px;
  height:32px;
  border-radius:8px;
  display:block;
}
.f-title{ font-weight:800; letter-spacing:-.01em }
.f-tagline{ margin:.1rem 0 0; color:var(--muted); font-size:13px }
.f-about{ margin:.35rem 0 0; color:var(--muted) }
.f-muted{ color:var(--muted) }

.f-head{
  font-size:15px;
  font-weight:800;
  margin:0 0 4px;
}
.f-links{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:6px;
}
.f-links a{
  color:inherit;
  text-decoration:none;
}
.f-links a:hover{ text-decoration:underline }

address.f-contact{
  font-style:normal;
  display:grid;
  gap:6px;
}
.f-cta{ margin-top:4px }

.f-badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:4px;
}
.f-badge{
  font-size:11px;
  padding:5px 8px;
  border-radius:999px;
  border:1px solid var(--border);
  color:var(--muted);
  background: color-mix(in oklab, var(--bg) 96%, #000 4%);
}

/* Kontaktliste i footer */
.site-footer .f-contact-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:4px;
}
.site-footer .f-contact-list li{
  display:flex;
  align-items:center;
  gap:8px;
  line-height:1.2;
}
.site-footer .f-contact-list a{
  color:inherit;
  text-decoration:none;
}
.site-footer .f-contact-list a:hover{
  text-decoration:underline;
}

/* Subfooter */
.site-footer .f-sub{
  border-top:1px solid var(--border);
  background: color-mix(in oklab, var(--bg) 96%, #000 4%);
}
.site-footer .f-sub-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  padding:10px 0;
}
@media (max-width:720px){
  .site-footer .f-sub-inner{
    flex-direction:column;
    align-items:flex-start;
  }
}
.site-footer .f-sub-inner small{
  color:var(--muted);
  line-height:1.2;
}
.site-footer .f-sub-inner small a{
  text-decoration:underline;
  text-underline-offset:2px;
}

/* “Bygget av” – basisbadge (Ruud Web-glow legges på i footer.html) */
.site-footer .f-provider{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  font-weight:700;
  line-height:1;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--bg) 96%, #000 4%);
  transition: box-shadow var(--transition), background var(--transition), border-color var(--transition);
}
.site-footer .f-provider img{
  width:16px;
  height:16px;
  border-radius:3px;
  display:block;
}
.site-footer .f-provider:hover{
  box-shadow: var(--shadow-sm);
  background:#fff;
  border-color: color-mix(in oklab, var(--accent-1) 45%, transparent);
}

/* ---------------------- Tilgjengelighet ---------------------- */
.visually-hidden{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* ---------------------- Redusert bevegelse ---------------------- */
@media (prefers-reduced-motion: reduce){
  *{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
}

/* ---------------------- Print ---------------------- */
@media print{
  .site-header,
  .site-footer,
  .nav-overlay{ display:none !important }
  a{ color:#000; text-decoration:underline }
}

/* Eyebrow – bruk lys aksent (matcher --accent-1/--accent-2) */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border-radius:999px;
  background: color-mix(in oklab, var(--accent-1) 18%, transparent);
  color: var(--brand-ink);
  border:1px solid color-mix(in oklab, var(--accent-1) 48%, transparent);
  font:700 12px/1.2 system-ui;
  box-shadow: inset 0 -1px 0 rgba(255,255,255,.35);
  backdrop-filter: blur(4px);
}

/* Logo i hero – enkel, uten plate bak */
.hero-logo-shell{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  /* ingen bakgrunn, ingen kant, ingen blur – kun layout */
}

.hero-logo{
  width: clamp(220px, 36vw, 520px);
  height:auto;
  display:block;
  margin:0;
  /* litt skygge kun på logoen, så den popper mot bakgrunnen */
  filter: drop-shadow(0 6px 22px rgba(0,0,0,.75));
}

