/* ==========================================================================
   RS REKLAME AS — Klistremerke-konfigurator (klistremerker.html)
   Bygger kun videre på tokens + komponenter fra main.css.
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. HERO-STRIPE
   -------------------------------------------------------------------------- */
.sticker-hero {
  position: relative;
  z-index: 2;
  overflow: hidden;
  padding-top: clamp(2.5rem, 1rem + 5vw, 5rem);
  padding-bottom: clamp(2.5rem, 1rem + 5vw, 5rem);
}
.sticker-hero__bgmark {
  position: absolute;
  font-family: var(--font-display);
  font-size: 24vw;
  line-height: 1;
  color: var(--ink);
  opacity: 0.03;
  top: 24%; left: -3%;
  transform: rotate(-6deg);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.sticker-hero__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: clamp(1.5rem, 1rem + 3vw, 4rem);
  align-items: center;
}
.sticker-hero__top {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
  flex-wrap: wrap;
}
.sticker-hero h1 {
  font-size: var(--fs-3xl);
  color: var(--ink);
  letter-spacing: -0.02em;
}
.sticker-hero h1 .line { display: block; }
.sticker-hero h1 .hi {
  color: var(--signal-dark);
  position: relative;
  display: inline-block;
}
.sticker-hero h1 .hi::after {
  content: "";
  position: absolute;
  left: -2%; right: -2%; bottom: 0.08em;
  height: 0.16em;
  background: var(--signal);
  z-index: -1;
  opacity: 0.55;
}
.sticker-hero__lead {
  font-size: var(--fs-lg);
  color: var(--ink-2);
  max-width: 48ch;
  margin-top: var(--sp-5);
}

/* Tre-stegs forklaring */
.steps {
  display: grid;
  gap: var(--sp-3);
  margin-top: var(--sp-6);
}
.step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-4);
  align-items: center;
}
.step__n {
  width: 38px; height: 38px;
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--paper);
  background: var(--ink);
  border-radius: var(--r-2);
}
.step strong {
  display: block;
  font-weight: 800;
  font-size: var(--fs-base);
  color: var(--ink);
}
.step span:not(.step__n) {
  font-size: var(--fs-sm);
  color: var(--ink-muted);
}

.trust {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2) var(--sp-5);
  margin-top: var(--sp-6);
}
.trust li {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-size: var(--fs-sm);
  color: var(--ink-2);
  font-weight: 600;
}
.trust li::before {
  content: "";
  width: 1.05em; height: 1.05em;
  flex: none;
  background: var(--signal);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 6 9 17l-5-5' fill='none' stroke='black' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 6 9 17l-5-5' fill='none' stroke='black' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* Hero-kunst (sticker-stack) */
.sticker-hero__art {
  position: relative;
  min-height: 300px;
}
.sticker-hero__art .sticker { position: absolute; }
.sticker-hero__art .sh-1 { width: 64%; top: 0; right: 6%; z-index: 2; }
.sticker-hero__art .sh-2 { width: 50%; bottom: 4%; left: 0; z-index: 3; }
.sticker-hero__blob {
  position: absolute;
  inset: 12% 22% 24% -6%;
  border-radius: 50%;
  z-index: 0;
}

/* --------------------------------------------------------------------------
   2. KONFIGURATOR-LAYOUT
   Desktop: forhåndsvisning (venstre) | valg (midt) + prispanel (under valg)
   -------------------------------------------------------------------------- */
.config__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  grid-template-areas:
    "preview options"
    "preview price";
  grid-template-rows: auto 1fr;
  gap: clamp(1.25rem, 0.8rem + 2vw, 2.5rem);
  align-items: start;
}
.preview  { grid-area: preview; }
.options  { grid-area: options; }
.pricebox { grid-area: price; }

/* --------------------------------------------------------------------------
   3. FORHÅNDSVISNING (wow-øyeblikket)
   -------------------------------------------------------------------------- */
.preview__sticky { position: sticky; top: calc(var(--nav-h) + var(--sp-4)); }
.preview__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-3);
}
.preview__label {
  font-family: var(--font-body);
  font-weight: 800;
  font-size: var(--fs-xs);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

/* Bordflate: subtil papir-gradient + halvtone */
.preview__stage {
  position: relative;
  border: 2px solid var(--ink);
  border-radius: var(--r-3);
  background:
    radial-gradient(120% 90% at 50% 0%, var(--paper) 0%, var(--paper-2) 60%, var(--paper-3) 100%);
  aspect-ratio: 4 / 3.4;
  display: grid;
  place-items: center;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.5), var(--sh-2);
}
.preview__halftone {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(var(--ink) 1.2px, transparent 1.3px);
  background-size: 16px 16px;
  opacity: 0.06;
  pointer-events: none;
}

/* Selve klistremerket: hvit kant + skygge + lett rotasjon */
.preview__sticker {
  position: relative;
  width: 56%;
  max-width: 280px;
  aspect-ratio: 1 / 1;
  padding: 10px;
  margin: 0;
  background: #fff;
  box-shadow: var(--sh-sticker), 0 18px 40px rgba(20,17,15,0.18);
  transform: rotate(-4deg);
  transition:
    border-radius var(--t-med),
    clip-path var(--t-med),
    width var(--t-med),
    aspect-ratio var(--t-med),
    transform var(--t-med);
}
.preview__sticker.is-bump { animation: stickerBump var(--t-med); }
@keyframes stickerBump {
  0% { transform: rotate(-4deg) scale(1); }
  45% { transform: rotate(-4deg) scale(1.045); }
  100% { transform: rotate(-4deg) scale(1); }
}

.preview__img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  position: relative;
  z-index: 1;
}

/* Holografisk glans-lag (vises kun for holografisk materiale) */
.preview__holo {
  position: absolute;
  inset: 10px;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  mix-blend-mode: screen;
  background: linear-gradient(125deg,
    rgba(255,0,128,0.55) 0%,
    rgba(0,174,239,0.5) 28%,
    rgba(255,242,0,0.5) 52%,
    rgba(0,200,120,0.5) 74%,
    rgba(180,0,255,0.55) 100%);
  background-size: 220% 220%;
  transition: opacity var(--t-med);
}
.preview__sticker[data-material="holografisk"] .preview__holo {
  opacity: 0.82;
  animation: holoShift 5.5s ease-in-out infinite;
}
@keyframes holoShift {
  0%, 100% { background-position: 0% 0%; }
  50% { background-position: 100% 100%; }
}

/* Transparent: ruteflate bak motivet i stedet for hvit */
.preview__sticker[data-material="transparent"] {
  background:
    conic-gradient(#e9e6dd 90deg, #f6f4ee 90deg 180deg, #e9e6dd 180deg 270deg, #f6f4ee 270deg) 0 0 / 18px 18px;
  box-shadow: var(--sh-sticker), 0 18px 40px rgba(20,17,15,0.18);
}

/* Løftet hjørne */
.preview__peel {
  position: absolute;
  right: -1px; bottom: -1px;
  width: 34px; height: 34px;
  z-index: 3;
  background: linear-gradient(135deg, transparent 50%, rgba(20,17,15,0.18) 50%);
  pointer-events: none;
}

/* Formvarianter (clip på selve stickeren + ramme) */
.preview__sticker[data-shape="rund"] { border-radius: 50%; }
.preview__sticker[data-shape="rund"] .preview__peel { display: none; }
.preview__sticker[data-shape="firkant"] { border-radius: var(--r-3); }
.preview__sticker[data-shape="oval"] {
  border-radius: 50% / 50%;
  width: 64%;
  aspect-ratio: 1.5 / 1;
}
.preview__sticker[data-shape="oval"] .preview__peel { display: none; }
/* Die-cut: organisk konturskåret form via clip-path */
.preview__sticker[data-shape="diecut"] {
  border-radius: 18% 22% 20% 24% / 24% 18% 26% 20%;
}

/* Dimensjonstag på bordet */
.preview__dimtag {
  position: absolute;
  left: var(--sp-4); bottom: var(--sp-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-display);
  font-size: var(--fs-sm);
  letter-spacing: 0.04em;
  padding: 0.35em 0.7em;
  border-radius: var(--r-1);
  transform: rotate(-1.5deg);
  z-index: 4;
}
.preview__caption {
  margin-top: var(--sp-3);
  font-size: var(--fs-sm);
  color: var(--ink-muted);
  text-align: center;
}

/* --------------------------------------------------------------------------
   4. VALG-KOLONNE
   -------------------------------------------------------------------------- */
.options { display: grid; gap: var(--sp-5); }
.opt {
  border: 2px solid var(--ink);
  border-radius: var(--r-3);
  padding: var(--sp-5);
  background: var(--paper);
  min-width: 0;
}
.opt legend {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  text-transform: uppercase;
  color: var(--ink);
  padding: 0;
  margin-bottom: var(--sp-4);
}
.opt__step {
  font-family: var(--font-display);
  font-size: var(--fs-xs);
  letter-spacing: 0.1em;
  color: var(--paper);
  background: var(--signal-dark);
  padding: 0.25em 0.5em;
  border-radius: var(--r-1);
}
.opt__hint {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fs-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-left: auto;
}

/* ---- Dropzone (opplasting) ---- */
.dropzone {
  border: 2px dashed var(--ink);
  border-radius: var(--r-3);
  background:
    radial-gradient(circle at 12px 12px, transparent 6px, var(--paper-2) 6.5px) 0 0/24px 24px;
  padding: var(--sp-6) var(--sp-4);
  text-align: center;
  color: var(--ink-2);
  transition: border-color var(--t-fast), background-color var(--t-fast), transform var(--t-fast);
  cursor: pointer;
}
.dropzone:hover,
.dropzone:focus-visible { border-color: var(--signal-dark); }
.dropzone.is-drag {
  border-color: var(--signal-dark);
  background-color: var(--signal-soft);
  transform: scale(1.01);
}
.dropzone__ic {
  width: 44px; height: 44px;
  margin: 0 auto var(--sp-3);
  color: var(--signal-dark);
}
.dropzone__t { font-weight: 700; color: var(--ink); }
.dropzone__link { color: var(--signal-dark); text-decoration: underline; text-underline-offset: 3px; }
.dropzone__sub { font-size: var(--fs-xs); color: var(--ink-muted); margin-top: var(--sp-2); }

.design-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-top: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 2px solid var(--ink);
  border-radius: var(--r-2);
  background: var(--signal-soft);
  flex-wrap: wrap;
}
.design-status__name {
  font-weight: 700;
  font-size: var(--fs-sm);
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 60%;
}
.design-status__clear {
  background: none;
  border: none;
  color: var(--signal-dark);
  font-weight: 800;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ---- Chips (form / materiale / størrelse / antall) ---- */
.chips { display: grid; gap: var(--sp-3); }
.chips--shape { grid-template-columns: repeat(2, 1fr); }
.chips--mat   { grid-template-columns: 1fr; }
.chips--size,
.chips--qty {
  grid-template-columns: repeat(auto-fit, minmax(64px, 1fr));
  gap: var(--sp-2);
}

.chip {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  border: 2px solid var(--line);
  border-radius: var(--r-2);
  padding: var(--sp-3) var(--sp-4);
  background: var(--paper);
  cursor: pointer;
  transition: border-color var(--t-fast), background-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
}
.chip:hover { border-color: var(--ink); transform: translateY(-1px); }
.chip input { position: absolute; opacity: 0; pointer-events: none; }
.chip:has(input:checked) {
  border-color: var(--ink);
  background: var(--ink);
  box-shadow: var(--sh-2);
}
.chip:has(input:checked) .chip__t,
.chip:has(input:checked) .chip__sub,
.chip:has(input:checked) .chip__ic { color: var(--paper); }
.chip:has(input:checked) .chip__sub { color: rgba(244,241,234,0.72); }
.chip:has(input:focus-visible) {
  outline: 3px solid var(--signal);
  outline-offset: 2px;
}
/* Fallback for nettlesere uten :has — JS speiler til data-checked */
.chip[data-checked="true"] {
  border-color: var(--ink);
  background: var(--ink);
  box-shadow: var(--sh-2);
}
.chip[data-checked="true"] .chip__t,
.chip[data-checked="true"] .chip__sub,
.chip[data-checked="true"] .chip__ic { color: var(--paper); }
.chip[data-checked="true"] .chip__sub { color: rgba(244,241,234,0.72); }

.chip__ic { width: 32px; height: 32px; flex: none; color: var(--ink); transition: color var(--t-fast); }
.chip__t { font-weight: 800; font-size: var(--fs-sm); color: var(--ink); transition: color var(--t-fast); }
.chip__sub { display: block; font-size: var(--fs-xs); color: var(--ink-muted); font-weight: 500; transition: color var(--t-fast); }

/* Form-chips: ikon over tekst */
.chips--shape .chip { flex-direction: column; text-align: center; gap: var(--sp-2); padding: var(--sp-4) var(--sp-3); }

/* Materiale-chips: swatch + tekstblokk */
.chip--wide { align-items: center; }
.chip__body { display: grid; gap: 0.1em; }
.chip__pill {
  font-family: var(--font-body);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--ink);
  background: var(--signal);
  padding: 0.12em 0.45em;
  border-radius: var(--r-pill);
  vertical-align: middle;
  margin-left: 0.3em;
}
.swatch {
  width: 38px; height: 38px;
  flex: none;
  border-radius: var(--r-2);
  border: 1.5px solid var(--ink);
}
.swatch--hvit { background: #fff; }
.swatch--trans {
  background:
    conic-gradient(#d9d5cc 90deg, #fff 90deg 180deg, #d9d5cc 180deg 270deg, #fff 270deg) 0 0 / 10px 10px;
}
.swatch--holo {
  background: linear-gradient(125deg, #ff0080, #00aeef, #fff200, #00c878, #b400ff);
  background-size: 200% 200%;
  animation: holoShift 4s ease-in-out infinite;
}

/* Pill-chips (størrelse + antall) */
.chip--pill {
  justify-content: center;
  text-align: center;
  padding: var(--sp-3) var(--sp-2);
}
.chip--pill .chip__t { font-family: var(--font-display); font-weight: 400; font-size: var(--fs-base); }

/* "Mest valgt"-badge på antall 100 */
.chip--pop { overflow: visible; }
.chip__badge {
  position: absolute;
  top: -0.7em; left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  font-family: var(--font-body);
  font-weight: 800;
  font-size: 0.6rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--signal);
  padding: 0.18em 0.55em;
  border-radius: var(--r-pill);
  border: 1.5px solid var(--ink);
}

/* Egendefinert felt */
.custom { margin-top: var(--sp-4); }
.custom__lbl {
  display: block;
  font-weight: 700;
  font-size: var(--fs-sm);
  margin-bottom: var(--sp-2);
}
.custom__field {
  display: flex;
  align-items: center;
  border: 2px solid var(--ink);
  border-radius: var(--r-2);
  background: var(--paper);
  overflow: hidden;
  max-width: 220px;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.custom__field:focus-within {
  border-color: var(--signal-dark);
  box-shadow: 0 0 0 3px var(--signal-soft);
}
.custom__field input {
  font: inherit;
  font-weight: 700;
  color: var(--ink);
  background: transparent;
  border: none;
  padding: 0.6em 0.8em;
  width: 100%;
  min-width: 0;
}
.custom__field input:focus { outline: none; }
.custom__unit {
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--ink-muted);
  padding-inline: 0.8em;
  border-left: 2px solid var(--line);
  align-self: stretch;
  display: flex;
  align-items: center;
}
.custom__err { color: var(--signal-dark); font-size: var(--fs-xs); font-weight: 700; margin-top: var(--sp-2); }

/* --------------------------------------------------------------------------
   5. PRIS-PANEL (sticky)
   -------------------------------------------------------------------------- */
.pricebox { align-self: start; }
.pricebox__inner {
  position: sticky;
  top: calc(var(--nav-h) + var(--sp-4));
  background: var(--ink);
  color: var(--paper);
  border: 2px solid var(--ink);
  border-radius: var(--r-3);
  padding: var(--sp-6);
  box-shadow: var(--sh-3);
}
.pricebox__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--signal);
  margin-bottom: var(--sp-3);
}
.pricebox__label {
  font-family: var(--font-body);
  font-weight: 800;
  font-size: var(--fs-xs);
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.pricebox__head .regmark { color: rgba(244,241,234,0.4); }

.pricebox__total {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.pricebox__amount {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 1.4rem + 3vw, 3.4rem);
  line-height: 1;
  color: #fff;
  transition: color var(--t-fast);
}
.pricebox__amount.is-bump { animation: priceBump var(--t-med); }
@keyframes priceBump {
  0% { transform: translateY(0); color: var(--signal); }
  50% { transform: translateY(-4px); }
  100% { transform: translateY(0); color: #fff; }
}
.pricebox__ex { font-size: var(--fs-xs); color: rgba(244,241,234,0.5); letter-spacing: 0.1em; text-transform: uppercase; }
.pricebox__unit {
  margin-top: var(--sp-2);
  font-size: var(--fs-sm);
  color: rgba(244,241,234,0.78);
}
.pricebox__unit b, .pricebox__unit span { color: var(--signal); font-weight: 800; }

.pricebox__spec {
  display: grid;
  gap: var(--sp-2);
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px solid rgba(244,241,234,0.16);
}
.pricebox__spec li {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-3);
  font-size: var(--fs-sm);
}
.pricebox__spec li span { color: rgba(244,241,234,0.6); }
.pricebox__spec li b { color: var(--paper); font-weight: 700; text-align: right; }

.pricebox__discount {
  margin-top: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  border: 1.5px dashed var(--signal);
  border-radius: var(--r-2);
  font-size: var(--fs-sm);
  color: var(--signal);
  font-weight: 700;
}
.pricebox__discount b { color: #fff; }

.pricebox__ship {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
  font-size: var(--fs-sm);
  color: rgba(244,241,234,0.78);
}
.pricebox__ship-ic {
  width: 30px; height: 30px;
  flex: none;
  color: var(--signal);
}
.pricebox__ship.is-free { color: var(--signal); font-weight: 700; }

.pricebox__cta { width: 100%; margin-top: var(--sp-5); }
.pricebox__note {
  margin-top: var(--sp-3);
  font-size: var(--fs-xs);
  color: rgba(244,241,234,0.5);
  text-align: center;
}

/* --------------------------------------------------------------------------
   6. FAQ
   -------------------------------------------------------------------------- */
.faq { background: var(--paper-2); border-top: 2px solid var(--ink); }
.faq__list { display: grid; gap: var(--sp-3); max-width: var(--maxw-rd); margin-inline: auto; }
.faq__item {
  border: 2px solid var(--ink);
  border-radius: var(--r-2);
  background: var(--paper);
  overflow: hidden;
}
.faq__item summary {
  list-style: none;
  cursor: pointer;
  padding: var(--sp-4) var(--sp-5);
  font-weight: 800;
  font-size: var(--fs-base);
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  transition: color var(--t-fast);
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after {
  content: "+";
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--signal-dark);
  flex: none;
  transition: transform var(--t-fast);
}
.faq__item[open] summary::after { transform: rotate(45deg); }
.faq__item summary:hover { color: var(--signal-dark); }
.faq__item p {
  padding: 0 var(--sp-5) var(--sp-5);
  color: var(--ink-2);
  font-size: var(--fs-sm);
  max-width: 62ch;
}

/* --------------------------------------------------------------------------
   7. BESTILL-MODAL
   -------------------------------------------------------------------------- */
.modal {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: var(--gutter);
}
.modal[hidden] { display: none; }
.modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20,17,15,0.6);
  backdrop-filter: blur(3px);
  animation: fadeIn var(--t-med);
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes modalIn {
  from { opacity: 0; transform: translateY(20px) scale(0.97); }
  to { opacity: 1; transform: none; }
}
.modal__panel {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 460px;
  background: var(--paper);
  border: 2px solid var(--ink);
  border-radius: var(--r-3);
  padding: var(--sp-7);
  box-shadow: var(--sh-3);
  max-height: 90vh;
  overflow-y: auto;
  animation: modalIn var(--t-med) cubic-bezier(.2,.7,.3,1);
}
.modal__close {
  position: absolute;
  top: var(--sp-3); right: var(--sp-3);
  width: 40px; height: 40px;
  border: 2px solid var(--ink);
  border-radius: var(--r-2);
  background: var(--paper);
  font-size: 1.5rem;
  line-height: 1;
  color: var(--ink);
  transition: background var(--t-fast), color var(--t-fast);
}
.modal__close:hover { background: var(--ink); color: var(--paper); }
.modal__panel .kicker { margin-bottom: var(--sp-3); }
.modal__panel h2 { font-size: var(--fs-xl); color: var(--ink); margin-bottom: var(--sp-3); }
.modal__lead { color: var(--ink-2); font-size: var(--fs-sm); margin-bottom: var(--sp-5); }
.modal__spec {
  display: grid;
  gap: var(--sp-2);
  border: 2px solid var(--ink);
  border-radius: var(--r-2);
  padding: var(--sp-4);
  background: var(--paper-2);
}
.modal__spec li {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-3);
  font-size: var(--fs-sm);
}
.modal__spec li span { color: var(--ink-muted); }
.modal__spec li b { color: var(--ink); font-weight: 700; text-align: right; }
.modal__spec-total {
  margin-top: var(--sp-2);
  padding-top: var(--sp-3);
  border-top: 2px solid var(--ink);
}
.modal__spec-total span { color: var(--ink) !important; font-weight: 800; }
.modal__spec-total b { font-family: var(--font-display); color: var(--signal-dark) !important; font-size: var(--fs-lg); }
.modal__ok { width: 100%; margin-top: var(--sp-5); }
.modal__demo { text-align: center; font-size: var(--fs-xs); color: var(--ink-muted); margin-top: var(--sp-3); }

/* --------------------------------------------------------------------------
   8. RESPONSIVE
   -------------------------------------------------------------------------- */
@media (max-width: 960px) {
  .sticker-hero__grid { grid-template-columns: 1fr; }
  .sticker-hero__art { min-height: 240px; order: -1; max-width: 360px; }

  /* Stable kolonner: forhåndsvisning øverst, så valg, så pris */
  .config__grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "preview"
      "options"
      "price";
  }
  .preview__sticky { position: static; }
  .preview__stage { aspect-ratio: 16 / 10; }
  .preview__sticker { max-width: 240px; }

  /* Pris-panel som sticky bunn-bar på mobil */
  .pricebox { position: sticky; bottom: 0; z-index: 40; }
  .pricebox__inner {
    position: static;
    padding: var(--sp-4) var(--sp-5);
    border-radius: var(--r-3) var(--r-3) 0 0;
    border-bottom: none;
    box-shadow: 0 -8px 24px rgba(20,17,15,0.22);
  }
  /* Kompakt bunn-bar: skjul spec/discount, behold total + CTA */
  .pricebox__inner.crop::before,
  .pricebox__inner.crop::after,
  .pricebox__inner .crop-bl,
  .pricebox__inner .crop-br { display: none; }
  .pricebox__spec,
  .pricebox__discount,
  .pricebox__note { display: none; }
  .pricebox__head { margin-bottom: var(--sp-2); }
  .pricebox__bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-4);
    flex-wrap: wrap;
  }
  .pricebox__cta { width: auto; margin-top: 0; flex: 1; min-width: 160px; }
  .pricebox__ship { margin-top: var(--sp-2); font-size: var(--fs-xs); }
}

@media (max-width: 520px) {
  .chips--shape { grid-template-columns: 1fr 1fr; }
  .sticker-hero h1 { font-size: var(--fs-2xl); }
  .modal__panel { padding: var(--sp-6) var(--sp-5); }
  .pricebox__bar { flex-direction: column; align-items: stretch; }
  .pricebox__cta { width: 100%; }
}
