/* =====================================================================
   0) Webfonter
   ===================================================================== */
@font-face {
  font-family: "Suisse Screen";
  src: url("/assets/fonts/SuisseScreen/webfiles/SuisseScreen-Regular-WebS.woff2") format("woff2"),
       url("/assets/fonts/SuisseScreen/webfiles/SuisseScreen-Regular-WebS.woff") format("woff");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Suisse Screen";
  src: url("/assets/fonts/SuisseScreen/webfiles/SuisseScreen-Regular-WebM.woff2") format("woff2"),
       url("/assets/fonts/SuisseScreen/webfiles/SuisseScreen-Regular-WebM.woff") format("woff");
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "ES Build";
  src: url("/assets/fonts/SuisseScreen/webfiles/SuisseScreen-Regular-WebM.woff2") format("woff2"),
       url("/assets/fonts/SuisseScreen/webfiles/SuisseScreen-Regular-WebM.woff") format("woff");
  font-weight: 700; font-style: normal; font-display: swap;
}

/* =====================================================================
   1) Reset & Variabler
   ===================================================================== */
*, *::before, *::after { box-sizing: border-box; }
:root{
  --brand-primary:#00444b; --brand-accent:#859b49; --brand-warm:#ed683a; --brand-gold:#e1aa36; --brand-black:#000;
  --bg:#fffef2; --bg-soft:#f9f9f7; --bg-tint:#ebefdc; --text:#333; --muted:#4f5b55; --line:#e2e2d3;
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --radius:16px; --radius-lg:24px; --container:1200px;
}

/* =====================================================================
   2) Base / Typografi / Containere / UI
   ===================================================================== */
html, body { height:100%; }
body{
  margin:0; font-family:"Suisse Screen",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background: radial-gradient(1200px 800px at 80% -10%, var(--bg-soft), transparent), var(--bg);
  line-height:1.5;
}
.wrap{ max-width:var(--container); margin-inline:auto; padding-inline:20px; }
h1{ font-family:"ES Build","Suisse Screen",system-ui; font-weight:700; letter-spacing:.2px;
    font-size:clamp(2rem,4vw,3.2rem); line-height:1.1; margin:10px 0 18px; color:var(--brand-primary); }
h2{ font-family:"ES Build","Suisse Screen",system-ui; font-size:clamp(1.6rem,2.6vw,2.2rem);
    margin:0 0 12px; color:var(--brand-primary); }
.sub{ color:var(--muted); margin-bottom:28px; }
.muted{ color:var(--muted); }

label{ display:block; font-weight:600; margin-bottom:6px; }
input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="file"]),
select, textarea{
  width:100%; padding:12px; border:1px solid var(--line); border-radius:12px;
  background:#fff; font:inherit; appearance:none;
}
input:focus, select:focus, textarea:focus{
  outline:none; border-color:var(--brand-primary);
  box-shadow:0 0 0 4px color-mix(in oklab, var(--brand-primary) 15%, transparent);
}
input.invalid, select.invalid, textarea.invalid { border-color:#b00020 !important; outline-color:#b00020 !important; }
input.invalid:focus, textarea.invalid:focus { box-shadow:0 0 0 2px rgba(176,0,32,.15); }
.field-error { color:#b00020; font-size:.9rem; margin-top:4px; }

.btn{
  display:inline-flex; align-items:center; gap:.6rem; padding:10px 16px; font-weight:600;
  border-radius:999px; border:1px solid var(--brand-primary);
  color:#fff; background:var(--brand-primary); box-shadow:var(--shadow);
}
.btn.outline{ background:transparent; color:var(--brand-primary); }
.btn.vipps { background:#ff5b24; color:#fff; border-color:#ff5b24; }
.btn.vipps:hover { filter:brightness(.95); }

.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); padding:14px;
}
table{ width:100%; border-collapse:collapse; }
th, td{ padding:10px 12px; border-bottom:1px solid var(--line); }

.pill{ display:inline-flex; align-items:center; gap:.5rem; padding:6px 10px;
       background:var(--bg-tint); color:#063d25; border-radius:999px; font-weight:600; font-size:.9rem; }
.badge{ display:inline-block; padding:4px 10px; border-radius:999px; font-weight:700; font-size:.8rem;
        background:var(--bg-tint); color:#063d25; }

/* =====================================================================
   3) Header & Navigasjon
   ===================================================================== */
header{ position:sticky; top:0; z-index:50; backdrop-filter:blur(8px);
  background:color-mix(in oklab, var(--bg) 88%, transparent); border-bottom:1px solid var(--line); }
.nav{ display:flex; align-items:center; justify-content:space-between; height:64px; }
.logo{ display:inline-flex; align-items:baseline; gap:8px; text-decoration:none; }
.logo .mark{ width:28px; height:28px; border-radius:8px; display:inline-block; object-fit:contain;
  background:none; box-shadow:inset 0 0 0 2px color-mix(in oklab, #fff 45%, transparent); }
.logo .logo-img{ display:block; height:28px; width:auto; }
.logo .word{ font-family:"ES Build","Suisse Screen",system-ui; font-weight:700; letter-spacing:.3px; color:var(--brand-primary); font-size:20px; }
.links{ display:flex; gap:20px; align-items:center; }
.nav a{ color:var(--text); text-decoration:none; font-weight:500; }
nav a.cta{ padding:10px 16px; border-radius:999px; background:var(--brand-primary); color:#fff; font-weight:700; text-decoration:none; box-shadow:var(--shadow); }

/* =====================================================================
   4) Hero (inkl. carousel)
   ===================================================================== */
.hero{ padding:64px 0 48px; }
.hero-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:36px; align-items:center; }
.eyebrow{ color:var(--brand-accent); text-transform:uppercase; letter-spacing:.12em; font-size:.85rem; font-weight:700; }
.lead{ font-size:clamp(1.05rem, 1.4vw, 1.2rem); color:var(--muted); }
.hero .btn-row{ display:flex; gap:12px; margin-top:18px; flex-wrap:wrap; }
.hero-card{ display:grid; gap:12px; margin-top:28px; padding:20px; }

.hero-media{
  aspect-ratio:4/5; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow);
  background:linear-gradient(160deg, #d8e3df, #eceadc 50%, #f4e1d4); position:relative; width:100%;
}
.hero-media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; padding:18px; }
@media (min-width:960px){ .hero-media{ max-width:520px; margin-left:auto; } }

.shine{ position:absolute; inset:0; background:linear-gradient(100deg, transparent 40%, rgba(255,255,255,.6), transparent 60%);
  transform:translateX(-120%); animation:shine 6s infinite; }
@keyframes shine{ 0%{transform:translateX(-120%);} 20%,100%{transform:translateX(160%);} }

/* Hero carousel */
.hero.hero-carousel .hero-media{ display:flex; position:relative; }
.hero.hero-carousel .hc-frame{
  position:relative; flex:1 1 auto; width:100%; height:100%;
  min-height:clamp(320px, 48vw, 640px); overflow:hidden; border-radius:16px; aspect-ratio:auto !important;
}
.hero.hero-carousel .hc-slide{ position:absolute; inset:0; z-index:0; opacity:0; transition:opacity var(--hc-dur,600ms) ease; }
.hero.hero-carousel .hc-slide.is-active{ opacity:1; z-index:1; }
.hero.hero-carousel .hc-slide img, .hero.hero-carousel .hc-slide video{ width:100%; height:100%; object-fit:cover; display:block; border:0; }
.hero.hero-carousel .hc-nav{ position:absolute; inset:0; display:flex; align-items:center; justify-content:space-between; padding:12px; z-index:10; pointer-events:none; }
.hero.hero-carousel .hc-nav .btn{ pointer-events:auto; opacity:.9; }
.hero.hero-carousel .hc-dots{ position:absolute; left:0; right:0; bottom:10px; display:flex; gap:8px; justify-content:center; z-index:10; }
.hero.hero-carousel .hc-dots > button{ width:8px; height:8px; border-radius:50%; border:0; background:#fff; opacity:.6; }
.hero.hero-carousel .hc-dots > button.active{ opacity:1; }
.hero.hero-carousel .hero-grid{ align-items:stretch; }

/* =====================================================================
   5) Seksjoner / Kort / Grids
   ===================================================================== */
section{ padding:56px 0; }
.grid-3{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px; }
.feature{ padding:18px; }
.feature h3{ margin:6px 0; font-size:1.1rem; }
.feature p{ color:var(--muted); }

.card .media{ border:1px solid var(--line); border-radius:12px; display:grid; place-items:center; background:#fff; aspect-ratio:1/1; overflow:hidden; }
.card .media img{ width:100%; height:100%; object-fit:contain; padding:10px; }
.card .name{ font-weight:800; }
.card .desc{ color:var(--muted); min-height:3.2em; }
.card .price{ font-weight:800; font-size:1.1rem; color:var(--brand-primary); }
.card .row{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

@media (max-width:860px){ .grid-3{ grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width:560px){ .grid-3{ grid-template-columns:1fr; } }

/* =====================================================================
   6) Produkt / Shop
   ===================================================================== */
.shop{ background:linear-gradient(180deg, var(--bg-tint) 0%, transparent 60%); border-block:1px solid var(--line); }
.product{ display:grid; grid-template-columns:1.1fr .9fr; gap:24px; align-items:start; }
.product-media{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:16px; display:grid; place-items:center; }
.price{ font-size:1.8rem; font-weight:800; color:var(--brand-primary); }
.opt{ display:grid; gap:12px; }
.opt label{ font-weight:600; }
.product-notes{ margin-top:10px; max-width:560px; margin-inline:auto; }
.product-notes p{ margin:0 0 8px; text-align:left; }
.product-notes ul{ margin:8px 0 0; padding-left:18px; color:var(--muted); }
.add{ display:flex; gap:8px; align-items:center; }

/* Drawer (handlekurv) */
.drawer{
  position:fixed; inset:0 0 0 auto; width:min(600px,100%); transform:translateX(100%); transition:transform .35s ease;
  background:#fff; border-left:1px solid var(--line); z-index:60; display:flex; flex-direction:column;
}
.drawer.open{ transform:translateX(0); }
.drawer header{ position:sticky; top:0; background:#fff; border-bottom:1px solid var(--line); padding:16px; }
.drawer .body{ padding:16px; overflow:auto; flex:1; }
.drawer .foot{ padding:16px; border-top:1px solid var(--line); }
.drawer .row{ display:grid; grid-template-columns:1fr auto; align-items:center; gap:10px; padding:10px 0; border-bottom:1px dashed var(--line); }
.drawer .row:last-child{ border:0; }
@media (max-width:640px){ .drawer{ width:100%; } }

/* Rader i checkout/cart */
#coItems .co-row{ display:grid; grid-template-columns:1fr auto auto; gap:8px; align-items:center; padding:8px 0; border-bottom:1px dashed var(--line); }
#coItems .co-row:last-child{ border-bottom:0; }
#coItems .co-qty{ width:84px; border:1px solid var(--line); border-radius:10px; padding:6px 8px; font:inherit; }
#coItems .co-remove{ white-space:nowrap; }
#cartItems .qty-input{ width:72px; border:1px solid var(--line); border-radius:10px; padding:6px 8px; font:inherit; }

/* =====================================================================
   7) FAQ
   ===================================================================== */
.faq details{ border:1px solid var(--line); background:#fff; border-radius:14px; padding:14px 16px; }
.faq details + details{ margin-top:12px; }
.faq summary{ cursor:pointer; font-weight:700; color:var(--brand-primary); }
.faq .faq-more details:first-child{ margin-top:0; }

/* =====================================================================
   8) Footer
   ===================================================================== */
footer{ border-top:1px solid var(--line); background:#fff; }
.footgrid{ display:grid; grid-template-columns:2fr 1fr 1fr; gap:18px; padding:28px 0; }
.copyright{ border-top:1px solid var(--line); padding:14px 0; color:var(--muted); font-size:.95rem; }

/* =====================================================================
   9) Modaler (checkout + juridiske)
   ===================================================================== */
.modal-backdrop{ position:fixed; inset:0; display:none; align-items:center; justify-content:center; background:rgba(0,0,0,.45); z-index:80; padding:16px; }
.modal-backdrop.open{ display:flex; }

.modal{
  width:min(760px,96vw); background:#fff;
  border:1px solid color-mix(in oklab, var(--brand-primary) 10%, var(--line));
  border-radius:var(--radius-lg); padding:24px; box-shadow:0 24px 64px rgba(0,0,0,.18), 0 6px 14px rgba(0,0,0,.08);
}
.modal .btn{ display:inline-flex; }
.modal .prose ul, .modal .prose ol, .modal ul, .modal ol{ padding-left:1.2rem; margin:0 0 .8rem; }
.modal li{ display:list-item; }

.modal-hd{ display:flex; align-items:center; justify-content:space-between; padding:10px 14px; border-bottom:1px solid #eee; }
.modal h3{ margin:0; font-size:18px; }
.modal button#paymentClose{ border:0; background:transparent; font-size:22px; line-height:1; cursor:pointer; }
.modal-bd{ padding:12px 16px 16px; }

/* Testbanner i modal */
.payments-test #checkoutModal .modal{ outline:3px solid #b00020; outline-offset:-3px; }
#checkoutModal .co-test-banner{
  border:2px solid #b00020; background:#ffe9ec; color:#8b0012; padding:10px 12px; border-radius:12px; margin:12px; font-weight:700; text-align:center;
}

/* Checkout – layout */
#checkoutModal .modal{ max-width:min(960px,92vw); width:92vw; max-height:min(92vh,980px); display:flex; flex-direction:column; }
.co-grid{ display:grid; gap:12px; }
.co-left, .co-right{ min-width:0; }
@media (min-width:900px){
  .co-grid{ grid-template-columns:1.05fr 1fr; align-items:start; }
  .co-left{ max-height:70vh; overflow:auto; }
}

/* Cart-kort i checkout */
#coCart.card{ margin:4px 0 8px; padding:10px; }
#coTotals{ margin-top:6px; display:grid; gap:3px; }

/* Skjema i checkout – kompakt */
#checkoutForm label{ font-size:.92rem; margin-bottom:3px; }
#checkoutForm input, #checkoutForm select, #checkoutForm textarea{
  font-size:.95rem; line-height:1.2; padding:.38rem .5rem; border-radius:8px; width:100%;
}
.form-grid-2, .form-grid-21{ display:grid; gap:8px; }
.form-grid-2{ grid-template-columns:1fr 1fr; }
.form-grid-21{ grid-template-columns:2fr 1fr; margin-top:12px; }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
@media (max-width:720px){ .form-grid-2, .form-grid-21{ grid-template-columns:1fr; } }
@media (max-width:560px){ .grid-2{ grid-template-columns:1fr; } }

/* Geo-rad: Region (bred) + Land */
#checkoutModal #row-geo.form-row.two{ display:grid; grid-template-columns:2fr 1fr; gap:10px; }
#checkoutModal #row-geo .field{ width:100%; }
#coRegion, #coState, #coCountry{ width:100%; }
#usStateWrap{ margin-top:0; } /* vises/skjules via JS */

/* Knappelinja nederst i checkout */
#checkoutModal .pay-row{
  display:flex; align-items:center; gap:10px; flex-wrap:nowrap;
}
@media (max-width:420px){ #checkoutModal .pay-row{ flex-wrap:wrap; } }

/* Vipps/PayPal: samme høyde og baseline */
#checkoutModal vipps-mobilepay-button{ display:inline-flex; align-items:center; height:42px; vertical-align:bottom; }
#checkoutModal #paypal-button-container{
  display:inline-flex; align-items:center; min-height:42px; width:220px; /* fast bredde → stabil */
  vertical-align:bottom; line-height:0; margin:0; padding:0;
}
#paypal-button-container > div{ width:100%; margin:0 !important; }
#paypal-button-container iframe{ display:block; }

/* Mindre luft mellom deler i checkout */
#checkoutModal h3#coTitle{ margin:0 0 4px; }
#checkoutModal .muted{ margin:0 0 8px !important; }
#checkoutModal #paypal-slot, #checkoutModal #payVipps{ margin-top:8px; }

/* === 1) Handlekurv-badge: tydeligere kontrast og “ring” === */
.cart-count{
  top: -6px; right: -6px;
  width: 22px; height: 22px;
  display: grid; place-items: center;
  background: var(--brand-warm);       /* oransje bakgrunn */
  color: #fff;                         /* hvitt tall */
  font-weight: 800; font-size: .8rem;
  border-radius: 999px;
  border: 2px solid #fff;              /* hvit ring for bedre synlighet */
  box-shadow: 0 4px 10px rgba(0,0,0,.18);
}

/* Hvis tallet ligger i et <span> eller <strong>, sørg for hvit tekst */
.cart-count span,
.cart-count strong { color:#fff; }

/* === 2) Checkout: enda strammere vertikal spacing === */
/* Modalramme og topptekst */
#checkoutModal .modal{
  padding: 10px 12px;                  /* var 14–16px */
}
#checkoutModal h3#coTitle{
  margin: 0 0 2px;                     /* tettere tittel */
}
#checkoutModal .muted{
  margin: 0 0 6px !important;          /* tettere ingress */
}

/* Grid og kort på venstresiden */
#checkoutModal .co-grid{ gap: 8px; }   /* var 12px */
#checkoutModal #coCart.card{
  margin: 2px 0 6px;
  padding: 8px;                        /* var 10px */
}
#checkoutModal #coTotals{
  gap: 2px;                            /* var 3px */
  margin-top: 4px !important;
}

/* Skjemafelt – kompakt uten å bli smått */
#checkoutModal label{
  margin-bottom: 2px;
  font-size: 12.5px;                   /* litt mindre label */
}
#checkoutModal input,
#checkoutModal select,
#checkoutModal textarea{
  font-size: 13.5px;
  line-height: 1.2;
  padding: 6px 8px;                    /* lavere felt-høyde */
  border-radius: 7px;
}

/* Rader og grids i skjema */
#checkoutModal .form-grid-2,
#checkoutModal .form-grid-21,
#checkoutModal .grid-2{
  gap: 6px;                            /* var 8px */
}

/* Geo-raden (Region | Land) – litt strammere, fortsatt bredere Region */
#checkoutModal #row-geo.form-row.two{
  grid-template-columns: 2fr 1fr;
  gap: 8px;                            /* var 10px */
}

/* Vareliste-rader i checkout */
#coItems .co-row{
  padding: 6px 0;                      /* var 8px */
  gap: 6px;
}

/* Knappelinja nederst – minsk mellomrom */
#checkoutModal .pay-row{
  gap: 8px;
}
#checkoutModal .modal > div:last-child{
  margin-top: 6px !important;          /* var 10px+ */
}

/* Vipps/PayPal: lik høyde, fast bredde – men litt smalere */
#checkoutModal vipps-mobilepay-button{
  height: 40px;
}
#checkoutModal #paypal-button-container{
  min-height: 40px;
  width: 208px;                        /* var 220px – gir litt plass */
}
#paypal-button-container > div{ width:100%; margin:0 !important; }
#paypal-button-container iframe{ display:block; line-height:0; }

/* =====================================================================
   10) Cookie consent
   ===================================================================== */
.cc-backdrop{ position:fixed; inset:0; display:none; align-items:end; justify-content:center; background:rgba(0,0,0,.35); z-index:90; padding:16px; }
.cc-backdrop.open{ display:flex; }
.cc-center{ align-items:center; }
.cc-card{ width:min(920px,100%); background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:0 24px 64px rgba(0,0,0,.18), 0 6px 14px rgba(0,0,0,.08); padding:16px; }
.cc-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.cc-title{ margin:0; color:var(--brand-primary); }
.cc-body{ display:grid; gap:12px; margin-top:10px; }
.cc-row{ display:flex; align-items:center; gap:10px; }
.cc-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }
.cc-small{ color:var(--muted); font-size:.92rem; }
.switch{ position:relative; display:inline-block; width:46px; height:26px; }
.switch input{ display:none; }
.slider{ position:absolute; cursor:pointer; inset:0; background:#dcdcdc; border-radius:999px; transition:.2s; }
.slider:before{ content:""; position:absolute; height:20px; width:20px; left:3px; top:3px; background:#fff; border-radius:50%; transition:.2s; box-shadow:0 1px 3px rgba(0,0,0,.15); }
input:checked + .slider{ background:color-mix(in oklab, var(--brand-primary) 60%, #dcdcdc); }
input:checked + .slider:before{ transform:translateX(20px); }

/* =====================================================================
   11) Compare table (kompakt)
   ===================================================================== */
.compare.card{ padding:16px; }
.cmp-table{ width:100%; border-collapse:collapse; }
.cmp-table thead th{ color:var(--brand-primary); font-weight:700; }
.cmp-table th:first-child, .cmp-table td:first-child{ width:56%; }
.cmp-table th.center, .cmp-table td.center{ text-align:center; }
.cmp-yes, .cmp-no{ display:inline-flex; align-items:center; justify-content:center; width:1.8rem; height:1.8rem; border-radius:999px; font-weight:800; border:1px solid var(--line); }
.cmp-yes{ background:var(--bg-tint); color:#063d25; border-color:color-mix(in oklab, var(--brand-primary) 35%, var(--line)); }
.cmp-no{ background:#f6f6f4; color:#a8a8a0; }

/* =====================================================================
   12) Utilities & Responsive
   ===================================================================== */
[id]{ scroll-margin-top:80px; }
@media (max-width:960px){ .hero-grid, .product{ grid-template-columns:1fr; } .grid-3{ grid-template-columns:1fr; } .links{ gap:14px; } }

/* Shop-modal større */
#shopModal .modal{ width:min(1100px,96vw); max-height:min(86vh,100%); overflow:auto; }

/* Shop grid varianter */
#shopGrid{ --mediaH:260px; display:grid; gap:16px; }
#shopGrid.auto{ grid-template-columns:repeat(3,minmax(260px,1fr)); }
@media (max-width:860px){ #shopGrid.auto{ grid-template-columns:repeat(2,minmax(260px,1fr)); } }
@media (max-width:560px){ #shopGrid.auto{ grid-template-columns:1fr; } }
#shopGrid.two{ grid-template-columns:repeat(2,minmax(320px,1fr)); }
@media (max-width:720px){ #shopGrid.two{ grid-template-columns:1fr; } }
#shopGrid.one{ grid-template-columns:minmax(360px,620px); justify-content:center; }
#shopGrid.one .card, #shopGrid.two .card{ padding:18px; }
#shopGrid.one .card .name, #shopGrid.two .card .name{ font-size:1.15rem; }
#shopGrid.one .shop-media, #shopGrid.two .shop-media{ max-width:350px; margin-inline:auto; }
#shopGrid .card{ overflow:hidden; display:flex; flex-direction:column; }
#shopGrid .card .media{ display:grid; place-items:center; aspect-ratio:1/1; min-height:var(--mediaH,260px); padding:10px; border:1px solid var(--line); border-radius:12px; background:#fff; overflow:hidden; }
#shopGrid .card .media img{ width:100%; height:100%; object-fit:contain; display:block; }
#shopGrid .card .foot{ margin-top:auto; display:grid; gap:10px; }

/* === Checkout: jevn høyde/linje for Vipps, PayPal og Avbryt === */
#checkoutModal .pay-row{
  margin-left: auto;               /* <- dette skyver den til høyre */
  display: inline-flex;
  display: flex;
  align-items: center;     /* baseline/vertikal sentrering */
  gap: 10px;
  flex-wrap: nowrap;
}
#checkoutModal .modal > div:last-child .cc-small{ order: 0; }
#checkoutModal .modal > div:last-child #coStatus{ order: 0; }
/* 1) Vipps-knapp: lås høyde */
#checkoutModal vipps-mobilepay-button{
  display: inline-flex;
  align-items: center;
  height: 42px;            /* master-høyde */
}

/* 2) PayPal-wrapper: fyll høyde, null ekstra margin */
#checkoutModal #paypal-button-container{
  display: inline-flex;
  align-items: stretch;    /* la knappen strekke seg til 42px */
  min-height: 42px;
  width: 220px;            /* samme som før, juster om ønskelig */
  margin: 0; padding: 0;
  line-height: 0;
}
#checkoutModal #paypal-button-container > div{  /* SDK wrapper */
  width: 100%;
  height: 100%;
}
#checkoutModal #paypal-button-container iframe{
  display: block;
  height: 42px !important; /* tving iframen til samme høyde */
}

/* 3) Avbryt-knappen: match 42px og baseline */
#checkoutModal #coCancel.btn{
  display: inline-flex;
  align-items: center;
  height: 42px;
  padding: 0 16px;         /* juster horisontal padding */
  line-height: 1;          /* ingen ekstra høyde fra tekstlinje */
}

/* (valgfritt) litt tettere gap på små skjermer */
@media (max-width: 420px){
  #checkoutModal .pay-row { gap: 8px; flex-wrap: wrap; }
}

/* Justér vertikal baseline slik at alle tre flukter perfekt */
#checkoutModal .pay-row > * {
  line-height: 0;                 /* fjern baseline-gap */
  vertical-align: middle;
}

/* Liten nudge på Vipps-knappen (juster verdien ved behov) */
#checkoutModal vipps-mobilepay-button{
  position: relative;
  top: -4px;                    /* prøv -1px, -1.5px eller -2px */
}

/* =====================================================================
   13) Night Animation
   ===================================================================== */
.night-anim { background: var(--bg, #f6f7f4); }

.night-anim .na-frame{
  --na-label-w: 120px;
  --na-axis-h: 24px;
  --na-gap-x: 12px;
  --pad: 12px;
  position: relative;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--na-bg, var(--bg, #f6f7f4));
  padding: var(--pad);
  overflow: hidden;
}

/* 2 kolonner: [labels | innhold] */
.night-anim .na-grid{
  display: grid;
  grid-template-columns: var(--na-label-w) 1fr;
  column-gap: var(--na-gap-x);
  row-gap: 10px;
  align-items: center;
  position: relative;
}

/* Tidsakse i innholdskolonnen (øverst) */
.night-anim .na-axis{
  grid-column: 2;
  position: relative;
  height: var(--na-axis-h);
  margin-bottom: 4px;
}
.night-anim .na-axis .tick{
  position: absolute; top: 0; bottom: 0;
  width: 1px; background: #ddd;
}
.night-anim .na-axis .tick-label{
  position: absolute; top: 0;
  transform: translateX(-50%);
  font-size: .8rem; color: #666;
}

/* Rad-labels og spor */
.night-anim .na-label{
  grid-column: 1;
  font-weight: 700;
  color: var(--brand-primary,#00444b);
  align-self: center;
}
.night-anim .na-track{
  grid-column: 2;
  position: relative;
  height: 28px;
  border-radius: 10px;
  background: var(--na-track, #f2f2ec);
  overflow: hidden;
}

/* Segmenter i sporene */
.night-anim .na-seg{
  position: absolute; top: 0; bottom: 0;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
}
.night-anim .na-seg.--on{     background: var(--na-on, #00444b);  opacity: .9;  color: #fff; }
.night-anim .na-seg.--motion{ background: var(--na-motion,#c53c3c); opacity: .75; color: #fff; }
.night-anim .na-seg.--pos{    color: #222; font-weight: 600; font-size: .85rem; }
.night-anim .na-seg .na-seg-text{ padding: 0 6px; white-space: nowrap; text-shadow: 0 1px 0 rgba(255,255,255,.6); }

/* Graf for søvndybde */
.night-anim .na-graph{ grid-column: 2; height: 64px; position: relative; }
.night-anim .na-graph svg{ width: 100%; height: 100%; display: block; }
.night-anim .na-graph path.area{
  fill: color-mix(in oklab, var(--brand-primary, #00444b) 15%, white);
}
.night-anim .na-graph path.stroke{
  fill: none; stroke: var(--brand-primary, #00444b); stroke-width: 2;
}

/* Playhead-overlay for hele innholdskolonnen */
.night-anim .na-overlay{
  position: absolute;
  left:  calc(var(--pad) + var(--na-label-w) + var(--na-gap-x));
  right: var(--pad);
  top:    calc(var(--pad) + var(--na-axis-h));
  bottom: var(--pad);
  z-index: 5;
  pointer-events: none;
}
.night-anim .na-head{
  position: absolute;
  top: 0; bottom: 0;
  width: 2px;
  background: #111;
  opacity: .85;
  box-shadow: 0 0 0 1px rgba(0,0,0,.05);
  will-change: left;
}

/* Kontroller under ramma */
.night-anim .na-controls{
  display: flex; justify-content: flex-end; gap: 8px; margin-top: 8px;
}

/* === Patch 1: Forankre handlekurv-badge til ikonet === */
.cart-btn { position: relative; }       /* container for .cart-count */
.cart-count { position: absolute; }     /* bruk top/right fra dine nye regler */

/* === Patch 2: Qty-step-knapper i cartlist === */
#cartItems .btn.step{
  padding: 6px 10px;
  min-width: 36px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* === Patch 3: Liten momstekst ved pris (om brukt) === */
.vat-note { 
  font-size: 12px;
  color: #777;
  margin-left: 6px;
}

/* === Patch 4: BOOK (manual) – gjeninnført kompakt versjon === */
.book{ background: var(--bg, #f6f7f4); }
.book .wrap > h2{ margin-bottom: 6px; }
.book-viewport{
  position: relative; overflow: hidden;
  border-radius: 16px; border: 1px solid var(--line); background: #fff;
}
.book-viewport::before{ /* “spine” */
  content:""; position:absolute; left:50%; top:0; bottom:0; width:1px;
  background: linear-gradient(to bottom, rgba(0,0,0,.06), rgba(0,0,0,0));
  transform: translateX(-.5px); pointer-events: none;
}
.book-track{ display:flex; transition: transform 500ms ease; will-change: transform; }
.book-page{ flex:0 0 100%; padding:0; background:#fff; border:0; }
.bp-grid{
  display:grid; grid-template-columns: 1.2fr 1fr; gap:16px; padding:18px;
  min-height: clamp(360px, 54vw, 680px);
}
.bp-grid.--right{ grid-template-columns: 1fr 1.2fr; }
.bp-grid.--top{ grid-template-columns: 1fr; }
.bp-media{
  position: relative; border-radius: 12px; overflow: hidden;
  background: #fafafa; min-height: 240px;
}
.bp-media > img{ width:100%; height:100%; object-fit:cover; display:block; }
.bp-body h3{ margin:0 0 8px; }
.bp-body .bp-text{ color:#444; line-height:1.6; }
.bp-body .bp-text p{ margin:0 0 10px; }
.book-prev, .book-next{
  position:absolute; top:50%; transform:translateY(-50%);
  border:0; width:40px; height:40px; border-radius:999px;
  display:grid; place-items:center; background:#fff; color:#111;
  box-shadow:0 6px 18px rgba(0,0,0,.13); cursor:pointer;
}
.book-prev{ left:10px; } .book-next{ right:10px; }
.book-dots{
  position:absolute; left:0; right:0; bottom:10px;
  display:flex; justify-content:center; gap:8px;
}
.book-dots .dot{
  width:8px; height:8px; border-radius:50%; border:0;
  background:#111; opacity:.35; cursor:pointer;
}
.book-dots .dot.active{ opacity:1; }
@media (max-width: 900px){ .bp-grid{ grid-template-columns: 1fr; } }

/* === Patch 5: (Valgfritt) Gjeninnfør dawn-variabler hvis noe refererer til dem === */
:root{
  --dawn-rose:#ede1d5; --dawn-sun:#f3c84e; --dawn-peach:#f4e1d4;
  --dawn-sea:#d8e3df; --dawn-stone:#e2e2d3; --dawn-tint:#ebefdc;
}

/* Basis-skygge på alle kort */
.card {
  box-shadow: var(--shadow); /* bruker allerede definert --shadow */
}

/* Sterkere variant ved behov: <div class="card --shadow"> */
.card.--shadow {
  box-shadow: 0 18px 44px rgba(0,0,0,.12), 0 6px 14px rgba(0,0,0,.30);
}

/* (valgfritt) Litt heving på hover */
.card {
  transition: box-shadow .2s ease;
}
.card:hover {
  box-shadow: 0 12px 36px rgba(0,0,0,.10);
}

/* ——— Juridiske modaler: høyde-lås + innvendig scroll ——— */
/* 1) Felles rammeoppsett */
#tosModal .modal,
#privacyModal .modal,
#withdrawalModal .modal,
#termsModal .modal,
#policyModal .modal {
  display: flex;
  flex-direction: column;
  width: min(880px, 94vw);
  max-height: calc(92vh - 0px);   /* lås til viewport */
  overflow: hidden;                /* skjul overskudd – innholdet får scroll */
  padding: 16px;
  border-radius: 16px;
}

/* 2) Innholdsområde får scroll (hvis du har .modal-bd) */
#tosModal .modal-bd,
#privacyModal .modal-bd,
#withdrawalModal .modal-bd,
#termsModal .modal-bd,
#policyModal .modal-bd {
  flex: 1 1 auto;
  overflow: auto;
  -webkit-overflow-scrolling: touch; /* iOS smooth scroll */
  padding: 12px 14px 14px;
}

/* 3) Fallback: hvis du IKKE har .modal-bd, la hele .modal scrolle */
#tosModal .modal:not(:has(.modal-bd)),
#privacyModal .modal:not(:has(.modal-bd)),
#withdrawalModal .modal:not(:has(.modal-bd)),
#termsModal .modal:not(:has(.modal-bd)),
#policyModal .modal:not(:has(.modal-bd)) {
  overflow: auto;
}

/* 4) Topp-linje kompakt og “sticky” dersom ønskelig */
#tosModal .modal-hd,
#privacyModal .modal-hd,
#withdrawalModal .modal-hd,
#termsModal .modal-hd,
#policyModal .modal-hd {
  padding: 10px 14px;
  border-bottom: 1px solid #eee;
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 1;
}

/* 5) Prose-stil inni tekstmodalene */
#tosModal .prose, #privacyModal .prose, #withdrawalModal .prose,
#termsModal .prose, #policyModal .prose {
  font-size: .98rem;
  line-height: 1.55;
  color: var(--text);
}
#tosModal .prose h4, #privacyModal .prose h4, #withdrawalModal .prose h4,
#termsModal .prose h4, #policyModal .prose h4 { margin: 10px 0 6px; color: var(--brand-primary); }
#tosModal .prose p, #privacyModal .prose p, #withdrawalModal .prose p,
#termsModal .prose p, #policyModal .prose p { margin: 0 0 10px; }
#tosModal .prose ul, #privacyModal .prose ul, #withdrawalModal .prose ul,
#termsModal .prose ul, #policyModal .prose ul,
#tosModal .prose ol, #privacyModal .prose ol, #withdrawalModal .prose ol,
#termsModal .prose ol, #policyModal .prose ol { margin: 0 0 10px 18px; padding: 0; }
