:root{
  --bg:#ffffff;--fg:#0a0a0a;--muted:#6b7280;--line:#e5e7eb;--accent:#111827;
  --maxw:960px;--radius:16px
}

/* Base */
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--fg);
  font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji"
}
a{color:inherit}
img{max-width:100%;height:auto;display:block}

/* Layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding:24px 20px}

/* ============ HEADER / NAV (ny, mobilvennlig) ============ */
.site-header {
  position: sticky; top: 0; z-index: 1000; background: #fff;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.site-header .container {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: .75rem 1rem;
}
.site-header .brand {
  display: inline-flex; align-items: center; gap: .5rem;
  text-decoration: none; color: inherit; font-weight: 600;
}
.site-header .brand img{height:46px;width:auto;display:block}

/* Hamburger */
.nav-toggle {
  appearance: none; border: 0; background: transparent; padding: .25rem; margin: 0;
  cursor: pointer; display: none;
}
.nav-toggle .nav-toggle-bar {
  display: block; width: 24px; height: 2px; background: currentColor; margin: 5px 0; border-radius: 2px;
}

/* Base nav */
.site-nav { display: block; }
.site-nav .top-level {
  display: flex; align-items: center; gap: 1rem;
  list-style: none; margin: 0; padding: 0;
}
.site-nav a, .site-nav .dropdown-toggle {
  font: inherit; text-decoration: none; color: inherit; padding: .5rem .6rem; border-radius: .5rem;
}
.site-nav .has-dropdown { position: relative; }
.site-nav .dropdown-toggle { background: transparent; border: 0; cursor: pointer; }
.site-nav .dropdown {
  position: absolute; left: 0; top: calc(100% + .25rem);
  min-width: 220px; background: #fff; border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 8px 24px rgba(0,0,0,.08); border-radius: .75rem; padding: .4rem; list-style: none;
  display: none;
}
.site-nav .has-dropdown.open > .dropdown { display: block; }
.site-nav .dropdown a { display: block; padding: .55rem .7rem; border-radius: .5rem; }
.site-nav .dropdown a:hover { background: rgba(0,0,0,.04); }

/* Hover på desktop */
@media (hover: hover) {
  .site-nav .has-dropdown:hover > .dropdown { display: block; }
}

/* Mobiloppsett */
@media (max-width: 860px) {
  .nav-toggle { display: inline-block; }
  .site-nav {
    position: fixed; inset: 0 0 0 auto; width: min(85vw, 360px);
    transform: translateX(100%); transition: transform .25s ease;
    background: #fff; border-left: 1px solid rgba(0,0,0,.06); padding: 1rem;
    overflow-y: auto; max-height: 100dvh;
  }
  .site-nav.open { transform: translateX(0); }
  body.nav-open { overflow: hidden; }

  .site-nav .top-level { flex-direction: column; align-items: stretch; gap: .25rem; }
  .site-nav a, .site-nav .dropdown-toggle { padding: .8rem .9rem; }
  .site-nav .has-dropdown { position: static; }
  .site-nav .dropdown {
    position: static; top: auto; left: auto; transform: none;
    min-width: 0; display: none; background: transparent; border: 0; box-shadow: none;
    padding: 0 .5rem .5rem;
  }
  .site-nav .has-dropdown.open > .dropdown { display: block; }
  .site-nav .dropdown a { padding-left: 1.2rem; }
}

/* Hero (generell) */
.hero{display:grid;place-items:center;text-align:center;padding:16px 0 8px}
.hero p{margin:8px 0 0;color:var(--muted)}
.hero .badge{
  margin-top:10px;display:inline-flex;gap:10px;align-items:center;
  border:1px solid var(--line);border-radius:999px;padding:6px 12px;color:var(--muted)
}

/* Intro-tekst */
.sv-text{
  margin:18px auto 16px;max-width:720px;opacity:0;transform:translateY(4px);
  animation:fadeUp .9s ease-out .1s forwards
}
@keyframes fadeUp{to{opacity:1;transform:none}}

/* CTA */
.cta{
  margin:6px 0 0;display:inline-block;border:1px solid var(--fg);border-radius:999px;
  padding:10px 18px;text-decoration:none
}
.cta:hover{background:var(--fg);color:#fff}

/* Seksjoner */
section{padding:16px 0;border-top:0}
h2{font-weight:650;font-size:clamp(18px,2.8vw,22px);margin:0 0 6px}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.card{border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.card p{margin:6px 0 0;color:var(--muted)}

/* Footer */
footer{padding:24px 0;color:var(--muted);text-align:center}

/* Redusert animasjon */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .sv-text{animation:none;opacity:1;transform:none}
}

/* ===== Intro page styles ===== */
body.intro{
  display:grid;place-items:center;background:#fff;
  font-family:system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}
svg{overflow:visible;}
.ring{stroke:#000;fill:none;stroke-linecap:round;stroke-linejoin:round;filter:url(#blur1);}
.logo,.textimg,.svtext{opacity:0;transform-origin:150px 150px;will-change:opacity,transform;}
.enter{margin-top:36px;opacity:0;transform:scale(.98);transition:opacity 800ms ease,transform 800ms ease;}
.enter a{
  display:inline-block;text-decoration:none;font-size:1.1rem;font-weight:600;letter-spacing:.05em;
  padding:12px 32px;border-radius:9999px;color:#fff;background:#111;
  box-shadow:0 6px 18px rgba(0,0,0,.15);transition:background 200ms ease,transform 200ms ease;
}
.enter a:hover{background:#000;transform:scale(1.04);}
.enter a:focus-visible{outline:2px solid #111;outline-offset:3px;}
.skip{position:fixed;right:14px;bottom:12px;font-size:13px;color:#444;user-select:none;}
.skip a{color:#444;text-decoration:none;padding:6px 10px;border-radius:8px;}
.skip a:hover{background:#f1f1f1;}

/* ===== Minimal front hero ===== */
.hero-plain{display:grid;place-items:center;text-align:center;padding:12px 0 10px;}
.hero-illustration{width:min(560px,72vw);height:auto;opacity:0;transform:translateY(6px) scale(.995);animation:heroFade .7s ease-out .05s forwards;}
.hero-tag{margin:8px 0 4px;font-weight:650;font-size:clamp(22px,4.6vw,34px);letter-spacing:.01em;}
.hero-subtle{margin:0;color:var(--muted);font-size:clamp(14px,2.2vw,16px);}
@keyframes heroFade{to{opacity:1;transform:none;}}

/* ===== Sektioner (kompakte varianter) ===== */
.section{padding:16px 0;border-top:0;}
.section.tight{padding:14px 0 6px;}
.section.soft{background:#fff;}
.section-title{margin:0 0 10px;font-size:clamp(18px,2.8vw,22px);font-weight:650;}

/* Manifest */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:0;padding:0;list-style:none;}
.pillars li{border:1px solid var(--line);border-radius:14px;padding:12px 14px;background:#fff;}
.pillars li strong{display:block;font-weight:700;margin-bottom:6px;}
.pillars li span{color:var(--muted);}

/* “Så här känns det” */
.feel-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));}
.feel-item{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff;}
.feel-item h3{margin:0 0 6px;font-size:16px;font-weight:700;}
.feel-item p{margin:0;color:var(--muted);}

/* Välfärdslöfte */
.pledge{text-align:center;}
.pledge-text{max-width:720px;margin:0 auto;color:var(--fg);}

/* Avsluttende quote */
.quote{border-top:none;padding-top:6px;padding-bottom:24px;}
.quote-text{text-align:center;color:#111;font-weight:600;font-size:clamp(16px,3.2vw,20px);}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .hero-illustration{animation:none;opacity:1;transform:none;}
}

/* ===== Rotating Gallery – 2×2 standard ===== */
.rg-gallery{clear:both;margin:0.5rem auto;padding-bottom:1.4rem;max-width:1200px;}
.rg-gallery *, .rg-gallery *::before, .rg-gallery *::after{box-sizing:border-box;}
.rg-gallery .rotogallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;align-items:stretch;aspect-ratio:auto;grid-auto-rows:auto;}
@media (max-width:760px){.rg-gallery .rotogallery-grid{grid-template-columns:1fr;}}
.rg-gallery .rotogallery-grid figure{margin:0;}
.rg-gallery .tile{position:relative;display:block;width:100%;overflow:hidden;background:#0f0f10;border-radius:14px;min-height:0;box-shadow:0 1px 10px rgba(0,0,0,.08);transition:transform .18s ease, box-shadow .18s ease;}
.rg-gallery .tile:hover{transform:translateY(-2px);box-shadow:0 4px 18px rgba(0,0,0,.12);}
.rg-gallery .tile[data-orientation="landscape"]{aspect-ratio:16/9;}
.rg-gallery .tile[data-orientation="portrait"]{aspect-ratio:4/5;}
@supports not (aspect-ratio:1/1){
  .rg-gallery .tile[data-orientation="landscape"]::before{content:"";display:block;padding-top:calc(100% * 9 / 16);}
  .rg-gallery .tile[data-orientation="portrait"]::before{content:"";display:block;padding-top:calc(100% * 5 / 4);}
  .rg-gallery .tile>img{position:absolute;inset:0;}
}
.rg-gallery .tile>img{width:100%;height:100%;display:block;object-fit:cover;object-position:center;opacity:1;transition:opacity .28s ease;background:#17181a;}
.rg-gallery .tile.is-replacing>img{opacity:0;}

/* ===== Rat Games – Regler (rg-rules) ===== */
.rg-rules.wrap{max-width:var(--container,900px);margin:20px auto;padding:0 var(--sp,16px);}
.rg-rules .page-head h1{font-size:clamp(28px,3.4vw,40px);line-height:1.15;letter-spacing:-.01em;margin:0 0 .2rem;}
.rg-rules .page-head .lead{color:var(--text-muted,#6b7280);margin:0}
.rg-rules .controls{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin:.3rem 0 .8rem;}
.rg-rules .controls .search{flex:1 1 260px;display:flex;align-items:center;gap:.5rem;border:1px solid var(--line,#e5e7eb);border-radius:.6rem;padding:.4rem .55rem;max-width:640px;}
.rg-rules .controls .search input{border:0;outline:0;width:100%;background:none;font:inherit;}
.rg-rules details.section{margin:.25rem 0;border-top:1px solid var(--line,#e5e7eb);}
.rg-rules details.section+details.section{margin-top:.3rem}
.rg-rules summary{list-style:none;cursor:pointer;user-select:none;display:flex;align-items:center;gap:.6rem;padding:.5rem 0;font-weight:700;}
.rg-rules summary::-webkit-details-marker{display:none}
.rg-rules .chev{width:10px;height:10px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg);transition:.25s transform ease;}
.rg-rules details[open]>summary .chev{transform:rotate(45deg)}
.rg-rules .anchor{opacity:0;transition:.15s opacity ease;margin-left:.5rem;color:var(--text-muted,#6b7280);text-decoration:none;}
.rg-rules summary:hover .anchor{opacity:1}
.rg-rules .content{overflow:hidden;height:0;border-top:1px solid rgba(229,231,235,.6);}
.rg-rules .inner{padding:.45rem 0 .6rem}
.rg-rules h3{font-size:clamp(18px,2.1vw,20px);margin:.5rem 0 .1rem;font-weight:700;}
.rg-rules p{margin:0 0 .35rem;max-width:70ch;}
.rg-rules .note,.rg-rules .muted,.rg-rules .meta{color:var(--text-muted,#313131)}
.rg-rules .meta{margin:.4rem 0 1rem}
@media (max-width:520px){
  .rg-rules .controls{gap:.4rem}
  .rg-rules summary{padding:.45rem 0}
  .rg-rules h3{font-size:18px}
}
@media (prefers-reduced-motion: reduce){.rg-rules .content{transition:none!important}}
@media print{
  .rg-rules .controls{display:none!important}
  .rg-rules details.section{border:0}
  .rg-rules .content{height:auto!important;overflow:visible!important;border:0}
}

/* ===== Artwall-galleri ===== */
.rg-gallery.artwall{max-width:1200px;margin:0.5rem auto;padding-bottom:1.4rem;}
.rg-gallery.artwall .rotogallery-grid{display:grid;grid-template-columns:repeat(8,1fr);grid-auto-rows:min(9vw,120px);gap:8px;}
.rg-gallery.artwall .rotogallery-grid figure{margin:0;}
.rg-gallery.artwall .tile{position:relative;overflow:hidden;border-radius:12px;background:#0f0f10;box-shadow:0 1px 10px rgba(0,0,0,.08);transition:transform .18s ease, box-shadow .18s ease;}
.rg-gallery.artwall .tile,.rg-gallery.artwall .tile[data-orientation],.rg-gallery.artwall .tile[data-need]{aspect-ratio:auto!important;}
.rg-gallery.artwall .tile:hover{transform:translateY(-2px);box-shadow:0 4px 18px rgba(0,0,0,.12);}
.rg-gallery.artwall .tile>img{position:absolute;inset:0;width:100%;height:100%;display:block;object-fit:cover;object-position:center;transition:opacity .28s ease;opacity:1;}
.rg-gallery.artwall .slot-a{grid-column:3 / span 4;grid-row:1 / span 3;}
.rg-gallery.artwall .slot-b{grid-column:1 / span 2;grid-row:1 / span 3;}
.rg-gallery.artwall .slot-c{grid-column:7 / span 2;grid-row:1 / span 2;}
.rg-gallery.artwall .slot-d{grid-column:7 / span 2;grid-row:3 / span 3;}
.rg-gallery.artwall .slot-e{grid-column:1 / span 3;grid-row:4 / span 3;}
.rg-gallery.artwall .slot-f{grid-column:4 / span 1;grid-row:4 / span 2;}
.rg-gallery.artwall .slot-g{grid-column:5 / span 2;grid-row:4 / span 2;}
.rg-gallery.artwall .slot-h{grid-column:7 / span 2;grid-row:6 / span 2;}
@media (max-width:760px){
  .rg-gallery.artwall .rotogallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:32vw;}
  .rg-gallery.artwall .slot-a{grid-column:1 / span 2;grid-row:auto / span 2;}
  .rg-gallery.artwall .slot-b{grid-column:auto / span 1;grid-row:auto / span 2;}
  .rg-gallery.artwall .slot-c{grid-column:auto / span 1;grid-row:auto / span 1;}
  .rg-gallery.artwall .slot-d{grid-column:auto / span 1;grid-row:auto / span 2;}
  .rg-gallery.artwall .slot-e{grid-column:1 / span 2;grid-row:auto / span 2;}
  .rg-gallery.artwall .slot-f{grid-column:auto / span 1;grid-row:auto / span 2;}
  .rg-gallery.artwall .slot-g{grid-column:auto / span 1;grid-row:auto / span 1;}
  .rg-gallery.artwall .slot-h{grid-column:auto / span 1;grid-row:auto / span 1;}
}

/* Kreditering */
.rg-gallery .tile .credit{
  position:absolute;right:6px;bottom:6px;padding:4px 8px;font-size:12px;line-height:1;color:#fff;
  background:rgba(0,0,0,.45);backdrop-filter:saturate(140%) blur(2px);border-radius:999px;
  pointer-events:none;user-select:none;letter-spacing:.01em;max-width:70%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.92;transition:opacity .2s ease;
}
.rg-gallery .tile:hover .credit{opacity:1;}

/* --- Fjern horisontale linjer/dividers globalt --- */
hr,.section-divider{display:none;}
/* ------- HEADER GRID: desktop (861px+) ------- */
@media (min-width: 861px){
  .mainnav{
    display:grid;
    grid-template-columns: 1fr auto 1fr;
    align-items:center;
    gap:20px;
  }
  .brand{ justify-self:center; }
  .nav-group{
    display:flex;
    align-items:center;
    gap:20px;
  }
  .nav-group.left{ justify-self:start; }
  .nav-group.right{ justify-self:end; }
  .nav-toggle{ display:none !important; }

  /* Desktop dropdown oppførsel */
  .nav-item{ position:relative; }
  .nav-item .dropdown{
    position:absolute; left:0; top:calc(100% + .25rem);
    min-width:220px; background:#fff; border:1px solid rgba(0,0,0,.08);
    box-shadow:0 8px 24px rgba(0,0,0,.08); border-radius:.75rem; padding:.4rem;
    display:none; list-style:none;
  }
  .has-menu.open > .dropdown{ display:block; }
  @media (hover:hover){
    .has-menu:hover > .dropdown{ display:block; }
  }
}

/* ------- HEADER: mobil (≤860px) beholdes ------- */
/* (du har allerede regler som: .nav-toggle vises, .nav-group skjules,
   og .mainnav.open .nav-group vises i stack) */
/* ==== HEADER: tvungen desktop-layout (861px+) ==== */
@media (min-width: 861px){
  .site-header .mainnav{
    display: grid !important;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 20px;
  }
  .site-header .brand{ justify-self: center; }
  .site-header .nav-group{
    display: flex !important;
    align-items: center;
    gap: 20px;
  }
  .site-header .nav-toggle{ display: none !important; }
  .site-header .has-menu{ position: relative; }
  .site-header .has-menu .dropdown{
    position: absolute; left: 0; top: calc(100% + .25rem);
    min-width: 220px; display: none; list-style: none;
    background: #fff; border: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 8px 24px rgba(0,0,0,.08); border-radius: .75rem; padding: .4rem;
  }
  .site-header .has-menu.open > .dropdown{ display: block; }
}
/* ==== HEADER (desktop 861px+) – tett, pent, logo midt ==== */
@media (min-width: 861px){
  .site-header{border-bottom:1px solid var(--line);}
  .mainnav{
    display:grid !important;
    grid-template-columns: auto auto auto; /* venstre · logo · høyre */
    justify-content:center;                 /* hold alt tett rundt logo */
    align-items:center;
    gap:32px; /* avstand mellom venstre/logo/høyre */
    padding:12px 24px;
  }
  .brand{ justify-self:center; }
  .nav-group{
    display:flex !important;
    align-items:center;
    gap:16px; /* tettere mellom lenker */
  }
  .nav-link{ text-decoration:none; padding:6px 2px; }
  .nav-toggle{ display:none !important; }

  /* Dropdown på desktop */
  .has-menu{ position:relative; }
  .has-menu .dropdown{
    position:absolute; left:0; top:calc(100% + .35rem);
    min-width:220px; display:none; list-style:none;
    background:#fff; border:1px solid rgba(0,0,0,.08);
    box-shadow:0 8px 24px rgba(0,0,0,.08); border-radius:.75rem; padding:.45rem;
  }
  .has-menu.open > .dropdown{ display:block; }
  @media (hover:hover){ .has-menu:hover > .dropdown{ display:block; } }
}

/* ==== HEADER (mobil ≤860px) – logo i midten + hamburger til høyre ==== */
@media (max-width: 860px){
  .mainnav{
    display:grid !important;
    grid-template-columns: 1fr auto 1fr; /* [tom] · logo · hamburger */
    align-items:center;
    padding:10px 16px;
    border-bottom:1px solid var(--line);
  }
  .brand{ grid-column:2; justify-self:center; }
  .nav-toggle{
    grid-column:3; justify-self:end;
    display:inline-flex !important; align-items:center; justify-content:center;
    padding:6px 8px; border:0; background:transparent; cursor:pointer;
  }
  .nav-toggle .nav-toggle-bar{ width:22px; height:2px; background:currentColor; margin:4px 0; border-radius:2px; }

  /* skjul grupper til meny åpnes */
  .nav-group{ display:none !important; }

  /* åpen meny: stack under headeren */
  .mainnav.open{ row-gap:10px; }
  .mainnav.open .nav-group{
    display:block !important; grid-column:1 / -1;
    padding:8px 4px 10px;
  }
  .mainnav.open .nav-group .nav-link{ display:block; padding:10px 6px; }

  /* dropdowns i mobilmodus er "inline" */
  .has-menu{ position:static; }
  .has-menu .dropdown{
    position:static; display:none; padding:0 0 8px 12px;
    border:0; box-shadow:none; background:transparent; margin-top:4px;
  }
  .has-menu.open > .dropdown{ display:block; }
}
