/* ============================================================
   APEIRON — Linjeforening for filosofi og etikk, NTNU
   Visuelt system: klassisk-retro akademisk segl
   Palett hentet fra logoen: marineblå · gull · vinrød · pergament
   ============================================================ */

/* ============================================================
   UNDER CONSTRUCTION — fjern hele denne blokken (og #wip-banner i index.html)
   for å skjule "under oppbygging"-banneret.
   ============================================================ */
@keyframes wip-scroll {
  from { background-position: 0 0; }
  to   { background-position: 51px 0; }
}
#wip-banner {
  position: absolute; bottom: 0; left: 0; right: 0;
  z-index: 10;
  padding: .6rem 1rem;
  background-image: repeating-linear-gradient(
    -45deg,
    #f5c518 0px,  #f5c518 28px,
    #111    28px, #111    36px
  );
  animation: wip-scroll 1.2s linear infinite;
  display: flex; align-items: center; justify-content: center;
}
#wip-banner span {
  background: #111;
  color: #f5c518;
  font-family: var(--body, sans-serif);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .25em .9em;
  border: 2px solid #f5c518;
}
/* ============ SLUTT UNDER CONSTRUCTION ============ */

:root {
  /* Brand */
  --navy:   #232740;
  --navy-2: #1a1d33;
  --gold:   #d4af37;
  --gold-deep: #a8842033;
  --gold-ink: #8a6d18;     /* gull mørket nok til tekst på pergament */
  --maroon: #76110f;
  --maroon-2: #5c0d0b;
  --paper:  #f4ecd9;
  --paper-2:#efe5cd;       /* litt dypere pergament */
  --ink:    #232740;
  --ink-soft: #4a4d63;

  /* Avledet av tweaks */
  --accent: var(--gold);
  --accent-ink: var(--gold-ink);

  /* Type */
  --display: "Cormorant Garamond", Georgia, serif;
  --body: "Spectral", Georgia, serif;

  --maxw: 1180px;
  --grain-op: 0.5;
}

/* ---------- Reset / base ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; scroll-padding-top:84px; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:18px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--gold); color:var(--navy); }

/* Retro paper grain overlay */
body::before{
  content:"";
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:var(--grain-op);
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
}

/* ---------- Layout helpers ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.section{ padding:104px 0; position:relative; }
.section--tight{ padding:76px 0; }

.eyebrow{
  font-family:var(--body);
  font-size:.74rem; font-weight:600;
  letter-spacing:.34em; text-transform:uppercase;
  color:var(--accent-ink);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:30px; height:1px; background:currentColor; opacity:.6; }
.eyebrow--center{ justify-content:center; }
.eyebrow--center::after{ content:""; width:30px; height:1px; background:currentColor; opacity:.6; }

h1,h2,h3{ font-family:var(--display); font-weight:600; line-height:1.04; letter-spacing:-.01em; color:var(--navy); }
.h-section{ font-size:clamp(2.4rem,5vw,3.7rem); margin:.32em 0 .5em; }
.lede{ font-size:1.22rem; color:var(--ink-soft); max-width:62ch; }

.center{ text-align:center; }
.center .lede{ margin-left:auto; margin-right:auto; }

/* Double rule divider */
.rule{ border:0; height:0; border-top:1px solid var(--navy); position:relative; opacity:.22; }
.rule::after{ content:""; position:absolute; left:0; right:0; top:3px; border-top:1px solid var(--navy); }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--navy); --fg:var(--paper);
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--body); font-weight:600; font-size:.98rem;
  letter-spacing:.02em;
  padding:.86em 1.6em;
  background:var(--bg); color:var(--fg);
  border:1px solid var(--bg);
  border-radius:2px;
  cursor:pointer; transition:transform .18s ease, box-shadow .25s ease, background .2s ease;
  position:relative;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 8px 22px -10px rgba(35,39,64,.6); }
.btn--gold{ --bg:var(--gold); --fg:var(--navy); border-color:var(--gold); font-weight:700; }
.btn--maroon{ --bg:var(--maroon); --fg:var(--paper); border-color:var(--maroon); }
.btn--ghost{ --bg:transparent; --fg:var(--navy); border-color:var(--navy); }
.btn--ghost:hover{ background:var(--navy); color:var(--paper); }
.btn--ghost-light{ --bg:transparent; --fg:var(--paper); border-color:rgba(244,236,217,.5); }
.btn--ghost-light:hover{ background:var(--gold); color:var(--navy); border-color:var(--gold); }
.btn .arr{ transition:transform .2s ease; }
.btn:hover .arr{ transform:translateX(3px); }

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 28px;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
}
.nav__brand{ display:flex; align-items:center; gap:12px; font-family:var(--display); font-weight:600; }
.nav__brand img{ width:42px; height:42px; }
.nav__brand .nm{ font-size:1.5rem; letter-spacing:.06em; color:var(--paper); line-height:1; }
.nav__brand .sub{ display:block; font-family:var(--body); font-size:.58rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin-top:3px; white-space:nowrap; }
.nav__links{ display:flex; align-items:center; gap:6px; }
.nav__links a{
  font-size:.92rem; font-weight:500; padding:.5em .8em; border-radius:2px;
  color:var(--paper); opacity:.85; transition:opacity .2s, color .2s;
  white-space:nowrap;
}
.nav__links a:hover{ opacity:1; color:var(--gold); }
.nav__links a.is-active{ opacity:1; color:var(--gold); }
.nav__links a.is-active::after{ content:""; position:absolute; left:.8em; right:.8em; bottom:.05em; height:1px; background:var(--gold); opacity:.7; }
.nav__links a{ position:relative; }
.nav__cta{ margin-left:8px; }

/* scrolled state */
.nav.is-stuck{ background:rgba(26,29,51,.94); backdrop-filter:blur(10px); box-shadow:0 1px 0 rgba(212,175,55,.28); padding:10px 28px; }

.nav__burger{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.nav__burger span{ display:block; width:26px; height:2px; background:var(--paper); margin:5px 0; transition:.25s; }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:999;
  background:var(--navy);
  display:flex; flex-direction:column; justify-content:flex-start; align-items:center; gap:6px;
  transform:translateY(-100%); transition:transform .42s cubic-bezier(.7,0,.2,1);
  overflow-y:auto; padding:100px 0 40px;
}
.drawer.is-open{ transform:translateY(0); }
.drawer a{ font-family:var(--display); font-size:2rem; color:var(--paper); padding:.2em; }
.drawer a:hover{ color:var(--gold); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; align-items:center;
  background:
    radial-gradient(120% 90% at 80% 10%, rgba(212,175,55,.14), transparent 55%),
    radial-gradient(80% 70% at 10% 100%, rgba(118,17,15,.34), transparent 60%),
    var(--navy);
  color:var(--paper);
  overflow:hidden;
  padding:120px 0 60px;
}
.hero__seal{
  position:absolute; right:-7%; top:50%; transform:translateY(-50%);
  width:min(56vw,720px); aspect-ratio:1; opacity:.16;
  filter:drop-shadow(0 0 1px rgba(212,175,55,.4));
  pointer-events:none;
}
.hero__inner{ position:relative; max-width:var(--maxw); margin:0 auto; padding:0 28px; width:100%; }
.hero__grid{ display:grid; grid-template-columns:1.25fr .75fr; gap:48px; align-items:center; }
.hero__eyebrow{ color:var(--gold); }
.hero h1{
  color:var(--paper);
  font-size:clamp(3.6rem,10vw,8rem);
  line-height:.92; letter-spacing:.01em; margin:.18em 0 0;
}
.hero h1 .infin{ color:var(--gold); }
.hero__tag{ font-family:var(--display); font-style:italic; font-size:clamp(1.5rem,3.4vw,2.3rem); color:var(--gold); margin-top:.1em; }
.hero__lede{ font-size:1.18rem; color:rgba(244,236,217,.82); max-width:48ch; margin:1.5em 0 2em; }
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero__logo-card{ justify-self:center; }
.hero__logo-card img{ width:min(38vw,360px); filter:drop-shadow(0 24px 50px rgba(0,0,0,.5)); animation:floaty 7s ease-in-out infinite; }
@keyframes floaty{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }

.hero__scroll{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
  font-size:.7rem; letter-spacing:.3em; text-transform:uppercase; color:rgba(244,236,217,.6);
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.hero__scroll .line{ width:1px; height:34px; background:linear-gradient(var(--gold),transparent); }

/* Greek-key marquee strip under hero */
.frieze{
  background:var(--maroon); color:var(--gold);
  border-top:2px solid var(--gold); border-bottom:2px solid var(--gold);
  overflow:hidden; white-space:nowrap;
}
.frieze__track{ display:inline-flex; gap:48px; padding:14px 0; animation:marq 38s linear infinite; font-family:var(--display); font-size:1.3rem; letter-spacing:.04em; }
.frieze__track span{ display:inline-flex; align-items:center; gap:48px; }
.frieze__track i{ font-style:normal; color:rgba(212,175,55,.55); }
@keyframes marq{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ============================================================
   OM OSS
   ============================================================ */
.about__grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.about__greek{ font-family:var(--display); font-size:clamp(3rem,7vw,5.5rem); color:var(--maroon); line-height:1; }
.about__greek small{ display:block; font-family:var(--body); font-size:.9rem; letter-spacing:.28em; text-transform:uppercase; color:var(--accent-ink); margin-top:.5em; }
.about p + p{ margin-top:1.1em; }
.about__card{
  background:var(--navy); color:var(--paper); padding:40px; border-radius:4px;
  position:relative; box-shadow:0 30px 60px -30px rgba(35,39,64,.6);
}
.about__card::after{ content:""; position:absolute; inset:10px; border:1px solid rgba(212,175,55,.4); border-radius:2px; pointer-events:none; }
.about__card h3{ color:var(--gold); font-size:1.7rem; margin-bottom:.4em; }
.about__card p{ color:rgba(244,236,217,.82); font-size:1.02rem; }
.about__hourglass{ width:46px; margin-bottom:18px; }

/* Teaser linking to the Fellesskap & samarbeid section */
.about__teaser{
  margin-top:22px; padding:30px 32px; border-radius:4px;
  background:var(--paper-2); border:1px solid rgba(35,39,64,.16);
  border-left:3px solid var(--gold);
}
.about__teaser .eyebrow{ display:block; margin-bottom:.5em; }
.about__teaser h4{
  font-family:var(--display); font-size:1.45rem; color:var(--maroon);
  margin-bottom:.45em; line-height:1.15;
}
.about__teaser p{ color:rgba(35,39,64,.78); font-size:1rem; margin-bottom:1.3em; }

/* Stats band */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid rgba(35,39,64,.18); border-radius:4px; overflow:hidden; margin-top:64px; background:var(--paper-2); }
.stat{ padding:34px 24px; text-align:center; border-right:1px solid rgba(35,39,64,.14); }
.stat:last-child{ border-right:0; }
.stat__num{ font-family:var(--display); font-size:3.1rem; color:var(--maroon); line-height:1; }
.stat__lbl{ font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-top:.6em; }

/* ============================================================
   STUDIET / STUDIERETNINGENE  (course-catalogue ledger)
   ============================================================ */
.studier{ background:var(--paper-2); }
.prog__list{ max-width:1020px; margin:0 auto; }

/* two studieretning cards */
.track__grid{ max-width:1020px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.track{
  position:relative; background:var(--paper); border:1px solid rgba(35,39,64,.16);
  border-top:3px solid var(--gold); border-radius:4px; padding:34px 34px 30px;
}
.track__glyph{
  position:absolute; top:18px; right:26px;
  font-family:var(--display); font-size:3.4rem; line-height:1;
  color:var(--gold); opacity:.5;
}
.track h3{ font-size:clamp(1.9rem,3vw,2.4rem); margin:.28em 0 .5em; }
.track > p{ color:var(--ink-soft); font-size:1.02rem; }
.track__points{ list-style:none; margin-top:20px; display:grid; gap:10px; }
.track__points li{
  position:relative; padding-left:22px; font-size:.96rem; color:var(--navy);
}
.track__points li::before{
  content:"\2014"; position:absolute; left:0; top:0; color:var(--maroon);
}

.studier__subhead{
  max-width:1020px; margin:64px auto 4px; font-size:.78rem; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase; color:var(--accent-ink);
  display:flex; align-items:center; gap:.9em;
}
.studier__subhead::after{ content:""; flex:1; height:1px; background:currentColor; opacity:.4; }
.prog{
  display:grid; grid-template-columns:.92fr 1.4fr; gap:48px;
  padding:46px 0; align-items:start;
  border-top:1px solid rgba(35,39,64,.22); position:relative;
}
.prog::after{ content:""; position:absolute; left:0; right:0; top:3px; border-top:1px solid rgba(35,39,64,.22); }
.prog:last-of-type{ border-bottom:1px solid rgba(35,39,64,.22); }
.prog:last-of-type::before{ content:""; position:absolute; left:0; right:0; bottom:-3px; border-top:1px solid rgba(35,39,64,.22); }

.prog__head{ display:flex; gap:22px; align-items:flex-start; }
.prog__num{
  flex:none; font-family:var(--display); font-style:italic;
  font-size:2.7rem; line-height:.9; color:var(--gold-ink);
  min-width:1.4em; text-align:center;
}
.prog__badges{ display:flex; flex-wrap:wrap; align-items:center; gap:10px; margin-bottom:.5em; }
.prog__level{
  font-size:.66rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:var(--paper); background:var(--maroon); border-radius:2px; padding:.4em .8em;
}
.prog__sp{ font-size:.8rem; letter-spacing:.06em; color:var(--ink-soft); }
.prog__head h3{ font-size:clamp(1.7rem,2.6vw,2.2rem); }

.prog__desc{ font-size:1.06rem; color:var(--ink-soft); max-width:54ch; }
.prog__pensum{ margin-top:22px; }
.prog__pensum-lbl{
  display:block; font-size:.68rem; font-weight:600; letter-spacing:.2em;
  text-transform:uppercase; color:var(--accent-ink); margin-bottom:12px;
}
.prog__chips{ list-style:none; display:flex; flex-wrap:wrap; gap:9px; }
.prog__chips li{
  font-size:.86rem; color:var(--navy);
  border:1px solid rgba(35,39,64,.28); border-radius:999px;
  padding:.42em 1em; background:var(--paper);
  transition:border-color .2s, color .2s, background .2s;
}
.prog__chips li:hover{ border-color:var(--gold); color:var(--maroon); }

.studier__note{
  max-width:1020px; margin:36px auto 0; text-align:center;
  font-size:.86rem; font-style:italic; color:var(--ink-soft); opacity:.85;
}

/* dark/marine mode adjustments */
body[data-mode="marine"] .prog,
body[data-mode="marine"] .prog::after,
body[data-mode="marine"] .prog:last-of-type,
body[data-mode="marine"] .prog:last-of-type::before{ border-color:rgba(244,236,217,.2); }
body[data-mode="marine"] .prog__chips li{ background:#2a2e4a; color:#f4ecd9; border-color:rgba(244,236,217,.28); }
body[data-mode="marine"] .prog__sp{ color:var(--ink-soft); }
body[data-mode="marine"] .track{ background:#2a2e4a; border-color:rgba(244,236,217,.16); border-top-color:var(--gold); }
body[data-mode="marine"] .track__points li{ color:#f4ecd9; }

/* ============================================================
   ARRANGEMENTER
   ============================================================ */
.events{ background:var(--paper); }
.events__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.evcard{
  background:var(--paper-2); border:1px solid rgba(35,39,64,.16); border-radius:4px;
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .22s ease, box-shadow .25s ease, border-color .25s ease;
}
.evcard:hover{ transform:translateY(-5px); box-shadow:0 24px 44px -26px rgba(35,39,64,.5); border-color:var(--gold); }
.evcard__img{ position:relative; aspect-ratio:16/10; background:var(--navy); }
.evcard__img image-slot{ width:100%; height:100%; }
.evcard__date{
  position:absolute; top:12px; left:12px; z-index:2;
  background:var(--paper); color:var(--navy); border-radius:3px;
  padding:7px 11px; text-align:center; line-height:1; box-shadow:0 4px 12px rgba(0,0,0,.25);
}
.evcard__date .d{ font-family:var(--display); font-size:1.5rem; font-weight:600; display:block; }
.evcard__date .m{ font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--maroon); margin-top:2px; }
.evcard__body{ padding:22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.tag{ align-self:flex-start; font-size:.68rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--accent-ink); border:1px solid currentColor; border-radius:999px; padding:.34em .9em; margin-bottom:14px; }
.evcard h3{ font-size:1.5rem; margin-bottom:.3em; }
.evcard__meta{ font-size:.92rem; color:var(--ink-soft); margin-top:auto; padding-top:16px; display:flex; align-items:center; gap:8px; }
.evcard__meta b{ color:var(--navy); font-weight:600; }

.events__foot{ margin-top:42px; display:flex; justify-content:center; }

/* ============================================================
   STYRET
   ============================================================ */
.board__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.member{ text-align:center; }
.member__ph{
  width:100%; max-width:200px; aspect-ratio:1; border-radius:50%; overflow:hidden;
  border:3px solid var(--gold); background:var(--navy);
  box-shadow:0 14px 30px -16px rgba(35,39,64,.6);
  margin:0 auto 18px; position:relative;
}
.member__ph image-slot{ width:100%; height:100%; }
/* hide the upload-icon empty state — initials replace it visually */
.member__ph image-slot::part(empty){ opacity:0; }
/* on published site (no editor), disable all pointer interaction on slots */
.member__ph image-slot:not([data-editable]){ pointer-events:none; cursor:default; }
/* initials overlay */
.member__initials{
  position:absolute; inset:0; display:flex;
  align-items:center; justify-content:center;
  font-family:var(--display); font-size:2rem; font-weight:600;
  letter-spacing:.06em; color:var(--gold);
  pointer-events:none; z-index:2; user-select:none;
}
/* hide initials once a photo is loaded */
.member__ph:has(image-slot[data-filled]) .member__initials{ display:none; }
.member__role{ font-size:.72rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--accent-ink); }
.member h3{ font-size:1.45rem; margin:.18em 0; }
.member__mail{ font-size:.86rem; color:var(--ink-soft); }
.member__mail:hover{ color:var(--maroon); }

/* ============================================================
   KOMITEER  (navy band)
   ============================================================ */
.committees{ background:var(--navy); color:var(--paper); }
.committees .h-section{ color:var(--paper); }
.committees .lede{ color:rgba(244,236,217,.8); }
.committees .eyebrow{ color:var(--gold); }
.comm__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:18px; }
.comm{
  border:1px solid rgba(212,175,55,.32); border-radius:4px; padding:30px 28px;
  background:rgba(244,236,217,.03); transition:background .25s, transform .2s, border-color .25s;
}
.comm:hover{ background:rgba(212,175,55,.08); transform:translateY(-4px); border-color:var(--gold); }
.comm__icon{ width:40px; height:40px; color:var(--gold); margin-bottom:16px; }
.comm h3{ color:var(--paper); font-size:1.5rem; margin-bottom:.35em; }
.comm p{ color:rgba(244,236,217,.74); font-size:.98rem; }

/* Én komité: S.A.K */
.sak__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:54px; align-items:center; margin-top:8px; }
.sak__full{ font-family:var(--display); font-style:italic; font-size:1.5rem; color:var(--gold); margin-bottom:.7em; }
.sak__lede{ color:rgba(244,236,217,.8); font-size:1.06rem; line-height:1.6; max-width:48ch; margin-bottom:1.9em; }
.sak__card{
  border:1px solid rgba(212,175,55,.32); border-radius:4px; padding:42px 40px;
  background:rgba(244,236,217,.03);
}
.sak__card .comm__icon{ width:46px; height:46px; margin-bottom:22px; }
.sak__breakdown{ list-style:none; display:flex; flex-direction:column; gap:16px; }
.sak__breakdown li{ display:flex; align-items:baseline; gap:.45em; }
.sak__breakdown b{ font-family:var(--display); font-weight:700; font-size:2.6rem; line-height:.9; color:var(--gold); width:1em; }
.sak__breakdown span{ font-family:var(--display); font-size:1.6rem; color:var(--paper); }

/* S.A.K — utvidet historie + krav-kort */
.sak__story p{ color:rgba(244,236,217,.8); font-size:1.06rem; line-height:1.66; max-width:50ch; }
.sak__story p + p{ margin-top:1.05em; }
.sak__asap{ color:var(--paper); }
.sak__asap b{ color:var(--gold); font-weight:600; }
.sak__founders{ margin:1.6em 0 1.9em; padding-top:1.4em; border-top:1px solid rgba(212,175,55,.22);
  font-size:.82rem; letter-spacing:.04em; color:rgba(244,236,217,.62); max-width:50ch; }
.sak__founders b{ color:rgba(244,236,217,.9); font-weight:600; }
.sak__krav-head{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; margin-bottom:24px; }
.sak__krav-head h3{ font-family:var(--display); font-size:1.7rem; color:var(--paper); }
.sak__krav-head small{ font-family:var(--body); font-size:.62rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold); }
.sak__krav{ list-style:none; display:flex; flex-direction:column; }
.sak__krav li{ display:grid; grid-template-columns:3.2em 1fr; gap:.6em; align-items:baseline;
  padding:14px 0; border-top:1px solid rgba(244,236,217,.1); }
.sak__krav li:first-child{ border-top:0; }
.sak__krav .par{ font-family:var(--display); font-weight:700; font-size:1.15rem; color:var(--gold); }
.sak__krav .txt{ font-size:1.02rem; color:var(--paper); }
.sak__krav li.is-open .txt{ color:rgba(244,236,217,.4); font-style:italic; }
.sak__krav li.is-open .txt::after{ content:"— holdt åpen"; }
.sak__krav-note{ margin-top:20px; font-size:.86rem; line-height:1.55; color:rgba(244,236,217,.55); font-style:italic; }

/* ============================================================
   APORETISK AFTEN  (fast månedlig — lett, kompakt stripe)
   ============================================================ */
.aporetic{ background:var(--paper-2); border-top:1px solid rgba(35,39,64,.1); border-bottom:1px solid rgba(35,39,64,.1); }
.apo{
  display:grid; grid-template-columns:1.35fr .85fr; gap:48px; align-items:start;
  border:1px solid rgba(35,39,64,.16); border-radius:5px;
  background:var(--paper);
  padding:46px 50px; position:relative;
}
.apo::before{ content:"✦"; position:absolute; top:18px; right:22px; color:var(--gold); font-size:1.1rem; opacity:.55; }
.apo__title{ font-size:clamp(2.1rem,4vw,3rem); margin:.22em 0 .42em; }
.apo__lede{ font-size:1.12rem; color:var(--ink-soft); max-width:54ch; line-height:1.62; }
.apo__meta{ display:flex; flex-wrap:wrap; gap:14px 30px; margin-top:1.6em; }
.apo__meta-item{ display:flex; flex-direction:column; gap:.2em; font-size:1rem; color:var(--navy); }
.apo__meta-item b{ font-family:var(--body); font-size:.66rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--accent-ink); }
.apo__aside{ border-left:1px solid rgba(35,39,64,.16); padding-left:42px; padding-top:2.8rem; }
.apo__greek{ font-family:var(--display); font-size:clamp(2.4rem,5vw,3.6rem); color:var(--maroon); line-height:1; }
.apo__greek small{ display:block; font-family:var(--body); font-size:.78rem; letter-spacing:.24em; text-transform:uppercase; color:var(--accent-ink); margin-top:.55em; }
.apo__note{ margin-top:1.3em; font-size:.98rem; line-height:1.6; color:var(--ink-soft); font-style:italic; }

body[data-mode="marine"] .aporetic{ background:#20233b; border-color:rgba(244,236,217,.12); }
body[data-mode="marine"] .apo{ background:#2a2e4a; border-color:rgba(244,236,217,.14); }
body[data-mode="marine"] .apo__title,
body[data-mode="marine"] .apo__meta-item{ color:#f4ecd9; }
body[data-mode="marine"] .apo__lede,
body[data-mode="marine"] .apo__note{ color:rgba(244,236,217,.78); }
body[data-mode="marine"] .apo__greek{ color:var(--gold); }
body[data-mode="marine"] .apo__aside{ border-color:rgba(244,236,217,.16); }

@media (max-width:760px){
  .apo{ grid-template-columns:1fr; gap:30px; padding:34px 26px; }
  .apo__aside{ border-left:0; border-top:1px solid rgba(35,39,64,.16); padding-left:0; padding-top:30px; }
  .sak__krav-head{ flex-direction:column; gap:4px; }
}

/* ============================================================
   APORETISK AFTEN — mini-kalender
   ============================================================ */
.apo__cal-area{ margin-top:1.5em; }

.apo-cal{
  display:inline-block; vertical-align:top;
  border:1px solid rgba(35,39,64,.16); border-radius:4px;
  background:var(--paper-2);
  padding:14px 16px 12px;
  min-width:224px;
}

/* Navigasjonsrad */
.apo-cal__nav{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:8px;
}
.apo-cal__month{
  font-family:var(--body); font-size:.76rem; font-weight:600;
  letter-spacing:.13em; text-transform:uppercase; color:var(--navy);
}
.apo-cal__arr{
  background:none; border:none; cursor:pointer;
  color:var(--ink-soft); font-size:1.1rem; line-height:1;
  padding:3px 6px; border-radius:2px;
  transition:background .15s, color .15s;
}
.apo-cal__arr:hover{ background:var(--gold-deep); color:var(--navy); }

/* Dagsgrid */
.apo-cal__grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:1px; }
.apo-cal__wd{
  font-family:var(--body); font-size:.58rem; letter-spacing:.06em;
  text-transform:uppercase; color:var(--ink-soft); text-align:center;
  padding-bottom:5px; opacity:.5;
}
.apo-cal__day{
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:2px;
  height:28px;
  font-family:var(--body); font-size:.76rem; color:var(--ink-soft);
  border-radius:2px;
}
.apo-cal__day--pad{ pointer-events:none; visibility:hidden; }
.apo-cal__day.is-past{ opacity:.28; }
.apo-cal__day.is-today .apo-cal__num{
  background:var(--navy); color:var(--paper);
  border-radius:50%; width:20px; height:20px;
  display:flex; align-items:center; justify-content:center;
}
.apo-cal__day.has-ev{ color:var(--navy); font-weight:700; }
.apo-cal__dot{
  width:4px; height:4px; border-radius:50%;
  background:var(--maroon); display:block; flex-shrink:0;
}

/* Neste arrangement-rad */
.apo-cal__next{
  display:flex; align-items:center; flex-wrap:wrap; gap:4px 8px;
  margin-top:10px; padding-top:9px;
  border-top:1px solid rgba(35,39,64,.1);
  font-size:.8rem;
}
.apo-cal__next-lbl{
  font-family:var(--body); font-size:.58rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase; color:var(--accent-ink);
  margin-right:2px;
}
.apo-cal__next-date{ color:var(--navy); font-weight:600; }
.apo-cal__next-sep{ color:var(--ink-soft); opacity:.35; margin:0 1px; }
.apo-cal__next-place{ color:var(--ink-soft); }

/* Vis alle-knapp */
.apo-cal__toggle{
  background:none; border:none; cursor:pointer;
  font-family:var(--body); font-size:.8rem; font-weight:600;
  color:var(--maroon); margin-top:11px; padding:0;
  display:inline-flex; align-items:center; gap:.35em;
  text-underline-offset:3px;
  transition:color .2s;
}
.apo-cal__toggle:hover{ color:var(--navy); text-decoration:underline; }

/* Utvidet liste */
.apo-cal__list{
  display:flex; flex-direction:column; gap:4px;
  margin-top:8px; max-height:220px; overflow-y:auto;
  padding-right:2px;
}
.apo-cal__ev{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  padding:7px 11px;
  background:var(--paper); border:1px solid rgba(35,39,64,.11);
  border-radius:3px; font-size:.82rem;
}
.apo-cal__ev-date{ font-weight:600; color:var(--maroon); white-space:nowrap; }
.apo-cal__ev-place{ color:var(--ink-soft); font-size:.76rem; flex:1; }
.apo-cal__ev-link{
  font-size:.75rem; font-weight:600; color:var(--navy);
  opacity:.6; transition:opacity .15s;
  white-space:nowrap;
}
.apo-cal__ev-link:hover{ opacity:1; }
.apo-cal__empty{ font-size:.82rem; color:var(--ink-soft); font-style:italic; margin:4px 0; }

/* Marine-modus */
body[data-mode="marine"] .apo-cal{
  background:rgba(255,255,255,.04); border-color:rgba(244,236,217,.13);
}
body[data-mode="marine"] .apo-cal__month,
body[data-mode="marine"] .apo-cal__day.has-ev,
body[data-mode="marine"] .apo-cal__next-date{ color:var(--paper); }
body[data-mode="marine"] .apo-cal__arr{ color:rgba(244,236,217,.45); }
body[data-mode="marine"] .apo-cal__arr:hover{ background:rgba(244,236,217,.08); color:var(--paper); }
body[data-mode="marine"] .apo-cal__day.is-today .apo-cal__num{ background:var(--paper); color:var(--navy); }
body[data-mode="marine"] .apo-cal__next{ border-color:rgba(244,236,217,.1); }
body[data-mode="marine"] .apo-cal__ev{
  background:rgba(255,255,255,.04); border-color:rgba(244,236,217,.1);
}
body[data-mode="marine"] .apo-cal__ev-date{ color:var(--gold); }
body[data-mode="marine"] .apo-cal__ev-link{ color:var(--paper); }
body[data-mode="marine"] .apo-cal__toggle{ color:var(--gold); }
body[data-mode="marine"] .apo-cal__toggle:hover{ color:var(--paper); }

/* ============================================================
   FELLESSKAP & SAMARBEID  (allies)
   ============================================================ */
.allies{ background:var(--paper); }
.ally__grid{ max-width:1020px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.ally{
  position:relative; background:var(--paper-2); border:1px solid rgba(35,39,64,.16);
  border-top:3px solid var(--maroon); border-radius:4px; padding:34px 34px 30px;
  display:flex; flex-direction:column;
}
.ally__glyph{
  position:absolute; top:18px; right:26px;
  font-family:var(--display); font-size:3rem; line-height:1; color:var(--maroon); opacity:.4;
}
.ally .prog__level{ align-self:flex-start; }
.ally h3{ font-size:clamp(1.9rem,3vw,2.4rem); margin:.28em 0 .5em; }
.ally > p{ color:var(--ink-soft); font-size:1.02rem; }
.ally__link{ margin-top:20px; align-self:flex-start; font-weight:600; font-size:.95rem; color:var(--maroon); display:inline-flex; align-items:center; gap:.5em; }
.ally__link:hover{ color:var(--navy); }
.ally__link .arr{ transition:transform .2s ease; }
.ally__link:hover .arr{ transform:translateX(3px); }
.ally__links{ margin-top:20px; display:flex; flex-wrap:wrap; gap:12px; }
.ally__links .ally__link{ margin-top:0; }
body[data-mode="marine"] .ally{ background:#2a2e4a; border-color:rgba(244,236,217,.16); border-top-color:var(--maroon); }
body[data-mode="marine"] .ally__link{ color:var(--gold); }

/* ============================================================
   LESESALEN
   ============================================================ */
.lesesal{ background:var(--cream,#f5f0e8); }
body[data-mode="marine"] .lesesal{ background:#1a1e35; }
.lesesal__grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.lesesal__lede{ font-size:1.1rem; color:var(--ink-soft); margin-bottom:2em; max-width:52ch; }
.lesesal__features{ list-style:none; display:grid; gap:22px; }
.lesesal__features li{ display:flex; gap:18px; align-items:flex-start; }
.lesesal__features svg{ flex:none; width:28px; height:28px; color:var(--maroon); margin-top:3px; }
body[data-mode="marine"] .lesesal__features svg{ color:var(--gold); }
.lesesal__features strong{ display:block; font-family:var(--display); font-size:1.15rem; color:var(--navy); margin-bottom:.25em; }
body[data-mode="marine"] .lesesal__features strong{ color:var(--paper); }
.lesesal__features span{ font-size:.97rem; color:var(--ink-soft); line-height:1.55; }
.lesesal__gallery{ display:flex; flex-direction:column; gap:12px; min-width:0; overflow:hidden; }
.lesesal__img-main{ border-radius:5px; overflow:hidden; width:100%; height:320px; background:var(--paper-2); }
.lesesal__img-main image-slot{ width:100%; height:100%; display:block; }
.lesesal__marquee-wrap{ overflow:hidden; border-radius:5px; }
.lesesal__marquee-track{ display:flex; gap:10px; width:max-content; animation:lesesal-marquee 35s linear infinite; }
.lesesal__marquee-wrap:hover .lesesal__marquee-track{ animation-play-state:paused; }
.lesesal__marquee-track image-slot{ flex:none; display:block; width:200px; height:140px; border-radius:5px; background:var(--paper-2); }
@keyframes lesesal-marquee{ 0%{ transform:translateX(0); } 100%{ transform:translateX(-50%); } }
@media(max-width:860px){
  .lesesal__grid{ grid-template-columns:1fr; gap:40px; }
  .lesesal__gallery{ order:-1; }
}

/* Calendar subscribe popup */
.cal-popup{ position:absolute; bottom:calc(100% + 10px); left:0; background:#fff; border:1px solid rgba(0,0,0,.12); border-radius:10px; box-shadow:0 8px 32px rgba(0,0,0,.14); padding:12px 16px; min-width:220px; z-index:200; }
.cal-popup__lbl{ font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:#888; margin:0 0 8px; }
.cal-popup__opt{ display:flex; align-items:center; gap:10px; padding:9px 10px; border-radius:7px; font-size:.93rem; font-weight:500; color:var(--navy); text-decoration:none; transition:.15s; }
.cal-popup__opt:hover{ background:var(--cream); color:var(--maroon); }
.cal-popup__opt svg{ flex-shrink:0; opacity:.7; }
body[data-mode="marine"] .cal-popup{ background:#1e2235; border-color:rgba(255,255,255,.12); }
body[data-mode="marine"] .cal-popup__opt{ color:var(--gold); }
body[data-mode="marine"] .cal-popup__opt:hover{ background:rgba(212,175,55,.1); }

/* ============================================================
   BLI MEDLEM  (maroon band)
   ============================================================ */
.join{ background:var(--maroon); color:var(--paper); position:relative; overflow:hidden; }
.join::before{
  content:"∞"; position:absolute; right:-2%; bottom:-30%;
  font-family:var(--display); font-size:34rem; color:rgba(212,175,55,.08); line-height:1; pointer-events:none;
}
.join__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:center; position:relative; }
.join .eyebrow{ color:var(--gold); }
.join .h-section{ color:var(--paper); }
.join__lede{ font-size:1.15rem; color:rgba(244,236,217,.85); margin-bottom:1.6em; max-width:46ch; }
.join__benefits{ list-style:none; display:grid; gap:14px; }
.join__benefits li{ display:flex; gap:14px; align-items:flex-start; font-size:1.04rem; }
.join__benefits svg{ flex:none; width:22px; height:22px; color:var(--gold); margin-top:3px; }
.join__card{
  background:var(--paper); color:var(--navy); border-radius:6px; padding:42px 38px;
  box-shadow:0 40px 70px -30px rgba(0,0,0,.5); text-align:center; position:relative;
}
.join__card::after{ content:""; position:absolute; inset:9px; border:1px solid rgba(118,17,15,.3); border-radius:3px; pointer-events:none; }
.join__price{ font-family:var(--display); font-size:4.6rem; color:var(--maroon); line-height:1; }
.join__price small{ font-family:var(--body); font-size:1rem; color:var(--ink-soft); display:block; letter-spacing:.04em; }
.join__card h3{ font-size:1.3rem; margin:.2em 0 1em; }
.join__steps{ text-align:left; list-style:none; display:grid; gap:10px; margin:18px 0 26px; font-size:.96rem; }
.join__steps li{ display:flex; gap:12px; }
.join__steps .n{ flex:none; width:24px; height:24px; border-radius:50%; background:var(--navy); color:var(--gold); font-size:.8rem; display:grid; place-items:center; font-weight:700; }

/* ============================================================
   KONTAKT / FAQ
   ============================================================ */
.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.faq__item{ border-bottom:1px solid rgba(35,39,64,.2); }
.faq__q{
  width:100%; text-align:left; background:none; border:0; cursor:pointer;
  font-family:var(--display); font-size:1.4rem; color:var(--navy);
  padding:22px 40px 22px 0; position:relative;
}
.faq__q::after{ content:"+"; position:absolute; right:4px; top:50%; transform:translateY(-50%); font-size:1.6rem; color:var(--maroon); transition:transform .25s; }
.faq__item.open .faq__q::after{ transform:translateY(-50%) rotate(45deg); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq__a p{ padding:0 0 22px; color:var(--ink-soft); font-size:1.02rem; max-width:54ch; }

.contact__box{ background:var(--navy); color:var(--paper); border-radius:5px; padding:40px; position:relative; }
.contact__box::after{ content:""; position:absolute; inset:9px; border:1px solid rgba(212,175,55,.35); border-radius:3px; pointer-events:none; }
.contact__box h3{ color:var(--gold); font-size:1.7rem; margin-bottom:.5em; }
.contact__row{ display:flex; gap:14px; align-items:center; padding:14px 0; border-bottom:1px solid rgba(244,236,217,.12); }
.contact__row:last-child{ border-bottom:0; }
.contact__row svg{ width:22px; height:22px; color:var(--gold); flex:none; }
.contact__row a, .contact__row span{ color:rgba(244,236,217,.9); font-size:1rem; }
.contact__row a:hover{ color:var(--gold); }
.contact__socials{ display:flex; gap:16px; margin-top:24px; flex-wrap:wrap; }
.contact__social-link{ display:flex; flex-direction:column; align-items:center; gap:5px; color:var(--gold); text-decoration:none; transition:.2s; }
.contact__social-link svg{ width:42px; height:42px; padding:10px; border:1px solid rgba(212,175,55,.4); border-radius:50%; box-sizing:border-box; transition:.2s; }
.contact__social-link span{ font-size:0.68rem; letter-spacing:.04em; text-transform:uppercase; opacity:.75; }
.contact__social-link:hover svg{ background:var(--gold); color:var(--navy); border-color:var(--gold); }
.contact__social-link:hover span{ opacity:1; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--navy-2); color:rgba(244,236,217,.7); padding:64px 0 32px; text-align:center; }
.footer img{ width:64px; margin:0 auto 18px; opacity:.95; }
.footer__name{ font-family:var(--display); font-size:2rem; color:var(--paper); letter-spacing:.08em; }
.footer__tag{ font-style:italic; font-family:var(--display); color:var(--gold); margin:.2em 0 1.4em; }
.footer__links{ display:flex; gap:24px; justify-content:center; flex-wrap:wrap; margin-bottom:28px; }
.footer__links a{ font-size:.9rem; letter-spacing:.04em; }
.footer__links a:hover{ color:var(--gold); }
.footer__fine{ font-size:.78rem; opacity:.6; letter-spacing:.04em; }

/* ============================================================
   NETTSTEDSØK — nav-knapp + overlay
   ============================================================ */

/* Søkeknapp i navbar */
.nav__search-btn {
  display: inline-flex; align-items: center; gap: .45em;
  background: rgba(212,175,55,.08); border: 1px solid rgba(212,175,55,.6); border-radius: 3px;
  color: var(--paper); cursor: pointer; padding: .44em .9em;
  font-family: var(--body); font-size: .85rem; font-weight: 500;
  opacity: 1; transition: border-color .2s, background .2s, color .2s;
  white-space: nowrap; flex-shrink: 0;
}
.nav__search-btn:hover { border-color: var(--gold); background: rgba(212,175,55,.18); color: var(--gold); }
.nav__search-btn svg { width: 15px; height: 15px; flex-shrink: 0; }
.nav__search-hint {
  font-size: .85rem; letter-spacing: .03em;
}
@media (max-width:1080px) {
  .nav__search-btn { padding: .5em .75em; }
  .nav__search-hint { display: inline; }
  .nav__search-btn:not(.drawer__search-row) { display: none; }
}

/* Search entry at top of drawer */
.drawer__search-row {
  display: flex; align-items: center; gap: .7em;
  background: rgba(244,236,217,.07); border: 1px solid rgba(212,175,55,.3);
  border-radius: 4px; padding: .85em 1.4em;
  font-family: var(--display); font-size: 1.8rem;
  color: rgba(244,236,217,.7); cursor: pointer;
  transition: color .2s, border-color .2s, background .2s;
  margin-bottom: 4px; width: 100%; max-width: 340px; text-align: left;
}
.drawer__search-row:hover { color: var(--gold); border-color: rgba(212,175,55,.6); background: rgba(212,175,55,.07); }
.drawer__search-row svg { width: 22px; height: 22px; flex-shrink: 0; opacity: .7; }

/* ── Overlay (sov) ── */
.sov {
  position: fixed; inset: 0; z-index: 10000;
  display: flex; align-items: flex-start; justify-content: center;
  padding: clamp(56px, 12vh, 130px) 16px 0;
  opacity: 0; pointer-events: none;
  transition: opacity .18s ease;
}
.sov.is-open { opacity: 1; pointer-events: auto; }

.sov__bg {
  position: absolute; inset: 0;
  background: rgba(10,12,28,.74);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
}
.sov__panel {
  position: relative; z-index: 1;
  width: min(620px, 100%);
  background: var(--navy);
  border: 1px solid rgba(212,175,55,.34);
  border-radius: 6px;
  box-shadow: 0 36px 72px -18px rgba(0,0,0,.75);
  overflow: hidden;
  transform: translateY(-10px) scale(.985);
  transition: transform .22s cubic-bezier(.2,.8,.2,1);
}
.sov.is-open .sov__panel { transform: none; }

.sov__inputrow {
  display: flex; align-items: center; gap: .75em;
  padding: 15px 18px;
  border-bottom: 1px solid rgba(212,175,55,.18);
}
.sov__icon { width: 18px; height: 18px; color: var(--gold); flex-shrink: 0; opacity: .85; }
.sov__input {
  flex: 1; background: none; border: 0; outline: none;
  font-family: var(--body); font-size: 1.05rem; color: var(--paper);
  caret-color: var(--gold); min-width: 0;
}
.sov__input::placeholder { color: rgba(244,236,217,.35); }
.sov__esc {
  background: rgba(244,236,217,.07); border: 1px solid rgba(244,236,217,.16);
  border-radius: 3px; color: rgba(244,236,217,.55); cursor: pointer;
  padding: .28em .65em; flex-shrink: 0;
  transition: background .15s, color .15s;
}
.sov__esc:hover { background: rgba(212,175,55,.14); color: var(--gold); }
.sov__esc kbd { font-family: var(--body); font-size: .75rem; }

.sov__body {
  max-height: min(440px, 55vh); overflow-y: auto; padding: 6px 0;
  scrollbar-width: thin; scrollbar-color: rgba(212,175,55,.28) transparent;
}
.sov__empty {
  text-align: center; padding: 32px 20px;
  color: rgba(244,236,217,.38); font-style: italic; font-size: .97rem;
}

.sov__grouplbl {
  font-family: var(--body); font-size: .67rem; font-weight: 700;
  letter-spacing: .24em; text-transform: uppercase;
  color: var(--gold); opacity: .65;
  padding: 10px 18px 3px;
}
.sov__grouplbl:first-child { padding-top: 8px; }

.sov__item {
  display: flex; align-items: center; gap: 11px;
  padding: 9px 18px; text-decoration: none; color: inherit;
  transition: background .1s;
}
.sov__item:hover,
.sov__item.is-active { background: rgba(212,175,55,.1); }
.sov__item__ico {
  flex-shrink: 0; width: 30px; height: 30px;
  display: grid; place-items: center; color: var(--gold); opacity: .65;
}
.sov__item__ico svg { width: 17px; height: 17px; }
.sov__item__txt { flex: 1; min-width: 0; }
.sov__item__title {
  display: block; font-family: var(--display); font-size: 1.04rem;
  font-weight: 600; color: var(--paper); line-height: 1.2;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sov__item__desc {
  display: block; font-size: .82rem; color: rgba(244,236,217,.5);
  line-height: 1.3; margin-top: .12em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sov__item mark { background: rgba(212,175,55,.32); color: inherit; border-radius: 1px; padding: 0 .05em; }
.sov__item__arr {
  flex-shrink: 0; color: rgba(212,175,55,.6); opacity: 0; font-size: 1rem;
  transition: opacity .12s, transform .14s;
}
.sov__item:hover .sov__item__arr,
.sov__item.is-active .sov__item__arr { opacity: 1; transform: translateX(3px); }

.sov__foot {
  display: flex; gap: 16px; align-items: center; justify-content: flex-end;
  padding: 9px 18px;
  border-top: 1px solid rgba(212,175,55,.12);
}
.sov__key { display: flex; gap: .3em; align-items: center; font-size: .71rem; color: rgba(244,236,217,.36); }
.sov__key kbd {
  background: rgba(244,236,217,.07); border: 1px solid rgba(244,236,217,.15);
  border-radius: 3px; padding: .14em .42em;
  font-family: var(--body); font-size: .71rem; color: rgba(244,236,217,.55);
}

@media (max-width:600px) {
  .sov__esc kbd { display: none; }
  .sov__esc::after { content: "×"; font-size: 1.2rem; line-height: 1; }
  .sov__foot { display: none; }
  /* Søk som bottom sheet på mobil */
  .sov { padding: 0; align-items: flex-end; }
  .sov__panel {
    width: 100%; border-radius: 16px 16px 0 0;
    border-left: 0; border-right: 0; border-bottom: 0;
    max-height: 80vh; display: flex; flex-direction: column;
  }
  .sov.is-open .sov__panel { transform: translateY(0); }
  .sov__body { flex: 1; overflow-y: auto; }
  .sov__input { font-size: 1rem; }
  /* Mobilmeny: mindre font på smale skjermer */
  .drawer a { font-size: 1.5rem; padding: .18em; }
  .drawer__search-row { font-size: 1.4rem; padding: .7em 1.1em; }
}
@media (max-height:680px) {
  .drawer { padding: 80px 0 24px; gap: 2px; }
  .drawer a { font-size: 1.3rem; padding: .14em; }
}

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){ .reveal{opacity:1;transform:none;transition:none} .hero__logo-card img{animation:none} .frieze__track{animation:none} }

/* ============================================================
   RESPONSIVE
    ============================================================ */
/* Nav: burger vises tidlig nok til at alle 11 lenker aldri trenger å ramle ut */
/* Nav: burger vises ved ~1080px — med færre toppnivå-lenker holder dette fint */
@media (max-width:1080px){
  .nav__links{ display:none; }
  .nav__burger{ display:block; }
}

/* ── Nav dropdowns ── */
.nav__dropdown{ position:relative; }
.nav__drop-trigger{
  display:inline-flex; align-items:center; justify-content:center; gap:.3em;
  font-family:var(--body); font-size:.92rem; font-weight:500;
  padding:.5em .8em; border-radius:2px;
  color:var(--paper); opacity:.85; background:none; border:0; cursor:pointer;
  transition:opacity .2s, color .2s; position:relative;
  white-space:nowrap;
}
.nav__drop-trigger:hover,
.nav__dropdown:hover .nav__drop-trigger,
.nav__dropdown:focus-within .nav__drop-trigger{ opacity:1; color:var(--gold); }
.nav__drop-trigger--active{ opacity:1; color:var(--gold); }
.nav__drop-trigger--active::after{ content:""; position:absolute; left:.8em; right:.8em; bottom:.05em; height:1px; background:var(--gold); opacity:.7; }
.nav__caret{ font-size:.72em; display:inline-block; transition:transform .2s ease; }
.nav__dropdown:hover .nav__caret,
.nav__dropdown:focus-within .nav__caret{ transform:rotate(180deg); }

.nav__drop-menu{
  position:absolute; top:100%; left:50%;
  transform:translateX(-50%) translateY(-4px);
  background:rgba(22,25,47,.97); backdrop-filter:blur(14px);
  border:1px solid rgba(212,175,55,.28); border-radius:4px;
  padding:14px 0 6px; min-width:190px;
  box-shadow:0 16px 40px -10px rgba(0,0,0,.55);
  opacity:0; pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  z-index:200;
}
.nav__dropdown:hover .nav__drop-menu,
.nav__dropdown:focus-within .nav__drop-menu{
  opacity:1; pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.nav__drop-menu::before{
  content:""; position:absolute; top:5px; left:50%; transform:translateX(-50%);
  border:5px solid transparent; border-top:0;
  border-bottom-color:rgba(212,175,55,.28);
}
.nav__drop-menu a{
  display:block; padding:.65em 1.25em;
  font-family:var(--body); font-size:.88rem; font-weight:500;
  color:rgba(244,236,217,.82); white-space:nowrap;
  transition:color .15s, background .15s;
}
.nav__drop-menu a:hover{ color:var(--gold); background:rgba(212,175,55,.07); }
.nav__drop-menu a.is-active{ color:var(--gold); }
.nav__drop-menu a + a{ border-top:1px solid rgba(212,175,55,.1); }
@media (max-width:980px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__logo-card{ display:none; }
  .about__grid, .join__grid, .contact__grid{ grid-template-columns:1fr; gap:40px; }
  .events__grid, .comm__grid{ grid-template-columns:1fr 1fr; }
  .board__grid{ grid-template-columns:1fr 1fr; }
  .member__ph{ max-width:150px; }
  .sak__grid{ grid-template-columns:1fr; gap:36px; }
  .prog{ grid-template-columns:1fr; gap:22px; }
  .track__grid{ grid-template-columns:1fr; }
  .ally__grid{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .stat{ border-bottom:1px solid rgba(35,39,64,.14); }
  .stat:nth-child(2){ border-right:0; }
}
@media (max-width:600px){
  body{ font-size:17px; }
  .section{ padding:72px 0; }
  .wrap{ padding:0 20px; }
  .events__grid, .comm__grid{ grid-template-columns:1fr; }
  .board__grid{ grid-template-columns:1fr 1fr; }
  .member__ph{ max-width:130px; }
  .stats{ grid-template-columns:1fr 1fr; }
  .hero h1{ font-size:clamp(3rem,18vw,5rem); }
}

/* ---------- Tweaks: dark/marine mode ---------- */
body[data-mode="marine"]{ --paper:#20233b; --paper-2:#262a45; --ink:#f4ecd9; --ink-soft:#b9bdd6; --accent-ink:var(--gold); }
body[data-mode="marine"] h1,body[data-mode="marine"] h2,body[data-mode="marine"] h3{ color:#f4ecd9; }
/* keep intentional gold headings on the always-dark navy cards */
body[data-mode="marine"] .about__card h3,
body[data-mode="marine"] .contact__box h3{ color:var(--gold); }
body[data-mode="marine"] .h-section{ color:#f4ecd9; }
body[data-mode="marine"] .about__greek{ color:var(--gold); }
body[data-mode="marine"] .stat__num{ color:var(--gold); }
body[data-mode="marine"] .evcard,body[data-mode="marine"] .about__card{ background:#2a2e4a; }
body[data-mode="marine"] .events{ background:#20233b; }
body[data-mode="marine"] .btn--ghost{ --fg:#f4ecd9; border-color:rgba(244,236,217,.5); }
body[data-mode="marine"] .rule{ border-color:#f4ecd9; }
body[data-mode="marine"] .faq__q{ color:#f4ecd9; }
body[data-mode="marine"] .tag{ color:var(--gold); }
body[data-mode="marine"] .nav.is-stuck{ background:rgba(10,12,24,.92); }

/* ============================================================
   ARRANGEMENTER — verktøylinje, visninger & kalender
   ============================================================ */
.ev-toolbar{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px 24px; flex-wrap:wrap; margin-bottom:14px;
  padding-bottom:18px; border-bottom:1px solid rgba(35,39,64,.16);
}
.ev-views{ display:inline-flex; border:1px solid rgba(35,39,64,.26); border-radius:3px; overflow:hidden; }
.ev-view{
  font-family:var(--body); font-size:.9rem; font-weight:600; letter-spacing:.02em;
  padding:.62em 1.15em; background:transparent; color:var(--ink-soft);
  border:0; border-right:1px solid rgba(35,39,64,.18); cursor:pointer;
  transition:background .2s, color .2s;
}
.ev-view:last-child{ border-right:0; }
.ev-view:hover{ color:var(--navy); }
.ev-view.is-active{ background:var(--ink); color:var(--paper); }

.ev-filters{ display:flex; flex-wrap:wrap; gap:8px; }
.ev-chip{
  font-size:.74rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft); background:transparent;
  border:1px solid rgba(35,39,64,.28); border-radius:999px;
  padding:.46em 1em; cursor:pointer; transition:.2s;
}
.ev-chip:hover{ border-color:var(--gold); color:var(--maroon); }
.ev-chip.is-active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

.ev-status{
  display:flex; align-items:center; gap:.6em;
  font-size:.84rem; font-style:italic; color:var(--ink-soft);
  margin:18px 0 4px;
}
.ev-status__dot{ width:8px; height:8px; border-radius:50%; background:var(--gold); flex:none; box-shadow:0 0 0 3px rgba(212,175,55,.22); }

/* Liste / agenda */
.ev-list{ display:flex; flex-direction:column; gap:14px; margin-top:26px; }
.evrow{
  display:grid; grid-template-columns:104px 1fr auto; gap:28px; align-items:center;
  background:var(--paper-2); border:1px solid rgba(35,39,64,.16); border-radius:4px;
  padding:22px 28px; transition:border-color .25s, transform .2s, box-shadow .25s;
}
.evrow:hover{ border-color:var(--gold); transform:translateX(3px); box-shadow:0 16px 34px -26px rgba(35,39,64,.5); }
.evrow__date{ text-align:center; border-right:1.5px solid rgba(35,39,64,.16); padding-right:22px; }
.evrow__date .d{ font-family:var(--display); font-size:2.3rem; font-weight:700; color:var(--maroon); line-height:1; }
.evrow__date .m{ display:block; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); margin-top:3px; }
.evrow__tags{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:8px; }
.evrow__tags .tag{ margin-bottom:0; color:var(--maroon); border-color:var(--maroon); }
.evrow__when{ font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); }
.evrow h3{ font-size:1.5rem; margin-bottom:.2em; }
.evrow__main p{ color:var(--ink-soft); font-size:1rem; line-height:1.5; max-width:62ch; }
.evrow__act{ display:flex; justify-content:flex-end; }
.ev-more{ font-weight:600; font-size:.95rem; color:var(--maroon); display:inline-flex; align-items:center; gap:.5em; white-space:nowrap; }
.ev-more:hover{ color:var(--navy); }
.ev-more .arr{ transition:transform .2s; }
.ev-more:hover .arr{ transform:translateX(3px); }
.ev-empty{ text-align:center; font-style:italic; color:var(--ink-soft); padding:30px 0; }

/* Rutenett uten bilde (kalender-drevne kort) */
.ev-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:26px; }
.evcard--plain{ background:var(--paper-2); }
.evcard__head{
  position:relative; background:var(--navy); color:var(--paper);
  padding:20px 22px; display:flex; align-items:center; justify-content:space-between; gap:14px;
}
.evcard__date2{ display:flex; align-items:baseline; gap:7px; }
.evcard__date2 .d{ font-family:var(--display); font-size:2.1rem; font-weight:700; color:var(--gold); line-height:1; }
.evcard__date2 .m{ font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(244,236,217,.75); }
.evcard__cat{ font-size:.66rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--navy); background:var(--gold); border-radius:999px; padding:.4em .85em; }
.evcard--plain .evcard__body{ padding:22px 22px 24px; }
.evcard--plain h3{ font-size:1.45rem; margin-bottom:.3em; }
.evcard--plain p{ color:var(--ink-soft); font-size:.98rem; line-height:1.5; }

/* Egen månedskalender (ingen Google) */
.ev-cal{ margin-top:26px; }
.evcal{
  border:1px solid rgba(35,39,64,.18); border-top:3px solid var(--gold); border-radius:5px;
  overflow:hidden; background:var(--paper-2); box-shadow:0 24px 50px -36px rgba(35,39,64,.5);
}
.evcal-bar{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:18px 22px; border-bottom:1px solid rgba(35,39,64,.14); }
.evcal-title{ font-family:var(--display); font-size:1.7rem; color:var(--navy); text-transform:capitalize; }
.evcal-nav{
  width:40px; height:40px; flex:none; border-radius:50%; cursor:pointer;
  border:1px solid rgba(35,39,64,.24); background:transparent; color:var(--maroon);
  font-size:1.3rem; line-height:1; display:grid; place-items:center; transition:.2s;
}
.evcal-nav:hover{ border-color:var(--gold); background:var(--gold); color:var(--navy); }
.evcal-grid{ display:grid; grid-template-columns:repeat(7,1fr); }
.evcal-wd{
  font-size:.68rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-soft); text-align:center; padding:12px 0; border-bottom:1px solid rgba(35,39,64,.12);
}
.evcal-cell{
  min-height:104px; padding:8px 8px 10px; border-right:1px solid rgba(35,39,64,.08);
  border-bottom:1px solid rgba(35,39,64,.08); display:flex; flex-direction:column; gap:5px;
}
.evcal-cell:nth-child(7n){ border-right:0; }
.evcal-cell--pad{ background:rgba(35,39,64,.025); }
.evcal-cell.has-ev{ background:rgba(212,175,55,.06); }
.evcal-num{ font-family:var(--display); font-size:1.05rem; font-weight:600; color:var(--ink-soft); }
.evcal-cell.is-today .evcal-num{
  color:var(--paper); background:var(--maroon); width:1.7em; height:1.7em; border-radius:50%;
  display:grid; place-items:center; line-height:1;
}
.evcal-chips{ display:flex; flex-direction:column; gap:4px; }
.evcal-chip{
  font-size:.74rem; line-height:1.25; color:var(--navy); background:var(--paper);
  border-left:3px solid var(--gold); border-radius:2px; padding:4px 7px;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.evcal-chip b{ color:var(--maroon); font-weight:700; }
.evcal-overflow{
  font-size:.72rem; font-weight:600; color:var(--maroon); background:none;
  border:none; padding:2px 0; cursor:pointer; text-align:left; line-height:1.3;
  opacity:.8;
}
.evcal-overflow:hover{ opacity:1; text-decoration:underline; }

.ev-show-more{
  display:block; width:100%; margin-top:24px;
  padding:14px 20px; font-size:.95rem; font-weight:600;
  color:var(--maroon); background:transparent;
  border:2px solid var(--maroon); border-radius:6px; cursor:pointer;
  transition:background .15s, color .15s;
}
.ev-show-more:hover{ background:var(--maroon); color:#fff; }

.events__foot{ margin-top:42px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   FADDERUKE
   ============================================================ */
.fadder{ background:var(--navy); color:var(--paper); position:relative; overflow:hidden; }
.fadder__glow{
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(60% 50% at 85% 0%, rgba(212,175,55,.16), transparent 60%),
    radial-gradient(60% 60% at 5% 100%, rgba(118,17,15,.4), transparent 60%);
}
.fadder .wrap{ position:relative; z-index:1; }
.fadder .h-section{ color:var(--paper); }
.fadder .eyebrow{ color:var(--gold); }
.fadder .lede{ color:rgba(244,236,217,.82); }
.fadder__intro{ margin-bottom:48px; }
.fadder__dates{
  display:inline-flex; align-items:center; gap:.7em; margin-top:22px;
  border:1px solid rgba(212,175,55,.5); border-radius:999px; padding:.5em 1.2em;
  font-family:var(--display); font-size:1.3rem; color:var(--gold);
}
.fadder__dates-lbl{ font-family:var(--body); font-size:.66rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:rgba(244,236,217,.7); }
/* full-program toggle */
.fadder__full-toggle{ text-align:center; margin-top:48px; }
.fadder__full-view{
  max-width:960px; margin:0 auto;
  overflow:hidden; max-height:0;
  transition:max-height .6s cubic-bezier(.4,0,.2,1), padding .4s ease;
}
.fadder__full-view.is-open{
  max-height:8000px;
  padding-top:42px;
}
.fadder__full-view.is-open::before{
  content:''; display:block; width:60px; height:1px;
  background:rgba(212,175,55,.35); margin:0 auto 38px;
}

.fadder__placeholder{
  max-width:60ch; margin:22px auto 0; font-size:.86rem; font-style:italic;
  color:rgba(244,236,217,.6); border:1px dashed rgba(212,175,55,.4);
  border-radius:4px; padding:.7em 1.1em;
}

/* veksle oppsett */
.fadder__stage{ max-width:780px; margin:0 auto; }
.fadder__stage[data-fadder-layout="overview"]{ max-width:960px; }
.fadder__stage .fd-pick,
.fadder__stage .fd-acc,
.fadder__stage .fd-ov{ display:none; }
.fadder__stage[data-fadder-layout="picker"] .fd-pick{ display:block; }
.fadder__stage[data-fadder-layout="accordion"] .fd-acc{ display:block; }
.fadder__stage[data-fadder-layout="overview"] .fd-ov{ display:block; }

/* shared item row */
.fd-items{ display:flex; flex-direction:column; gap:10px; }
.fd-item{ display:flex; gap:16px; align-items:baseline; padding:12px 16px; background:rgba(244,236,217,.04); border:1px solid rgba(212,175,55,.2); border-radius:4px; }
.fd-item__time{ font-family:var(--display); font-weight:600; font-size:1.05rem; color:var(--gold); min-width:52px; }
.fd-item__body{ display:flex; flex-direction:column; gap:2px; }
.fd-item__title{ font-size:1.05rem; color:var(--paper); }
.fd-item__meta{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(244,236,217,.55); }
.fd-rest{ font-style:italic; color:rgba(244,236,217,.55); padding:6px 2px; }

/* 1) dagsvelger */
.fd-weeks{ display:inline-flex; border:1px solid rgba(212,175,55,.4); border-radius:3px; overflow:hidden; margin-bottom:18px; }
.fd-week{
  font-family:var(--body); font-size:.9rem; font-weight:600; letter-spacing:.02em;
  padding:.6em 1.5em; background:transparent; color:rgba(244,236,217,.7);
  border:0; border-right:1px solid rgba(212,175,55,.3); cursor:pointer; transition:.2s;
}
.fd-week:last-child{ border-right:0; }
.fd-week:hover{ color:var(--gold); }
.fd-week.is-active{ background:var(--gold); color:var(--navy); }
.fd-days{ display:grid; grid-template-columns:repeat(7,1fr); gap:8px; margin-bottom:24px; }
.fd-day{
  display:flex; flex-direction:column; align-items:center; gap:5px; cursor:pointer;
  padding:12px 4px 10px; background:rgba(244,236,217,.04); color:rgba(244,236,217,.78);
  border:1px solid rgba(212,175,55,.22); border-radius:5px; transition:.2s;
}
.fd-day:hover{ border-color:rgba(212,175,55,.6); color:var(--paper); }
.fd-day__wd{ font-family:var(--body); font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; }
.fd-day__dt{ font-family:var(--display); font-size:1.05rem; color:inherit; }
.fd-day__dot{ width:5px; height:5px; border-radius:50%; background:var(--gold); opacity:.85; }
.fd-day.is-empty .fd-day__dot{ opacity:0; }
.fd-day.is-active{ background:var(--gold); border-color:var(--gold); color:var(--navy); }
.fd-day.is-active .fd-day__dot{ background:var(--navy); }
.fd-panel{ background:rgba(244,236,217,.05); border:1px solid rgba(212,175,55,.28); border-top:3px solid var(--gold); border-radius:6px; padding:26px 28px 28px; }
.fd-panel__head{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; flex-wrap:wrap; margin-bottom:18px; }
.fd-panel__head h4{ font-family:var(--display); font-size:2rem; color:var(--gold); }
.fd-panel__date{ font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(244,236,217,.65); }

/* 2) accordion */
.fd-acc{ max-width:680px; margin:0 auto; }
.fd-acc__week{ margin:22px 0 12px; }
.fd-acc__week:first-child{ margin-top:0; }
.fd-acc__wklbl{ font-family:var(--body); font-size:.72rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); }
.fd-acc__day{ border:1px solid rgba(212,175,55,.22); border-radius:5px; background:rgba(244,236,217,.04); margin-bottom:8px; overflow:hidden; }
.fd-acc__day[open]{ border-color:rgba(212,175,55,.45); }
.fd-acc__day summary{ display:flex; align-items:center; gap:14px; padding:14px 18px; cursor:pointer; list-style:none; }
.fd-acc__day summary::-webkit-details-marker{ display:none; }
.fd-acc__wd{ font-family:var(--display); font-size:1.25rem; color:var(--gold); min-width:108px; }
.fd-acc__dt{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(244,236,217,.6); flex:1; }
.fd-acc__cnt{ font-size:.74rem; letter-spacing:.06em; color:rgba(244,236,217,.55); }
.fd-acc__chev{ font-family:var(--display); font-size:1.5rem; color:var(--gold); line-height:1; transition:transform .25s; }
.fd-acc__day[open] .fd-acc__chev{ transform:rotate(45deg); }
.fd-acc__body{ padding:0 18px 18px; }

/* 3) helhetlig oversikt */
.fd-ov__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; align-items:start; }
.fd-ov__wk{ font-family:var(--body); font-size:.72rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); padding-bottom:10px; margin-bottom:14px; border-bottom:1px solid rgba(212,175,55,.3); }
.fd-ov__day{ display:grid; grid-template-columns:64px 1fr; gap:14px; padding:12px 0; border-top:1px solid rgba(244,236,217,.08); }
.fd-ov__day:first-of-type{ border-top:0; }
.fd-ov__day.is-empty{ opacity:.5; }
.fd-ov__dh{ display:flex; flex-direction:column; gap:1px; padding-top:2px; }
.fd-ov__wd{ font-family:var(--body); font-size:.7rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--paper); }
.fd-ov__dt{ font-size:.68rem; letter-spacing:.04em; color:rgba(244,236,217,.55); }
.fd-ov__items{ display:flex; flex-direction:column; gap:8px; }
.fd-ov__it{ display:flex; gap:12px; align-items:baseline; }
.fd-ov__t{ font-family:var(--display); font-weight:600; font-size:1rem; color:var(--gold); min-width:48px; flex-shrink:0; }
.fd-ov__n{ display:flex; flex-direction:column; gap:1px; font-size:.96rem; color:var(--paper); }
.fd-ov__m{ font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:rgba(244,236,217,.5); }
.fd-ov__rest{ font-style:italic; font-size:.92rem; color:rgba(244,236,217,.5); padding-top:2px; }

/* marine-mode justeringer for arrangement-lista */
body[data-mode="marine"] .ev-toolbar{ border-bottom-color:rgba(244,236,217,.16); }
body[data-mode="marine"] .ev-views{ border-color:rgba(244,236,217,.26); }
body[data-mode="marine"] .ev-view{ border-right-color:rgba(244,236,217,.18); }
body[data-mode="marine"] .ev-chip{ border-color:rgba(244,236,217,.28); }
body[data-mode="marine"] .evrow,
body[data-mode="marine"] .evcard--plain{ background:#2a2e4a; border-color:rgba(244,236,217,.16); }
body[data-mode="marine"] .evrow__date{ border-right-color:rgba(244,236,217,.18); }
body[data-mode="marine"] .evcal{ background:#2a2e4a; border-color:rgba(244,236,217,.2); }
body[data-mode="marine"] .evcal-bar{ border-bottom-color:rgba(244,236,217,.14); }
body[data-mode="marine"] .evcal-title{ color:var(--paper); }
body[data-mode="marine"] .evcal-nav{ border-color:rgba(244,236,217,.26); color:var(--gold); }
body[data-mode="marine"] .evcal-wd{ color:rgba(244,236,217,.6); border-bottom-color:rgba(244,236,217,.12); }
body[data-mode="marine"] .evcal-cell{ border-color:rgba(244,236,217,.1); }
body[data-mode="marine"] .evcal-cell--pad{ background:rgba(244,236,217,.03); }
body[data-mode="marine"] .evcal-num{ color:rgba(244,236,217,.75); }
body[data-mode="marine"] .evcal-chip{ color:var(--paper); background:#1f2238; }

/* responsiv */
@media (max-width:860px){
  .ev-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .ev-toolbar{ gap:14px; }
  .ev-views{ width:100%; }
  .ev-view{ flex:1; text-align:center; }
  .evrow{ grid-template-columns:72px 1fr; gap:18px; padding:18px 20px; }
  .evrow__date{ padding-right:16px; }
  .evrow__date .d{ font-size:1.9rem; }
  .evrow__act{ grid-column:1 / -1; justify-content:flex-start; }
  .ev-grid{ grid-template-columns:1fr; }
  .evcal-cell{ min-height:78px; padding:6px 5px 8px; }
  .evcal-chip{ font-size:0; padding:5px; border-left-width:4px; }
  .evcal-chip b{ display:none; }
  .fd-day{ padding:9px 2px 8px; }
  .fd-day__wd{ font-size:.6rem; letter-spacing:.06em; }
  .fd-day__dt{ font-size:.9rem; }
  .fd-acc__wd{ min-width:88px; font-size:1.1rem; }
  .fd-ov__grid{ grid-template-columns:1fr; gap:8px; }
}

/* ── Lesesalen lightbox ── */
.lesesal__img-main image-slot,
.lesesal__marquee-track image-slot { cursor: pointer; }
.ls-lb {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(5,7,18,.93);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .22s ease;
}
.ls-lb.is-open { opacity: 1; pointer-events: all; }
.ls-lb__img-wrap {
  position: relative; max-width: min(92vw, 1200px); max-height: 88vh;
  display: flex; align-items: center; justify-content: center;
}
.ls-lb__img {
  max-width: 100%; max-height: 88vh;
  object-fit: contain; border-radius: 3px;
  box-shadow: 0 24px 80px rgba(0,0,0,.6); display: block;
}
.ls-lb__btn {
  position: fixed; top: 50%; transform: translateY(-50%);
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18);
  color: var(--paper); cursor: pointer; font-size: 1.4rem;
  display: flex; align-items: center; justify-content: center;
  transition: background .18s; backdrop-filter: blur(4px);
}
.ls-lb__btn:hover { background: rgba(255,255,255,.2); }
.ls-lb__prev { left: 18px; }
.ls-lb__next { right: 18px; }
.ls-lb__close {
  position: fixed; top: 20px; right: 22px;
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18);
  color: var(--paper); cursor: pointer; font-size: 1.3rem;
  display: flex; align-items: center; justify-content: center;
  transition: background .18s; backdrop-filter: blur(4px);
}
.ls-lb__close:hover { background: rgba(255,255,255,.2); }
.ls-lb__info {
  position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%);
  color: rgba(255,255,255,.65); font-size: .82rem; letter-spacing: .04em;
  white-space: nowrap;
}
@media (max-width: 600px) {
  .ls-lb__btn { width: 42px; height: 42px; font-size: 1.1rem; }
  .ls-lb__prev { left: 8px; }
  .ls-lb__next { right: 8px; }
}
