/* Hammock Kit Configurator — editorial builder (Claude-design Hammockkit port).
   Scoped under .mj-kit. The hkc engine inputs are visually hidden; the cards are
   the UI. The kit product page is fully taken over (gallery/summary/tabs hidden). */

/* ---- Page takeover: hide the default single-product chrome on the kit page ---- */
.mj-kit-page .woocommerce-product-gallery,
.mj-kit-page #commercegurus-pdp-gallery-wrapper,
.mj-kit-page .product-details-wrapper > .images,
.mj-kit-page .summary.entry-summary,
.mj-kit-page .single-product div.product .woocommerce-tabs,
.mj-kit-page .single-product div.product .related,
.mj-kit-page .single-product div.product .up-sells,
.mj-kit-page .woocommerce-breadcrumb,
.mj-kit-page .shoptimizer-breadcrumb,
.mj-kit-page .rank-math-breadcrumb{ display:none !important; }
/* Neutralise EVERY content wrapper so the builder spans the full viewport with no
   side gutters at any breakpoint (the mobile white edges came from Shoptimizer's
   wrappers keeping their horizontal padding/max-width). */
.mj-kit-page #content,
.mj-kit-page .site-content,
.mj-kit-page #primary,
.mj-kit-page .content-area,
.mj-kit-page .site-main,
.mj-kit-page .col-full,
.mj-kit-page .single-product div.product,
.mj-kit-page .product-details-wrapper{
  width:100% !important; max-width:none !important;
  padding-left:0 !important; padding-right:0 !important;
  margin-left:0 !important; margin-right:0 !important;
  display:block !important;
}
.mj-kit-page #content, .mj-kit-page .site-content{ padding-top:0 !important; margin-top:0 !important; }

/* ---- Full-bleed wrapper ---- */
.mj-scope.mj-kit{ width:100vw; max-width:100vw; margin-left:calc(50% - 50vw); overflow-x:clip; color:var(--ink); }
.mj-kit .wrap{ max-width:1400px; margin:0 auto; padding:0 32px; }

/* Inputs are controlled via the cards/labels — keep them in the a11y tree but invisible. */
.mj-kit .hkc-opt-input{ position:absolute; width:1px; height:1px; opacity:0; pointer-events:none; margin:0; }

/* ============= HERO ============= */
.mj-kit .kit-hero{ position:relative; min-height:560px; display:grid; align-items:end; overflow:hidden; color:#f3efe4; }
.mj-kit .kit-hero .bg{ position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; }
.mj-kit .kit-hero .inner{ position:relative; z-index:1; padding:118px 0 60px; }
.mj-kit .kit-hero .inner > .wrap{ display:grid; grid-template-columns:1fr auto; align-items:end; gap:32px; }
.mj-kit .kit-hero .label{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#f3c95c; display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.mj-kit .kit-hero .label::before{ content:""; width:28px; height:1px; background:#f3c95c; }
.mj-kit .kit-hero h1{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:clamp(52px,8vw,128px); line-height:.92; letter-spacing:-.028em; text-shadow:0 2px 24px rgba(0,0,0,.3); }
.mj-kit .kit-hero h1 em{ font-style:italic; color:#f3c95c; }
.mj-kit .kit-hero .sub{ margin-top:22px; max-width:56ch; font-size:17px; line-height:1.55; color:color-mix(in oklab,#f3efe4 88%,transparent); text-shadow:0 1px 6px rgba(0,0,0,.4); }
.mj-kit .kit-hero-meta{ text-align:right; font-family:var(--ff-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:color-mix(in oklab,#f3efe4 80%,transparent); }
.mj-kit .kit-hero-meta .big{ display:block; font-family:var(--ff-display); font-weight:var(--display-weight); font-style:italic; font-size:clamp(44px,5vw,84px); line-height:1; letter-spacing:-.025em; color:#f3efe4; text-transform:none; margin-bottom:4px; }
.mj-kit .kit-hero-meta .stars-row{ margin-top:12px; }
.mj-kit .kit-hero-meta .stars-row .stars{ color:#f3c95c; }

/* ============= USECASE ============= */
.mj-kit .usecase-section{ padding:80px 0 52px; background:var(--paper-2); border-bottom:1px solid var(--hairline); }
.mj-kit .usecase-head{ display:flex; justify-content:space-between; align-items:end; margin-bottom:30px; gap:20px; }
.mj-kit .usecase-head h2{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:clamp(32px,4vw,54px); line-height:1.02; letter-spacing:-.02em; }
.mj-kit .usecase-head h2 em{ font-style:italic; color:var(--brand); }
.mj-kit .usecase-head .meta{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); max-width:30ch; text-align:right; }
.mj-kit .usecase-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.mj-kit .uc-card{ position:relative; aspect-ratio:4/5; border-radius:6px; overflow:hidden; cursor:pointer; display:block; transition:transform .35s ease; background:var(--paper-3); border:0; padding:0; text-align:left; color:#f3efe4; }
.mj-kit .uc-card:hover{ transform:translateY(-4px); }
.mj-kit .uc-card img{ width:100%; height:100%; object-fit:cover; transition:transform .8s ease; }
.mj-kit .uc-card:hover img{ transform:scale(1.05); }
.mj-kit .uc-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,24,15,.08) 0%,rgba(20,24,15,0) 35%,rgba(20,24,15,.78) 100%); }
.mj-kit .uc-card .uc-body{ position:absolute; left:22px; right:22px; bottom:22px; z-index:2; }
.mj-kit .uc-card .uc-season{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:#f3c95c; margin-bottom:8px; }
.mj-kit .uc-card .uc-name{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:28px; line-height:1; letter-spacing:-.015em; margin-bottom:6px; }
.mj-kit .uc-card .uc-name em{ font-style:italic; }
.mj-kit .uc-card .uc-rec{ font-size:12px; color:color-mix(in oklab,#f3efe4 86%,transparent); line-height:1.4; }
.mj-kit .uc-card.on::before{ content:""; position:absolute; inset:0; border:3px solid #f3c95c; border-radius:6px; z-index:3; pointer-events:none; }
.mj-kit .uc-card.on .uc-body::after{ content:"✓"; display:inline-flex; align-items:center; justify-content:center; margin-top:12px; width:26px; height:26px; background:#f3c95c; color:var(--ink); border-radius:999px; font-size:13px; font-weight:700; }
.mj-kit .uc-card.custom{ background:var(--ink); color:var(--paper); display:flex; flex-direction:column; justify-content:space-between; padding:28px 22px; }
.mj-kit .uc-card.custom::after{ display:none; }
.mj-kit .uc-card.custom .uc-body{ position:static; }
.mj-kit .uc-card.custom .uc-season{ color:var(--gold); }
.mj-kit .uc-card.custom .uc-name{ color:var(--paper); }
.mj-kit .uc-card.custom .uc-rec{ color:color-mix(in oklab,var(--paper) 80%,transparent); }
.mj-kit .uc-card.custom .uc-top{ font-family:var(--ff-display); font-style:italic; font-size:52px; line-height:1; color:var(--gold); }

/* ============= SHELL / STEPS ============= */
.mj-kit .kit-main-section{ padding:80px 0; }
.mj-kit .kit-main{ display:grid; grid-template-columns:1fr 420px; gap:56px; align-items:start; }
.mj-kit .kit-steps{ display:flex; flex-direction:column; gap:72px; }
.mj-kit .chapter{ display:grid; grid-template-columns:88px 1fr; gap:32px; align-items:start; scroll-margin-top:100px; }
.mj-kit .chapter-num{ position:sticky; top:100px; font-family:var(--ff-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute); border-top:1px solid var(--hairline); padding-top:12px; }
.mj-kit .chapter-num .n{ display:block; font-family:var(--ff-display); font-style:italic; font-weight:var(--display-weight); font-size:54px; line-height:1; letter-spacing:-.02em; color:var(--ink); text-transform:none; margin-top:6px; }
.mj-kit .chapter-num.completed{ border-top-color:var(--brand); }
.mj-kit .chapter-num.completed .n{ color:var(--brand); }
.mj-kit .chapter-num.completed::after{ content:"Klart"; display:block; margin-top:8px; color:var(--brand); font-family:var(--ff-mono); font-size:10px; letter-spacing:.14em; }
/* Language-aware "completed" badge (keyed on <html lang>). sv default = "Klart" above. */
html[lang^="en"] .mj-kit .chapter-num.completed::after{ content:"Done"; }
html[lang^="de"] .mj-kit .chapter-num.completed::after{ content:"Fertig"; }
html[lang^="fr"] .mj-kit .chapter-num.completed::after{ content:"Terminé"; }
html[lang^="es"] .mj-kit .chapter-num.completed::after{ content:"Hecho"; }
html[lang^="it"] .mj-kit .chapter-num.completed::after{ content:"Fatto"; }
html[lang^="nl"] .mj-kit .chapter-num.completed::after{ content:"Klaar"; }
html[lang^="da"] .mj-kit .chapter-num.completed::after{ content:"Færdig"; }
html[lang^="fi"] .mj-kit .chapter-num.completed::after{ content:"Valmis"; }
html[lang^="nb"] .mj-kit .chapter-num.completed::after{ content:"Ferdig"; }
html[lang^="no"] .mj-kit .chapter-num.completed::after{ content:"Ferdig"; }
html[lang^="pl"] .mj-kit .chapter-num.completed::after{ content:"Gotowe"; }
.mj-kit .chapter-head{ margin-bottom:8px; }
.mj-kit .chapter-head .eyebrow{ display:block; margin-bottom:10px; font-family:var(--ff-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); }
.mj-kit .chapter-head h2{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:clamp(38px,4.4vw,68px); line-height:1; letter-spacing:-.025em; }
.mj-kit .chapter-head h2 em{ font-style:italic; color:var(--brand); }
.mj-kit .chapter-head p{ color:var(--ink-soft); font-size:16px; line-height:1.6; margin-top:16px; max-width:55ch; }
.mj-kit .chapter-head p em{ font-style:italic; color:var(--ink); }

/* ============= HAMMOCK CARD ============= */
.mj-kit .hammock-card{ display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:center; margin-top:28px; background:var(--paper-2); border-radius:10px; padding:32px; overflow:hidden; }
.mj-kit .hammock-card .art{ aspect-ratio:4/5; border-radius:6px; overflow:hidden; background:var(--paper-3); }
.mj-kit .hammock-card .art img{ width:100%; height:100%; object-fit:cover; }
.mj-kit .hammock-card .body h3{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:34px; line-height:1.02; letter-spacing:-.015em; }
.mj-kit .hammock-card .body h3 em{ font-style:italic; color:var(--brand); }
.mj-kit .hammock-card .specs-mini{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:18px 0 22px; }
.mj-kit .spec-mini .k{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); display:block; }
.mj-kit .spec-mini .v{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:22px; letter-spacing:-.01em; margin-top:2px; }
.mj-kit .hammock-card .price-line{ display:flex; align-items:baseline; gap:12px; margin-bottom:14px; }
.mj-kit .hammock-card .price-line .now{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:34px; letter-spacing:-.015em; }
.mj-kit .hammock-card .price-line .was{ font-size:16px; color:var(--ink-mute); text-decoration:line-through; }
.mj-kit .hammock-card .included-tag{ display:inline-flex; align-items:center; gap:8px; background:var(--brand-soft); color:var(--brand-deep); padding:8px 14px; border-radius:999px; font-family:var(--ff-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; font-weight:500; }
.mj-kit .hkc-stockline{ font-size:13px; color:var(--ink-soft); }
.mj-kit .hkc-stockline .hkc-stock{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.06em; }
.mj-kit .hkc-stockline .hkc-in{ color:var(--brand); }

/* ============= UQ — rec banner + temp viz ============= */
.mj-kit .uq-rec-banner{ margin-bottom:22px; padding:14px 18px; background:var(--brand-soft); border:1px solid color-mix(in oklab,var(--brand) 30%,transparent); color:var(--brand-deep); border-radius:8px; font-size:14px; display:none; align-items:center; gap:14px; }
.mj-kit .uq-rec-banner.show{ display:flex; }
.mj-kit .uq-rec-banner b{ font-weight:600; }
.mj-kit .temp-viz{ margin:28px 0; padding:26px 30px; background:var(--paper-2); border-radius:10px; }
.mj-kit .temp-viz .lbl{ display:flex; justify-content:space-between; font-family:var(--ff-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); margin-bottom:16px; }
.mj-kit .temp-viz .gradient{ position:relative; height:12px; background:linear-gradient(to right,#4a7ab8,#6ba0d4,#2f6b3a,#c66a2e,#b14b2a); border-radius:999px; margin:26px 0 38px; }
.mj-kit .temp-viz .gradient .mark{ position:absolute; top:-8px; width:4px; height:28px; background:var(--ink); border-radius:2px; cursor:pointer; transition:all .25s ease; }
.mj-kit .temp-viz .gradient .mark::before{ content:attr(data-name); position:absolute; bottom:34px; left:50%; transform:translateX(-50%); font-family:var(--ff-mono); font-size:10px; letter-spacing:.08em; white-space:nowrap; color:var(--ink); font-weight:600; background:var(--bg); padding:3px 8px; border-radius:4px; border:1px solid var(--hairline); }
.mj-kit .temp-viz .gradient .mark::after{ content:attr(data-temp); position:absolute; top:34px; left:50%; transform:translateX(-50%); font-family:var(--ff-mono); font-size:10px; color:var(--ink-mute); white-space:nowrap; }
.mj-kit .temp-viz .gradient .mark.you{ width:8px; height:32px; top:-10px; background:var(--brand); z-index:2; cursor:default; }
.mj-kit .temp-viz .gradient .mark.you::before{ content:"Du är här"; background:var(--brand); color:#fff; border-color:var(--brand); }
.mj-kit .temp-viz .gradient .mark.active{ height:36px; top:-12px; }
.mj-kit .temp-viz .axis{ display:flex; justify-content:space-between; font-family:var(--ff-mono); font-size:10px; color:var(--ink-mute); letter-spacing:.08em; margin-top:4px; }
.mj-kit .temp-info-btn{ display:inline-flex; align-items:center; gap:6px; background:transparent; border:0; cursor:pointer; padding:0; font-family:var(--ff-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--brand); }
.mj-kit .temp-info-btn svg{ opacity:.85; }
.mj-kit .temp-info-btn:hover{ color:var(--brand-deep); }

/* ---- Temperature info modal ---- */
.mj-temp-modal{ position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center; padding:20px; background:color-mix(in oklab,var(--ink) 52%,transparent); -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); }
.mj-temp-modal[hidden]{ display:none; }
.mj-temp-modal-card{ position:relative; background:var(--bg); border:1px solid var(--hairline); border-radius:14px; max-width:480px; width:100%; max-height:86vh; overflow-y:auto; padding:32px 28px; box-shadow:0 24px 64px rgba(0,0,0,.28); }
.mj-temp-modal-card h4{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:27px; letter-spacing:-.01em; margin:0 0 14px; color:var(--ink); }
.mj-temp-modal-card p{ color:var(--ink-soft); font-size:15px; line-height:1.6; margin:0 0 14px; }
.mj-temp-modal-card ul{ margin:0 0 14px; padding-left:18px; color:var(--ink-soft); font-size:14px; line-height:1.6; }
.mj-temp-modal-card li{ margin-bottom:7px; }
.mj-temp-modal-card strong{ color:var(--ink); font-weight:600; }
.mj-temp-modal-card .mj-temp-modal-fine{ font-size:13px; color:var(--ink-mute); margin-bottom:0; }
.mj-temp-modal-close{ position:absolute; top:12px; right:14px; width:38px; height:38px; border:0; background:transparent; font-size:28px; line-height:1; color:var(--ink-mute); cursor:pointer; border-radius:999px; }
.mj-temp-modal-close:hover{ background:var(--paper-2); color:var(--ink); }
body.mj-modal-open{ overflow:hidden; }

/* ---- Floating mobile add-to-cart bar (always shows live total + CTA) ---- */
.mj-kit-floatbar{ display:none; }

/* ============= UQ cards ============= */
.mj-kit .uq-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.mj-kit .uq-card{ position:relative; background:var(--card); border:1.5px solid var(--hairline); border-radius:10px; overflow:hidden; cursor:pointer; text-align:left; padding:0; display:flex; flex-direction:column; transition:all .25s ease; }
.mj-kit .uq-card:hover{ border-color:var(--ink-soft); transform:translateY(-3px); box-shadow:0 12px 32px rgba(0,0,0,.06); }
.mj-kit .uq-card.on{ border-color:var(--brand); box-shadow:0 0 0 2px color-mix(in oklab,var(--brand) 30%,transparent),0 16px 36px rgba(0,0,0,.08); }
.mj-kit .uq-card.is-oos{ cursor:default; }
.mj-kit .uq-card.is-oos .uq-art img{ filter:grayscale(.4) opacity(.8); }
.mj-kit .uq-card .uq-art{ aspect-ratio:16/11; background:var(--paper-2); overflow:hidden; position:relative; }
.mj-kit .uq-card .uq-art img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.mj-kit .uq-card:hover .uq-art img{ transform:scale(1.04); }
.mj-kit .badge-tl{ position:absolute; top:14px; left:14px; background:var(--brand); color:#fff; padding:5px 12px; border-radius:999px; font-family:var(--ff-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; z-index:2; font-weight:600; }
.mj-kit .badge-tl.gold{ background:var(--gold); color:var(--ink); }
.mj-kit .badge-tl.ember{ background:var(--ember); }
.mj-kit .uq-card .uq-body{ padding:20px 22px 22px; display:flex; flex-direction:column; gap:8px; flex:1; }
.mj-kit .uq-card .uq-name{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:25px; line-height:1; letter-spacing:-.01em; }
.mj-kit .uq-card .uq-name em{ font-style:italic; color:var(--brand); }
.mj-kit .uq-card .uq-season{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); }
.mj-kit .uq-card .uq-meta{ font-size:13px; color:var(--ink-soft); line-height:1.45; margin-top:4px; flex:1; }
.mj-kit .uq-card .uq-foot{ display:flex; justify-content:space-between; align-items:end; margin-top:12px; padding-top:14px; border-top:1px solid var(--hairline); }
.mj-kit .uq-card .uq-price{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:22px; letter-spacing:-.01em; }
.mj-kit .uq-card .uq-price .was{ display:block; font-size:11px; color:var(--ink-mute); text-decoration:line-through; font-family:var(--ff-sans); font-weight:400; margin-bottom:2px; }
.mj-kit .uq-radio{ width:22px; height:22px; border-radius:50%; border:1.5px solid var(--hairline-strong); display:flex; align-items:center; justify-content:center; background:var(--card); flex:none; }
.mj-kit .on .uq-radio{ border-color:var(--brand); background:var(--brand); }
.mj-kit .on .uq-radio::after{ content:""; width:8px; height:8px; border-radius:50%; background:#fff; }
.mj-kit .notify-pill{ background:var(--ink); color:var(--paper); padding:6px 14px; border-radius:999px; font-family:var(--ff-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; white-space:nowrap; }
.mj-kit .notify-pill:hover{ background:var(--brand); color:#fff; }

.mj-kit .uq-skip-card,
.mj-kit .pair-skip{ background:var(--paper-2); border:1.5px dashed var(--hairline-strong); border-radius:10px; padding:16px 22px; display:flex; align-items:center; justify-content:space-between; cursor:pointer; margin-top:14px; transition:all .2s ease; width:100%; text-align:left; }
.mj-kit .uq-skip-card:hover,
.mj-kit .pair-skip:hover{ border-color:var(--ink-soft); }
.mj-kit .uq-skip-card.on,
.mj-kit .pair-skip.on{ border-style:solid; border-color:var(--brand); background:var(--brand-soft); }
.mj-kit .uq-skip-card.on .uq-radio,
.mj-kit .pair-skip.on .uq-radio{ border-color:var(--brand); background:var(--brand); }
.mj-kit .uq-skip-card.on .uq-radio::after,
.mj-kit .pair-skip.on .uq-radio::after{ content:""; width:8px; height:8px; border-radius:50%; background:#fff; }
.mj-kit .uq-skip-card .lbl,
.mj-kit .pair-skip .lbl{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:17px; }
.mj-kit .uq-skip-card .sub,
.mj-kit .pair-skip .sub{ font-size:12px; color:var(--ink-mute); }

/* ============= PAIR (tarp / topquilt) ============= */
.mj-kit .pair-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:28px; }
.mj-kit .pair-card{ background:var(--card); border:1.5px solid var(--hairline); border-radius:10px; overflow:hidden; position:relative; cursor:pointer; text-align:left; padding:0; display:flex; flex-direction:column; transition:all .25s ease; }
.mj-kit .pair-card.is-oos{ cursor:default; }
.mj-kit .pair-card.is-single{ grid-column:1 / -1; max-width:560px; }
.mj-kit .pair-card:not(.is-oos):hover{ border-color:var(--ink-soft); transform:translateY(-3px); }
.mj-kit .pair-card.on{ border-color:var(--brand); box-shadow:0 0 0 2px color-mix(in oklab,var(--brand) 30%,transparent); }
.mj-kit .pair-card .pair-art{ aspect-ratio:5/4; background:var(--paper-2); overflow:hidden; position:relative; }
.mj-kit .pair-card.is-single .pair-art{ aspect-ratio:16/10; }
.mj-kit .pair-card .pair-art img{ width:100%; height:100%; object-fit:cover; }
.mj-kit .pair-card.is-oos .pair-art img{ filter:grayscale(.4) opacity(.8); }
.mj-kit .pair-card .pair-art .badge-tl{ background:var(--ink); }
.mj-kit .pair-card .pair-body{ padding:22px; display:grid; gap:8px; }
.mj-kit .pair-card .eyebrow{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); }
.mj-kit .pair-card .pair-name{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:27px; letter-spacing:-.01em; line-height:1; }
.mj-kit .pair-card .pair-meta{ font-size:13px; color:var(--ink-soft); line-height:1.45; }
.mj-kit .pair-card .pair-foot{ display:flex; justify-content:space-between; align-items:end; margin-top:8px; padding-top:14px; border-top:1px solid var(--hairline); }
.mj-kit .pair-card .pair-price{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:22px; letter-spacing:-.01em; }

/* ============= ACCESSORIES ============= */
.mj-kit .acc-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:24px; }
.mj-kit .acc-card{ background:var(--card); border:1.5px solid var(--hairline); border-radius:8px; overflow:hidden; cursor:pointer; position:relative; text-align:left; padding:0; display:flex; flex-direction:column; transition:all .2s ease; }
.mj-kit .acc-card:hover{ border-color:var(--ink-soft); }
.mj-kit .acc-card.on{ border-color:var(--brand); box-shadow:0 0 0 2px color-mix(in oklab,var(--brand) 25%,transparent); }
.mj-kit .acc-card.disabled,.mj-kit .acc-card.is-oos{ opacity:.55; cursor:default; }
.mj-kit .acc-card .acc-art{ aspect-ratio:1/1; background:var(--paper-2); overflow:hidden; }
.mj-kit .acc-card .acc-art img{ width:100%; height:100%; object-fit:cover; }
.mj-kit .acc-card .acc-body{ padding:12px 14px 14px; }
.mj-kit .acc-card .acc-name{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:16px; letter-spacing:-.005em; }
.mj-kit .acc-card .acc-meta{ font-size:11px; color:var(--ink-soft); margin-top:2px; line-height:1.35; }
.mj-kit .acc-card .acc-foot{ margin-top:10px; display:flex; justify-content:space-between; align-items:center; }
.mj-kit .acc-card .acc-price{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:15px; }
.mj-kit .acc-card .acc-mark{ width:20px; height:20px; border-radius:4px; border:1.5px solid var(--hairline-strong); background:var(--card); display:inline-flex; align-items:center; justify-content:center; flex:none; }
.mj-kit .acc-card.on .acc-mark{ background:var(--brand); border-color:var(--brand); }
.mj-kit .acc-card.on .acc-mark::after{ content:""; width:10px; height:6px; border:2px solid #fff; border-top:0; border-right:0; transform:rotate(-45deg) translate(1px,-1px); }
.mj-kit .acc-card .notify-tag{ position:absolute; top:8px; right:8px; background:var(--ink); color:var(--paper); padding:3px 8px; border-radius:999px; font-family:var(--ff-mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase; z-index:2; }
.mj-kit .acc-card .low-tag{ position:absolute; top:8px; right:8px; background:var(--ember); color:#fff; padding:3px 8px; border-radius:999px; font-family:var(--ff-mono); font-size:9px; letter-spacing:.08em; text-transform:uppercase; z-index:2; }

/* ============= ATMOSPHERIC BREAK ============= */
.mj-kit .atmo{ position:relative; min-height:460px; background:linear-gradient(180deg,rgba(20,24,15,0) 0%,rgba(20,24,15,.55) 100%),url("/wp-content/uploads/2025/03/hammockvila_1280_1280.jpg") center/cover no-repeat; display:grid; place-items:center; color:#f3efe4; margin:80px 0; border-radius:12px; }
.mj-kit .atmo blockquote{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:clamp(28px,3.8vw,48px); line-height:1.2; letter-spacing:-.015em; text-align:center; max-width:24ch; margin:0; padding:0 32px; text-shadow:0 2px 18px rgba(0,0,0,.3); }
.mj-kit .atmo blockquote em{ font-style:italic; color:#f3c95c; }
.mj-kit .atmo cite{ display:block; margin-top:26px; font-family:var(--ff-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:color-mix(in oklab,#f3efe4 70%,transparent); font-style:normal; }

/* ============= STICKY SUMMARY ============= */
/* width/float reset — `.summary` is also a WooCommerce class Shoptimizer floats + widths */
.mj-kit .summary{ position:sticky; top:100px; width:auto !important; max-width:none !important; float:none !important; margin:0 !important; background:var(--card); border:1px solid var(--hairline); border-radius:10px; padding:28px; display:flex; flex-direction:column; gap:22px; box-shadow:0 8px 32px rgba(0,0,0,.04); box-sizing:border-box; }
.mj-kit .summary > *{ min-width:0; }
.mj-kit .summary-head{ display:flex; align-items:baseline; justify-content:space-between; padding-bottom:18px; border-bottom:1px solid var(--hairline); }
.mj-kit .summary-head h4{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:26px; letter-spacing:-.01em; }
.mj-kit .summary-head h4 em{ font-style:italic; color:var(--brand); }
.mj-kit .summary-head .progress{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); }
.mj-kit .stack{ display:flex; flex-direction:column; gap:8px; min-height:90px; }
.mj-kit .stack-row{ display:grid; grid-template-columns:44px 1fr auto; align-items:center; gap:12px; padding:10px 12px; background:var(--paper-2); border-radius:6px; font-size:13px; }
.mj-kit .stack-row.empty{ background:transparent; border:1px dashed var(--hairline); font-family:var(--ff-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); justify-content:center; padding:14px 12px; grid-template-columns:1fr; text-align:center; }
.mj-kit .stack-thumb{ width:44px; height:44px; border-radius:4px; overflow:hidden; background:var(--paper-3); flex-shrink:0; }
.mj-kit .stack-thumb img{ width:100%; height:100%; object-fit:cover; }
.mj-kit .stack-row .name{ font-weight:500; line-height:1.2; }
.mj-kit .stack-row .cat{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.1em; color:var(--ink-mute); text-transform:uppercase; }
.mj-kit .stack-row .price{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:14px; white-space:nowrap; }
.mj-kit .stack-row.includes{ background:var(--brand-soft); }
.mj-kit .stack-row.includes .stack-thumb{ background:var(--brand); color:#fff; display:flex; align-items:center; justify-content:center; }
.mj-kit .stack-row.includes .stack-thumb svg{ width:22px; height:22px; }
.mj-kit .stack-row.includes .price{ color:var(--brand); font-size:12px; }
.mj-kit .totals{ display:grid; gap:8px; font-size:13px; }
.mj-kit .totals .row{ display:flex; justify-content:space-between; align-items:baseline; gap:14px; }
.mj-kit .totals .row .k{ color:var(--ink-soft); }
.mj-kit .totals .row .v{ white-space:nowrap; font-variant-numeric:tabular-nums; }
.mj-kit .totals .row.discount .v{ color:var(--brand); }
.mj-kit .totals .ship-bar{ margin:6px 0 2px; display:grid; gap:5px; }
.mj-kit .totals .ship-bar .msg{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-mute); }
.mj-kit .totals .ship-bar .msg.ok{ color:var(--brand); }
.mj-kit .totals .ship-bar .bar{ height:5px; background:var(--paper-2); border-radius:999px; overflow:hidden; }
.mj-kit .totals .ship-bar .fill{ height:100%; background:var(--brand); transition:width .4s ease; }
.mj-kit .grand{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; padding-top:14px; border-top:1px solid var(--hairline); }
.mj-kit .grand .k{ font-family:var(--ff-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); flex:none; }
.mj-kit .grand .v{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:clamp(30px,2.6vw,40px); line-height:1; letter-spacing:-.02em; white-space:nowrap; font-variant-numeric:tabular-nums; }
.mj-kit .hkc-atc{ display:flex; align-items:center; justify-content:center; gap:10px; width:100%; background:var(--brand); color:#fff; border:0; border-radius:999px; font-family:var(--ff-sans); font-weight:600; font-size:15px; padding:16px 22px; cursor:pointer; transition:background .2s ease; }
.mj-kit .hkc-atc:hover{ background:var(--brand-deep); }
.mj-kit .hkc-atc[disabled]{ opacity:.5; cursor:not-allowed; }
.mj-kit .hkc-atc.loading{ opacity:.7; pointer-events:none; }
.mj-kit .hkc-atc .arr{ width:14px; height:14px; }
.mj-kit .pay-row{ display:flex; gap:6px; flex-wrap:wrap; align-items:center; font-family:var(--ff-mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-mute); }
.mj-kit .pay-row .t{ padding:3px 8px; background:var(--paper-2); border-radius:4px; color:var(--ink-soft); font-weight:600; }
.mj-kit .hkc-fineprint{ font-size:11px; color:var(--ink-mute); margin:0; line-height:1.55; }
.mj-kit .hkc-notice{ font-size:13px; padding:12px 14px; border-radius:8px; }
.mj-kit .hkc-notice.hkc-ok{ background:var(--brand-soft); color:var(--brand-deep); }
.mj-kit .hkc-notice.hkc-err{ background:color-mix(in oklab,var(--ember) 16%,var(--card)); color:var(--ember); }
.mj-kit .hkc-notice.hkc-info{ background:var(--paper-2); color:var(--ink-soft); }
.mj-kit .hkc-notice a{ color:inherit; text-decoration:underline; }

/* ============= ALWAYS INCLUDED ============= */
.mj-kit .always-section{ padding:80px 0; background:var(--paper-2); border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline); }
.mj-kit .always-head{ text-align:center; max-width:700px; margin:0 auto 46px; }
.mj-kit .always-head .eyebrow{ font-family:var(--ff-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); }
.mj-kit .always-head h2{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:clamp(32px,4vw,56px); letter-spacing:-.02em; line-height:1.05; }
.mj-kit .always-head h2 em{ font-style:italic; color:var(--brand); }
.mj-kit .always-head p{ margin-top:14px; color:var(--ink-soft); font-size:16px; }
.mj-kit .always-grid{ display:grid; grid-template-columns:repeat(4,1fr); border:1px solid var(--hairline); border-radius:10px; background:var(--bg); overflow:hidden; }
.mj-kit .always-item{ padding:32px 24px; border-right:1px solid var(--hairline); display:flex; flex-direction:column; gap:10px; }
.mj-kit .always-item:last-child{ border-right:0; }
.mj-kit .always-item .ic{ width:36px; height:36px; border-radius:50%; background:var(--brand-soft); color:var(--brand); display:flex; align-items:center; justify-content:center; margin-bottom:6px; }
.mj-kit .always-item .ic svg{ width:18px; height:18px; }
.mj-kit .always-item h5{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:22px; letter-spacing:-.005em; line-height:1.1; }
.mj-kit .always-item h5 em{ font-style:italic; color:var(--brand); }
.mj-kit .always-item p{ font-size:13px; color:var(--ink-soft); line-height:1.5; margin:0; }

/* ============= FAQ ============= */
.mj-kit .faq-section{ padding:80px 0; background:var(--paper-2); border-top:1px solid var(--hairline); }
.mj-kit .faq-grid{ display:grid; grid-template-columns:300px 1fr; gap:56px; align-items:start; }
.mj-kit .faq-grid h2{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:clamp(32px,3.5vw,44px); line-height:1.05; letter-spacing:-.015em; position:sticky; top:100px; }
.mj-kit .faq-grid h2 em{ font-style:italic; color:var(--brand); }
.mj-kit .faq-list{ display:grid; border-top:1px solid var(--hairline); }
.mj-kit .faq-item{ border-bottom:1px solid var(--hairline); }
.mj-kit .faq-q{ display:flex; justify-content:space-between; align-items:center; gap:18px; width:100%; text-align:left; padding:22px 0; cursor:pointer; background:transparent; border:0; font-family:var(--ff-display); font-weight:var(--display-weight); letter-spacing:-.005em; font-size:17px; color:var(--ink); }
.mj-kit .faq-q::after{ content:"+"; font-family:var(--ff-mono); font-size:22px; color:var(--ink-mute); flex:none; }
.mj-kit .faq-item.open .faq-q::after{ content:"−"; }
.mj-kit .faq-a{ display:none; padding:0 0 22px; color:var(--ink-soft); font-size:15px; line-height:1.6; max-width:70ch; }
.mj-kit .faq-item.open .faq-a{ display:block; }

/* ============= RESPONSIVE ============= */
@media (max-width:1100px){
  .mj-kit .kit-main{ grid-template-columns:1fr; }
  .mj-kit .summary{ position:static; }
  .mj-kit .chapter{ grid-template-columns:1fr; gap:0; }
  .mj-kit .chapter-num{ position:static; border-top:0; padding-top:0; margin-bottom:6px; display:flex; align-items:baseline; gap:10px; }
  .mj-kit .chapter-num .n{ display:inline; font-size:30px; margin:0; }
  .mj-kit .chapter-num.completed::after{ display:inline; margin:0 0 0 8px; }
}
/* Floating ATC bar — mobile/tablet only (≤980). Always visible: the kit always
   contains the hammock, so there's always a buyable total. */
@media (max-width:980px){
  .mj-kit-floatbar{
    display:flex; align-items:center; justify-content:space-between; gap:14px;
    position:fixed; left:0; right:0; bottom:0; z-index:90;
    padding:10px 16px calc(10px + env(safe-area-inset-bottom));
    background:color-mix(in oklab,var(--bg) 95%,transparent);
    -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
    border-top:1px solid var(--hairline); box-shadow:0 -4px 22px rgba(0,0,0,.10);
  }
  .mj-kit-floatbar .fb-info{ display:flex; flex-direction:column; line-height:1.05; }
  .mj-kit-floatbar .fb-k{ font-family:var(--ff-mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); }
  .mj-kit-floatbar .fb-v{ font-family:var(--ff-display); font-weight:var(--display-weight); font-size:23px; letter-spacing:-.01em; white-space:nowrap; color:var(--ink); }
  .mj-kit-floatbar .hkc-atc-float{ flex:1; max-width:60%; display:inline-flex; align-items:center; justify-content:center; gap:8px; background:var(--brand); color:#fff; border:0; border-radius:999px; font-family:var(--ff-sans); font-weight:600; font-size:15px; padding:14px 18px; cursor:pointer; }
  .mj-kit-floatbar .hkc-atc-float[disabled]{ opacity:.5; }
  .mj-kit-floatbar .hkc-atc-float .arr{ width:14px; height:14px; }
  /* room so the fixed bar never covers the last content */
  .mj-kit-page #content{ padding-bottom:84px !important; }
}

@media (max-width:820px){
  .mj-kit .wrap{ padding:0 20px; }
  .mj-kit .kit-main-section{ padding:48px 0; }
  .mj-kit .kit-steps{ gap:52px; }
  /* Compact season banners — no more full-height cards that need endless scrolling */
  .mj-kit .usecase-grid{ grid-template-columns:1fr; gap:12px; }
  .mj-kit .uc-card{ aspect-ratio:5/2; }
  .mj-kit .uc-card .uc-body{ left:18px; right:18px; bottom:16px; }
  .mj-kit .uc-card .uc-name{ font-size:24px; }
  .mj-kit .usecase-head{ flex-direction:column; align-items:flex-start; }
  .mj-kit .usecase-head .meta{ text-align:left; }
  /* Temperature scale: declutter on mobile — hide the colliding per-mark labels,
     keep the gradient + tappable dots + "Du är här" + the bottom axis. The detailed
     ratings live in the UQ cards right below. */
  .mj-kit .temp-viz .gradient .mark::before,
  .mj-kit .temp-viz .gradient .mark::after{ display:none; }
  .mj-kit .temp-viz .gradient .mark.you::before{ display:block; font-size:9px; padding:2px 7px; }
  .mj-kit .temp-viz .gradient{ margin:22px 0 18px; }
  .mj-kit .uq-grid,.mj-kit .pair-grid{ grid-template-columns:1fr; }
  .mj-kit .pair-card.is-single{ max-width:none; }
  .mj-kit .acc-grid{ grid-template-columns:1fr 1fr; }
  .mj-kit .always-grid{ grid-template-columns:1fr 1fr; }
  .mj-kit .always-item:nth-child(2){ border-right:0; }
  .mj-kit .always-item:nth-child(-n+2){ border-bottom:1px solid var(--hairline); }
  .mj-kit .hammock-card{ grid-template-columns:1fr; }
  .mj-kit .faq-grid{ grid-template-columns:1fr; gap:24px; }
  .mj-kit .faq-grid h2{ position:static; }
  .mj-kit .kit-hero .inner > .wrap{ grid-template-columns:1fr; }
  .mj-kit .kit-hero-meta{ text-align:left; }
  .mj-kit .kit-hero .inner{ padding:96px 0 44px; }
  .mj-kit .temp-viz{ padding:22px 18px; }
  /* Less endless scroll on mobile: shorter hero + shorter card images. */
  .mj-kit .kit-hero{ min-height:56vh; }
  .mj-kit .kit-steps{ gap:40px; }
  .mj-kit .hammock-card{ padding:22px; gap:20px; }
  .mj-kit .hammock-card .art{ aspect-ratio:16/10; }
  .mj-kit .uq-card .uq-art{ aspect-ratio:16/9; }
  .mj-kit .pair-card .pair-art,.mj-kit .pair-card.is-single .pair-art{ aspect-ratio:16/9; }
}
@media (max-width:520px){
  .mj-kit .usecase-grid{ grid-template-columns:1fr; }
  .mj-kit .acc-grid{ grid-template-columns:1fr; }
}
