/* ─── tokens ────────────────────────────────────────────────────────── */
  :root{
    /* default = Sand palette (Lene's pick) */
    --ivory:#EAE2D2;
    --ivory-2:#E2D9C6;
    --sand:#D7CCB7;
    --paper:#F4ECDC;
    --taupe:#CEC1B2;
    --camel:#C2A17C;
    --blush:#D4B69B;
    --clay:#C2A17C;
    --gold:#A07A1E;
    --gold-soft:#D9BE7A;
    --sage:#9BA68A;
    --espresso:#3D2A1E;
    --espresso-2:#5A4636;
    --coffee:#5F4F3E;
    --line:rgba(61,42,30,.14);
    --line-soft:rgba(61,42,30,.08);

    --display:"Cormorant Garamond", "Cormorant", serif;
    --sans:"Manrope", ui-sans-serif, system-ui, -apple-system, sans-serif;

    --maxw:1320px;
    --gutter:clamp(24px, 5vw, 80px);
    --nav-h:78px;
  }

  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  html{scroll-behavior:smooth}
  section[id], h2[id], h3[id], dl dt[id], .seo-anchor{scroll-margin-top:100px}
  body{
    background:var(--ivory);
    color:var(--espresso);
    font-family:var(--sans);
    font-weight:400;
    font-size:16px;
    line-height:1.65;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }
  img{display:block;max-width:100%;height:auto}
  /* <picture> is a layout-transparent wrapper: AVIF/WebP sources with JPG/PNG
     fallback. display:contents keeps every existing `figure img` / `.treat-img img`
     selector and the morph measurements working exactly as before. */
  picture{display:contents}
  a{color:inherit;text-decoration:none}
  button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

  /* type ----------------------------------------------------------------- */
  .display{font-family:var(--display);font-weight:400;letter-spacing:.005em;line-height:1.04;color:var(--espresso)}
  .display em{font-style:italic;color:var(--espresso-2)}
  .h-1{font-size:clamp(40px, 5.6vw, 84px)}
  .h-2{font-size:clamp(30px, 3.6vw, 52px)}
  .h-3{font-size:clamp(22px, 2.2vw, 30px)}

  .eyebrow{
    font-family:var(--sans);
    font-size:11px;font-weight:500;
    letter-spacing:.32em;text-transform:uppercase;
    color:var(--coffee);
  }
  .eyebrow .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--gold);margin:0 .9em .2em 0;vertical-align:middle}
  .eyebrow.center{display:flex;align-items:center;justify-content:center;gap:14px}
  .eyebrow.center::before,.eyebrow.center::after{content:"";display:inline-block;width:36px;height:1px;background:var(--line)}

  .lede{font-size:clamp(17px,1.35vw,20px);line-height:1.7;color:var(--espresso-2);max-width:62ch;text-wrap:pretty}
  .body{color:var(--espresso-2);text-wrap:pretty}

  /* map block — static SVG map card + click-through to Google Maps (always visible) */
  .map-card{display:block;position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line-soft);background:var(--sand);transition:transform .35s ease, box-shadow .35s ease}
  .map-card:hover{transform:translateY(-2px);box-shadow:0 18px 40px -20px rgba(61,42,30,.35)}
  .map-card-img{display:block;width:100%;height:auto;aspect-ratio:920/540;object-fit:cover}
  .map-card-cta{position:absolute;left:14px;bottom:14px;display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:rgba(61,42,30,.92);color:var(--paper);font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;border-radius:999px;backdrop-filter:blur(6px);transition:background .25s ease}
  .map-card:hover .map-card-cta{background:var(--espresso)}
  .map-card-cta .arr{display:inline-block;transition:transform .25s ease}
  .map-card:hover .map-card-cta .arr{transform:translateX(3px)}

  /* layout --------------------------------------------------------------- */
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
  section{position:relative}

  /* buttons -------------------------------------------------------------- */
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
    padding:16px 28px;border-radius:999px;
    transition:transform .35s ease, background .35s ease, color .35s ease, box-shadow .35s ease, border-color .35s ease;
  }
  .btn .arr{display:inline-block;transition:transform .35s ease}
  .btn:hover .arr{transform:translateX(4px)}
  .btn-primary{background:var(--espresso);color:var(--paper)}
  .btn-primary:hover{background:#26170E}
  .btn-ghost{background:transparent;color:var(--espresso);border:1px solid var(--line)}
  .btn-ghost:hover{background:var(--paper);border-color:var(--espresso)}
  .btn-quiet{
    padding:0;background:none;color:var(--espresso);
    font-size:11.5px;letter-spacing:.28em;text-transform:uppercase;
    border-bottom:1px solid var(--coffee);padding-bottom:6px;border-radius:0;
  }
  .btn-quiet:hover{border-color:var(--espresso)}

  /* ─── morphing wordmark ────────────────────────────────────────────── */
  .morph{
    position:fixed;left:0;top:0;
    pointer-events:auto;z-index:80;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    transform-origin:50% 50%;
    will-change:transform;
  }
  .morph .shield{
    width:96px;height:auto;display:block;
    margin-bottom:18px;
    transition:opacity .4s ease;
  }
  .morph .wordmark{
    font-family:var(--display);font-weight:300;
    letter-spacing:.42em;text-transform:uppercase;
    color:var(--espresso);
    font-size:clamp(88px, 19vw, 220px);line-height:1;
    padding-left:.42em;
    white-space:nowrap;
  }
  /* logo placement variants */
  .morph[data-logo="above"]{flex-direction:column}
  .morph[data-logo="left"]{flex-direction:row;gap:24px}
  .morph[data-logo="left"] .shield{margin-bottom:0;width:120px}
  .morph[data-logo="right"]{flex-direction:row-reverse;gap:24px}
  .morph[data-logo="right"] .shield{margin-bottom:0;width:120px}
  .morph[data-logo="nav-only"] .shield,
  .morph[data-logo="hidden"] .shield{display:none}

  /* when fully docked: visually treat as nav element */
  .morph.locked{will-change:auto}

  @media (max-width:880px){
    .morph .shield{width:60px;margin-bottom:14px}
    .morph[data-logo="left"] .shield, .morph[data-logo="right"] .shield{width:72px}
  }

  /* ─── nav ──────────────────────────────────────────────────────────── */
  .nav{
    position:fixed;top:0;left:0;right:0;z-index:50;
    transition:background .4s ease, border-color .4s ease, backdrop-filter .4s ease;
    height:var(--nav-h);display:flex;align-items:center;
  }
  .nav.scrolled{
    background:rgba(234,226,210,.82);
    backdrop-filter:blur(14px) saturate(140%);
    -webkit-backdrop-filter:blur(14px) saturate(140%);
    border-bottom:1px solid var(--line-soft);
  }
  .nav-row{display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%}
  /* invisible target where the morph wordmark lands */
  .nav-anchor{
    visibility:hidden;
    font-family:var(--display);font-weight:300;
    letter-spacing:.42em;text-transform:uppercase;
    font-size:30px;line-height:1;padding-left:.42em;
    display:inline-block;
  }
  @media (max-width:880px){ .nav-anchor{font-size:24px} }
  .nav-links{display:flex;align-items:center;gap:36px}
  .nav-links a{font-size:13px;letter-spacing:.04em;color:var(--espresso-2);position:relative;padding:6px 0}
  .nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--espresso);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
  .nav-links a:hover{color:var(--espresso)}
  .nav-links a:hover::after{transform:scaleX(1)}
  .nav-cta{display:flex;align-items:center;gap:14px}
  .nav-phone{font-size:13px;color:var(--coffee);letter-spacing:.04em}
  .nav .btn{padding:12px 22px;font-size:11px}
  .nav-burger{display:none;width:36px;height:36px;align-items:center;justify-content:center}
  .nav-burger span{display:block;width:18px;height:1px;background:var(--espresso);position:relative}
  .nav-burger span::before,.nav-burger span::after{content:"";position:absolute;left:0;width:18px;height:1px;background:var(--espresso)}
  .nav-burger span::before{top:-6px}
  .nav-burger span::after{top:6px}

  @media (max-width:1080px){ .nav-phone{display:none} }
  @media (max-width:880px){
    .nav-links{display:none}
    .nav-burger{display:inline-flex}
  }

  /* mobile sheet --------------------------------------------------------- */
  .sheet{
    position:fixed;inset:0;z-index:100;background:rgba(234,226,210,.98);
    display:flex;flex-direction:column;padding:32px var(--gutter);
    overflow-y:auto;
    visibility:hidden;pointer-events:none;
    transform:translateY(-100%);transition:transform .55s cubic-bezier(.7,0,.3,1), visibility 0s linear .55s;
  }
  .sheet.open{transform:translateY(0);visibility:visible;pointer-events:auto;transition:transform .55s cubic-bezier(.7,0,.3,1)}
  .sheet-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:48px}
  .sheet-close{font-size:14px;letter-spacing:.2em;text-transform:uppercase}
  .sheet a{font-family:var(--display);font-size:36px;color:var(--espresso);padding:12px 0;border-bottom:1px solid var(--line-soft);display:block}
    .sheet a:last-child{border-bottom:0}
    .sheet .btn{
      font-family:var(--sans);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
      background:var(--espresso);color:var(--paper);padding:16px 28px;border-radius:999px;
      display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;width:auto;margin:0 auto
    }
    .sheet .btn:hover{background:#26170E}
    .sheet .btn .arr{display:inline-block}

  /* ─── HERO ─────────────────────────────────────────────────────────── */
  /* GLOBAL REGEL: scroll-indikator må ALDRIG overlappe interaktive elementer
     (CTA-knapper, links, formfelter) på nogen viewport. Hvis du tilføjer nyt
     indhold i hero, brug flex-flow så scroll-indikatoren forbliver sidste
     element med naturlig gap. */
  .hero{
    min-height:max(680px, 100svh);
    display:flex;flex-direction:column;
    position:relative;overflow:hidden;
  }
  .hero-inner{
    flex:1 1 auto;
    text-align:center;width:100%;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    padding-top:calc(var(--nav-h) + 24px);padding-bottom:24px;
  }
  /* invisible anchor — reserves space for the morph wordmark at rest */
  .hero-anchor{
    visibility:hidden;
    font-family:var(--display);font-weight:300;
    font-size:clamp(88px, 19vw, 220px);line-height:1;
    letter-spacing:.42em;text-transform:uppercase;padding-left:.42em;
    white-space:nowrap;
  }
  /* extra space above for the shield (only when shield is visible) */
  .hero-anchor.with-shield{padding-top:clamp(72px, 11vw, 114px)}

  .hero-sub{
    margin-top:44px;
    font-family:var(--display);font-style:italic;font-weight:300;
    font-size:clamp(22px,2.5vw,34px);
    color:var(--espresso-2);
    letter-spacing:.01em;
    opacity:0;animation:rise 1.1s .35s cubic-bezier(.2,.7,.2,1) forwards;
  }
  .hero-eyebrow{
    margin-top:18px;
    font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--coffee);
    opacity:0;animation:rise 1.1s .55s cubic-bezier(.2,.7,.2,1) forwards;
  }
  .hero-cta{
    margin-top:52px;display:flex;gap:18px;flex-wrap:wrap;justify-content:center;align-items:center;
    opacity:0;animation:rise 1.1s .75s cubic-bezier(.2,.7,.2,1) forwards;
  }
  /* Scroll-indikator: sidste flex-item i .hero (normal flow, IKKE absolut).
     margin-top skubber den væk fra CTA; flow-elementer kan aldrig overlappe →
     overlap er strukturelt umuligt på enhver viewport/aspect-ratio. */
  .hero-scroll{
      flex:0 0 auto;
      margin:clamp(28px,5vh,44px) auto 32px;width:fit-content;
      font-size:10px;letter-spacing:.42em;text-transform:uppercase;color:var(--coffee);
      display:flex;flex-direction:column;align-items:center;gap:14px;
    opacity:0;animation:rise 1.2s 1.1s cubic-bezier(.2,.7,.2,1) forwards;
  }
  .hero-scroll .ln{width:1px;height:48px;background:var(--coffee);position:relative;overflow:hidden}
  .hero-scroll .ln::after{content:"";position:absolute;left:0;right:0;top:-48px;height:48px;background:var(--ivory);animation:slideDown 2.4s 1.4s infinite}
  @keyframes slideDown{0%{transform:translateY(0)}100%{transform:translateY(96px)}}
  @keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
  /* Ekstra fallback for meget korte viewports (split-screen / DevTools åben
     nederst): skjul scroll-cue helt så hero-indhold får al pladsen. */
  @media (max-height:560px){.hero-scroll{display:none}}

  /* very faint warm radial glows behind hero */
  .hero::before, .hero::after{
    content:"";position:absolute;border-radius:50%;
    pointer-events:none;
  }
  .hero::before{width:60vw;height:60vw;left:-20vw;top:-10vw;background:radial-gradient(closest-side, rgba(199,162,74,.08), transparent 70%)}
  .hero::after{width:50vw;height:50vw;right:-15vw;bottom:-20vw;background:radial-gradient(closest-side, rgba(212,182,155,.10), transparent 70%)}

  /* ─── MANIFEST (section after hero) ────────────────────────────────── */
  .manifest{padding:clamp(130px, 16vw, 200px) 0}
  body:not([data-posthero="manifest"]) .manifest{display:none}

  .manifest-grid{
    display:grid;grid-template-columns:1fr 1fr;
    gap:clamp(48px, 7vw, 120px);align-items:center;
  }
  .manifest-text .eyebrow{margin-bottom:32px}
  .manifest-text .display{margin:0}
  .manifest-lines{
    list-style:none;padding:0;margin:56px 0 0;
    display:flex;flex-direction:column;gap:18px;align-items:flex-start;
  }
  .manifest-lines .word-line{
    font-family:var(--display);font-style:italic;font-weight:300;
    font-size:clamp(24px,2.6vw,36px);line-height:1.25;
    color:var(--espresso);
    opacity:0;transform:translateY(14px);
    transition:opacity .9s ease, transform .9s ease;
    max-width:24ch;
  }
  .manifest-lines .word-line.in{opacity:1;transform:none}
  .manifest-lines .word-line:nth-child(1){transition-delay:.05s}
  .manifest-lines .word-line:nth-child(2){transition-delay:.22s}
  .manifest-lines .word-line:nth-child(3){transition-delay:.39s}
  .manifest-body{margin-top:48px;max-width:42ch}
  /* Mobile: trim the manifest copy — keep the poetic word-lines, drop the
     longer supporting paragraph (its info also lives in Om Lene / Find vej). */
  @media (max-width:620px){
    .manifest-text .eyebrow{margin-bottom:22px}
    .manifest-lines{margin:28px 0 0}
    .manifest-body{display:none}
  }

  /* right column: animated showcase */
  #showcase{
    position:relative;width:100%;aspect-ratio:4/5;overflow:hidden;background:var(--sand);
  }
  .show-slide{
    position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease;
  }
  .show-slide.on{opacity:1;z-index:1}
  .show-slide img{
    width:100%;height:100%;object-fit:cover;
    transform:scale(1);transition:transform 6.5s linear;
  }
  .show-slide.on img{transform:scale(1.06)}
  .show-cap{
    position:absolute;left:0;bottom:24px;
    background:var(--ivory);padding:12px 18px;
    font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--coffee);
    opacity:0;transition:opacity .8s ease .4s;
  }
  .show-slide.on .show-cap{opacity:1}
  .show-dots{
    position:absolute;right:20px;bottom:20px;display:flex;gap:8px;z-index:2;
  }
  .show-dots button{
    width:22px;height:1px;background:rgba(244,236,220,.55);cursor:pointer;transition:all .4s ease;padding:0;
  }
  .show-dots button.on{width:36px;background:var(--paper)}

  @media (max-width:880px){
    .manifest-grid{grid-template-columns:1fr;gap:56px}
  }

  /* ─── alt post-hero variants ──────────────────────────────────────── */

  /* rotating-strip: full-width horizontal slow scroll w/ a calm headline */
  .ph-strip{padding:clamp(110px, 14vw, 180px) 0}
  body:not([data-posthero="strip"]) .ph-strip{display:none}
  .ph-strip-head{text-align:center;max-width:680px;margin:0 auto 64px}
  .ph-strip .strip-track{
    display:flex;gap:18px;width:max-content;
    animation:drift 90s linear infinite;
  }
  .ph-strip:hover .strip-track{animation-play-state:paused}
  .ph-strip .strip-track figure{
    margin:0;flex:0 0 auto;width:clamp(280px,28vw,420px);aspect-ratio:4/5;overflow:hidden;background:var(--paper);position:relative;
  }
  .ph-strip .strip-track figure img{width:100%;height:100%;object-fit:cover}

  /* simple-text: just a centered short paragraph */
  .ph-simple{padding:clamp(110px, 14vw, 180px) 0;text-align:center}
  body:not([data-posthero="simple"]) .ph-simple{display:none}
  .ph-simple-inner{max-width:780px;margin:0 auto}
  .ph-simple .display{margin:18px 0 0}
  .ph-simple .lede{margin:32px auto 0}

  /* ─── BEHANDLINGER ────────────────────────────────────────────────── */
  .treatments{padding:clamp(100px,12vw,160px) 0 clamp(120px,14vw,180px)}
  .section-head{display:flex;justify-content:space-between;align-items:end;gap:32px;margin-bottom:80px;flex-wrap:wrap}
  .section-head .h-1{margin:.2em 0 0;max-width:14ch}
  .section-head p{max-width:42ch;margin:0;color:var(--espresso-2)}

  /* main row: 3 featured cards */
  .treat-main{
    display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
    margin-bottom:72px;
  }
  .treat-card{
    position:relative;background:var(--paper);
    overflow:hidden;border:1px solid var(--line-soft);
    transition:transform .5s ease, box-shadow .5s ease;
    display:flex;flex-direction:column;
  }
  .treat-card:hover{transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(61,42,30,.25)}
  .treat-img{aspect-ratio:4/5;overflow:hidden;background:var(--sand)}
  .treat-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s ease}
  .treat-card:hover .treat-img img{transform:scale(1.06)}
  .treat-meta{padding:26px 28px 30px;display:flex;flex-direction:column;gap:8px;flex:1}
  .treat-meta .num{font-family:var(--display);font-style:italic;font-size:14px;color:var(--coffee)}
  .treat-meta h3{font-family:var(--display);font-weight:400;font-size:30px;margin:0;line-height:1.05}
  .treat-meta p{font-size:13.5px;color:var(--espresso-2);margin:0;line-height:1.55}
  .treat-meta .more{margin-top:auto;padding-top:16px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--espresso);display:inline-flex;align-items:center;gap:8px}
  .treat-card:hover .more .arr{transform:translateX(4px)}

  .treat-main .treat-card .treat-img{aspect-ratio:4/4.4}
  .treat-main .treat-meta h3{font-size:clamp(26px, 2.4vw, 34px)}

  /* secondary row: 4 compact cards */
  .treat-divider{
    display:flex;align-items:center;gap:18px;margin:0 0 40px;
    font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--coffee);
  }
  .treat-divider::before,.treat-divider::after{content:"";flex:1;height:1px;background:var(--line-soft)}
  .treat-secondary{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .treat-secondary .treat-card{background:transparent;border:0}
  .treat-secondary .treat-card:hover{box-shadow:none;transform:translateY(-3px)}
  .treat-secondary .treat-img{aspect-ratio:4/5;border:1px solid var(--line-soft)}
  .treat-secondary .treat-meta{padding:18px 4px 8px;gap:4px}
  .treat-secondary .treat-meta h3{font-size:22px}
  .treat-secondary .treat-meta p{font-size:12.5px}

  @media (max-width:880px){
    .section-head{margin-bottom:48px}
    /* stack the 3 featured cards image-on-top — breathing room, no overlap */
    .treat-main{grid-template-columns:1fr;gap:26px;margin-bottom:56px}
    .treat-main .treat-card{display:flex;flex-direction:column;background:var(--paper)}
    .treat-main .treat-card .treat-img{aspect-ratio:16/10;height:auto}
    .treat-main .treat-meta{padding:24px 26px 28px;gap:10px}
    .treat-main .treat-meta .num{font-size:13px}
    .treat-main .treat-meta h3{font-size:clamp(24px,6.5vw,30px)}
    .treat-main .treat-meta p{font-size:14px;line-height:1.6}
    .treat-main .treat-meta .more{padding-top:14px}

    .treat-secondary{grid-template-columns:repeat(2,1fr);gap:28px 16px}
    .treat-secondary .treat-meta h3{font-size:18px}
    .treat-secondary .treat-meta p{font-size:12px}
  }
  @media (max-width:480px){
    .treat-main .treat-card .treat-img{aspect-ratio:3/2}
    .treat-main .treat-meta h3{font-size:24px}
  }

  /* content-visibility: defer rendering of below-fold sections */
    .stemning,.gift,.booking-band,.om,.practical,footer,.cookie,.bk-overlay{content-visibility:auto;contain-intrinsic-size:600px}

    /* ─── STEMNING ────────────────────────────────────────────────────── */
    .stemning{
    background:linear-gradient(180deg,var(--ivory-2) 0%, var(--sand) 100%);
    padding:clamp(120px,14vw,180px) 0;position:relative;overflow:hidden;
  }
  .stemning-head{text-align:center;max-width:820px;margin:0 auto 80px}
  .stemning-head .h-1 em{color:var(--clay)}

  /* slideshow */
  .slideshow{position:relative;width:100%;aspect-ratio:16/9;max-height:78vh;overflow:hidden;background:var(--sand)}
  .slideshow .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.6s ease}
  .slideshow .slide.on{opacity:1;z-index:1}
  .slideshow .slide img{width:100%;height:100%;object-fit:cover;transform:scale(1);transition:transform 8s linear}
  .slideshow .slide.on img{transform:scale(1.06)}
  .slideshow .slide-cap{position:absolute;left:24px;bottom:24px;background:rgba(244,236,220,.92);padding:10px 16px;font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--espresso);opacity:0;transition:opacity .8s ease .4s}
  .slideshow .slide.on .slide-cap{opacity:1}
  .slide-dots{position:absolute;right:24px;bottom:24px;display:flex;gap:8px;z-index:2}
  .slide-dots button{width:24px;height:1px;background:rgba(244,236,220,.55);cursor:pointer;transition:all .4s ease;padding:0}
  .slide-dots button.on{width:40px;background:var(--paper)}
  .slide-counter{position:absolute;left:24px;top:24px;z-index:2;font-family:var(--display);font-style:italic;font-size:14px;color:var(--paper);text-shadow:0 1px 4px rgba(61,42,30,.4)}

  /* grid */
  .stem-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:22px}
  .stem-grid figure{margin:0;overflow:hidden;background:var(--paper);position:relative;opacity:0;transform:translateY(20px);transition:opacity 1.1s ease, transform 1.1s ease}
  .stem-grid figure.in{opacity:1;transform:none}
  .stem-grid figure img{width:100%;height:100%;object-fit:cover;transform:scale(1);transition:transform 16s linear}
  .stem-grid figure.in img{transform:scale(1.07)}
  .stem-grid .a{grid-column:span 5;aspect-ratio:4/5}
  .stem-grid .b{grid-column:span 4;aspect-ratio:3/4;margin-top:64px}
  .stem-grid .c{grid-column:span 3;aspect-ratio:3/4;align-self:end}
  .stem-grid .d{grid-column:span 4;aspect-ratio:4/3;margin-top:32px}
  .stem-grid .e{grid-column:span 5;aspect-ratio:5/3.5}
  .stem-grid .f{grid-column:span 3;aspect-ratio:3/4;margin-top:-40px}
  .stem-cap{position:absolute;left:14px;bottom:14px;background:rgba(244,236,220,.92);padding:8px 12px;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--espresso-2)}
  @media (max-width:880px){
    .stem-grid .a,.stem-grid .b,.stem-grid .c,.stem-grid .d,.stem-grid .e,.stem-grid .f{
      grid-column:span 6;margin-top:0;aspect-ratio:4/5;
    }
  }

  /* drift */
  .drift{position:relative;width:100%;overflow:hidden;padding:8px 0}
  .drift-track{display:flex;gap:22px;width:max-content;animation:drift 80s linear infinite}
  .drift:hover .drift-track{animation-play-state:paused}
  .drift-track figure{margin:0;flex:0 0 auto;width:clamp(300px,29vw,460px);aspect-ratio:4/5;overflow:hidden;background:var(--paper);position:relative}
  .drift-track figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s ease}
  .drift-track figure:hover img{transform:scale(1.05)}
  @keyframes drift{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* hide non-active stem variants */
  body:not([data-stem="slideshow"]) .slideshow{display:none}
  body:not([data-stem="grid"]) .stem-grid{display:none}
  body:not([data-stem="drift"]) .drift{display:none}

  /* ─── NYHED HOS VIDA ──────────────────────────────────────────────── */
  .news{padding:clamp(80px,10vw,130px) 0;background:linear-gradient(180deg,var(--paper),var(--ivory))}
  .news-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:16px;padding:clamp(36px,5vw,60px);display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,4vw,48px);align-items:start;position:relative;overflow:hidden}
  .news-card::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(199,162,74,.06),transparent 60%);pointer-events:none}
  .news-badge{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--paper);background:var(--gold);padding:6px 16px;border-radius:999px;white-space:nowrap;display:inline-block}
  .news-content{display:flex;flex-direction:column;gap:20px;position:relative;z-index:1}
    .news-content h2{margin:0;line-height:1.2;letter-spacing:.01em}
    .news-content h2 em{color:var(--clay)}
    .news-lede{font-size:clamp(15px,1.2vw,17px);color:var(--espresso-2);margin:0;max-width:52ch}
    .news-list{list-style:none;padding:0;margin:8px 0 12px;display:flex;flex-wrap:wrap;gap:10px}
    .news-list li{font-family:var(--display);font-size:clamp(17px,1.5vw,21px);color:var(--espresso);background:var(--ivory-2);padding:10px 22px;border-radius:999px;border:1px solid var(--line-soft)}
    .news-body{font-size:14px;color:var(--coffee);margin:0 0 4px;max-width:48ch}
    .news-offer{font-family:var(--display);font-size:clamp(22px,2.4vw,30px);color:var(--gold);margin:8px 0 16px}
    .news .btn{margin-top:8px}
    .news-closure{margin-top:48px;padding:clamp(28px,4vw,48px) clamp(32px,5vw,56px);background:var(--paper);border:1px solid var(--line-soft);border-radius:14px;display:flex;align-items:center;gap:clamp(20px,4vw,48px);flex-wrap:wrap}
    .news-closure .eyebrow{margin:0;flex-shrink:0}
    .news-closure-text{font-size:14px;color:var(--espresso-2);margin:0;line-height:1.7}
  @media (max-width:620px){
        .news-card{grid-template-columns:1fr;gap:28px;padding:clamp(28px,6vw,40px)}
        .news-closure{flex-direction:column;align-items:flex-start;gap:20px;padding:clamp(28px,5vw,40px);margin-top:36px}
        .news-list{gap:10px}
        .news-list li{font-size:16px;padding:10px 18px}
        .news .btn{width:100%;justify-content:center}
        .news-closure-text{font-size:15px;line-height:1.8}
        .news-offer{font-size:clamp(20px,5.5vw,26px);margin:10px 0 16px}
        .news{padding:clamp(60px,8vw,100px) 0}
        .news-content{gap:22px}
      }

  /* ─── GAVEKORT ────────────────────────────────────────────────────── */
  .gift{padding:clamp(110px,12vw,160px) 0}
  .gift-card{display:grid;grid-template-columns:1.05fr 1fr;gap:0;background:var(--espresso);color:var(--paper);overflow:hidden;position:relative}
  .gift-text{padding:clamp(44px,5vw,80px);display:flex;flex-direction:column;justify-content:space-between;gap:56px}
  .gift-text .eyebrow{color:var(--gold-soft)}
  .gift-text .h-1{color:var(--paper);margin:.4em 0 0}
  .gift-text .h-1 em{color:var(--gold-soft)}
  .gift-text .body{color:rgba(244,236,220,.78)}
  .gift-actions{display:flex;gap:14px;flex-wrap:wrap}
  .gift-actions .btn-primary{background:var(--paper);color:var(--espresso)}
  .gift-actions .btn-primary:hover{background:var(--gold-soft)}
  .gift-actions .btn-ghost{color:var(--paper);border-color:rgba(244,236,220,.3)}
  .gift-actions .btn-ghost:hover{background:rgba(244,236,220,.06);border-color:var(--paper)}
  .gift-amt-label{margin:32px 0 14px;font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-soft)}
  .gift-amounts{display:flex;gap:18px;flex-wrap:wrap}
  /* Inspiration only — not a selector. The amount is chosen on the booking page. */
  .gift-amounts .amt{border:1px solid rgba(244,236,220,.18);padding:14px 22px;font-family:var(--display);font-size:22px;display:flex;align-items:baseline;gap:6px;color:var(--paper)}
  .gift-amounts .amt.on{border-color:var(--gold-soft);background:rgba(217,190,122,.12)}
  .gift-amounts .amt small{font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,236,220,.6)}
  .gift-perks{margin:24px 0 0;font-size:12px;letter-spacing:.04em;color:rgba(244,236,220,.7)}
  .gift-image{position:relative;min-height:480px;background:var(--sand);overflow:hidden}
  .gift-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .gift-image::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 50%,rgba(61,42,30,.35))}
  @media (max-width:880px){
    .gift-card{grid-template-columns:1fr}
    .gift-image{min-height:320px;order:-1}
  }

  /* ─── BOOKING ─────────────────────────────────────────────────────── */
  .booking-band{padding:clamp(110px,12vw,160px) 0;background:var(--ivory);border-top:1px solid var(--line-soft)}
  .booking-inner{max-width:680px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center}
  .booking-inner .h-2{margin:.3em 0 .1em}
  .booking-inner .h-2 em{color:var(--espresso-2)}
  .booking-inner .lede{margin:0 auto 36px;color:var(--espresso-2)}
  .booking-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
  .booking-note{margin-top:24px;font-size:13px;letter-spacing:.04em;color:var(--coffee)}
  .booking-note a{color:var(--espresso);border-bottom:1px solid var(--line)}
  .booking-note a:hover{border-color:var(--espresso)}

  /* ─── OM LENE ─────────────────────────────────────────────────────── */
  .om{padding:clamp(110px,12vw,160px) 0;background:var(--paper)}
  .om-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(48px,7vw,110px);align-items:center}
  .om-photo{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--sand)}
  .om-photo img{width:100%;height:100%;object-fit:cover}
  .om-photo .badge{
    position:absolute;top:24px;right:24px;
    width:122px;height:122px;border-radius:50%;
    background:var(--ivory);color:var(--espresso);
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    font-family:var(--display);font-style:italic;line-height:1.1;text-align:center;
    transform:rotate(-8deg);box-shadow:0 18px 40px -16px rgba(61,42,30,.35);
    border:1px solid var(--line-soft);
  }
  .om-photo .badge .tiny{font-family:var(--sans);font-style:normal;font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:var(--coffee);display:block;margin-bottom:6px}
  .om-photo .badge .big{font-size:14px;color:var(--espresso)}
  .om-photo .badge .num{font-size:22px;color:var(--gold);margin-top:2px;font-weight:500}

  .om-text .quote{
    font-family:var(--display);font-style:italic;font-size:clamp(24px,2.4vw,34px);line-height:1.3;
    color:var(--espresso);margin:32px 0 24px;border-left:1px solid var(--gold);padding-left:24px;
  }
  .om-sig{display:flex;align-items:center;gap:14px;margin-top:40px;font-size:12.5px;color:var(--coffee)}
  .om-sig .line{flex:1;height:1px;background:var(--line)}
  @media (max-width:880px){.om-grid{grid-template-columns:1fr;gap:56px}}

  /* ─── PRACTICAL ───────────────────────────────────────────────────── */
  .practical{padding:clamp(100px,12vw,150px) 0}
  .pr-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
  .pr-info dl{display:grid;grid-template-columns:130px 1fr;gap:2px 28px;margin:0}
  .pr-info dt{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--coffee);padding:20px 0;border-top:1px solid var(--line-soft)}
  .pr-info dd{margin:0;padding:20px 0;border-top:1px solid var(--line-soft);color:var(--espresso);font-size:15.5px;line-height:1.6}
  .pr-info dd em{font-family:var(--display);font-style:italic;color:var(--coffee);font-size:14px;display:block;margin-top:2px}
  .pr-right{display:flex;flex-direction:column;gap:clamp(28px,3.4vw,44px)}
  .pr-map{aspect-ratio:16/10;background:linear-gradient(135deg,#E4DCCB,#D7CCB7);position:relative;overflow:hidden;border-radius:12px}
  .pr-map .facade{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.95}
  .pr-map .pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-100%);background:var(--paper);padding:12px 16px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--espresso);box-shadow:0 14px 30px -10px rgba(61,42,30,.4);display:flex;align-items:center;gap:10px}
  .map-wrap{border-radius:12px;overflow:hidden;box-shadow:0 4px 20px -8px rgba(61,42,30,.2);margin-top:4px}
  .pr-map .pin::after{content:"";position:absolute;left:50%;bottom:-7px;transform:translateX(-50%) rotate(45deg);width:12px;height:12px;background:var(--paper)}
  .pr-map .pin .dot{width:8px;height:8px;border-radius:50%;background:var(--gold)}
  /* kontaktform ---------------------------------------------------------- */
  .kontakt-form{background:var(--paper);border:1px solid var(--line-soft);border-radius:14px;padding:clamp(26px,3vw,38px)}
  .kontakt-form .eyebrow{margin-bottom:14px}
  .kontakt-form h3{color:var(--espresso)}
  .form-group{margin-bottom:18px}
  .form-label{display:block;font-family:var(--display);font-style:italic;font-size:18px;color:var(--coffee);margin-bottom:7px}
  .form-label .form-opt{font-family:var(--sans);font-style:normal;font-size:11px;letter-spacing:.06em;color:var(--coffee);opacity:.7}
  .form-input{width:100%;font-family:var(--sans);font-size:15px;line-height:1.5;color:var(--espresso);background:var(--ivory);border:1px solid var(--line-soft);border-radius:8px;padding:12px 14px;transition:border-color .25s ease, box-shadow .25s ease}
  .form-input::placeholder{color:var(--coffee);opacity:.6}
  .form-input:focus-visible{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--camel)}
  .form-textarea{resize:vertical;min-height:104px}
  .form-submit{margin-top:6px;cursor:pointer;border:none}
  .form-submit:disabled{opacity:.6;cursor:wait}
  .buur-feedback{font-size:14.5px;color:var(--espresso-2);min-height:1.2em}
  @media (max-width:880px){.pr-grid{grid-template-columns:1fr}}

  /* ─── FOOTER ──────────────────────────────────────────────────────── */
  footer{background:var(--espresso);color:var(--paper);padding:clamp(80px,9vw,120px) 0 40px}
  .ft-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:56px;align-items:start}
  /* Official ornate logo — shown directly so its original white & gold reads
     cleanly on the espresso footer. */
  .ft-brand-logo{
    width:clamp(240px, 20vw, 320px);height:auto;
    display:block;margin-bottom:8px;
  }
  .ft-brand .tagline{
    font-family:var(--display);font-style:italic;font-size:20px;color:rgba(244,236,220,.7);
    max-width:32ch;line-height:1.4;margin:4px 0 0;
  }
  footer h4{font-family:var(--sans);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-soft);margin:0 0 22px}
  footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;font-size:14px;color:rgba(244,236,220,.78)}
  footer ul a:hover{color:var(--paper)}

  /* Social icons — prominent circular */
  .ft-social{display:flex;gap:12px;margin-top:6px}
  .ft-social a{
    display:inline-flex;align-items:center;justify-content:center;
    width:52px;height:52px;border-radius:50%;
    border:1px solid rgba(244,236,220,.22);
    color:var(--paper);
    transition:all .35s ease;
  }
  .ft-social a:hover{background:var(--gold-soft);color:var(--espresso);border-color:var(--gold-soft);transform:translateY(-2px)}
  .ft-social svg{width:22px;height:22px;fill:currentColor}
  .ft-social .label{
    margin-left:14px;display:inline-flex;align-items:center;
    font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,236,220,.65);
  }

  .ft-bottom{display:flex;justify-content:space-between;align-items:center;gap:24px;padding-top:56px;margin-top:72px;border-top:1px solid rgba(244,236,220,.12);font-size:12px;color:rgba(244,236,220,.5);flex-wrap:wrap}
    @media (max-width:880px){
      .ft-top{grid-template-columns:1fr 1fr;gap:40px}
      footer .ft-brand{grid-column:span 2;text-align:center}
      .ft-brand-logo{margin:0 auto}
    }

  /* scroll reveal generic */
  .reveal{opacity:0;transform:translateY(20px);transition:opacity .9s ease, transform .9s ease}
  .reveal.in{opacity:1;transform:none}

  ::selection{background:var(--gold);color:var(--paper)}

  /* density: scales section padding via a custom multiplier */
  body[data-density="airy"]{--pad-mult:1.25}
  body[data-density="standard"]{--pad-mult:1}
  body[data-density="dense"]{--pad-mult:.75}
  body[data-density]:not([data-density="standard"]) .manifest{padding-block:calc(clamp(130px,16vw,200px) * var(--pad-mult,1))}
  body[data-density]:not([data-density="standard"]) .treatments{padding-block:calc(clamp(100px,12vw,160px) * var(--pad-mult,1))}
  body[data-density]:not([data-density="standard"]) .stemning{padding-block:calc(clamp(120px,14vw,180px) * var(--pad-mult,1))}
  body[data-density]:not([data-density="standard"]) .gift{padding-block:calc(clamp(110px,12vw,160px) * var(--pad-mult,1))}
  body[data-density]:not([data-density="standard"]) .om{padding-block:calc(clamp(110px,12vw,160px) * var(--pad-mult,1))}
  body[data-density]:not([data-density="standard"]) .practical{padding-block:calc(clamp(100px,12vw,150px) * var(--pad-mult,1))}

  /* tweak toggles via body data-attrs */
  body[data-badge="off"] .om-photo .badge{display:none}
  body[data-scrollcue="off"] .hero-scroll{display:none}
  body[data-herosub="off"] .hero-sub{display:none}
  /* headline weight */
  body[data-hw="light"] .display{font-weight:300}
  body[data-hw="regular"] .display{font-weight:400}
  body[data-hw="medium"] .display{font-weight:500}
  body[data-hw="light"] .morph .wordmark,
  body[data-hw="light"] .nav-anchor,
  body[data-hw="light"] .hero-anchor{font-weight:300}
  body[data-hw="regular"] .morph .wordmark,
  body[data-hw="regular"] .nav-anchor,
  body[data-hw="regular"] .hero-anchor{font-weight:400}
  body[data-hw="medium"] .morph .wordmark,
  body[data-hw="medium"] .nav-anchor,
  body[data-hw="medium"] .hero-anchor{font-weight:500}

  /* ─── Jordnære detaljer — tweak-styrede lag (default: fra) ────────────── */
  /* 1 · Lysere flader — et strejf mere lys i de midterste sektioner */
  body[data-lightwash="on"] .manifest{background:linear-gradient(180deg,var(--paper) 0%, var(--ivory) 100%)}
  body[data-lightwash="on"] .treatments{background:linear-gradient(180deg,var(--paper) 0%, var(--ivory) 58%)}
  body[data-lightwash="on"] .stemning{background:linear-gradient(180deg,var(--paper) 0%, var(--ivory-2) 100%)}

  /* 2 · Linje-motiver — fine botaniske streg-mærker (erstatter prikken i eyebrows) */
  body[data-motifs="on"] .eyebrow .dot{
    width:17px;height:17px;border-radius:0;background:transparent;margin-right:.5em;vertical-align:-3px;
    background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C2A17C' stroke-width='1.2' stroke-linecap='round'><path d='M12 22 V5'/><path d='M12 11 C8 10.5 6 8 6 4.8'/><path d='M12 11 C16 10.5 18 8 18 4.8'/><path d='M12 16 C9 15.6 7.5 13.6 7.5 11'/><path d='M12 16 C15 15.6 16.5 13.6 16.5 11'/></svg>");
    background-size:contain;background-repeat:no-repeat;background-position:center;
  }
  body[data-motifs="on"] .gift-text .eyebrow .dot{
    background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23D9BE7A' stroke-width='1.2' stroke-linecap='round'><path d='M12 22 V5'/><path d='M12 11 C8 10.5 6 8 6 4.8'/><path d='M12 11 C16 10.5 18 8 18 4.8'/><path d='M12 16 C9 15.6 7.5 13.6 7.5 11'/><path d='M12 16 C15 15.6 16.5 13.6 16.5 11'/></svg>");
  }
  /* delicate corner brackets framing the gavekort card */
  body[data-motifs="on"] .gift-card::before,
  body[data-motifs="on"] .gift-card::after{
    content:"";position:absolute;width:38px;height:38px;z-index:3;pointer-events:none;opacity:.5;
  }
  body[data-motifs="on"] .gift-card::before{left:20px;top:20px;border-left:1px solid var(--gold-soft);border-top:1px solid var(--gold-soft)}
  body[data-motifs="on"] .gift-card::after{right:20px;bottom:20px;border-right:1px solid var(--gold-soft);border-bottom:1px solid var(--gold-soft)}

  /* 3 · Jordnær tekstur — næsten umærkelig kornethed bag mørke flader */
  body[data-texture="on"] .gift-card{
    background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='160' height='160' filter='url(%23n)' opacity='0.5'/></svg>");
    background-size:170px 170px;background-blend-mode:soft-light;
  }

  @media (prefers-reduced-motion: reduce){
    *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  }

  /* ─── BOOKING POPUP (mock af bestilling.nu-overlay) ──────────────────── */
  .bk-overlay{
    position:fixed;inset:0;z-index:200;
    display:flex;align-items:center;justify-content:center;
    padding:clamp(14px,4vw,48px);
    /* Solid scrim (no live backdrop-filter): a full-viewport blur re-rasterises
       the whole page every frame and made both the page behind AND the iframe
       jank badly while the drift marquee kept animating. */
    background:rgba(40,27,19,.78);
    opacity:0;visibility:hidden;pointer-events:none;
    transition:opacity .3s ease, visibility 0s linear .3s;
  }
  /* When the booking modal is open, freeze background motion so the GPU isn't
     compositing the marquee under a full-screen overlay. */
  body.bk-open .drift-track,
  body.bk-open .strip-track,
  body.bk-open .intro-media{animation-play-state:paused !important}
  .bk-overlay.open{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .3s ease}
  .bk-modal{
    width:min(780px,100%);height:min(84vh,840px);
    display:flex;flex-direction:column;
    background:var(--paper);color:var(--espresso);
    border:1px solid var(--line-soft);
    box-shadow:0 50px 130px -40px rgba(45,30,21,.6);
    transform:translateY(20px) scale(.985);opacity:.5;
    transition:transform .34s cubic-bezier(.2,.7,.2,1), opacity .34s ease;
    overflow:hidden;
  }
  .bk-overlay.open .bk-modal{transform:none;opacity:1}
  .bk-head{
    display:flex;align-items:flex-start;justify-content:space-between;gap:20px;
    padding:22px 24px 18px;border-bottom:1px solid var(--line-soft);background:var(--ivory);
  }
  .bk-head h3{font-family:var(--display);font-weight:400;font-size:clamp(24px,3vw,32px);margin:8px 0 0;line-height:1}
  .bk-close{
    width:42px;height:42px;flex:0 0 auto;border:1px solid var(--line);border-radius:50%;position:relative;
    transition:background .3s ease, border-color .3s ease, transform .4s ease;
  }
  .bk-close:hover{background:var(--ivory-2);border-color:var(--espresso);transform:rotate(90deg)}
  .bk-close span{position:absolute;left:50%;top:50%;width:15px;height:1px;background:var(--espresso)}
  .bk-close span:first-child{transform:translate(-50%,-50%) rotate(45deg)}
  .bk-close span:last-child{transform:translate(-50%,-50%) rotate(-45deg)}
  .bk-frame-wrap{position:relative;flex:1;min-height:0;background:var(--ivory)}
  .bk-frame{position:absolute;inset:0;width:100%;height:100%;border:0;background:#fff;z-index:2}
  .bk-fallback{
    position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:40px;gap:18px;
  }
  .bk-fallback .display{font-size:26px;margin:0}
  .bk-fallback p{max-width:34ch;color:var(--espresso-2);margin:0}
  .bk-loading{
    position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
    background:var(--ivory);transition:opacity .5s ease, visibility 0s linear .5s;
  }
  .bk-loading.hide{opacity:0;visibility:hidden}
  .bk-spinner{width:34px;height:34px;border-radius:50%;border:2px solid var(--line);border-top-color:var(--clay);animation:bkspin .9s linear infinite}
  @keyframes bkspin{to{transform:rotate(360deg)}}
  .bk-loading p{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--coffee);margin:0}
  .bk-foot{
    display:flex;align-items:center;justify-content:space-between;gap:16px;
    padding:14px 24px;border-top:1px solid var(--line-soft);background:var(--ivory);
    font-size:11px;letter-spacing:.04em;color:var(--coffee);
  }
  .bk-foot a{border-bottom:1px solid var(--line);padding-bottom:2px;color:var(--espresso)}
  .bk-foot a:hover{border-color:var(--espresso)}
  body[data-bookingpopup="off"] .bk-overlay{display:none}
  @media (max-width:620px){
    .bk-modal{height:90vh;width:100%}
    .bk-head{padding:18px 18px 14px}
    .bk-foot{padding:12px 18px}
  }

  /* ─── COOKIE BANNER ──────────────────────────────────────────────────── */
  .cookie{
    position:fixed;left:clamp(16px,4vw,32px);right:clamp(16px,4vw,32px);bottom:clamp(16px,4vw,28px);
    z-index:180;max-width:560px;margin-inline:auto;
    background:var(--paper);color:var(--espresso);border:1px solid var(--line);
    box-shadow:0 30px 80px -30px rgba(45,30,21,.45);
    padding:22px 24px;
    display:flex;flex-direction:column;gap:16px;
    opacity:0;transform:translateY(14px);visibility:hidden;
    transition:opacity .4s ease, transform .4s cubic-bezier(.2,.7,.2,1), visibility 0s linear .4s;
  }
  .cookie.show{opacity:1;transform:none;visibility:visible;transition:opacity .4s ease, transform .4s cubic-bezier(.2,.7,.2,1)}
  .cookie p{margin:0;font-size:13px;line-height:1.6;color:var(--espresso-2)}
  .cookie p a{border-bottom:1px solid var(--line);padding-bottom:1px}
  .cookie p a:hover{border-color:var(--espresso)}
  .cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
  .cookie-actions .btn{padding:11px 22px}
  @media (max-width:480px){ .cookie-actions .btn{flex:1 1 auto;text-align:center} }

  /* ─── MOBILE: less text ──────────────────────────────────────────────── */
  /* Phones get the headings + the essential sentences; secondary lead/flavour
     paragraphs are hidden (desktop keeps the full copy). */
  @media (max-width:620px){
    .section-head > .body{display:none}        /* Behandlinger + Find vej lead lines */
    .om-text .body{display:none}               /* keeps Lene's quote, drops the vol.2 note */
    .gift-text .body{font-size:14px;max-width:38ch}
    .treat-secondary .treat-meta p{display:none} /* card titles stay, micro-descriptions go */
  }

/* a11y / SEO utility */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ═══ SUBPAGES (behandlinger / om / gavekort) ═══════════════════════════ */
.nav-brand{font-family:var(--display);font-weight:300;letter-spacing:.42em;text-transform:uppercase;font-size:30px;line-height:1;padding-left:.42em;color:var(--espresso)}
@media (max-width:880px){ .nav-brand{font-size:24px} }

.subhero{padding:calc(var(--nav-h) + clamp(48px,9vw,120px)) 0 clamp(40px,6vw,72px);background:linear-gradient(180deg,var(--paper),var(--ivory));text-align:center}
.subhero .eyebrow{justify-content:center}
.subhero .h-1{margin:.18em 0 .28em}
.subhero .lede{margin:0 auto;color:var(--espresso-2)}
.subhero .hero-cta{display:flex;gap:18px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:34px}

.sect{padding:clamp(64px,9vw,120px) 0;position:relative}
.sect.alt{background:linear-gradient(180deg,var(--ivory),var(--paper))}
.sect-intro{max-width:60ch;margin:0 0 clamp(34px,5vw,56px)}

/* treatment catalogue */
.cat{margin-bottom:clamp(48px,7vw,86px)}
.cat:last-child{margin-bottom:0}
.cat-head{display:flex;align-items:baseline;justify-content:space-between;gap:24px;padding-bottom:20px;border-bottom:1px solid var(--line);margin-bottom:8px}
.cat-head h2{margin:0}
.cat-count{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--coffee);white-space:nowrap}
.treat-row{display:grid;grid-template-columns:1fr auto;gap:8px 32px;padding:26px 0;border-bottom:1px solid var(--line-soft);align-items:start}
.treat-row:last-child{border-bottom:0}
.tr-name{
  font-family:var(--display);font-size:clamp(20px,2vw,26px);font-weight:500;
  color:var(--espresso);line-height:1.2;
  cursor:pointer;position:relative;padding-right:32px;
  -webkit-tap-highlight-color:transparent;
  user-select:none;
}
.tr-name::after{
  content:"+";position:absolute;right:0;top:0.04em;
  font-family:var(--sans);font-size:clamp(16px,1.4vw,20px);font-weight:300;
  color:var(--coffee);line-height:1;
  transition:transform .25s ease, color .25s ease;
}
.tr-name:hover::after{color:var(--espresso)}
.tr-name.expanded::after{content:"−"}
.tr-desc{
  grid-column:1/2;color:var(--espresso-2);font-size:15px;line-height:1.62;
  margin:0;max-width:64ch;text-wrap:pretty;
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .45s cubic-bezier(.4,0,.2,1), opacity .35s ease, margin .35s ease;
}
.tr-desc.expanded{
  max-height:600px;opacity:1;margin:8px 0 0;
}
.tr-meta{text-align:right;white-space:nowrap}
.tr-price{font-family:var(--display);font-size:clamp(20px,2vw,26px);color:var(--espresso);font-weight:500}
.tr-dur{display:block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--coffee);margin-top:4px}
@media (max-width:620px){
  .treat-row{grid-template-columns:1fr auto;gap:4px 16px}
  .tr-desc{grid-column:1/-1}
}

/* nominations */
.noms{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px;margin-top:clamp(32px,5vw,48px)}
.nom{border:1px solid var(--line);border-radius:14px;padding:26px 22px;text-align:center;background:var(--paper)}
.nom-year{font-family:var(--display);font-size:34px;color:var(--gold);line-height:1;margin-bottom:8px}
.nom-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--coffee)}

/* om-layout */
.om-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(36px,6vw,72px);align-items:center}
@media (max-width:880px){ .om-grid{grid-template-columns:1fr} }
.om-portrait{position:relative}
.om-portrait img{width:100%;border-radius:18px;aspect-ratio:4/5;object-fit:cover}
.om-badge{position:absolute;top:-22px;right:-18px;width:118px;height:118px;border-radius:50%;transform:rotate(-8deg);background:var(--paper);border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 18px 40px rgba(61,42,30,.14)}
.om-badge .tiny{font-family:var(--sans);font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:var(--coffee);margin-bottom:5px}
.om-badge .big{font-family:var(--display);font-size:15px;line-height:1.1;color:var(--espresso)}
.om-badge .num{font-family:var(--display);font-size:23px;color:var(--gold);margin-top:3px;font-weight:500}
.om-quote{font-family:var(--display);font-style:italic;font-size:clamp(22px,2.4vw,30px);line-height:1.4;color:var(--espresso);border-left:2px solid var(--gold);padding-left:24px;margin:0 0 28px}
.om-sign{font-family:var(--display);font-size:24px;color:var(--espresso-2);margin-top:24px}

/* team-grid */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(32px,4vw,48px);max-width:1100px;margin:0 auto}
.team-card{text-align:center}
.team-name{font-family:var(--display);font-size:clamp(22px,2.2vw,30px);font-weight:400;color:var(--espresso);margin:0 0 2px}
.team-role{font-family:var(--sans);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--coffee);margin:0 0 14px}
.team-card .body{font-size:14.5px;line-height:1.7;color:var(--espresso-2)}
@media (max-width:880px){.team-grid{grid-template-columns:1fr 1fr;gap:32px;max-width:720px}}
@media (max-width:560px){.team-grid{grid-template-columns:1fr;gap:40px}}

/* gavekort */
.giftcard{background:var(--espresso);color:var(--paper);border-radius:22px;padding:clamp(36px,6vw,72px);position:relative;overflow:hidden;text-align:center}
.giftcard .eyebrow{color:var(--gold-soft);justify-content:center}
.giftcard h2{color:var(--paper);margin:.2em 0 .4em}
.giftcard .gift-em{color:var(--gold-soft);font-style:italic}
.giftcard p{color:rgba(244,236,220,.82);max-width:54ch;margin:0 auto}
.chips{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin:34px 0}
.chip{border:1px solid rgba(244,236,220,.32);border-radius:999px;padding:14px 26px;font-family:var(--display);font-size:22px;color:var(--paper)}
.chip.alt{font-size:13px;letter-spacing:.12em;text-transform:uppercase;font-family:var(--sans);align-self:center}
.gift-perks{display:flex;gap:28px;justify-content:center;flex-wrap:wrap;margin-top:30px;color:rgba(244,236,220,.7);font-size:13px;letter-spacing:.04em}
.gift-perks span::before{content:"·";margin-right:.6em;color:var(--gold-soft)}


/* om nominations line (forside) */
.om-noms{margin:18px 0 0;font-family:var(--sans);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--coffee)}
.om-noms a{border-bottom:1px solid var(--line);padding-bottom:3px;transition:border-color .35s ease}
.om-noms a strong{color:var(--gold);font-weight:600}
.om-noms a:hover{border-color:var(--gold)}

/* legal / policy pages */
.legal{max-width:760px}
.legal h2{margin:36px 0 10px}
.legal .body{margin:0 0 14px}
.legal-list{margin:0 0 18px;padding-left:20px;color:var(--espresso-2)}
.legal-list li{margin-bottom:8px;line-height:1.6}


/* focus-visible (keyboard a11y, WCAG 2.4.7) */
a:focus-visible,button:focus-visible,.btn:focus-visible,.chip:focus-visible,input:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--espresso);outline-offset:3px;border-radius:4px}
.btn-primary:focus-visible{outline-color:var(--gold)}

/* award seal (real Danmarks Bedste finalist badge, recolored to palette) */
.award-seal{width:122px;height:auto;filter:drop-shadow(0 12px 26px rgba(61,42,30,.30))}
.om-photo .award-seal,.om-portrait .award-seal{position:absolute;top:16px;right:16px;width:120px;height:auto;max-width:none;aspect-ratio:auto;object-fit:contain;border-radius:0;transform:rotate(-6deg);z-index:3}
@media (max-width:620px){ .om-photo .award-seal,.om-portrait .award-seal{width:88px;top:12px;right:12px} }
.noms-seal{display:block;width:168px;height:auto;margin:0 auto 22px;filter:drop-shadow(0 12px 26px rgba(61,42,30,.20))}